Sophie

Sophie

distrib > Mageia > 7 > armv7hl > media > core-release > by-pkgid > d8d30ad953f2dbe7e871721325480315 > files > 208

librttr-devel-0.9.6-1.mga7.armv7hl.rpm

<!-- HTML header for doxygen 1.8.8-->
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <!-- For Mobile Devices -->
        <meta name="viewport" content="width=device-width, initial-scale=1">
        <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
        <meta name="generator" content="Doxygen 1.8.15"/>
        <script type="text/javascript" src="jquery.min.js"></script>
        <title>rttr: rttr::registration::class_&lt; Class_Type &gt; Class Template Reference</title>
        <!--<link href="tabs.css" rel="stylesheet" type="text/css"/>-->
        <script type="text/javascript" src="dynsections.js"></script>
        <link rel = "shortcut icon" type = "image/x-icon" href = "favicon.ico">
        <link rel = "stylesheet" href = "fonts/ptsans_regular_macroman/stylesheet.css">
        <link rel = "stylesheet" href = "fonts/source_code_pro_regular/stylesheet.css">
        <link href="doxygen.css" rel="stylesheet" type="text/css" />
        <link href="custom-doxygen.css" rel="stylesheet" type="text/css"/>
        <link rel="stylesheet" href="bootstrap/css/bootstrap.min.css">
        <link rel="stylesheet" href="custom-bootstrap.css">
        <script src="bootstrap/js/bootstrap.min.js"></script>
        <script type="text/javascript" src="doxy-boot.js"></script>
    </head>
    <body>
     <!--
        <nav class="navbar navbar-default" role="navigation">
            <div class="container">
                <div class="navbar-header">
                    <a class="navbar-brand">rttr 0.9.6</a>
                </div>
            </div>
        </nav>
        -->
        <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
            <div class="content" id="content">
                <div class="container">
                    <div class="row">
                        <div class="col-sm-12 panel panel-default" style="padding-bottom: 15px;">
                            <div style="margin-bottom: 15px;">
<!-- end header part -->
<!-- Generated by Doxygen 1.8.15 -->
<script type="text/javascript" src="menudata.js"></script>
<script type="text/javascript" src="menu.js"></script>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
$(function() {
  initMenu('',false,false,'search.php','Search');
});
/* @license-end */</script>
<div id="main-nav"></div>
<div id="nav-path" class="navpath">
  <ul>
<li class="navelem"><a class="el" href="namespacerttr.html">rttr</a></li><li class="navelem"><a class="el" href="classrttr_1_1registration.html">registration</a></li><li class="navelem"><a class="el" href="classrttr_1_1registration_1_1class__.html">class_</a></li>  </ul>
</div>
</div><!-- top -->
<div class="header">
  <div class="summary">
<a href="#pub-methods">Public Member Functions</a> &#124;
<a href="classrttr_1_1registration_1_1class__-members.html">List of all members</a>  </div>
  <div class="headertitle">
<div class="title">rttr::registration::class_&lt; Class_Type &gt; Class Template Reference</div>  </div>
</div><!--header-->
<div class="contents">

<p>The <a class="el" href="classrttr_1_1registration_1_1class__.html">class_</a> is used to register classes to RTTR.  
 <a href="classrttr_1_1registration_1_1class__.html#details">More...</a></p>

