blob: 47c241c4cb640f5721e3db7a885594bf995f5b2e [file] [log] [blame]
.. Sequences/Views//transform_view
transform_view
==============
Synopsis
--------
.. parsed-literal::
template<
typename Sequence
, typename F
>
struct transform_view
{
// |unspecified|
// |...|
};
Description
-----------
A view the full range of ``Sequence``\ 's transformed elements.
Header
------
.. parsed-literal::
#include <boost/mpl/transform_view.hpp>
Model of
--------
* |Forward Sequence|
Parameters
----------
+---------------+-------------------------------+-------------------------------+
| Parameter | Requirement | Description |
+===============+===============================+===============================+
| ``Sequence`` | |Forward Sequence| | A sequence to wrap. |
+---------------+-------------------------------+-------------------------------+
| ``F`` | Unary |Lambda Expression| | A transformation. |
+---------------+-------------------------------+-------------------------------+
Expression semantics
--------------------
|Semantics disclaimer...| |Forward Sequence|.
In the following table, ``v`` is an instance of ``transform_view``, ``s`` is an arbitrary
|Forward Sequence|, and ``f`` is an unary |Lambda Expression|.
+-----------------------------------+-----------------------------------------------------------+
| Expression | Semantics |
+===================================+===========================================================+
| .. parsed-literal:: | A lazy |Forward Sequence| such that for each ``i`` in the |
| | range |begin/end<v>| and each ``j`` in for in the range |
| transform_view<s,f> | |begin/end<s>| ``deref<i>::type`` is identical to |
| transform_view<s,f>::type | ``apply< f, deref<j>::type >::type``. |
+-----------------------------------+-----------------------------------------------------------+
| ``size<v>::type`` | The size of ``v``; |
| | ``size<v>::value == size<s>::value``; |
| | linear complexity; see |Forward Sequence|. |
+-----------------------------------+-----------------------------------------------------------+
Example
-------
Find the largest type in a sequence.
.. parsed-literal::
typedef vector<int,long,char,char[50],double> types;
typedef max_element<
transform_view< types, size_of<_> >
>::type iter;
BOOST_MPL_ASSERT_RELATION( deref<iter>::type::value, ==, 50 );
See also
--------
|Sequences|, |Views|, |filter_view|, |joint_view|, |zip_view|, |iterator_range|
.. copyright:: Copyright © 2001-2009 Aleksey Gurtovoy and David Abrahams
Distributed under the Boost Software License, Version 1.0. (See accompanying
file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)