Sophie

Sophie

distrib > Fedora > 16 > i386 > by-pkgid > 4bc66056a634db26a1f4d0845dc41ca6 > files > 11606

mrpt-doc-0.9.5-0.1.20110925svn2670.fc16.i686.rpm

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><meta http-equiv="Content-Type" content="text/html;charset=iso-8859-1">
<title>mrpt::utils::metaprogramming Namespace Reference</title>
<link href="doxygen.css" rel="stylesheet" type="text/css">
<link href="tabs.css" rel="stylesheet" type="text/css">
</head><body>
<div align="left"><a href="http://www.mrpt.org/">Main MRPT website</a> &gt; <b>C++ reference</b> </div>
<div align="right">
<a href="index.html"><img border="0" src="mrpt_logo.png" alt="MRPT logo"></a>
</div>
<!-- Generated by Doxygen 1.7.5 -->
<script type="text/javascript">
var searchBox = new SearchBox("searchBox", "search",false,'Search');
</script>
  <div id="navrow1" class="tabs">
    <ul class="tablist">
      <li><a href="index.html"><span>Main&#160;Page</span></a></li>
      <li><a href="pages.html"><span>Related&#160;Pages</span></a></li>
      <li><a href="modules.html"><span>Modules</span></a></li>
      <li class="current"><a href="namespaces.html"><span>Namespaces</span></a></li>
      <li><a href="annotated.html"><span>Classes</span></a></li>
      <li><a href="files.html"><span>Files</span></a></li>
      <li>
        <div id="MSearchBox" class="MSearchBoxInactive">
          <div class="left">
            <form id="FSearchBox" action="search.php" method="get">
              <img id="MSearchSelect" src="search/mag.png" alt=""/>
              <input type="text" id="MSearchField" name="query" value="Search" size="20" accesskey="S" 
                     onfocus="searchBox.OnSearchFieldFocus(true)" 
                     onblur="searchBox.OnSearchFieldFocus(false)"/>
            </form>
          </div><div class="right"></div>
        </div>
      </li>
    </ul>
  </div>
  <div id="navrow2" class="tabs2">
    <ul class="tablist">
      <li><a href="namespaces.html"><span>Namespace&#160;List</span></a></li>
      <li><a href="namespacemembers.html"><span>Namespace&#160;Members</span></a></li>
    </ul>
  </div>
  <div id="nav-path" class="navpath">
    <ul>
      <li class="navelem"><a class="el" href="namespacemrpt.html">mrpt</a>      </li>
      <li class="navelem"><a class="el" href="namespacemrpt_1_1utils.html">utils</a>      </li>
      <li class="navelem"><a class="el" href="namespacemrpt_1_1utils_1_1metaprogramming.html">metaprogramming</a>      </li>
    </ul>
  </div>
</div>
<div class="header">
  <div class="summary">
<a href="#nested-classes">Classes</a> &#124;
<a href="#func-members">Functions</a>  </div>
  <div class="headertitle">
