2007-11-06 12:13:52 +00:00
< html >
< head >
< meta http-equiv = "Content-Type" content = "text/html; charset=ISO-8859-1" >
< title > Forward
Sequence< / title >
2007-11-07 03:46:23 +00:00
< link rel = "stylesheet" href = "../../../../../../../doc/html/boostbook.css" type = "text/css" >
2007-11-06 12:13:52 +00:00
< meta name = "generator" content = "DocBook XSL Stylesheets V1.66.1" >
< link rel = "start" href = "../../../index.html" title = "Chapter<65> 1.<2E> Fusion 2.0" >
< link rel = "up" href = "../concepts.html" title = "Concepts" >
< link rel = "prev" href = "../concepts.html" title = "Concepts" >
< link rel = "next" href = "bidirectional_sequence.html" title = "Bidirectional
Sequence">
< / head >
< body bgcolor = "white" text = "black" link = "#0000FF" vlink = "#840084" alink = "#0000FF" >
< table cellpadding = "2" width = "100%" > < tr >
< td valign = "top" > < img alt = "Boost C++ Libraries" width = "277" height = "86" src = "../../../../../../../boost.png" > < / td >
< td align = "center" > < a href = "../../../../../../../index.htm" > Home< / a > < / td >
< td align = "center" > < a href = "../../../../../../libraries.htm" > Libraries< / a > < / td >
< td align = "center" > < a href = "../../../../../../../people/people.htm" > People< / a > < / td >
< td align = "center" > < a href = "../../../../../../../more/faq.htm" > FAQ< / a > < / td >
< td align = "center" > < a href = "../../../../../../../more/index.htm" > More< / a > < / td >
< / tr > < / table >
< hr >
< div class = "spirit-nav" >
< a accesskey = "p" href = "../concepts.html" > < img src = "../../../../../../../doc/html/images/prev.png" alt = "Prev" > < / a > < a accesskey = "u" href = "../concepts.html" > < img src = "../../../../../../../doc/html/images/up.png" alt = "Up" > < / a > < a accesskey = "h" href = "../../../index.html" > < img src = "../../../../../../../doc/html/images/home.png" alt = "Home" > < / a > < a accesskey = "n" href = "bidirectional_sequence.html" > < img src = "../../../../../../../doc/html/images/next.png" alt = "Next" > < / a >
< / div >
< div class = "section" lang = "en" >
< div class = "titlepage" > < div > < div > < h4 class = "title" >
< a name = "fusion.sequence.concepts.forward_sequence" > < / a > < a href = "forward_sequence.html" title = "Forward
Sequence">Forward
Sequence< / a > < / h4 > < / div > < / div > < / div >
< a name = "fusion.sequence.concepts.forward_sequence.description" > < / a > < h5 >
2007-12-17 09:27:42 +00:00
< a name = "id490819" > < / a >
2007-11-06 12:13:52 +00:00
< a href = "forward_sequence.html#fusion.sequence.concepts.forward_sequence.description" > Description< / a >
< / h5 >
< p >
A Forward Sequence is a Sequence whose elements are arranged in a definite
order. The ordering is guaranteed not to change from iteration to iteration.
The requirement of a definite ordering allows the definition of element-by-element
equality (if the container's element type is Equality Comparable) and of
lexicographical ordering (if the container's element type is LessThan Comparable).
< / p >
< div class = "variablelist" >
< p class = "title" > < b > Notation< / b > < / p >
< dl >
< dt > < span class = "term" > < tt class = "computeroutput" > < span class = "identifier" > s< / span > < / tt > < / span > < / dt >
< dd > < p >
A Forward Sequence
< / p > < / dd >
< dt > < span class = "term" > < tt class = "computeroutput" > < span class = "identifier" > S< / span > < / tt > < / span > < / dt >
< dd > < p >
A Forward Sequence type
< / p > < / dd >
< dt > < span class = "term" > < tt class = "computeroutput" > < span class = "identifier" > o< / span > < / tt > < / span > < / dt >
< dd > < p >
An arbitrary object
< / p > < / dd >
< dt > < span class = "term" > < tt class = "computeroutput" > < span class = "identifier" > e< / span > < / tt > < / span > < / dt >
< dd > < p >
A Sequence element
< / p > < / dd >
< / dl >
< / div >
< a name = "fusion.sequence.concepts.forward_sequence.valid_expressions" > < / a > < h5 >
2007-12-17 09:27:42 +00:00
< a name = "id490955" > < / a >
2007-11-06 12:13:52 +00:00
< a href = "forward_sequence.html#fusion.sequence.concepts.forward_sequence.valid_expressions" > Valid
Expressions< / a >
< / h5 >
< p >
For any Forward Sequence the following expressions must be valid:
< / p >
< div class = "informaltable" > < table class = "table" >
< colgroup >
< col >
< col >
< col >
< col >
< / colgroup >
< thead > < tr >
< th >
< p >
Expression
< / p >
< / th >
< th >
< p >
Return type
< / p >
< / th >
< th >
< p >
Type Requirements
< / p >
< / th >
< th >
< p >
Runtime Complexity
< / p >
< / th >
< / tr > < / thead >
< tbody >
< tr >
< td >
< p >
< tt class = "computeroutput" > < a href = "../intrinsic/functions/begin.html" title = "begin" > < tt class = "computeroutput" > < span class = "identifier" > begin< / span > < / tt > < / a > < span class = "special" > (< / span > < span class = "identifier" > s< / span > < span class = "special" > )< / span > < / tt >
< / p >
< / td >
< td >
< p >
< a href = "../../iterator/concepts/forward_iterator.html" title = "Forward
Iterator">Forward
Iterator< / a >
< / p >
< / td >
< td >
< p >
< / p >
< / td >
< td >
< p >
Constant
< / p >
< / td >
< / tr >
< tr >
< td >
< p >
< tt class = "computeroutput" > < a href = "../intrinsic/functions/end.html" title = "end" > < tt class = "computeroutput" > < span class = "identifier" > end< / span > < / tt > < / a > < span class = "special" > (< / span > < span class = "identifier" > s< / span > < span class = "special" > )< / span > < / tt >
< / p >
< / td >
< td >
< p >
< a href = "../../iterator/concepts/forward_iterator.html" title = "Forward
Iterator">Forward
Iterator< / a >
< / p >
< / td >
< td >
< p >
< / p >
< / td >
< td >
< p >
Constant
< / p >
< / td >
< / tr >
< tr >
< td >
< p >
< tt class = "computeroutput" > < a href = "../intrinsic/functions/size.html" title = "size" > < tt class = "computeroutput" > < span class = "identifier" > size< / span > < / tt > < / a > < span class = "special" > (< / span > < span class = "identifier" > s< / span > < span class = "special" > )< / span > < / tt >
< / p >
< / td >
< td >
< p >
< a href = "http://www.boost.org/libs/mpl/doc/refmanual/integral-constant.html" target = "_top" > MPL
Integral Constant< / a > . Convertible to int.
< / p >
< / td >
< td >
< p >
< / p >
< / td >
< td >
< p >
Constant
< / p >
< / td >
< / tr >
< tr >
< td >
< p >
< tt class = "computeroutput" > < a href = "../intrinsic/functions/empty.html" title = "empty" > < tt class = "computeroutput" > < span class = "identifier" > empty< / span > < / tt > < / a > < span class = "special" > (< / span > < span class = "identifier" > s< / span > < span class = "special" > )< / span > < / tt >
< / p >
< / td >
< td >
< p >
< a href = "http://www.boost.org/libs/mpl/doc/refmanual/integral-constant.html" target = "_top" > MPL
Boolean Constant< / a > . Convertible to bool.
< / p >
< / td >
< td >
< p >
< / p >
< / td >
< td >
< p >
Constant
< / p >
< / td >
< / tr >
< tr >
< td >
< p >
< tt class = "computeroutput" > < a href = "../intrinsic/functions/front.html" title = "front" > < tt class = "computeroutput" > < span class = "identifier" > front< / span > < / tt > < / a > < span class = "special" > (< / span > < span class = "identifier" > s< / span > < span class = "special" > )< / span > < / tt >
< / p >
< / td >
< td >
< p >
Any type
< / p >
< / td >
< td >
< p >
< / p >
< / td >
< td >
< p >
Constant
< / p >
< / td >
< / tr >
< tr >
< td >
< p >
< tt class = "computeroutput" > < a href = "../intrinsic/functions/front.html" title = "front" > < tt class = "computeroutput" > < span class = "identifier" > front< / span > < / tt > < / a > < span class = "special" > (< / span > < span class = "identifier" > s< / span > < span class = "special" > )< / span >
< span class = "special" > =< / span > < span class = "identifier" > o< / span > < / tt >
< / p >
< / td >
< td >
< p >
Any type
< / p >
< / td >
< td >
< p >
< tt class = "computeroutput" > < span class = "identifier" > s< / span > < / tt > is mutable and
< tt class = "computeroutput" > < span class = "identifier" > e< / span > < span class = "special" > =< / span >
< span class = "identifier" > o< / span > < / tt > , where < tt class = "computeroutput" > < span class = "identifier" > e< / span > < / tt > is the first element in the
sequence, is a valid expression.
< / p >
< / td >
< td >
< p >
Constant
< / p >
< / td >
< / tr >
< / tbody >
< / table > < / div >
< a name = "fusion.sequence.concepts.forward_sequence.result_type_expressions" > < / a > < h5 >
2007-12-17 09:27:42 +00:00
< a name = "id491539" > < / a >
2007-11-06 12:13:52 +00:00
< a href = "forward_sequence.html#fusion.sequence.concepts.forward_sequence.result_type_expressions" > Result
Type Expressions< / a >
< / h5 >
< div class = "informaltable" > < table class = "table" >
< colgroup >
< col >
< col >
< / colgroup >
< thead > < tr >
< th >
< p >
Expression
< / p >
< / th >
< th >
< p >
Compile Time Complexity
< / p >
< / th >
< / tr > < / thead >
< tbody >
< tr >
< td >
< p >
< tt class = "computeroutput" > < a href = "../intrinsic/metafunctions/begin.html" title = "begin" > < tt class = "computeroutput" > < span class = "identifier" > result_of< / span > < span class = "special" > ::< / span > < span class = "identifier" > begin< / span > < / tt > < / a > < span class = "special" > < < / span > < span class = "identifier" > S< / span > < span class = "special" > > ::< / span > < span class = "identifier" > type< / span > < / tt >
< / p >
< / td >
< td >
< p >
Amortized constant time
< / p >
< / td >
< / tr >
< tr >
< td >
< p >
< tt class = "computeroutput" > < a href = "../intrinsic/metafunctions/end.html" title = "end" > < tt class = "computeroutput" > < span class = "identifier" > result_of< / span > < span class = "special" > ::< / span > < span class = "identifier" > end< / span > < / tt > < / a > < span class = "special" > < < / span > < span class = "identifier" > S< / span > < span class = "special" > > ::< / span > < span class = "identifier" > type< / span > < / tt >
< / p >
< / td >
< td >
< p >
Amortized constant time
< / p >
< / td >
< / tr >
< tr >
< td >
< p >
< tt class = "computeroutput" > < a href = "../intrinsic/metafunctions/size.html" title = "size" > < tt class = "computeroutput" > < span class = "identifier" > result_of< / span > < span class = "special" > ::< / span > < span class = "identifier" > size< / span > < / tt > < / a > < span class = "special" > < < / span > < span class = "identifier" > S< / span > < span class = "special" > > ::< / span > < span class = "identifier" > type< / span > < / tt >
< / p >
< / td >
< td >
< p >
Unspecified
< / p >
< / td >
< / tr >
< tr >
< td >
< p >
< tt class = "computeroutput" > < a href = "../intrinsic/metafunctions/empty.html" title = "empty" > < tt class = "computeroutput" > < span class = "identifier" > result_of< / span > < span class = "special" > ::< / span > < span class = "identifier" > empty< / span > < / tt > < / a > < span class = "special" > < < / span > < span class = "identifier" > S< / span > < span class = "special" > > ::< / span > < span class = "identifier" > type< / span > < / tt >
< / p >
< / td >
< td >
< p >
Constant time
< / p >
< / td >
< / tr >
< tr >
< td >
< p >
< tt class = "computeroutput" > < a href = "../intrinsic/metafunctions/front.html" title = "front" > < tt class = "computeroutput" > < span class = "identifier" > result_of< / span > < span class = "special" > ::< / span > < span class = "identifier" > front< / span > < / tt > < / a > < span class = "special" > < < / span > < span class = "identifier" > S< / span > < span class = "special" > > ::< / span > < span class = "identifier" > type< / span > < / tt >
< / p >
< / td >
< td >
< p >
Amortized constant time
< / p >
< / td >
< / tr >
< / tbody >
< / table > < / div >
< a name = "fusion.sequence.concepts.forward_sequence.expression_semantics" > < / a > < h5 >
2007-12-17 09:27:42 +00:00
< a name = "id491958" > < / a >
2007-11-06 12:13:52 +00:00
< a href = "forward_sequence.html#fusion.sequence.concepts.forward_sequence.expression_semantics" > Expression
Semantics< / a >
< / h5 >
< div class = "informaltable" > < table class = "table" >
< colgroup >
< col >
< col >
< / colgroup >
< thead > < tr >
< th >
< p >
Expression
< / p >
< / th >
< th >
< p >
Semantics
< / p >
< / th >
< / tr > < / thead >
< tbody >
< tr >
< td >
< p >
< tt class = "computeroutput" > < a href = "../intrinsic/functions/begin.html" title = "begin" > < tt class = "computeroutput" > < span class = "identifier" > begin< / span > < / tt > < / a > < span class = "special" > (< / span > < span class = "identifier" > s< / span > < span class = "special" > )< / span > < / tt >
< / p >
< / td >
< td >
< p >
An iterator to the first element of the sequence; see < a href = "../intrinsic/functions/begin.html" title = "begin" > < tt class = "computeroutput" > < span class = "identifier" > begin< / span > < / tt > < / a > .
< / p >
< / td >
< / tr >
< tr >
< td >
< p >
< tt class = "computeroutput" > < a href = "../intrinsic/functions/end.html" title = "end" > < tt class = "computeroutput" > < span class = "identifier" > end< / span > < / tt > < / a > < span class = "special" > (< / span > < span class = "identifier" > s< / span > < span class = "special" > )< / span > < / tt >
< / p >
< / td >
< td >
< p >
A past-the-end iterator to the sequence; see < a href = "../intrinsic/functions/end.html" title = "end" > < tt class = "computeroutput" > < span class = "identifier" > end< / span > < / tt > < / a > .
< / p >
< / td >
< / tr >
< tr >
< td >
< p >
< tt class = "computeroutput" > < a href = "../intrinsic/functions/size.html" title = "size" > < tt class = "computeroutput" > < span class = "identifier" > size< / span > < / tt > < / a > < span class = "special" > (< / span > < span class = "identifier" > s< / span > < span class = "special" > )< / span > < / tt >
< / p >
< / td >
< td >
< p >
The size of the sequence; see < a href = "../intrinsic/functions/size.html" title = "size" > < tt class = "computeroutput" > < span class = "identifier" > size< / span > < / tt > < / a > .
< / p >
< / td >
< / tr >
< tr >
< td >
< p >
< tt class = "computeroutput" > < a href = "../intrinsic/functions/empty.html" title = "empty" > < tt class = "computeroutput" > < span class = "identifier" > empty< / span > < / tt > < / a > < span class = "special" > (< / span > < span class = "identifier" > s< / span > < span class = "special" > )< / span > < / tt >
< / p >
< / td >
< td >
< p >
A boolean Integral Constant < tt class = "computeroutput" > < span class = "identifier" > c< / span > < / tt >
such that < tt class = "computeroutput" > < span class = "identifier" > c< / span > < span class = "special" > ::< / span > < span class = "identifier" > value< / span > < span class = "special" > ==< / span >
< span class = "keyword" > true< / span > < / tt > if and only if the
sequence is empty; see < a href = "../intrinsic/functions/empty.html" title = "empty" > < tt class = "computeroutput" > < span class = "identifier" > empty< / span > < / tt > < / a > .
< / p >
< / td >
< / tr >
< tr >
< td >
< p >
< tt class = "computeroutput" > < a href = "../intrinsic/functions/front.html" title = "front" > < tt class = "computeroutput" > < span class = "identifier" > front< / span > < / tt > < / a > < span class = "special" > (< / span > < span class = "identifier" > s< / span > < span class = "special" > )< / span > < / tt >
< / p >
< / td >
< td >
< p >
The first element in the sequence; see < a href = "../intrinsic/functions/front.html" title = "front" > < tt class = "computeroutput" > < span class = "identifier" > front< / span > < / tt > < / a > .
< / p >
< / td >
< / tr >
< / tbody >
< / table > < / div >
< a name = "fusion.sequence.concepts.forward_sequence.invariants" > < / a > < h5 >
2007-12-17 09:27:42 +00:00
< a name = "id492427" > < / a >
2007-11-06 12:13:52 +00:00
< a href = "forward_sequence.html#fusion.sequence.concepts.forward_sequence.invariants" > Invariants< / a >
< / h5 >
< p >
For any Forward Sequence s the following invariants always hold:
< / p >
< div class = "itemizedlist" > < ul type = "disc" >
< li >
< tt class = "computeroutput" > < span class = "special" > [< / span > < a href = "../intrinsic/functions/begin.html" title = "begin" > < tt class = "computeroutput" > < span class = "identifier" > begin< / span > < / tt > < / a > < span class = "special" > (< / span > < span class = "identifier" > s< / span > < span class = "special" > ),< / span > < a href = "../intrinsic/functions/end.html" title = "end" > < tt class = "computeroutput" > < span class = "identifier" > end< / span > < / tt > < / a > < span class = "special" > (< / span > < span class = "identifier" > s< / span > < span class = "special" > ))< / span > < / tt > is always a valid range.
< / li >
< li >
An < a href = "../../algorithm.html" title = "Algorithm" > Algorithm< / a > that iterates through
the range < tt class = "computeroutput" > < span class = "special" > [< / span > < a href = "../intrinsic/functions/begin.html" title = "begin" > < tt class = "computeroutput" > < span class = "identifier" > begin< / span > < / tt > < / a > < span class = "special" > (< / span > < span class = "identifier" > s< / span > < span class = "special" > ),< / span > < a href = "../intrinsic/functions/end.html" title = "end" > < tt class = "computeroutput" > < span class = "identifier" > end< / span > < / tt > < / a > < span class = "special" > (< / span > < span class = "identifier" > s< / span > < span class = "special" > ))< / span > < / tt > will pass through every element of
< tt class = "computeroutput" > < span class = "identifier" > s< / span > < / tt > exactly once.
< / li >
< li >
< tt class = "computeroutput" > < a href = "../intrinsic/functions/begin.html" title = "begin" > < tt class = "computeroutput" > < span class = "identifier" > begin< / span > < / tt > < / a > < span class = "special" > (< / span > < span class = "identifier" > s< / span > < span class = "special" > )< / span > < / tt >
is identical to < tt class = "computeroutput" > < a href = "../intrinsic/functions/end.html" title = "end" > < tt class = "computeroutput" > < span class = "identifier" > end< / span > < / tt > < / a > < span class = "special" > (< / span > < span class = "identifier" > s< / span > < span class = "special" > ))< / span > < / tt >
if and only if < tt class = "computeroutput" > < span class = "identifier" > s< / span > < / tt > is empty.
< / li >
< li >
Two different iterations through < tt class = "computeroutput" > < span class = "identifier" > s< / span > < / tt >
will access its elements in the same order.
< / li >
< / ul > < / div >
< a name = "fusion.sequence.concepts.forward_sequence.models" > < / a > < h5 >
2007-12-17 09:27:42 +00:00
< a name = "id492740" > < / a >
2007-11-06 12:13:52 +00:00
< a href = "forward_sequence.html#fusion.sequence.concepts.forward_sequence.models" > Models< / a >
< / h5 >
< div class = "itemizedlist" > < ul type = "disc" >
< li > < a href = "../../adapted/std__pair.html" title = "std::pair" > < tt class = "computeroutput" > < span class = "identifier" > std< / span > < span class = "special" > ::< / span > < span class = "identifier" > pair< / span > < / tt > < / a > < / li >
< li > < a href = "../../adapted/boost__array.html" title = "boost::array" > < tt class = "computeroutput" > < span class = "identifier" > boost< / span > < span class = "special" > ::< / span > < span class = "identifier" > array< / span > < / tt > < / a > < / li >
< li > < a href = "../../container/vector.html" title = "vector" > < tt class = "computeroutput" > < span class = "identifier" > vector< / span > < / tt > < / a > < / li >
< li > < a href = "../../container/cons.html" title = "cons" > < tt class = "computeroutput" > < span class = "identifier" > cons< / span > < / tt > < / a > < / li >
< li > < a href = "../../container/list.html" title = "list" > < tt class = "computeroutput" > < span class = "identifier" > list< / span > < / tt > < / a > < / li >
< li > < a href = "../../container/set.html" title = "set" > < tt class = "computeroutput" > < span class = "identifier" > set< / span > < / tt > < / a > < / li >
< li > < a href = "../../container/map.html" title = "map" > < tt class = "computeroutput" > < span class = "identifier" > map< / span > < / tt > < / a > < / li >
< li > < a href = "../../view/single_view.html" title = "single_view" > < tt class = "computeroutput" > < span class = "identifier" > single_view< / span > < / tt > < / a > < / li >
< li > < a href = "../../view/filter_view.html" title = "filter_view" > < tt class = "computeroutput" > < span class = "identifier" > filter_view< / span > < / tt > < / a > < / li >
< li > < a href = "../../view/iterator_range.html" title = "iterator_range" > < tt class = "computeroutput" > < span class = "identifier" > iterator_range< / span > < / tt > < / a > < / li >
< li > < a href = "../../view/joint_view.html" title = "joint_view" > < tt class = "computeroutput" > < span class = "identifier" > joint_view< / span > < / tt > < / a > < / li >
< li > < a href = "../../view/transform_view.html" title = "transform_view" > < tt class = "computeroutput" > < span class = "identifier" > transform_view< / span > < / tt > < / a > < / li >
< li > < a href = "../../view/reverse_view.html" title = "reverse_view" > < tt class = "computeroutput" > < span class = "identifier" > reverse_view< / span > < / tt > < / a > < / li >
< li > < a href = "../../view/zip_view.html" title = "zip_view" > < tt class = "computeroutput" > < span class = "identifier" > zip_view< / span > < / tt > < / a > < / li >
< / ul > < / div >
< / div >
< table xmlns:rev = "http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width = "100%" > < tr >
< td align = "left" > < / td >
2007-11-14 10:17:09 +00:00
< td align = "right" > < div class = "copyright-footer" > Copyright <20> 2001-2007 Joel de Guzman, Dan Marsden, Tobias
2007-11-07 02:12:28 +00:00
Schwinger< p >
Distributed under the Boost Software License, Version 1.0. (See accompanying
file LICENSE_1_0.txt or copy at < a href = "http://www.boost.org/LICENSE_1_0.txt" target = "_top" > http://www.boost.org/LICENSE_1_0.txt< / a > )
2007-11-14 10:17:09 +00:00
< / p >
< / div > < / td >
2007-11-06 12:13:52 +00:00
< / tr > < / table >
< hr >
< div class = "spirit-nav" >
< a accesskey = "p" href = "../concepts.html" > < img src = "../../../../../../../doc/html/images/prev.png" alt = "Prev" > < / a > < a accesskey = "u" href = "../concepts.html" > < img src = "../../../../../../../doc/html/images/up.png" alt = "Up" > < / a > < a accesskey = "h" href = "../../../index.html" > < img src = "../../../../../../../doc/html/images/home.png" alt = "Home" > < / a > < a accesskey = "n" href = "bidirectional_sequence.html" > < img src = "../../../../../../../doc/html/images/next.png" alt = "Next" > < / a >
< / div >
< / body >
< / html >