transform_iterator.html 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346
  1. <?xml version="1.0" encoding="utf-8" ?>
  2. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  3. <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
  4. <head>
  5. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  6. <meta name="generator" content="Docutils 0.5: http://docutils.sourceforge.net/" />
  7. <title>Transform Iterator</title>
  8. <meta name="author" content="David Abrahams, Jeremy Siek, Thomas Witt" />
  9. <meta name="organization" content="Boost Consulting, Indiana University Open Systems Lab, University of Hanover Institute for Transport Railway Operation and Construction" />
  10. <meta name="date" content="2006-09-11" />
  11. <meta name="copyright" content="Copyright David Abrahams, Jeremy Siek, and Thomas Witt 2003." />
  12. <link rel="stylesheet" href="../../../rst.css" type="text/css" />
  13. </head>
  14. <body>
  15. <div class="document" id="transform-iterator">
  16. <h1 class="title">Transform Iterator</h1>
  17. <table class="docinfo" frame="void" rules="none">
  18. <col class="docinfo-name" />
  19. <col class="docinfo-content" />
  20. <tbody valign="top">
  21. <tr><th class="docinfo-name">Author:</th>
  22. <td>David Abrahams, Jeremy Siek, Thomas Witt</td></tr>
  23. <tr><th class="docinfo-name">Contact:</th>
  24. <td><a class="first reference external" href="mailto:dave&#64;boost-consulting.com">dave&#64;boost-consulting.com</a>, <a class="reference external" href="mailto:jsiek&#64;osl.iu.edu">jsiek&#64;osl.iu.edu</a>, <a class="last reference external" href="mailto:witt&#64;ive.uni-hannover.de">witt&#64;ive.uni-hannover.de</a></td></tr>
  25. <tr><th class="docinfo-name">Organization:</th>
  26. <td><a class="first reference external" href="http://www.boost-consulting.com">Boost Consulting</a>, Indiana University <a class="reference external" href="http://www.osl.iu.edu">Open Systems
  27. Lab</a>, University of Hanover <a class="last reference external" href="http://www.ive.uni-hannover.de">Institute for Transport
  28. Railway Operation and Construction</a></td></tr>
  29. <tr><th class="docinfo-name">Date:</th>
  30. <td>2006-09-11</td></tr>
  31. <tr><th class="docinfo-name">Copyright:</th>
  32. <td>Copyright David Abrahams, Jeremy Siek, and Thomas Witt 2003.</td></tr>
  33. </tbody>
  34. </table>
  35. <!-- Distributed under the Boost -->
  36. <!-- Software License, Version 1.0. (See accompanying -->
  37. <!-- file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) -->
  38. <table class="docutils field-list" frame="void" rules="none">
  39. <col class="field-name" />
  40. <col class="field-body" />
  41. <tbody valign="top">
  42. <tr class="field"><th class="field-name">abstract:</th><td class="field-body"><!-- Copyright David Abrahams 2006. Distributed under the Boost -->
  43. <!-- Software License, Version 1.0. (See accompanying -->
  44. <!-- file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) -->
  45. The transform iterator adapts an iterator by modifying the
  46. <tt class="docutils literal"><span class="pre">operator*</span></tt> to apply a function object to the result of
  47. dereferencing the iterator and returning the result.</td>
  48. </tr>
  49. </tbody>
  50. </table>
  51. <div class="contents topic" id="table-of-contents">
  52. <p class="topic-title first">Table of Contents</p>
  53. <ul class="simple">
  54. <li><a class="reference internal" href="#transform-iterator-synopsis" id="id2"><tt class="docutils literal"><span class="pre">transform_iterator</span></tt> synopsis</a></li>
  55. <li><a class="reference internal" href="#transform-iterator-requirements" id="id3"><tt class="docutils literal"><span class="pre">transform_iterator</span></tt> requirements</a></li>
  56. <li><a class="reference internal" href="#transform-iterator-models" id="id4"><tt class="docutils literal"><span class="pre">transform_iterator</span></tt> models</a></li>
  57. <li><a class="reference internal" href="#transform-iterator-operations" id="id5"><tt class="docutils literal"><span class="pre">transform_iterator</span></tt> operations</a></li>
  58. <li><a class="reference internal" href="#example" id="id6">Example</a></li>
  59. </ul>
  60. </div>
  61. <div class="section" id="transform-iterator-synopsis">
  62. <h1><a class="toc-backref" href="#id2"><tt class="docutils literal"><span class="pre">transform_iterator</span></tt> synopsis</a></h1>
  63. <!-- Copyright David Abrahams 2006. Distributed under the Boost -->
  64. <!-- Software License, Version 1.0. (See accompanying -->
  65. <!-- file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) -->
  66. <!-- Version 1.3 of this document was accepted for TR1 -->
  67. <pre class="literal-block">
  68. template &lt;class UnaryFunction,
  69. class Iterator,
  70. class Reference = use_default,
  71. class Value = use_default&gt;
  72. class transform_iterator
  73. {
  74. public:
  75. typedef /* see below */ value_type;
  76. typedef /* see below */ reference;
  77. typedef /* see below */ pointer;
  78. typedef iterator_traits&lt;Iterator&gt;::difference_type difference_type;
  79. typedef /* see below */ iterator_category;
  80. transform_iterator();
  81. transform_iterator(Iterator const&amp; x, UnaryFunction f);
  82. template&lt;class F2, class I2, class R2, class V2&gt;
  83. transform_iterator(
  84. transform_iterator&lt;F2, I2, R2, V2&gt; const&amp; t
  85. , typename enable_if_convertible&lt;I2, Iterator&gt;::type* = 0 // exposition only
  86. , typename enable_if_convertible&lt;F2, UnaryFunction&gt;::type* = 0 // exposition only
  87. );
  88. UnaryFunction functor() const;
  89. Iterator const&amp; base() const;
  90. reference operator*() const;
  91. transform_iterator&amp; operator++();
  92. transform_iterator&amp; operator--();
  93. private:
  94. Iterator m_iterator; // exposition only
  95. UnaryFunction m_f; // exposition only
  96. };
  97. </pre>
  98. <p>If <tt class="docutils literal"><span class="pre">Reference</span></tt> is <tt class="docutils literal"><span class="pre">use_default</span></tt> then the <tt class="docutils literal"><span class="pre">reference</span></tt> member of
  99. <tt class="docutils literal"><span class="pre">transform_iterator</span></tt> is
  100. <tt class="docutils literal"><span class="pre">result_of&lt;const UnaryFunction(iterator_traits&lt;Iterator&gt;::reference)&gt;::type</span></tt>.
  101. Otherwise, <tt class="docutils literal"><span class="pre">reference</span></tt> is <tt class="docutils literal"><span class="pre">Reference</span></tt>.</p>
  102. <p>If <tt class="docutils literal"><span class="pre">Value</span></tt> is <tt class="docutils literal"><span class="pre">use_default</span></tt> then the <tt class="docutils literal"><span class="pre">value_type</span></tt> member is
  103. <tt class="docutils literal"><span class="pre">remove_cv&lt;remove_reference&lt;reference&gt;</span> <span class="pre">&gt;::type</span></tt>. Otherwise,
  104. <tt class="docutils literal"><span class="pre">value_type</span></tt> is <tt class="docutils literal"><span class="pre">Value</span></tt>.</p>
  105. <p>If <tt class="docutils literal"><span class="pre">Iterator</span></tt> models Readable Lvalue Iterator and if <tt class="docutils literal"><span class="pre">Iterator</span></tt>
  106. models Random Access Traversal Iterator, then <tt class="docutils literal"><span class="pre">iterator_category</span></tt> is
  107. convertible to <tt class="docutils literal"><span class="pre">random_access_iterator_tag</span></tt>. Otherwise, if
  108. <tt class="docutils literal"><span class="pre">Iterator</span></tt> models Bidirectional Traversal Iterator, then
  109. <tt class="docutils literal"><span class="pre">iterator_category</span></tt> is convertible to
  110. <tt class="docutils literal"><span class="pre">bidirectional_iterator_tag</span></tt>. Otherwise <tt class="docutils literal"><span class="pre">iterator_category</span></tt> is
  111. convertible to <tt class="docutils literal"><span class="pre">forward_iterator_tag</span></tt>. If <tt class="docutils literal"><span class="pre">Iterator</span></tt> does not
  112. model Readable Lvalue Iterator then <tt class="docutils literal"><span class="pre">iterator_category</span></tt> is
  113. convertible to <tt class="docutils literal"><span class="pre">input_iterator_tag</span></tt>.</p>
  114. </div>
  115. <div class="section" id="transform-iterator-requirements">
  116. <h1><a class="toc-backref" href="#id3"><tt class="docutils literal"><span class="pre">transform_iterator</span></tt> requirements</a></h1>
  117. <p>The type <tt class="docutils literal"><span class="pre">UnaryFunction</span></tt> must be Assignable, Copy Constructible, and
  118. the expression <tt class="docutils literal"><span class="pre">f(*i)</span></tt> must be valid where <tt class="docutils literal"><span class="pre">f</span></tt> is a const object of
  119. type <tt class="docutils literal"><span class="pre">UnaryFunction</span></tt>, <tt class="docutils literal"><span class="pre">i</span></tt> is an object of type <tt class="docutils literal"><span class="pre">Iterator</span></tt>, and
  120. where the type of <tt class="docutils literal"><span class="pre">f(*i)</span></tt> must be
  121. <tt class="docutils literal"><span class="pre">result_of&lt;const UnaryFunction(iterator_traits&lt;Iterator&gt;::reference)&gt;::type</span></tt>.</p>
  122. <p>The argument <tt class="docutils literal"><span class="pre">Iterator</span></tt> shall model Readable Iterator.</p>
  123. </div>
  124. <div class="section" id="transform-iterator-models">
  125. <h1><a class="toc-backref" href="#id4"><tt class="docutils literal"><span class="pre">transform_iterator</span></tt> models</a></h1>
  126. <p>The resulting <tt class="docutils literal"><span class="pre">transform_iterator</span></tt> models the most refined of the
  127. following that is also modeled by <tt class="docutils literal"><span class="pre">Iterator</span></tt>.</p>
  128. <blockquote>
  129. <ul class="simple">
  130. <li>Writable Lvalue Iterator if <tt class="docutils literal"><span class="pre">transform_iterator::reference</span></tt> is a non-const reference.</li>
  131. <li>Readable Lvalue Iterator if <tt class="docutils literal"><span class="pre">transform_iterator::reference</span></tt> is a const reference.</li>
  132. <li>Readable Iterator otherwise.</li>
  133. </ul>
  134. </blockquote>
  135. <p>The <tt class="docutils literal"><span class="pre">transform_iterator</span></tt> models the most refined standard traversal
  136. concept that is modeled by the <tt class="docutils literal"><span class="pre">Iterator</span></tt> argument.</p>
  137. <p>If <tt class="docutils literal"><span class="pre">transform_iterator</span></tt> is a model of Readable Lvalue Iterator then
  138. it models the following original iterator concepts depending on what
  139. the <tt class="docutils literal"><span class="pre">Iterator</span></tt> argument models.</p>
  140. <table border="1" class="docutils">
  141. <colgroup>
  142. <col width="47%" />
  143. <col width="53%" />
  144. </colgroup>
  145. <thead valign="bottom">
  146. <tr><th class="head">If <tt class="docutils literal"><span class="pre">Iterator</span></tt> models</th>
  147. <th class="head">then <tt class="docutils literal"><span class="pre">transform_iterator</span></tt> models</th>
  148. </tr>
  149. </thead>
  150. <tbody valign="top">
  151. <tr><td>Single Pass Iterator</td>
  152. <td>Input Iterator</td>
  153. </tr>
  154. <tr><td>Forward Traversal Iterator</td>
  155. <td>Forward Iterator</td>
  156. </tr>
  157. <tr><td>Bidirectional Traversal Iterator</td>
  158. <td>Bidirectional Iterator</td>
  159. </tr>
  160. <tr><td>Random Access Traversal Iterator</td>
  161. <td>Random Access Iterator</td>
  162. </tr>
  163. </tbody>
  164. </table>
  165. <p>If <tt class="docutils literal"><span class="pre">transform_iterator</span></tt> models Writable Lvalue Iterator then it is a
  166. mutable iterator (as defined in the old iterator requirements).</p>
  167. <p><tt class="docutils literal"><span class="pre">transform_iterator&lt;F1,</span> <span class="pre">X,</span> <span class="pre">R1,</span> <span class="pre">V1&gt;</span></tt> is interoperable with
  168. <tt class="docutils literal"><span class="pre">transform_iterator&lt;F2,</span> <span class="pre">Y,</span> <span class="pre">R2,</span> <span class="pre">V2&gt;</span></tt> if and only if <tt class="docutils literal"><span class="pre">X</span></tt> is
  169. interoperable with <tt class="docutils literal"><span class="pre">Y</span></tt>.</p>
  170. </div>
  171. <div class="section" id="transform-iterator-operations">
  172. <h1><a class="toc-backref" href="#id5"><tt class="docutils literal"><span class="pre">transform_iterator</span></tt> operations</a></h1>
  173. <p>In addition to the operations required by the concepts modeled by
  174. <tt class="docutils literal"><span class="pre">transform_iterator</span></tt>, <tt class="docutils literal"><span class="pre">transform_iterator</span></tt> provides the following
  175. operations.</p>
  176. <p><tt class="docutils literal"><span class="pre">transform_iterator();</span></tt></p>
  177. <table class="docutils field-list" frame="void" rules="none">
  178. <col class="field-name" />
  179. <col class="field-body" />
  180. <tbody valign="top">
  181. <tr class="field"><th class="field-name">Returns:</th><td class="field-body">An instance of <tt class="docutils literal"><span class="pre">transform_iterator</span></tt> with <tt class="docutils literal"><span class="pre">m_f</span></tt>
  182. and <tt class="docutils literal"><span class="pre">m_iterator</span></tt> default constructed.</td>
  183. </tr>
  184. </tbody>
  185. </table>
  186. <p><tt class="docutils literal"><span class="pre">transform_iterator(Iterator</span> <span class="pre">const&amp;</span> <span class="pre">x,</span> <span class="pre">UnaryFunction</span> <span class="pre">f);</span></tt></p>
  187. <table class="docutils field-list" frame="void" rules="none">
  188. <col class="field-name" />
  189. <col class="field-body" />
  190. <tbody valign="top">
  191. <tr class="field"><th class="field-name">Returns:</th><td class="field-body">An instance of <tt class="docutils literal"><span class="pre">transform_iterator</span></tt> with <tt class="docutils literal"><span class="pre">m_f</span></tt>
  192. initialized to <tt class="docutils literal"><span class="pre">f</span></tt> and <tt class="docutils literal"><span class="pre">m_iterator</span></tt> initialized to <tt class="docutils literal"><span class="pre">x</span></tt>.</td>
  193. </tr>
  194. </tbody>
  195. </table>
  196. <pre class="literal-block">
  197. template&lt;class F2, class I2, class R2, class V2&gt;
  198. transform_iterator(
  199. transform_iterator&lt;F2, I2, R2, V2&gt; const&amp; t
  200. , typename enable_if_convertible&lt;I2, Iterator&gt;::type* = 0 // exposition only
  201. , typename enable_if_convertible&lt;F2, UnaryFunction&gt;::type* = 0 // exposition only
  202. );
  203. </pre>
  204. <table class="docutils field-list" frame="void" rules="none">
  205. <col class="field-name" />
  206. <col class="field-body" />
  207. <tbody valign="top">
  208. <tr class="field"><th class="field-name">Returns:</th><td class="field-body">An instance of <tt class="docutils literal"><span class="pre">transform_iterator</span></tt> with <tt class="docutils literal"><span class="pre">m_f</span></tt>
  209. initialized to <tt class="docutils literal"><span class="pre">t.functor()</span></tt> and <tt class="docutils literal"><span class="pre">m_iterator</span></tt> initialized to
  210. <tt class="docutils literal"><span class="pre">t.base()</span></tt>.</td>
  211. </tr>
  212. <tr class="field"><th class="field-name">Requires:</th><td class="field-body"><tt class="docutils literal"><span class="pre">OtherIterator</span></tt> is implicitly convertible to <tt class="docutils literal"><span class="pre">Iterator</span></tt>.</td>
  213. </tr>
  214. </tbody>
  215. </table>
  216. <p><tt class="docutils literal"><span class="pre">UnaryFunction</span> <span class="pre">functor()</span> <span class="pre">const;</span></tt></p>
  217. <table class="docutils field-list" frame="void" rules="none">
  218. <col class="field-name" />
  219. <col class="field-body" />
  220. <tbody valign="top">
  221. <tr class="field"><th class="field-name">Returns:</th><td class="field-body"><tt class="docutils literal"><span class="pre">m_f</span></tt></td>
  222. </tr>
  223. </tbody>
  224. </table>
  225. <p><tt class="docutils literal"><span class="pre">Iterator</span> <span class="pre">const&amp;</span> <span class="pre">base()</span> <span class="pre">const;</span></tt></p>
  226. <table class="docutils field-list" frame="void" rules="none">
  227. <col class="field-name" />
  228. <col class="field-body" />
  229. <tbody valign="top">
  230. <tr class="field"><th class="field-name">Returns:</th><td class="field-body"><tt class="docutils literal"><span class="pre">m_iterator</span></tt></td>
  231. </tr>
  232. </tbody>
  233. </table>
  234. <p><tt class="docutils literal"><span class="pre">reference</span> <span class="pre">operator*()</span> <span class="pre">const;</span></tt></p>
  235. <table class="docutils field-list" frame="void" rules="none">
  236. <col class="field-name" />
  237. <col class="field-body" />
  238. <tbody valign="top">
  239. <tr class="field"><th class="field-name">Returns:</th><td class="field-body"><tt class="docutils literal"><span class="pre">m_f(*m_iterator)</span></tt></td>
  240. </tr>
  241. </tbody>
  242. </table>
  243. <p><tt class="docutils literal"><span class="pre">transform_iterator&amp;</span> <span class="pre">operator++();</span></tt></p>
  244. <table class="docutils field-list" frame="void" rules="none">
  245. <col class="field-name" />
  246. <col class="field-body" />
  247. <tbody valign="top">
  248. <tr class="field"><th class="field-name">Effects:</th><td class="field-body"><tt class="docutils literal"><span class="pre">++m_iterator</span></tt></td>
  249. </tr>
  250. <tr class="field"><th class="field-name">Returns:</th><td class="field-body"><tt class="docutils literal"><span class="pre">*this</span></tt></td>
  251. </tr>
  252. </tbody>
  253. </table>
  254. <p><tt class="docutils literal"><span class="pre">transform_iterator&amp;</span> <span class="pre">operator--();</span></tt></p>
  255. <table class="docutils field-list" frame="void" rules="none">
  256. <col class="field-name" />
  257. <col class="field-body" />
  258. <tbody valign="top">
  259. <tr class="field"><th class="field-name">Effects:</th><td class="field-body"><tt class="docutils literal"><span class="pre">--m_iterator</span></tt></td>
  260. </tr>
  261. <tr class="field"><th class="field-name">Returns:</th><td class="field-body"><tt class="docutils literal"><span class="pre">*this</span></tt></td>
  262. </tr>
  263. </tbody>
  264. </table>
  265. <!-- Copyright David Abrahams 2006. Distributed under the Boost -->
  266. <!-- Software License, Version 1.0. (See accompanying -->
  267. <!-- file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) -->
  268. <pre class="literal-block">
  269. template &lt;class UnaryFunction, class Iterator&gt;
  270. transform_iterator&lt;UnaryFunction, Iterator&gt;
  271. make_transform_iterator(Iterator it, UnaryFunction fun);
  272. </pre>
  273. <table class="docutils field-list" frame="void" rules="none">
  274. <col class="field-name" />
  275. <col class="field-body" />
  276. <tbody valign="top">
  277. <tr class="field"><th class="field-name">Returns:</th><td class="field-body">An instance of <tt class="docutils literal"><span class="pre">transform_iterator&lt;UnaryFunction,</span> <span class="pre">Iterator&gt;</span></tt> with <tt class="docutils literal"><span class="pre">m_f</span></tt>
  278. initialized to <tt class="docutils literal"><span class="pre">f</span></tt> and <tt class="docutils literal"><span class="pre">m_iterator</span></tt> initialized to <tt class="docutils literal"><span class="pre">x</span></tt>.</td>
  279. </tr>
  280. </tbody>
  281. </table>
  282. <pre class="literal-block">
  283. template &lt;class UnaryFunction, class Iterator&gt;
  284. transform_iterator&lt;UnaryFunction, Iterator&gt;
  285. make_transform_iterator(Iterator it);
  286. </pre>
  287. <table class="docutils field-list" frame="void" rules="none">
  288. <col class="field-name" />
  289. <col class="field-body" />
  290. <tbody valign="top">
  291. <tr class="field"><th class="field-name">Returns:</th><td class="field-body">An instance of <tt class="docutils literal"><span class="pre">transform_iterator&lt;UnaryFunction,</span> <span class="pre">Iterator&gt;</span></tt> with <tt class="docutils literal"><span class="pre">m_f</span></tt>
  292. default constructed and <tt class="docutils literal"><span class="pre">m_iterator</span></tt> initialized to <tt class="docutils literal"><span class="pre">x</span></tt>.</td>
  293. </tr>
  294. </tbody>
  295. </table>
  296. <!-- Copyright David Abrahams 2006. Distributed under the Boost -->
  297. <!-- Software License, Version 1.0. (See accompanying -->
  298. <!-- file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) -->
  299. </div>
  300. <div class="section" id="example">
  301. <h1><a class="toc-backref" href="#id6">Example</a></h1>
  302. <p>This is a simple example of using the transform_iterators class to
  303. generate iterators that multiply (or add to) the value returned by
  304. dereferencing the iterator. It would be cooler to use lambda library
  305. in this example.</p>
  306. <pre class="literal-block">
  307. int x[] = { 1, 2, 3, 4, 5, 6, 7, 8 };
  308. const int N = sizeof(x)/sizeof(int);
  309. typedef boost::binder1st&lt; std::multiplies&lt;int&gt; &gt; Function;
  310. typedef boost::transform_iterator&lt;Function, int*&gt; doubling_iterator;
  311. doubling_iterator i(x, boost::bind1st(std::multiplies&lt;int&gt;(), 2)),
  312. i_end(x + N, boost::bind1st(std::multiplies&lt;int&gt;(), 2));
  313. std::cout &lt;&lt; &quot;multiplying the array by 2:&quot; &lt;&lt; std::endl;
  314. while (i != i_end)
  315. std::cout &lt;&lt; *i++ &lt;&lt; &quot; &quot;;
  316. std::cout &lt;&lt; std::endl;
  317. std::cout &lt;&lt; &quot;adding 4 to each element in the array:&quot; &lt;&lt; std::endl;
  318. std::copy(boost::make_transform_iterator(x, boost::bind1st(std::plus&lt;int&gt;(), 4)),
  319. boost::make_transform_iterator(x + N, boost::bind1st(std::plus&lt;int&gt;(), 4)),
  320. std::ostream_iterator&lt;int&gt;(std::cout, &quot; &quot;));
  321. std::cout &lt;&lt; std::endl;
  322. </pre>
  323. <p>The output is:</p>
  324. <pre class="literal-block">
  325. multiplying the array by 2:
  326. 2 4 6 8 10 12 14 16
  327. adding 4 to each element in the array:
  328. 5 6 7 8 9 10 11 12
  329. </pre>
  330. <p>The source code for this example can be found <a class="reference external" href="../example/transform_iterator_example.cpp">here</a>.</p>
  331. </div>
  332. </div>
  333. <div class="footer">
  334. <hr class="footer" />
  335. <a class="reference external" href="transform_iterator.rst">View document source</a>.
  336. Generated by <a class="reference external" href="http://docutils.sourceforge.net/">Docutils</a> from <a class="reference external" href="http://docutils.sourceforge.net/rst.html">reStructuredText</a> source.
  337. </div>
  338. </body>
  339. </html>