1.. Algorithms/Transformation Algorithms//copy_if |20 2 3copy_if 4======= 5 6Synopsis 7-------- 8 9.. parsed-literal:: 10 11 template< 12 typename Sequence 13 , typename Pred 14 , typename In = |unspecified| 15 > 16 struct copy_if 17 { 18 typedef |unspecified| type; 19 }; 20 21 22 23Description 24----------- 25 26Returns a filtered copy of the original sequence containing the elements that satisfy 27the predicate ``Pred``. 28 29|transformation algorithm disclaimer| 30 31Header 32------ 33 34.. parsed-literal:: 35 36 #include <boost/mpl/copy_if.hpp> 37 38 39Model of 40-------- 41 42|Reversible Algorithm| 43 44 45Parameters 46---------- 47 48+---------------+-------------------------------+-------------------------------+ 49| Parameter | Requirement | Description | 50+===============+===============================+===============================+ 51| ``Sequence`` | |Forward Sequence| | A sequence to copy. | 52+---------------+-------------------------------+-------------------------------+ 53| ``Pred`` | Unary |Lambda Expression| | A copying condition. | 54+---------------+-------------------------------+-------------------------------+ 55| ``In`` | |Inserter| | An inserter. | 56+---------------+-------------------------------+-------------------------------+ 57 58 59Expression semantics 60-------------------- 61 62|Semantics disclaimer...| |Reversible Algorithm|. 63 64For any |Forward Sequence| ``s``, an unary |Lambda Expression| ``pred``, and 65an |Inserter| ``in``: 66 67 68.. parsed-literal:: 69 70 typedef copy_if<s,pred,in>::type r; 71 72 73:Return type: 74 A type. 75 76:Semantics: 77 Equivalent to 78 79 .. parsed-literal:: 80 81 typedef lambda<pred>::type p; 82 typedef lambda<in::operation>::type op; 83 84 typedef fold< 85 s 86 , in::state 87 , eval_if< 88 apply_wrap\ ``1``\<p,_2> 89 , apply_wrap\ ``2``\<op,_1,_2> 90 , identity<_1> 91 > 92 >::type r; 93 94 95Complexity 96---------- 97 98Linear. Exactly ``size<s>::value`` applications of ``pred``, and at 99most ``size<s>::value`` applications of ``in::operation``. 100 101 102Example 103------- 104 105.. parsed-literal:: 106 107 typedef copy_if< 108 range_c<int,0,10> 109 , less< _1, int_<5> > 110 , back_inserter< vector<> > 111 >::type result; 112 113 BOOST_MPL_ASSERT_RELATION( size<result>::value, ==, 5 ); 114 BOOST_MPL_ASSERT(( equal<result,range_c<int,0,5> > )); 115 116 117See also 118-------- 119 120|Transformation Algorithms|, |Reversible Algorithm|, |reverse_copy_if|, |copy|, |remove_if|, |replace_if| 121 122 123.. copyright:: Copyright � 2001-2009 Aleksey Gurtovoy and David Abrahams 124 Distributed under the Boost Software License, Version 1.0. (See accompanying 125 file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) 126