1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
2 <html xmlns="http://www.w3.org/1999/xhtml">
4 <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
5 <meta http-equiv="X-UA-Compatible" content="IE=9"/>
6 <meta name="generator" content="Doxygen 1.9.1"/>
7 <meta name="viewport" content="width=device-width, initial-scale=1"/>
8 <title>libsigc++: sigc::adapts< T_functor > Struct Template Reference</title>
9 <link href="tabs.css" rel="stylesheet" type="text/css"/>
10 <script type="text/javascript" src="jquery.js"></script>
11 <script type="text/javascript" src="dynsections.js"></script>
12 <link href="doxygen.css" rel="stylesheet" type="text/css" />
13 <link href="doxygen-extra.css" rel="stylesheet" type="text/css"/>
16 <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
18 <table cellspacing="0" cellpadding="0">
20 <tr style="height: 56px;">
21 <td id="projectalign" style="padding-left: 0.5em;">
22 <div id="projectname">libsigc++
23  <span id="projectnumber">2.10.8</span>
30 <!-- end header part -->
31 <!-- Generated by Doxygen 1.9.1 -->
32 <script type="text/javascript" src="menudata.js"></script>
33 <script type="text/javascript" src="menu.js"></script>
34 <script type="text/javascript">
35 /* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
37 initMenu('',false,false,'search.php','Search');
39 /* @license-end */</script>
40 <div id="main-nav"></div>
41 <div id="nav-path" class="navpath">
43 <li class="navelem"><a class="el" href="namespacesigc.html">sigc</a></li><li class="navelem"><a class="el" href="structsigc_1_1adapts.html">adapts</a></li> </ul>
48 <a href="#pub-types">Public Types</a> |
49 <a href="#pub-methods">Public Member Functions</a> |
50 <a href="#pub-attribs">Public Attributes</a> |
51 <a href="structsigc_1_1adapts-members.html">List of all members</a> </div>
52 <div class="headertitle">
53 <div class="title">sigc::adapts< T_functor > Struct Template Reference<div class="ingroups"><a class="el" href="group__adaptors.html">Adaptors</a></div></div> </div>
55 <div class="contents">
57 <p>Base type for adaptors.
58 <a href="structsigc_1_1adapts.html#details">More...</a></p>
60 <p><code>#include <sigc++/adaptors/adaptor_trait.h></code></p>
61 <div class="dynheader">
62 Inheritance diagram for sigc::adapts< T_functor >:</div>
63 <div class="dyncontent">
64 <div class="center"><img src="structsigc_1_1adapts__inherit__graph.png" border="0" usemap="#asigc_1_1adapts_3_01T__functor_01_4_inherit__map" alt="Inheritance graph"/></div>
65 <map name="asigc_1_1adapts_3_01T__functor_01_4_inherit__map" id="asigc_1_1adapts_3_01T__functor_01_4_inherit__map">
66 <area shape="rect" title="Base type for adaptors." alt="" coords="385,400,576,427"/>
67 <area shape="rect" href="structsigc_1_1bind__functor_3_010_00_01T__functor_00_01T__bound_00_01nil_00_01nil_00_01nil_00_01nil_00_01nil_00_01nil_01_4.html" title="Adaptor that binds an argument to the wrapped functor." alt="" coords="640,5,821,61"/>
68 <area shape="rect" href="structsigc_1_1bind__functor_3-1_00_01T__functor_00_01T__type1_00_01nil_00_01nil_00_01nil_00_01nil_00_01nil_00_01nil_01_4.html" title="Adaptor that binds 1 argument(s) to the wrapped functor." alt="" coords="641,85,820,141"/>
69 <area shape="rect" href="structsigc_1_1bind__return__functor.html" title="Adaptor that fixes the return value of the wrapped functor." alt="" coords="639,166,822,207"/>
70 <area shape="rect" href="structsigc_1_1exception__catch__functor.html" title=" " alt="" coords="647,232,814,288"/>
71 <area shape="rect" href="structsigc_1_1exception__catch__functor_3_01T__functor_00_01T__catcher_00_01void_01_4.html" title=" " alt="" coords="649,312,812,368"/>
72 <area shape="rect" href="structsigc_1_1hide__functor_3_010_00_01T__functor_01_4.html" title="Adaptor that adds a dummy parameter to the wrapped functor." alt="" coords="662,393,799,434"/>
73 <area shape="rect" href="structsigc_1_1hide__functor_3-1_00_01T__functor_01_4.html" title="Adaptor that adds a dummy parameter to the wrapped functor." alt="" coords="662,458,799,499"/>
74 <area shape="rect" href="structsigc_1_1retype__functor.html" title="Adaptor that performs C-style casts on the parameters passed on to the functor." alt="" coords="624,523,837,594"/>
75 <area shape="rect" href="structsigc_1_1retype__return__functor.html" title="Adaptor that performs a C-style cast on the return value of a functor." alt="" coords="657,619,805,675"/>
76 <area shape="rect" href="structsigc_1_1retype__return__functor_3_01void_00_01T__functor_01_4.html" title="Adaptor that performs a C-style cast on the return value of a functor." alt="" coords="629,699,832,741"/>
77 <area shape="rect" href="classsigc_1_1track__obj__functor1.html" title="track_obj_functor1 wraps a functor and stores a reference to a trackable object." alt="" coords="642,765,819,806"/>
78 <area shape="rect" href="structsigc_1_1adaptor__base.html" title="A hint to the compiler." alt="" coords="193,400,337,427"/>
79 <area shape="rect" href="structsigc_1_1functor__base.html" title="A hint to the compiler." alt="" coords="5,400,145,427"/>
80 <area shape="rect" href="classsigc_1_1track__obj__functor2.html" title="track_obj_functor2 wraps a functor and stores 2 references to trackable objects." alt="" coords="891,571,1105,613"/>
81 <area shape="rect" href="classsigc_1_1track__obj__functor3.html" title="track_obj_functor3 wraps a functor and stores 3 references to trackable objects." alt="" coords="909,637,1087,693"/>
82 <area shape="rect" href="classsigc_1_1track__obj__functor4.html" title="track_obj_functor4 wraps a functor and stores 4 references to trackable objects." alt="" coords="909,717,1087,773"/>
83 <area shape="rect" href="classsigc_1_1track__obj__functor5.html" title="track_obj_functor5 wraps a functor and stores 5 references to trackable objects." alt="" coords="885,797,1111,853"/>
84 <area shape="rect" href="classsigc_1_1track__obj__functor6.html" title="track_obj_functor6 wraps a functor and stores 6 references to trackable objects." alt="" coords="909,878,1087,949"/>
85 <area shape="rect" href="classsigc_1_1track__obj__functor7.html" title="track_obj_functor7 wraps a functor and stores 7 references to trackable objects." alt="" coords="909,973,1087,1043"/>
87 <center><span class="legend">[<a href="graph_legend.html">legend</a>]</span></center></div>
88 <table class="memberdecls">
89 <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-types"></a>
90 Public Types</h2></td></tr>
91 <tr class="memitem:a5c3f3b614455552f4cd5d88b1f330248"><td class="memItemLeft" align="right" valign="top">typedef <a class="el" href="structsigc_1_1adaptor__trait.html">adaptor_trait</a>< T_functor >::<a class="el" href="structsigc_1_1adapts.html#a5c3f3b614455552f4cd5d88b1f330248">adaptor_type</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="structsigc_1_1adapts.html#a5c3f3b614455552f4cd5d88b1f330248">adaptor_type</a></td></tr>
92 <tr class="separator:a5c3f3b614455552f4cd5d88b1f330248"><td class="memSeparator" colspan="2"> </td></tr>
93 <tr class="memitem:a914e75556dae1fdcf0162c4c99aca79d"><td class="memItemLeft" align="right" valign="top">typedef <a class="el" href="structsigc_1_1adaptor__trait.html">adaptor_trait</a>< T_functor >::<a class="el" href="structsigc_1_1adapts.html#a914e75556dae1fdcf0162c4c99aca79d">result_type</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="structsigc_1_1adapts.html#a914e75556dae1fdcf0162c4c99aca79d">result_type</a></td></tr>
94 <tr class="separator:a914e75556dae1fdcf0162c4c99aca79d"><td class="memSeparator" colspan="2"> </td></tr>
95 </table><table class="memberdecls">
96 <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
97 Public Member Functions</h2></td></tr>
98 <tr class="memitem:a947b69ccbdcabd4ef4163dcab96096f8"><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="structsigc_1_1adapts.html#a947b69ccbdcabd4ef4163dcab96096f8">adapts</a> (const T_functor & _A_functor)</td></tr>
99 <tr class="memdesc:a947b69ccbdcabd4ef4163dcab96096f8"><td class="mdescLeft"> </td><td class="mdescRight">Constructs an adaptor that wraps the passed functor. <a href="structsigc_1_1adapts.html#a947b69ccbdcabd4ef4163dcab96096f8">More...</a><br /></td></tr>
100 <tr class="separator:a947b69ccbdcabd4ef4163dcab96096f8"><td class="memSeparator" colspan="2"> </td></tr>
101 </table><table class="memberdecls">
102 <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-attribs"></a>
103 Public Attributes</h2></td></tr>
104 <tr class="memitem:a2f4b37eb160708baf17de57f2abce7a7"><td class="memItemLeft" align="right" valign="top"><a class="el" href="structsigc_1_1adapts.html#a5c3f3b614455552f4cd5d88b1f330248">adaptor_type</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="structsigc_1_1adapts.html#a2f4b37eb160708baf17de57f2abce7a7">functor_</a></td></tr>
105 <tr class="memdesc:a2f4b37eb160708baf17de57f2abce7a7"><td class="mdescLeft"> </td><td class="mdescRight">Adaptor that is invoked from operator()(). <a href="structsigc_1_1adapts.html#a2f4b37eb160708baf17de57f2abce7a7">More...</a><br /></td></tr>
106 <tr class="separator:a2f4b37eb160708baf17de57f2abce7a7"><td class="memSeparator" colspan="2"> </td></tr>
108 <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
109 <div class="textblock"><h3>template<class T_functor><br />
110 struct sigc::adapts< T_functor ></h3>
112 <p>Base type for adaptors. </p>
113 <p><a class="el" href="structsigc_1_1adapts.html" title="Base type for adaptors.">sigc::adapts</a> wraps adaptors, functors, function pointers and class methods. It contains a single member functor which is always a <a class="el" href="structsigc_1_1adaptor__base.html" title="A hint to the compiler.">sigc::adaptor_base</a>. The typedef adaptor_type defines the exact type that is used to store the adaptor, functor, function pointer or class method passed into the constructor. It differs from <em>T_functor</em> unless <em>T_functor</em> inherits from <a class="el" href="structsigc_1_1adaptor__base.html" title="A hint to the compiler.">sigc::adaptor_base</a>.</p>
114 <dl class="section user"><dt>Example of a simple adaptor:</dt><dd><div class="fragment"><div class="line"><span class="keyword">namespace </span>my_ns</div>
115 <div class="line">{</div>
116 <div class="line"><span class="keyword">template</span> <<span class="keyword">class</span> T_functor></div>
117 <div class="line"><span class="keyword">struct </span>my_adaptor : <span class="keyword">public</span> <a class="code" href="structsigc_1_1adapts.html">sigc::adapts</a><T_functor></div>
118 <div class="line">{</div>
119 <div class="line"> <span class="keyword">template</span> <<span class="keyword">class</span> T_arg1=<span class="keywordtype">void</span>, <span class="keyword">class</span> T_arg2=<span class="keywordtype">void</span>></div>
120 <div class="line"> <span class="keyword">struct </span>deduce_result_type</div>
121 <div class="line"> { <span class="keyword">typedef</span> <a class="code" href="namespacesigc.html#ab7791439fb79592300826fe076a8e3d1">sigc::deduce_result_t<T_functor, T_arg1, T_arg2></a> type; };</div>
122 <div class="line"> <span class="keyword">typedef</span> <span class="keyword">typename</span> <a class="code" href="structsigc_1_1functor__trait.html#af1324bf0d3cec3d1f2e39e932b228d6d">sigc::functor_trait<T_functor>::result_type</a> <a class="code" href="structsigc_1_1adapts.html#a914e75556dae1fdcf0162c4c99aca79d">result_type</a>;</div>
123 <div class="line"> <span class="comment">//</span></div>
124 <div class="line"> <a class="code" href="structsigc_1_1adapts.html#a914e75556dae1fdcf0162c4c99aca79d">result_type</a></div>
125 <div class="line"> operator()() <span class="keyword">const</span>;</div>
126 <div class="line"> <span class="comment">//</span></div>
127 <div class="line"> <span class="keyword">template</span> <<span class="keyword">class</span> T_arg1></div>
128 <div class="line"> <span class="keyword">typename</span> <a class="code" href="structsigc_1_1deduce__result__type.html#a529a6b7809ea3ad1a2d4392b9ffcec42">deduce_result_type<T_arg1>::type</a></div>
129 <div class="line"> operator()(T_arg1 _A_arg1) <span class="keyword">const</span>;</div>
130 <div class="line"> <span class="comment">//</span></div>
131 <div class="line"> <span class="keyword">template</span> <<span class="keyword">class</span> T_arg1, <span class="keyword">class</span> T_arg2></div>
132 <div class="line"> <span class="keyword">typename</span> <a class="code" href="structsigc_1_1deduce__result__type.html#a529a6b7809ea3ad1a2d4392b9ffcec42">deduce_result_type<T_arg1, T_arg2>::type</a></div>
133 <div class="line"> operator()(T_arg1 _A_arg1, T_arg2 _A_arg2) <span class="keyword">const</span>;</div>
134 <div class="line"> <span class="comment">//</span></div>
135 <div class="line"> <span class="comment">// Constructs a my_adaptor object that wraps the passed functor.</span></div>
136 <div class="line"> <span class="comment">// Initializes adapts<T_functor>::functor_, which is invoked from operator()().</span></div>
137 <div class="line"> <span class="keyword">explicit</span> my_adaptor(<span class="keyword">const</span> T_functor& _A_functor)</div>
138 <div class="line"> : <a class="code" href="namespacesigc.html">sigc</a>::<a class="code" href="structsigc_1_1adapts.html#a947b69ccbdcabd4ef4163dcab96096f8">adapts</a><T_functor>(_A_functor) {}</div>
139 <div class="line">};</div>
140 <div class="line">} <span class="comment">// end namespace my_ns</span></div>
141 <div class="line"><span class="comment">//</span></div>
142 <div class="line"><span class="comment">// Specialization of sigc::visitor for my_adaptor.</span></div>
143 <div class="line"><span class="keyword">namespace </span><a class="code" href="namespacesigc.html">sigc</a></div>
144 <div class="line">{</div>
145 <div class="line"><span class="keyword">template</span> <<span class="keyword">class</span> T_functor></div>
146 <div class="line"><span class="keyword">struct </span>visitor<my_ns::my_adaptor<T_functor> ></div>
147 <div class="line">{</div>
148 <div class="line"> <span class="keyword">template</span> <<span class="keyword">class</span> T_action></div>
149 <div class="line"> <span class="keyword">static</span> <span class="keywordtype">void</span> do_visit_each(<span class="keyword">const</span> T_action& _A_action,</div>
150 <div class="line"> <span class="keyword">const</span> my_ns::my_adaptor<T_functor>& _A_target)</div>
151 <div class="line"> {</div>
152 <div class="line"> <a class="code" href="group__sigcfunctors.html#ga64cb7832acc1e58efb5ffe0b4f5e9404">sigc::visit_each</a>(_A_action, _A_target.functor_);</div>
153 <div class="line"> }</div>
154 <div class="line">};</div>
155 <div class="line">} <span class="comment">// end namespace sigc</span></div>
156 <div class="ttc" id="agroup__sigcfunctors_html_ga64cb7832acc1e58efb5ffe0b4f5e9404"><div class="ttname"><a href="group__sigcfunctors.html#ga64cb7832acc1e58efb5ffe0b4f5e9404">sigc::visit_each</a></div><div class="ttdeci">void visit_each(const T_action &_A_action, const T_functor &_A_functor)</div><div class="ttdoc">This function performs a functor on each of the targets of a functor.</div><div class="ttdef"><b>Definition:</b> visit_each.h:169</div></div>
157 <div class="ttc" id="anamespacesigc_html"><div class="ttname"><a href="namespacesigc.html">sigc</a></div><div class="ttdoc">The libsigc++ namespace.</div><div class="ttdef"><b>Definition:</b> limit_reference.h:12</div></div>
158 <div class="ttc" id="anamespacesigc_html_ab7791439fb79592300826fe076a8e3d1"><div class="ttname"><a href="namespacesigc.html#ab7791439fb79592300826fe076a8e3d1">sigc::deduce_result_t</a></div><div class="ttdeci">typename deduce_result_type< T_functor, T_args... >::type deduce_result_t</div><div class="ttdef"><b>Definition:</b> deduce_result_type.h:68</div></div>
159 <div class="ttc" id="astructsigc_1_1adapts_html"><div class="ttname"><a href="structsigc_1_1adapts.html">sigc::adapts</a></div><div class="ttdoc">Base type for adaptors.</div><div class="ttdef"><b>Definition:</b> adaptor_trait.h:387</div></div>
160 <div class="ttc" id="astructsigc_1_1adapts_html_a914e75556dae1fdcf0162c4c99aca79d"><div class="ttname"><a href="structsigc_1_1adapts.html#a914e75556dae1fdcf0162c4c99aca79d">sigc::adapts::result_type</a></div><div class="ttdeci">adaptor_trait< T_functor >::result_type result_type</div><div class="ttdef"><b>Definition:</b> adaptor_trait.h:388</div></div>
161 <div class="ttc" id="astructsigc_1_1adapts_html_a947b69ccbdcabd4ef4163dcab96096f8"><div class="ttname"><a href="structsigc_1_1adapts.html#a947b69ccbdcabd4ef4163dcab96096f8">sigc::adapts::adapts</a></div><div class="ttdeci">adapts(const T_functor &_A_functor)</div><div class="ttdoc">Constructs an adaptor that wraps the passed functor.</div><div class="ttdef"><b>Definition:</b> adaptor_trait.h:394</div></div>
162 <div class="ttc" id="astructsigc_1_1deduce__result__type_html_a529a6b7809ea3ad1a2d4392b9ffcec42"><div class="ttname"><a href="structsigc_1_1deduce__result__type.html#a529a6b7809ea3ad1a2d4392b9ffcec42">sigc::deduce_result_type::type</a></div><div class="ttdeci">decltype(test< T_functor >()) type</div><div class="ttdef"><b>Definition:</b> deduce_result_type.h:64</div></div>
163 <div class="ttc" id="astructsigc_1_1functor__trait_html_af1324bf0d3cec3d1f2e39e932b228d6d"><div class="ttname"><a href="structsigc_1_1functor__trait.html#af1324bf0d3cec3d1f2e39e932b228d6d">sigc::functor_trait::result_type</a></div><div class="ttdeci">void result_type</div><div class="ttdef"><b>Definition:</b> functor_trait.h:135</div></div>
164 </div><!-- fragment --></dd></dl>
165 <p>If you implement your own adaptor, you must also provide your specialization of sigc::visitor<>::do_visit_each<>() that will forward the call to the functor(s) your adapter is wrapping. Otherwise, pointers stored within the functor won't be invalidated when a <a class="el" href="structsigc_1_1trackable.html" title="Base class for objects with auto-disconnection.">sigc::trackable</a> object is destroyed and you can end up executing callbacks on destroyed objects.</p>
166 <p>Your specialization of sigc::visitor<> must be in namespace sigc. </p>
167 </div><h2 class="groupheader">Member Typedef Documentation</h2>
168 <a id="a5c3f3b614455552f4cd5d88b1f330248"></a>
169 <h2 class="memtitle"><span class="permalink"><a href="#a5c3f3b614455552f4cd5d88b1f330248">◆ </a></span>adaptor_type</h2>
171 <div class="memitem">
172 <div class="memproto">
173 <div class="memtemplate">
174 template <class T_functor > </div>
175 <table class="memname">
177 <td class="memname">typedef <a class="el" href="structsigc_1_1adaptor__trait.html">adaptor_trait</a><T_functor>::<a class="el" href="structsigc_1_1adapts.html#a5c3f3b614455552f4cd5d88b1f330248">adaptor_type</a> <a class="el" href="structsigc_1_1adapts.html">sigc::adapts</a>< T_functor >::<a class="el" href="structsigc_1_1adapts.html#a5c3f3b614455552f4cd5d88b1f330248">adaptor_type</a></td>
180 </div><div class="memdoc">
184 <a id="a914e75556dae1fdcf0162c4c99aca79d"></a>
185 <h2 class="memtitle"><span class="permalink"><a href="#a914e75556dae1fdcf0162c4c99aca79d">◆ </a></span>result_type</h2>
187 <div class="memitem">
188 <div class="memproto">
189 <div class="memtemplate">
190 template <class T_functor > </div>
191 <table class="memname">
193 <td class="memname">typedef <a class="el" href="structsigc_1_1adaptor__trait.html">adaptor_trait</a><T_functor>::<a class="el" href="structsigc_1_1adapts.html#a914e75556dae1fdcf0162c4c99aca79d">result_type</a> <a class="el" href="structsigc_1_1adapts.html">sigc::adapts</a>< T_functor >::<a class="el" href="structsigc_1_1adapts.html#a914e75556dae1fdcf0162c4c99aca79d">result_type</a></td>
196 </div><div class="memdoc">
200 <h2 class="groupheader">Constructor & Destructor Documentation</h2>
201 <a id="a947b69ccbdcabd4ef4163dcab96096f8"></a>
202 <h2 class="memtitle"><span class="permalink"><a href="#a947b69ccbdcabd4ef4163dcab96096f8">◆ </a></span>adapts()</h2>
204 <div class="memitem">
205 <div class="memproto">
206 <div class="memtemplate">
207 template <class T_functor > </div>
208 <table class="mlabels">
210 <td class="mlabels-left">
211 <table class="memname">
213 <td class="memname"><a class="el" href="structsigc_1_1adapts.html">sigc::adapts</a>< T_functor >::<a class="el" href="structsigc_1_1adapts.html">adapts</a> </td>
215 <td class="paramtype">const T_functor & </td>
216 <td class="paramname"><em>_A_functor</em></td><td>)</td>
221 <td class="mlabels-right">
222 <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">explicit</span></span> </td>
225 </div><div class="memdoc">
227 <p>Constructs an adaptor that wraps the passed functor. </p>
228 <dl class="params"><dt>Parameters</dt><dd>
229 <table class="params">
230 <tr><td class="paramname">_A_functor</td><td>Functor to invoke from operator()(). </td></tr>
237 <h2 class="groupheader">Member Data Documentation</h2>
238 <a id="a2f4b37eb160708baf17de57f2abce7a7"></a>
239 <h2 class="memtitle"><span class="permalink"><a href="#a2f4b37eb160708baf17de57f2abce7a7">◆ </a></span>functor_</h2>
241 <div class="memitem">
242 <div class="memproto">
243 <div class="memtemplate">
244 template <class T_functor > </div>
245 <table class="mlabels">
247 <td class="mlabels-left">
248 <table class="memname">
250 <td class="memname"><a class="el" href="structsigc_1_1adapts.html#a5c3f3b614455552f4cd5d88b1f330248">adaptor_type</a> <a class="el" href="structsigc_1_1adapts.html">sigc::adapts</a>< T_functor >::functor_</td>
254 <td class="mlabels-right">
255 <span class="mlabels"><span class="mlabel">mutable</span></span> </td>
258 </div><div class="memdoc">
260 <p>Adaptor that is invoked from operator()(). </p>
264 </div><!-- contents -->
265 <!-- start footer part -->
266 <hr class="footer"/><address class="footer"><small>
267 Generated on Fri Feb 11 2022 15:40:57 for libsigc++ by <a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.9.1