View source code Display the source code in std/range/primitives.d from which this page was generated on github. Improve this page Quickly fork, edit online, and submit a pull request for this page. Requires a signed-in GitHub account. This works well for small changes. If you'd like to make larger changes you may want to consider using local clone. Page wiki View or edit the community-maintained wiki page associated with this page.

Function std.range.primitives.moveFront

Moves the front of r out and returns it. Leaves r.front in a destroyable state that does not allocate any resources (usually equal to its .init value).

Prototype

ElementType!R moveFront(R)(
  R r
);

Example

auto a = [ 1, 2, 3 ];
assert(moveFront(a) == 1);

// define a perfunctory input range
struct InputRange
{
    @property bool empty() { return false; }
    @property int front() { return 42; }
    void popFront() {}
    int moveFront() { return 43; }
}
InputRange r;
assert(moveFront(r) == 43);

Authors

Andrei Alexandrescu, David Simcha, and Jonathan M Davis. Credit for some of the ideas in building this module goes to Leonardo Maffi.

License

Boost License 1.0.

Comments