Implement DList.popFirstOf and DList.popLastOf

Fix #37.
This commit is contained in:
Eugen Wissner 2018-04-17 14:46:05 +02:00
parent 012c2d4c18
commit 3fee712c6c

View File

@ -437,13 +437,13 @@ struct SList(T)
version (assert) version (assert)
{ {
private bool checkRangeBelonging(ref Range r) const private bool checkRangeBelonging(ref const Range r) const
{ {
const(Entry*)* pos = &this.head; const(Entry)* pos = this.head;
for (; pos != r.head && *pos !is null; pos = &(*pos).next) for (; pos !is *r.head && pos !is null; pos = pos.next)
{ {
} }
return pos == r.head; return pos is *r.head;
} }
} }
@ -721,12 +721,12 @@ struct SList(T)
} }
/** /**
* Removes the fron element of the $(D_PARAM range) from the list. * Removes the front element of the $(D_PARAM range) from the list.
* *
* Params: * Params:
* range = Range whose front element should be removed. * range = Range whose front element should be removed.
* *
* Returns: $(D_PSYMBOL range) with the first element removed. * Returns: $(D_PSYMBOL range) with its front element removed.
* *
* Precondition: $(D_INLINECODE !range.empty). * Precondition: $(D_INLINECODE !range.empty).
* $(D_PARAM range) is extracted from this list. * $(D_PARAM range) is extracted from this list.
@ -1604,13 +1604,13 @@ struct DList(T)
version (assert) version (assert)
{ {
private bool checkRangeBelonging(ref Range r) const private bool checkRangeBelonging(ref const Range r) const
{ {
const(Entry*)* pos = &this.head; const(Entry)* pos = this.head;
for (; pos != r.head && *pos !is null; pos = &(*pos).next) for (; pos !is *r.head && pos !is null; pos = pos.next)
{ {
} }
return pos == r.head; return pos is *r.head;
} }
} }
@ -2112,6 +2112,57 @@ struct DList(T)
assert(l1 == l2); assert(l1 == l2);
} }
/**
* Removes the front or back element of the $(D_PARAM range) from the list
* respectively.
*
* Params:
* range = Range whose element should be removed.
*
* Returns: $(D_PSYMBOL range) with its front or back element removed.
*
* Precondition: $(D_INLINECODE !range.empty).
* $(D_PARAM range) is extracted from this list.
*/
Range popFirstOf(Range range)
in
{
assert(!range.empty);
}
do
{
remove(Range(*range.head, *range.head));
return range;
}
/// ditto
Range popLastOf(Range range)
in
{
assert(!range.empty);
}
do
{
remove(Range(*range.tail, *range.tail));
return range;
}
///
@nogc nothrow pure @safe unittest
{
auto list = DList!int([5, 234, 30]);
auto range = list[];
range.popFront();
range = list.popFirstOf(range);
assert(range.front == 30);
assert(range.back == 30);
assert(list.popLastOf(range).empty);
assert(list[].front == 5);
assert(list[].back == 5);
}
/** /**
* Returns: Range that iterates over all elements of the container, in * Returns: Range that iterates over all elements of the container, in
* forward order. * forward order.