<div class="title">mrpt::utils::metaprogramming Namespace Reference<div class="ingroups"><a class="el" href="group__stlext__grp.html">STL extensions and metaprogramming</a></div></div>  </div>
</div>
<div class="contents">
<hr/><a name="details" id="details"></a><h2>Detailed Description</h2>
<div class="textblock"><p>A set of utility objects for metaprogramming with STL algorithms. </p>
</div><table class="memberdecls">
<tr><td colspan="2"><h2><a name="nested-classes"></a>
Classes</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_delete.html">ObjectDelete</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">An object for deleting pointers (intended for STL algorithms)  <a href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_delete.html#details">More...</a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_clear.html">ObjectClear</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">An object for clearing an object (invokes its method "-&gt;clear()") given a pointer or smart-pointer, intended for being used in STL algorithms.  <a href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_clear.html#details">More...</a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_clear2.html">ObjectClear2</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">An object for clearing an object (invokes its method ".clear()") given a pointer or smart-pointer, intended for being used in STL algorithms.  <a href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_clear2.html#details">More...</a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_clear_second.html">ObjectClearSecond</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">An object for clearing an object-&gt;second (invokes its method "clear()") given a pointer or smart-pointer, intended for being used in STL algorithms.  <a href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_clear_second.html#details">More...</a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_convert.html">ObjectConvert</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">An object for transforming between types/classes, intended for being used in STL algorithms.  <a href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_convert.html#details">More...</a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_make_unique.html">ObjectMakeUnique</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">An object for making smart pointers unique (ie, making copies if necessary), intended for being used in STL algorithms.  <a href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_make_unique.html#details">More...</a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_pair_make_unique.html">ObjectPairMakeUnique</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">An object for making smart pointers unique (ie, making copies if necessary), intended for being used in STL algorithms.  <a href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_pair_make_unique.html#details">More...</a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_clear_unique.html">ObjectClearUnique</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">An object for making smart pointers unique (ie, making copies if necessary), intended for being used in STL algorithms.  <a href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_clear_unique.html#details">More...</a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_read_from_stream.html">ObjectReadFromStream</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">An object for reading objects from a stream, intended for being used in STL algorithms.  <a href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_read_from_stream.html#details">More...</a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_write_to_stream.html">ObjectWriteToStream</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">An object for writing objects to a stream, intended for being used in STL algorithms.  <a href="structmrpt_1_1utils_1_1metaprogramming_1_1_object_write_to_stream.html#details">More...</a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classmrpt_1_1utils_1_1metaprogramming_1_1_memory_bypasser_iterator.html">MemoryBypasserIterator</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">This class bypasses pointer access in iterators to pointers, thus allowing the use of algorithms that expect an object of class T with containers of T*.  <a href="classmrpt_1_1utils_1_1metaprogramming_1_1_memory_bypasser_iterator.html#details">More...</a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classmrpt_1_1utils_1_1metaprogramming_1_1_binary_member_function_wrapper.html">BinaryMemberFunctionWrapper</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">This template encapsulates a binary member function and a single object into a function expecting the two parameters of the member function.  <a href="classmrpt_1_1utils_1_1metaprogramming_1_1_binary_member_function_wrapper.html#details">More...</a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classmrpt_1_1utils_1_1metaprogramming_1_1_unary_member_function_wrapper.html">UnaryMemberFunctionWrapper</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">This template encapsulates an unary member function and a single object into a function expecting the parameter of the member function.  <a href="classmrpt_1_1utils_1_1metaprogramming_1_1_unary_member_function_wrapper.html#details">More...</a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classmrpt_1_1utils_1_1metaprogramming_1_1_member_function_wrapper.html">MemberFunctionWrapper</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">This template encapsulates a member function without arguments and a single object into a function.  <a href="classmrpt_1_1utils_1_1metaprogramming_1_1_member_function_wrapper.html#details">More...</a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classmrpt_1_1utils_1_1metaprogramming_1_1_non_const_bind1st.html">NonConstBind1st</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Equivalent of std::bind1st for functions with non-const arguments.  <a href="classmrpt_1_1utils_1_1metaprogramming_1_1_non_const_bind1st.html#details">More...</a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classmrpt_1_1utils_1_1metaprogramming_1_1_non_const_bind2nd.html">NonConstBind2nd</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Equivalent of std::bind2nd for functions with non-const arguments.  <a href="classmrpt_1_1utils_1_1metaprogramming_1_1_non_const_bind2nd.html#details">More...</a><br/></td></tr>
<tr><td colspan="2"><h2><a name="func-members"></a>
Functions</h2></td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;typename T &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">void&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__stlext__grp.html#gadaaa552aaf3cf45f086333c0b3aa07f4">DeleteContainer</a> (T &amp;container)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">A function which deletes a container of pointers.  <a href="group__stlext__grp.html#gadaaa552aaf3cf45f086333c0b3aa07f4"></a><br/></td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;typename it_src , typename it_dst &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">void&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__stlext__grp.html#gaa09727cae72f8986348c41e13a3f1eb6">copy_typecasting</a> (it_src first, it_src last, it_dst target)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Behaves like std::copy but allows the source and target iterators to be of different types through static typecasting.  <a href="group__stlext__grp.html#gaa09727cae72f8986348c41e13a3f1eb6"></a><br/></td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;typename src_container , typename dst_container &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">void&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__stlext__grp.html#ga5263f98f648cdc32c1a74efc05d48d60">copy_container_typecasting</a> (const src_container &amp;src, dst_container &amp;trg)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Copy all the elements in a container (vector, deque, list) into a different one performing the appropriate typecasting.  <a href="group__stlext__grp.html#ga5263f98f648cdc32c1a74efc05d48d60"></a><br/></td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;typename U , typename T &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top"><a class="el" href="classmrpt_1_1utils_1_1metaprogramming_1_1_memory_bypasser_iterator.html">MemoryBypasserIterator</a>&lt; T, U &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__stlext__grp.html#ga8e4c960e8ea93586b181c7ce63f2d0f5">bypassPointer</a> (const T &amp;baseIterator)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Sintactic sugar for <a class="el" href="classmrpt_1_1utils_1_1metaprogramming_1_1_memory_bypasser_iterator.html" title="This class bypasses pointer access in iterators to pointers, thus allowing the use of algorithms that...">MemoryBypasserIterator</a>.  <a href="group__stlext__grp.html#ga8e4c960e8ea93586b181c7ce63f2d0f5"></a><br/></td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;typename T , typename U1 , typename U2 , typename V &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top"><a class="el" href="classmrpt_1_1utils_1_1metaprogramming_1_1_binary_member_function_wrapper.html">BinaryMemberFunctionWrapper</a>&lt; T, <br class="typebreak"/>
U1, U2, V &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__stlext__grp.html#ga312b016e67b4b7c0438fd9523d83d447">wrapMember</a> (V &amp;obj, T(V::*fun)(U1, U2))</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">This function creates a function from an object and a member function.  <a href="group__stlext__grp.html#ga312b016e67b4b7c0438fd9523d83d447"></a><br/></td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;typename T , typename U , typename V &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top"><a class="el" href="classmrpt_1_1utils_1_1metaprogramming_1_1_unary_member_function_wrapper.html">UnaryMemberFunctionWrapper</a>&lt; T, <br class="typebreak"/>
U, V &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__stlext__grp.html#ga15235972fd7c18534c13c3eb0b371024">wrapMember</a> (V &amp;obj, T(V::*fun)(U))</td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;typename T , typename V &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top"><a class="el" href="classmrpt_1_1utils_1_1metaprogramming_1_1_member_function_wrapper.html">MemberFunctionWrapper</a>&lt; T, V &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__stlext__grp.html#ga34f7c25bf9bff668efdf2f33e1d87e51">wrapMember</a> (V &amp;obj, T(V::*fun)(void))</td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;typename Op &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top"><a class="el" href="classmrpt_1_1utils_1_1metaprogramming_1_1_non_const_bind1st.html">NonConstBind1st</a>&lt; Op &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__stlext__grp.html#ga117bd381b8f0b2f9216d0c2f78bbe843">nonConstBind1st</a> (Op &amp;o, typename Op::first_argument_type &amp;t)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Use this function instead of directly calling <a class="el" href="classmrpt_1_1utils_1_1metaprogramming_1_1_non_const_bind1st.html" title="Equivalent of std::bind1st for functions with non-const arguments.">NonConstBind1st</a>.  <a href="group__stlext__grp.html#ga117bd381b8f0b2f9216d0c2f78bbe843"></a><br/></td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;typename Op &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top"><a class="el" href="classmrpt_1_1utils_1_1metaprogramming_1_1_non_const_bind2nd.html">NonConstBind2nd</a>&lt; Op &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__stlext__grp.html#ga3adb0c601312a6404a50ae746526fac4">nonConstBind2nd</a> (Op &amp;o, typename Op::second_argument_type &amp;t)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Do not directly use the <a class="el" href="classmrpt_1_1utils_1_1metaprogramming_1_1_non_const_bind2nd.html" title="Equivalent of std::bind2nd for functions with non-const arguments.">NonConstBind2nd</a> class directly.  <a href="group__stlext__grp.html#ga3adb0c601312a6404a50ae746526fac4"></a><br/></td></tr>
</table>
</div>
<br><hr><br> <table border="0" width="100%"> <tr> <td> Page generated by <a href="http://www.doxygen.org" target="_blank">Doxygen 1.7.5</a> for MRPT 0.9.5 SVN: at Sun Sep 25 17:20:18 UTC 2011</td><td></td> <td width="100"> </td> <td width="150">  </td></tr> </table>  </body></html>