<p><code>#include &lt;<a class="el" href="registration_8h_source.html">registration.h</a>&gt;</code></p>
<table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
Public Member Functions</h2></td></tr>
<tr class="memitem:a723c8bc8b91535b391d0eeee36458ea9"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classrttr_1_1registration_1_1class__.html#a723c8bc8b91535b391d0eeee36458ea9">class_</a> (<a class="el" href="namespacerttr.html#a61265f69675ac438ecfa23b084adaa56">string_view</a> name)</td></tr>
<tr class="memdesc:a723c8bc8b91535b391d0eeee36458ea9"><td class="mdescLeft">&#160;</td><td class="mdescRight">Construct a <a class="el" href="classrttr_1_1registration_1_1class__.html" title="The class_ is used to register classes to RTTR.">class_</a> object with the given name <code>name</code>.  <a href="#a723c8bc8b91535b391d0eeee36458ea9">More...</a><br /></td></tr>
<tr class="separator:a723c8bc8b91535b391d0eeee36458ea9"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a75fd948ca0675a8db670cc52d40127a0"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classrttr_1_1registration_1_1class__.html#a75fd948ca0675a8db670cc52d40127a0">~class_</a> ()</td></tr>
<tr class="separator:a75fd948ca0675a8db670cc52d40127a0"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a92925cd9adc8c53c6c2df6e5f7f86e8a"><td class="memTemplParams" colspan="2">template&lt;typename... Args, typename acc_level  = detail::public_access, typename Tp  = typename std::enable_if&lt;detail::contains&lt;acc_level, detail::access_levels_list&gt;::value&gt;::type&gt; </td></tr>
<tr class="memitem:a92925cd9adc8c53c6c2df6e5f7f86e8a"><td class="memTemplItemLeft" align="right" valign="top"><a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a>&lt; detail::ctor, Class_Type, acc_level, Args... &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classrttr_1_1registration_1_1class__.html#a92925cd9adc8c53c6c2df6e5f7f86e8a">constructor</a> (acc_level level=acc_level())</td></tr>
<tr class="memdesc:a92925cd9adc8c53c6c2df6e5f7f86e8a"><td class="mdescLeft">&#160;</td><td class="mdescRight">Register a constructor for this class type with or without arguments.  <a href="#a92925cd9adc8c53c6c2df6e5f7f86e8a">More...</a><br /></td></tr>
<tr class="separator:a92925cd9adc8c53c6c2df6e5f7f86e8a"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a54b2d5501df646b98a2ca0853b3752e0"><td class="memTemplParams" colspan="2">template&lt;typename F , typename acc_level  = detail::public_access, typename Tp  = typename std::enable_if&lt;!detail::contains&lt;F, detail::access_levels_list&gt;::value&gt;::type&gt; </td></tr>
<tr class="memitem:a54b2d5501df646b98a2ca0853b3752e0"><td class="memTemplItemLeft" align="right" valign="top"><a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a>&lt; detail::ctor_func, Class_Type, F, acc_level &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classrttr_1_1registration_1_1class__.html#a54b2d5501df646b98a2ca0853b3752e0">constructor</a> (F func, acc_level level=acc_level())</td></tr>
<tr class="memdesc:a54b2d5501df646b98a2ca0853b3752e0"><td class="mdescLeft">&#160;</td><td class="mdescRight">Register a constructor for this class type which uses a function <code>F</code>.  <a href="#a54b2d5501df646b98a2ca0853b3752e0">More...</a><br /></td></tr>
<tr class="separator:a54b2d5501df646b98a2ca0853b3752e0"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad4f37155a55668afd8fcb66441f3ef88"><td class="memTemplParams" colspan="2">template&lt;typename Enum_Type &gt; </td></tr>
<tr class="memitem:ad4f37155a55668afd8fcb66441f3ef88"><td class="memTemplItemLeft" align="right" valign="top"><a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a>&lt; detail::enum_, Class_Type, Enum_Type &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classrttr_1_1registration_1_1class__.html#ad4f37155a55668afd8fcb66441f3ef88">enumeration</a> (<a class="el" href="namespacerttr.html#a61265f69675ac438ecfa23b084adaa56">string_view</a> name)</td></tr>
<tr class="memdesc:ad4f37155a55668afd8fcb66441f3ef88"><td class="mdescLeft">&#160;</td><td class="mdescRight">Register a nested enumeration of type <code>Enum_Type</code>.  <a href="#ad4f37155a55668afd8fcb66441f3ef88">More...</a><br /></td></tr>
<tr class="separator:ad4f37155a55668afd8fcb66441f3ef88"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3997256452d390b54990f202cf768bc7"><td class="memTemplParams" colspan="2">template&lt;typename F , typename acc_level  = detail::public_access&gt; </td></tr>
<tr class="memitem:a3997256452d390b54990f202cf768bc7"><td class="memTemplItemLeft" align="right" valign="top"><a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a>&lt; detail::meth, Class_Type, F, acc_level &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classrttr_1_1registration_1_1class__.html#a3997256452d390b54990f202cf768bc7">method</a> (<a class="el" href="namespacerttr.html#a61265f69675ac438ecfa23b084adaa56">string_view</a> name, F f, acc_level level=acc_level())</td></tr>
<tr class="memdesc:a3997256452d390b54990f202cf768bc7"><td class="mdescLeft">&#160;</td><td class="mdescRight">Register a method to this class.  <a href="#a3997256452d390b54990f202cf768bc7">More...</a><br /></td></tr>
<tr class="separator:a3997256452d390b54990f202cf768bc7"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a17d658b8d88ce353d0ad777d1b01a360"><td class="memTemplParams" colspan="2">template&lt;typename... Args&gt; </td></tr>
<tr class="memitem:a17d658b8d88ce353d0ad777d1b01a360"><td class="memTemplItemLeft" align="right" valign="top"><a class="el" href="classrttr_1_1registration_1_1class__.html">class_</a>&lt; Class_Type &gt; &amp;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classrttr_1_1registration_1_1class__.html#a17d658b8d88ce353d0ad777d1b01a360">operator()</a> (Args &amp;&amp;...args)</td></tr>
<tr class="memdesc:a17d658b8d88ce353d0ad777d1b01a360"><td class="mdescLeft">&#160;</td><td class="mdescRight">The bracket operator can be used to add additional meta data to the class type.  <a href="#a17d658b8d88ce353d0ad777d1b01a360">More...</a><br /></td></tr>
<tr class="separator:a17d658b8d88ce353d0ad777d1b01a360"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a005a60417fb6d183af475cb4059dc0a0"><td class="memTemplParams" colspan="2">template&lt;typename A , typename acc_level  = detail::public_access, typename Tp  = typename std::enable_if&lt;detail::contains&lt;acc_level, detail::access_levels_list&gt;::value&gt;::type&gt; </td></tr>
<tr class="memitem:a005a60417fb6d183af475cb4059dc0a0"><td class="memTemplItemLeft" align="right" valign="top"><a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a>&lt; detail::prop, Class_Type, A, acc_level &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classrttr_1_1registration_1_1class__.html#a005a60417fb6d183af475cb4059dc0a0">property</a> (<a class="el" href="namespacerttr.html#a61265f69675ac438ecfa23b084adaa56">string_view</a> name, A acc, acc_level level=acc_level())</td></tr>
<tr class="memdesc:a005a60417fb6d183af475cb4059dc0a0"><td class="mdescLeft">&#160;</td><td class="mdescRight">Register a property to this class.  <a href="#a005a60417fb6d183af475cb4059dc0a0">More...</a><br /></td></tr>
<tr class="separator:a005a60417fb6d183af475cb4059dc0a0"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:af46d69abe0ea22712777ff420bcfd7b4"><td class="memTemplParams" colspan="2">template&lt;typename A1 , typename A2 , typename Tp  = typename std::enable_if&lt;!detail::contains&lt;A2, detail::access_levels_list&gt;::value&gt;::type, typename acc_level  = detail::public_access&gt; </td></tr>
<tr class="memitem:af46d69abe0ea22712777ff420bcfd7b4"><td class="memTemplItemLeft" align="right" valign="top"><a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a>&lt; detail::prop, Class_Type, A1, A2, acc_level &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classrttr_1_1registration_1_1class__.html#af46d69abe0ea22712777ff420bcfd7b4">property</a> (<a class="el" href="namespacerttr.html#a61265f69675ac438ecfa23b084adaa56">string_view</a> name, A1 getter, A2 setter, acc_level level=acc_level())</td></tr>
<tr class="memdesc:af46d69abe0ea22712777ff420bcfd7b4"><td class="mdescLeft">&#160;</td><td class="mdescRight">Register a property to this class.  <a href="#af46d69abe0ea22712777ff420bcfd7b4">More...</a><br /></td></tr>
<tr class="separator:af46d69abe0ea22712777ff420bcfd7b4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a174f7ef563a97b910dbf894694653ce5"><td class="memTemplParams" colspan="2">template&lt;typename A , typename acc_level  = detail::public_access, typename Tp  = typename std::enable_if&lt;detail::contains&lt;acc_level, detail::access_levels_list&gt;::value&gt;::type&gt; </td></tr>
<tr class="memitem:a174f7ef563a97b910dbf894694653ce5"><td class="memTemplItemLeft" align="right" valign="top"><a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a>&lt; detail::prop_readonly, Class_Type, A, acc_level &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classrttr_1_1registration_1_1class__.html#a174f7ef563a97b910dbf894694653ce5">property_readonly</a> (<a class="el" href="namespacerttr.html#a61265f69675ac438ecfa23b084adaa56">string_view</a> name, A acc, acc_level level=acc_level())</td></tr>
<tr class="memdesc:a174f7ef563a97b910dbf894694653ce5"><td class="mdescLeft">&#160;</td><td class="mdescRight">Register a read only property to this class.  <a href="#a174f7ef563a97b910dbf894694653ce5">More...</a><br /></td></tr>
<tr class="separator:a174f7ef563a97b910dbf894694653ce5"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table>
<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
<div class="textblock"><h3>template&lt;typename Class_Type&gt;<br />
class rttr::registration::class_&lt; Class_Type &gt;</h3>

<p>The <a class="el" href="classrttr_1_1registration_1_1class__.html">class_</a> is used to register classes to RTTR. </p>
</div><h2 class="groupheader">Constructor &amp; Destructor Documentation</h2>
<a id="a723c8bc8b91535b391d0eeee36458ea9"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a723c8bc8b91535b391d0eeee36458ea9">&#9670;&nbsp;</a></span>class_()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename Class_Type&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classrttr_1_1registration_1_1class__.html">rttr::registration::class_</a>&lt; Class_Type &gt;::<a class="el" href="classrttr_1_1registration_1_1class__.html">class_</a> </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="namespacerttr.html#a61265f69675ac438ecfa23b084adaa56">string_view</a>&#160;</td>
          <td class="paramname"><em>name</em></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Construct a <a class="el" href="classrttr_1_1registration_1_1class__.html" title="The class_ is used to register classes to RTTR.">class_</a> object with the given name <code>name</code>. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">name</td><td>The name of the class as string literal. Can be retrieved later via <a class="el" href="classrttr_1_1type.html#a16d519457c68429ef2316067d1cf6700" title="Returns the unique and human-readable name of the type.">type::get_name()</a>. </td></tr>
  </table>
  </dd>
</dl>

</div>
</div>
<a id="a75fd948ca0675a8db670cc52d40127a0"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a75fd948ca0675a8db670cc52d40127a0">&#9670;&nbsp;</a></span>~class_()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename Class_Type&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classrttr_1_1registration_1_1class__.html">rttr::registration::class_</a>&lt; Class_Type &gt;::~<a class="el" href="classrttr_1_1registration_1_1class__.html">class_</a> </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div><div class="memdoc">

</div>
</div>
<h2 class="groupheader">Member Function Documentation</h2>
<a id="a92925cd9adc8c53c6c2df6e5f7f86e8a"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a92925cd9adc8c53c6c2df6e5f7f86e8a">&#9670;&nbsp;</a></span>constructor() <span class="overload">[1/2]</span></h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename Class_Type&gt; </div>
<div class="memtemplate">
template&lt;typename... Args, typename acc_level  = detail::public_access, typename Tp  = typename std::enable_if&lt;detail::contains&lt;acc_level, detail::access_levels_list&gt;::value&gt;::type&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a>&lt;detail::ctor, Class_Type, acc_level, Args...&gt; <a class="el" href="classrttr_1_1registration_1_1class__.html">rttr::registration::class_</a>&lt; Class_Type &gt;::<a class="el" href="classrttr_1_1constructor.html">constructor</a> </td>
          <td>(</td>
          <td class="paramtype">acc_level&#160;</td>
          <td class="paramname"><em>level</em> = <code>acc_level()</code></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Register a constructor for this class type with or without arguments. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">level</td><td>The access level of the constructor; default is: <a class="el" href="classrttr_1_1registration.html#a45df26a4b45b6715ac17e9a03594c369" title="This variable can be used to specify during registration of a class member the access level: public.">registration::public_access</a>.<br />
 (can be also: <a class="el" href="classrttr_1_1registration.html#a5ac82a82df83ce2dd8c34ada18d7b904" title="This variable can be used to specify during registration of a class member the access level: protecte...">registration::protected_access</a> or <a class="el" href="classrttr_1_1registration.html#a8920352ec53e1cd44bdec18ef5e89568" title="This variable can be used to specify during registration of a class member the access level: private.">registration::private_access</a>)</td></tr>
  </table>
  </dd>
</dl>
<dl class="section remark"><dt>Remarks</dt><dd>The default constructor create policy is: <a class="el" href="structrttr_1_1policy_1_1ctor.html#a40f2a2ef8f270cad3deabf1b83e8764c">policy::ctor::as_std_shared_ptr</a>.</dd></dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="classrttr_1_1constructor.html" title="The constructor class provides several meta information about a constructor and can be invoked.">constructor</a>, <a class="el" href="classrttr_1_1type.html#ae1ed385e76752e7c02ffd9bf5a0ae410" title="Returns a public constructor whose parameters match the types in the specified list.">type::get_constructor()</a>, <a class="el" href="classrttr_1_1type.html#ad44572a03514d83035580f516ebaf4e1" title="Creates an instance of the current type, with the given arguments args for the constructor.">type::create()</a></dd></dl>
<dl class="section return"><dt>Returns</dt><dd>A <a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a> object, in order to chain more calls. </dd></dl>

</div>
</div>
<a id="a54b2d5501df646b98a2ca0853b3752e0"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a54b2d5501df646b98a2ca0853b3752e0">&#9670;&nbsp;</a></span>constructor() <span class="overload">[2/2]</span></h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename Class_Type&gt; </div>
<div class="memtemplate">
template&lt;typename F , typename acc_level  = detail::public_access, typename Tp  = typename std::enable_if&lt;!detail::contains&lt;F, detail::access_levels_list&gt;::value&gt;::type&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a>&lt;detail::ctor_func, Class_Type, F, acc_level&gt; <a class="el" href="classrttr_1_1registration_1_1class__.html">rttr::registration::class_</a>&lt; Class_Type &gt;::<a class="el" href="classrttr_1_1constructor.html">constructor</a> </td>
          <td>(</td>
          <td class="paramtype">F&#160;</td>
          <td class="paramname"><em>func</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">acc_level&#160;</td>
          <td class="paramname"><em>level</em> = <code>acc_level()</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Register a constructor for this class type which uses a function <code>F</code>. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">func</td><td>A function which creates an instance of <code>Class_Type</code>; This can be a pointer to a function or a std::function. </td></tr>
    <tr><td class="paramname">level</td><td>The access level of the constructor; default is: <a class="el" href="classrttr_1_1registration.html#a45df26a4b45b6715ac17e9a03594c369" title="This variable can be used to specify during registration of a class member the access level: public.">registration::public_access</a>.<br />
 (can be also: <a class="el" href="classrttr_1_1registration.html#a5ac82a82df83ce2dd8c34ada18d7b904" title="This variable can be used to specify during registration of a class member the access level: protecte...">registration::protected_access</a> or <a class="el" href="classrttr_1_1registration.html#a8920352ec53e1cd44bdec18ef5e89568" title="This variable can be used to specify during registration of a class member the access level: private.">registration::private_access</a>)</td></tr>
  </table>
  </dd>
</dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="classrttr_1_1constructor.html" title="The constructor class provides several meta information about a constructor and can be invoked.">constructor</a>, <a class="el" href="classrttr_1_1type.html#ae1ed385e76752e7c02ffd9bf5a0ae410" title="Returns a public constructor whose parameters match the types in the specified list.">type::get_constructor()</a>, <a class="el" href="classrttr_1_1type.html#ad44572a03514d83035580f516ebaf4e1" title="Creates an instance of the current type, with the given arguments args for the constructor.">type::create()</a></dd></dl>
<dl class="section return"><dt>Returns</dt><dd>A <a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a> object, in order to chain more calls. </dd></dl>

</div>
</div>
<a id="ad4f37155a55668afd8fcb66441f3ef88"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ad4f37155a55668afd8fcb66441f3ef88">&#9670;&nbsp;</a></span>enumeration()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename Class_Type&gt; </div>
<div class="memtemplate">
template&lt;typename Enum_Type &gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a>&lt;detail::enum_, Class_Type, Enum_Type&gt; <a class="el" href="classrttr_1_1registration_1_1class__.html">rttr::registration::class_</a>&lt; Class_Type &gt;::<a class="el" href="classrttr_1_1enumeration.html">enumeration</a> </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="namespacerttr.html#a61265f69675ac438ecfa23b084adaa56">string_view</a>&#160;</td>
          <td class="paramname"><em>name</em></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Register a nested enumeration of type <code>Enum_Type</code>. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">name</td><td>The name of the enumeration.</td></tr>
  </table>
  </dd>
</dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="classrttr_1_1enumeration.html" title="The enumeration class provides several meta information about an enum.">enumeration</a>, <a class="el" href="classrttr_1_1type.html#aa0b0e3e85de99df74f956a84b463f10b" title="Returns the enumerator if this type is an enum type; otherwise the returned value is not valid.">type::get_enumeration()</a></dd></dl>
<dl class="section return"><dt>Returns</dt><dd>A <a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a> object, in order to chain more calls. </dd></dl>

</div>
</div>
<a id="a3997256452d390b54990f202cf768bc7"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a3997256452d390b54990f202cf768bc7">&#9670;&nbsp;</a></span>method()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename Class_Type&gt; </div>
<div class="memtemplate">
template&lt;typename F , typename acc_level  = detail::public_access&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a>&lt;detail::meth, Class_Type, F, acc_level&gt; <a class="el" href="classrttr_1_1registration_1_1class__.html">rttr::registration::class_</a>&lt; Class_Type &gt;::<a class="el" href="classrttr_1_1method.html">method</a> </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="namespacerttr.html#a61265f69675ac438ecfa23b084adaa56">string_view</a>&#160;</td>
          <td class="paramname"><em>name</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">F&#160;</td>
          <td class="paramname"><em>f</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">acc_level&#160;</td>
          <td class="paramname"><em>level</em> = <code>acc_level()</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Register a method to this class. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">name</td><td>The name of the method. </td></tr>
    <tr><td class="paramname">function</td><td>The function accessor to this method; this can be a member function, a function or an std::function. </td></tr>
    <tr><td class="paramname">level</td><td>The access level of the method; default is: <a class="el" href="classrttr_1_1registration.html#a45df26a4b45b6715ac17e9a03594c369" title="This variable can be used to specify during registration of a class member the access level: public.">registration::public_access</a>.<br />
 (can be also: <a class="el" href="classrttr_1_1registration.html#a5ac82a82df83ce2dd8c34ada18d7b904" title="This variable can be used to specify during registration of a class member the access level: protecte...">registration::protected_access</a> or <a class="el" href="classrttr_1_1registration.html#a8920352ec53e1cd44bdec18ef5e89568" title="This variable can be used to specify during registration of a class member the access level: private.">registration::private_access</a>)</td></tr>
  </table>
  </dd>
</dl>
<dl class="section remark"><dt>Remarks</dt><dd>The method name does not have to be unique for this class.</dd></dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="classrttr_1_1method.html" title="The method class provides several meta information about a method and can be invoked.">method</a>, <a class="el" href="classrttr_1_1type.html#a4d31b84c050f5b22509c16d0379fe0c7" title="Returns a method with the name name.">type::get_method()</a>, <a class="el" href="classrttr_1_1type.html#afc7329cac11337f4022d7d10eebe80d3" title="Invokes the method represented by the current instance object.">type::invoke()</a></dd></dl>
<dl class="section return"><dt>Returns</dt><dd>A <a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a> object, in order to chain more calls. </dd></dl>

</div>
</div>
<a id="a17d658b8d88ce353d0ad777d1b01a360"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a17d658b8d88ce353d0ad777d1b01a360">&#9670;&nbsp;</a></span>operator()()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename Class_Type&gt; </div>
<div class="memtemplate">
template&lt;typename... Args&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classrttr_1_1registration_1_1class__.html">class_</a>&lt;Class_Type&gt;&amp; <a class="el" href="classrttr_1_1registration_1_1class__.html">rttr::registration::class_</a>&lt; Class_Type &gt;::operator() </td>
          <td>(</td>
          <td class="paramtype">Args &amp;&amp;...&#160;</td>
          <td class="paramname"><em>args</em></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>The bracket operator can be used to add additional meta data to the class type. </p>

</div>
</div>
<a id="a005a60417fb6d183af475cb4059dc0a0"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a005a60417fb6d183af475cb4059dc0a0">&#9670;&nbsp;</a></span>property() <span class="overload">[1/2]</span></h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename Class_Type&gt; </div>
<div class="memtemplate">
template&lt;typename A , typename acc_level  = detail::public_access, typename Tp  = typename std::enable_if&lt;detail::contains&lt;acc_level, detail::access_levels_list&gt;::value&gt;::type&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a>&lt;detail::prop, Class_Type, A, acc_level&gt; <a class="el" href="classrttr_1_1registration_1_1class__.html">rttr::registration::class_</a>&lt; Class_Type &gt;::<a class="el" href="classrttr_1_1property.html">property</a> </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="namespacerttr.html#a61265f69675ac438ecfa23b084adaa56">string_view</a>&#160;</td>
          <td class="paramname"><em>name</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">A&#160;</td>
          <td class="paramname"><em>acc</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">acc_level&#160;</td>
          <td class="paramname"><em>level</em> = <code>acc_level()</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Register a property to this class. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">name</td><td>The name of the property. </td></tr>
    <tr><td class="paramname">acc</td><td>The accessor to the property; this can be a pointer to a member or a pointer to a variable. </td></tr>
    <tr><td class="paramname">level</td><td>The access level of the property; default is: <a class="el" href="classrttr_1_1registration.html#a45df26a4b45b6715ac17e9a03594c369" title="This variable can be used to specify during registration of a class member the access level: public.">registration::public_access</a>.<br />
 (can be also: <a class="el" href="classrttr_1_1registration.html#a5ac82a82df83ce2dd8c34ada18d7b904" title="This variable can be used to specify during registration of a class member the access level: protecte...">registration::protected_access</a> or <a class="el" href="classrttr_1_1registration.html#a8920352ec53e1cd44bdec18ef5e89568" title="This variable can be used to specify during registration of a class member the access level: private.">registration::private_access</a>)</td></tr>
  </table>
  </dd>
</dl>
<dl class="section remark"><dt>Remarks</dt><dd>The name of the property has to be unique for this class, otherwise it will not be registered.</dd></dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="classrttr_1_1property.html" title="The property class provides several meta information about a property and gives read/write access to ...">property</a>, <a class="el" href="classrttr_1_1type.html#ae53c4df812c270f3f74b77210bc6a926" title="Returns a property with the name name.">type::get_property()</a>, <a class="el" href="classrttr_1_1type.html#a3010aa9577570ea86078b2ce2b2f8677" title="Returns the property value of property named name from the instance obj.">type::get_property_value()</a>, <a class="el" href="classrttr_1_1type.html#af57f575909bf13fa24d03ad14393204a" title="This function will set the given value arg to a property named name to the instance obj.">type::set_property_value()</a></dd></dl>
<dl class="section return"><dt>Returns</dt><dd>A <a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a> object, in order to chain more calls. </dd></dl>

</div>
</div>
<a id="af46d69abe0ea22712777ff420bcfd7b4"></a>
<h2 class="memtitle"><span class="permalink"><a href="#af46d69abe0ea22712777ff420bcfd7b4">&#9670;&nbsp;</a></span>property() <span class="overload">[2/2]</span></h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename Class_Type&gt; </div>
<div class="memtemplate">
template&lt;typename A1 , typename A2 , typename Tp  = typename std::enable_if&lt;!detail::contains&lt;A2, detail::access_levels_list&gt;::value&gt;::type, typename acc_level  = detail::public_access&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a>&lt;detail::prop, Class_Type, A1, A2, acc_level&gt; <a class="el" href="classrttr_1_1registration_1_1class__.html">rttr::registration::class_</a>&lt; Class_Type &gt;::<a class="el" href="classrttr_1_1property.html">property</a> </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="namespacerttr.html#a61265f69675ac438ecfa23b084adaa56">string_view</a>&#160;</td>
          <td class="paramname"><em>name</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">A1&#160;</td>
          <td class="paramname"><em>getter</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">A2&#160;</td>
          <td class="paramname"><em>setter</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">acc_level&#160;</td>
          <td class="paramname"><em>level</em> = <code>acc_level()</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Register a property to this class. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">name</td><td>The name of the property. </td></tr>
    <tr><td class="paramname">getter</td><td>The getter accessor to the property; this can be a pointer to a member function, a pointer to a function or a std::function. </td></tr>
    <tr><td class="paramname">setter</td><td>The setter accessor to the property; this can be a pointer to a member function, a pointer to a function or a std::function. </td></tr>
    <tr><td class="paramname">level</td><td>The access level of the property; default is: <a class="el" href="classrttr_1_1registration.html#a45df26a4b45b6715ac17e9a03594c369" title="This variable can be used to specify during registration of a class member the access level: public.">registration::public_access</a>.<br />
 (can be also: <a class="el" href="classrttr_1_1registration.html#a5ac82a82df83ce2dd8c34ada18d7b904" title="This variable can be used to specify during registration of a class member the access level: protecte...">registration::protected_access</a> or <a class="el" href="classrttr_1_1registration.html#a8920352ec53e1cd44bdec18ef5e89568" title="This variable can be used to specify during registration of a class member the access level: private.">registration::private_access</a>)</td></tr>
  </table>
  </dd>
</dl>
<dl class="section remark"><dt>Remarks</dt><dd>The name of the property has to be unique for this class, otherwise it will not be registered.</dd></dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="classrttr_1_1property.html" title="The property class provides several meta information about a property and gives read/write access to ...">property</a>, <a class="el" href="classrttr_1_1type.html#ae53c4df812c270f3f74b77210bc6a926" title="Returns a property with the name name.">type::get_property()</a>, <a class="el" href="classrttr_1_1type.html#a3010aa9577570ea86078b2ce2b2f8677" title="Returns the property value of property named name from the instance obj.">type::get_property_value()</a>, <a class="el" href="classrttr_1_1type.html#af57f575909bf13fa24d03ad14393204a" title="This function will set the given value arg to a property named name to the instance obj.">type::set_property_value()</a></dd></dl>
<dl class="section return"><dt>Returns</dt><dd>A <a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a> object, in order to chain more calls. </dd></dl>

</div>
</div>
<a id="a174f7ef563a97b910dbf894694653ce5"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a174f7ef563a97b910dbf894694653ce5">&#9670;&nbsp;</a></span>property_readonly()</h2>

<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename Class_Type&gt; </div>
<div class="memtemplate">
template&lt;typename A , typename acc_level  = detail::public_access, typename Tp  = typename std::enable_if&lt;detail::contains&lt;acc_level, detail::access_levels_list&gt;::value&gt;::type&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a>&lt;detail::prop_readonly, Class_Type, A, acc_level&gt; <a class="el" href="classrttr_1_1registration_1_1class__.html">rttr::registration::class_</a>&lt; Class_Type &gt;::property_readonly </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="namespacerttr.html#a61265f69675ac438ecfa23b084adaa56">string_view</a>&#160;</td>
          <td class="paramname"><em>name</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">A&#160;</td>
          <td class="paramname"><em>acc</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">acc_level&#160;</td>
          <td class="paramname"><em>level</em> = <code>acc_level()</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Register a read only property to this class. </p>
<dl class="params"><dt>Parameters</dt><dd>
  <table class="params">
    <tr><td class="paramname">name</td><td>The name of the property. </td></tr>
    <tr><td class="paramname">acc</td><td>The accessor to the property; this can be a pointer to a member, a pointer to a variable, a pointer to a member function, a pointer to a function or a std::function. </td></tr>
    <tr><td class="paramname">level</td><td>The access level of the read only property; default is: <a class="el" href="classrttr_1_1registration.html#a45df26a4b45b6715ac17e9a03594c369" title="This variable can be used to specify during registration of a class member the access level: public.">registration::public_access</a>.<br />
 (can be: <a class="el" href="classrttr_1_1registration.html#a5ac82a82df83ce2dd8c34ada18d7b904" title="This variable can be used to specify during registration of a class member the access level: protecte...">registration::protected_access</a> or <a class="el" href="classrttr_1_1registration.html#a8920352ec53e1cd44bdec18ef5e89568" title="This variable can be used to specify during registration of a class member the access level: private.">registration::private_access</a>)</td></tr>
  </table>
  </dd>
</dl>
<dl class="section remark"><dt>Remarks</dt><dd>The name of the property has to be unique for this class, otherwise it will not be registered.</dd></dl>
<dl class="section see"><dt>See also</dt><dd><a class="el" href="classrttr_1_1property.html" title="The property class provides several meta information about a property and gives read/write access to ...">property</a>, <a class="el" href="classrttr_1_1type.html#ae53c4df812c270f3f74b77210bc6a926" title="Returns a property with the name name.">type::get_property()</a>, <a class="el" href="classrttr_1_1type.html#a3010aa9577570ea86078b2ce2b2f8677" title="Returns the property value of property named name from the instance obj.">type::get_property_value()</a>, <a class="el" href="classrttr_1_1type.html#af57f575909bf13fa24d03ad14393204a" title="This function will set the given value arg to a property named name to the instance obj.">type::set_property_value()</a></dd></dl>
<dl class="section return"><dt>Returns</dt><dd>A <a class="el" href="classrttr_1_1registration_1_1bind.html">bind</a> object, in order to chain more calls. </dd></dl>

</div>
</div>
<hr/>The documentation for this class was generated from the following file:<ul>
<li><a class="el" href="registration_8h_source.html">registration.h</a></li>
</ul>
</div><!-- contents -->
<!-- HTML footer for doxygen 1.8.9.1-->
<!-- start footer part -->
<hr class="footer"/>
<address class="footer">
<small>
Generated on Thu Apr 11 2019 20:05:59 for rttr - 0.9.6 by 
<a href="http://www.doxygen.org/index.html">doxygen</a>.
</small>
</address>
</body>
</html>