Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: downloads/boost_1_33_1/libs/mpl/doc/src/refmanual/unique.rst @ 12

Last change on this file since 12 was 12, checked in by landauf, 18 years ago

added boost

File size: 2.9 KB

unique

Synopsis

template<
      typename Seq
    , typename Pred
    , typename In = |unspecified|
    >
struct unique
{
    typedef |unspecified| type;
};

Description

Returns a sequence of the initial elements of every subrange of the original sequence Seq whose elements are all the same.

|transformation algorithm disclaimer|

Parameters

Parameter Requirement Description
Sequence |Forward Sequence| An original sequence.
Pred Binary |Lambda Expression| An equivalence relation.
In |Inserter| An inserter.

Expression semantics

|Semantics disclaimer...| |Reversible Algorithm|.

For any |Forward Sequence| s, a binary |Lambda Expression| pred, and an |Inserter| in:

typedef unique<s,pred,in>::type r;
Return type:

A type.

Semantics:

If size<s>::value <= 1, then equivalent to

typedef copy<s,in>::type r;

otherwise equivalent to

typedef lambda<pred>::type p;
typedef lambda<in::operation>::type in_op;
typedef apply_wrap2<
      in_op
    , in::state
    , front<types>::type
    >::type in_state;
typedef fold<
      s
    , pair< in_state, front<s>::type >
    , eval_if<
          apply_wrap2<p, second<_1>, _2>
        , identity< first<_1> >
        , apply_wrap2<in_op, first<_1>, _2>
        >
    >::type::first r;

Complexity

Linear. Performs exactly size<s>::value - 1 applications of pred, and at most size<s>::value insertions.

Example

typedef vector<int,float,float,char,int,int,int,double> types;
typedef vector<int,float,char,int,double> expected;
typedef unique< types, is_same<_1,_2> >::type result;
BOOST_MPL_ASSERT(( equal< result,expected > ));

Docutils System Messages

??????????????????
Note: See TracBrowser for help on using the repository browser.