mirror of
https://github.com/dlang/phobos.git
synced 2025-04-29 22:50:38 +03:00
Merge pull request #6522 from BBasile/issue-18470
fix issue 18470 - std.algorithm.splitter has frame access problems for custom preds merged-on-behalf-of: Jack Stouffer <jack@jackstouffer.com>
This commit is contained in:
commit
a6bf2b6c47
1 changed files with 19 additions and 2 deletions
|
@ -3796,7 +3796,7 @@ if (is(typeof(binaryFun!pred(r.front, s)) : bool)
|
|||
import std.algorithm.searching : find;
|
||||
import std.conv : unsigned;
|
||||
|
||||
static struct Result
|
||||
struct Result
|
||||
{
|
||||
private:
|
||||
Range _input;
|
||||
|
@ -3817,7 +3817,7 @@ if (is(typeof(binaryFun!pred(r.front, s)) : bool)
|
|||
|
||||
static if (isBidirectionalRange!Range)
|
||||
{
|
||||
static size_t lastIndexOf(Range haystack, Separator needle)
|
||||
size_t lastIndexOf(Range haystack, Separator needle)
|
||||
{
|
||||
import std.range : retro;
|
||||
auto r = haystack.retro().find!pred(needle);
|
||||
|
@ -4142,6 +4142,23 @@ if (is(typeof(binaryFun!pred(r.front, s)) : bool)
|
|||
assert(s.empty);
|
||||
}
|
||||
|
||||
@safe unittest // issue 18470
|
||||
{
|
||||
import std.algorithm.comparison : equal;
|
||||
|
||||
const w = [[0], [1], [2]];
|
||||
assert(w.splitter!((a, b) => a.front() == b)(1).equal([[[0]], [[2]]]));
|
||||
}
|
||||
|
||||
@safe unittest // issue 18470
|
||||
{
|
||||
import std.algorithm.comparison : equal;
|
||||
import std.ascii : toLower;
|
||||
|
||||
assert("abXcdxef".splitter!"a.toLower == b"('x').equal(["ab", "cd", "ef"]));
|
||||
assert("abXcdxef".splitter!((a, b) => a.toLower == b)('x').equal(["ab", "cd", "ef"]));
|
||||
}
|
||||
|
||||
/// ditto
|
||||
auto splitter(alias pred = "a == b", Range, Separator)(Range r, Separator s)
|
||||
if (is(typeof(binaryFun!pred(r.front, s.front)) : bool)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue