mirror of
https://github.com/USCiLab/cereal.git
synced 2025-07-21 02:12:01 +02:00
595 lines
44 KiB
HTML
595 lines
44 KiB
HTML
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
|
<html xmlns="http://www.w3.org/1999/xhtml">
|
|
<head>
|
|
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
<meta name="generator" content="Doxygen 1.8.17"/>
|
|
<meta name="viewport" content="width=device-width, initial-scale=1"/>
|
|
<title>cereal: polymorphic.hpp File Reference</title>
|
|
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
<script type="text/javascript" src="jquery.js"></script>
|
|
<script type="text/javascript" src="dynsections.js"></script>
|
|
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
<script type="text/javascript" src="search/search.js"></script>
|
|
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
</head>
|
|
<body>
|
|
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
<div id="titlearea">
|
|
<table cellspacing="0" cellpadding="0">
|
|
<tbody>
|
|
<tr style="height: 56px;">
|
|
<td id="projectalign" style="padding-left: 0.5em;">
|
|
<div id="projectname">cereal
|
|
</div>
|
|
<div id="projectbrief">A C++11 library for serialization</div>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
<!-- end header part -->
|
|
<!-- Generated by Doxygen 1.8.17 -->
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
|
|
var searchBox = new SearchBox("searchBox", "search",false,'Search');
|
|
/* @license-end */
|
|
</script>
|
|
<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&dn=gpl-2.0.txt GPL-v2 */
|
|
$(function() {
|
|
initMenu('',true,false,'search.php','Search');
|
|
$(document).ready(function() { init_search(); });
|
|
});
|
|
/* @license-end */</script>
|
|
<div id="main-nav"></div>
|
|
<!-- window showing the filter options -->
|
|
<div id="MSearchSelectWindow"
|
|
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
</div>
|
|
|
|
<!-- iframe showing the search results (closed by default) -->
|
|
<div id="MSearchResultsWindow">
|
|
<iframe src="javascript:void(0)" frameborder="0"
|
|
name="MSearchResults" id="MSearchResults">
|
|
</iframe>
|
|
</div>
|
|
|
|
<div id="nav-path" class="navpath">
|
|
<ul>
|
|
<li class="navelem"><a class="el" href="dir_d44c64559bbebec7f509842c48db8b23.html">include</a></li><li class="navelem"><a class="el" href="dir_d445d0c097210746bce3afd9a77bcad9.html">cereal</a></li><li class="navelem"><a class="el" href="dir_056182efa28390c8a7ef83cb1836ec86.html">types</a></li> </ul>
|
|
</div>
|
|
</div><!-- top -->
|
|
<div class="header">
|
|
<div class="summary">
|
|
<a href="#define-members">Macros</a> |
|
|
<a href="#func-members">Functions</a> </div>
|
|
<div class="headertitle">
|
|
<div class="title">polymorphic.hpp File Reference<div class="ingroups"><a class="el" href="group__TypeSupport.html">Support for Serializing Various Types</a> » <a class="el" href="group__OtherTypes.html">Miscellaneous Types Support</a></div></div> </div>
|
|
</div><!--header-->
|
|
<div class="contents">
|
|
|
|
<p>Support for pointers to polymorphic base classes.
|
|
<a href="#details">More...</a></p>
|
|
<div class="textblock"><code>#include "<a class="el" href="cereal_8hpp_source.html">cereal/cereal.hpp</a>"</code><br />
|
|
<code>#include "<a class="el" href="memory_8hpp_source.html">cereal/types/memory.hpp</a>"</code><br />
|
|
<code>#include "<a class="el" href="util_8hpp_source.html">cereal/details/util.hpp</a>"</code><br />
|
|
<code>#include "<a class="el" href="helpers_8hpp_source.html">cereal/details/helpers.hpp</a>"</code><br />
|
|
<code>#include "<a class="el" href="traits_8hpp_source.html">cereal/details/traits.hpp</a>"</code><br />
|
|
<code>#include "<a class="el" href="polymorphic__impl_8hpp_source.html">cereal/details/polymorphic_impl.hpp</a>"</code><br />
|
|
</div>
|
|
<p><a href="polymorphic_8hpp_source.html">Go to the source code of this file.</a></p>
|
|
<table class="memberdecls">
|
|
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="define-members"></a>
|
|
Macros</h2></td></tr>
|
|
<tr class="memitem:a94967009fc480f164511d6bd369f5329"><td class="memItemLeft" align="right" valign="top"><a id="a94967009fc480f164511d6bd369f5329"></a>
|
|
#define </td><td class="memItemRight" valign="bottom"><b>CEREAL_STATIC_CONSTEXPR</b>   static constexpr</td></tr>
|
|
<tr class="separator:a94967009fc480f164511d6bd369f5329"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:aad63585dab771e2dea41bb102c4d7a4c"><td class="memItemLeft" align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#aad63585dab771e2dea41bb102c4d7a4c">CEREAL_REGISTER_TYPE</a>(...)</td></tr>
|
|
<tr class="memdesc:aad63585dab771e2dea41bb102c4d7a4c"><td class="mdescLeft"> </td><td class="mdescRight">Registers a derived polymorphic type with cereal. <a href="polymorphic_8hpp.html#aad63585dab771e2dea41bb102c4d7a4c">More...</a><br /></td></tr>
|
|
<tr class="separator:aad63585dab771e2dea41bb102c4d7a4c"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a84efbe4f256827ca26fe3d86d8bd528c"><td class="memItemLeft" align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#a84efbe4f256827ca26fe3d86d8bd528c">CEREAL_REGISTER_TYPE_WITH_NAME</a>(T, Name)</td></tr>
|
|
<tr class="separator:a84efbe4f256827ca26fe3d86d8bd528c"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a5d730928a52a379ad0d6f2dcdee07953"><td class="memItemLeft" align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#a5d730928a52a379ad0d6f2dcdee07953">CEREAL_REGISTER_POLYMORPHIC_RELATION</a>(Base, Derived)</td></tr>
|
|
<tr class="memdesc:a5d730928a52a379ad0d6f2dcdee07953"><td class="mdescLeft"> </td><td class="mdescRight">Registers the base-derived relationship for a polymorphic type. <a href="polymorphic_8hpp.html#a5d730928a52a379ad0d6f2dcdee07953">More...</a><br /></td></tr>
|
|
<tr class="separator:a5d730928a52a379ad0d6f2dcdee07953"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a01ebe0f840ac20c307f64622384e4dae"><td class="memItemLeft" align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#a01ebe0f840ac20c307f64622384e4dae">CEREAL_REGISTER_DYNAMIC_INIT</a>(LibName)</td></tr>
|
|
<tr class="separator:a01ebe0f840ac20c307f64622384e4dae"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a8e0d5df9830c0ed7c60451cf2f873ff5"><td class="memItemLeft" align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#a8e0d5df9830c0ed7c60451cf2f873ff5">CEREAL_FORCE_DYNAMIC_INIT</a>(LibName)</td></tr>
|
|
<tr class="separator:a8e0d5df9830c0ed7c60451cf2f873ff5"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a6a90af3fca239017978477a753225101"><td class="memItemLeft" align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#a6a90af3fca239017978477a753225101">UNREGISTERED_POLYMORPHIC_EXCEPTION</a>(LoadSave, Name)</td></tr>
|
|
<tr class="memdesc:a6a90af3fca239017978477a753225101"><td class="mdescLeft"> </td><td class="mdescRight">Error message used for unregistered polymorphic types. <a href="polymorphic_8hpp.html#a6a90af3fca239017978477a753225101">More...</a><br /></td></tr>
|
|
<tr class="separator:a6a90af3fca239017978477a753225101"><td class="memSeparator" colspan="2"> </td></tr>
|
|
</table><table class="memberdecls">
|
|
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="func-members"></a>
|
|
Functions</h2></td></tr>
|
|
<tr class="memitem:a1ba6164125996cf35136a4309f966453"><td class="memTemplParams" colspan="2"><a id="a1ba6164125996cf35136a4309f966453"></a>
|
|
template<class Archive > </td></tr>
|
|
<tr class="memitem:a1ba6164125996cf35136a4309f966453"><td class="memTemplItemLeft" align="right" valign="top">typename ::<a class="el" href="structcereal_1_1detail_1_1InputBindingMap.html">cereal::detail::InputBindingMap</a>< Archive >::Serializers </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#a1ba6164125996cf35136a4309f966453">cereal::polymorphic_detail::getInputBinding</a> (Archive &ar, std::uint32_t const nameid)</td></tr>
|
|
<tr class="memdesc:a1ba6164125996cf35136a4309f966453"><td class="mdescLeft"> </td><td class="mdescRight">Get an input binding from the given archive by deserializing the type meta data. <br /></td></tr>
|
|
<tr class="separator:a1ba6164125996cf35136a4309f966453"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a8d33747ce687e324440a360c1b8987b8"><td class="memTemplParams" colspan="2">template<class Archive , class T > </td></tr>
|
|
<tr class="memitem:a8d33747ce687e324440a360c1b8987b8"><td class="memTemplItemLeft" align="right" valign="top">std::enable_if<(traits::is_default_constructible< T >::value||traits::has_load_and_construct< T, Archive >::value) &&!std::is_abstract< T >::value, bool >::type </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#a8d33747ce687e324440a360c1b8987b8">cereal::polymorphic_detail::serialize_wrapper</a> (Archive &ar, std::shared_ptr< T > &ptr, std::uint32_t const nameid)</td></tr>
|
|
<tr class="memdesc:a8d33747ce687e324440a360c1b8987b8"><td class="mdescLeft"> </td><td class="mdescRight">Serialize a shared_ptr if the 2nd msb in the nameid is set, and if we can actually construct the pointee. <a href="polymorphic_8hpp.html#a8d33747ce687e324440a360c1b8987b8">More...</a><br /></td></tr>
|
|
<tr class="separator:a8d33747ce687e324440a360c1b8987b8"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a8c9e4b18c837d2487a4edcffe4c2a879"><td class="memTemplParams" colspan="2">template<class Archive , class T , class D > </td></tr>
|
|
<tr class="memitem:a8c9e4b18c837d2487a4edcffe4c2a879"><td class="memTemplItemLeft" align="right" valign="top">std::enable_if<(traits::is_default_constructible< T >::value||traits::has_load_and_construct< T, Archive >::value) &&!std::is_abstract< T >::value, bool >::type </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#a8c9e4b18c837d2487a4edcffe4c2a879">cereal::polymorphic_detail::serialize_wrapper</a> (Archive &ar, std::unique_ptr< T, D > &ptr, std::uint32_t const nameid)</td></tr>
|
|
<tr class="memdesc:a8c9e4b18c837d2487a4edcffe4c2a879"><td class="mdescLeft"> </td><td class="mdescRight">Serialize a unique_ptr if the 2nd msb in the nameid is set, and if we can actually construct the pointee. <a href="polymorphic_8hpp.html#a8c9e4b18c837d2487a4edcffe4c2a879">More...</a><br /></td></tr>
|
|
<tr class="separator:a8c9e4b18c837d2487a4edcffe4c2a879"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a0e8faa1bd3d8119fcdb34b5b5453e6be"><td class="memTemplParams" colspan="2">template<class Archive , class T > </td></tr>
|
|
<tr class="memitem:a0e8faa1bd3d8119fcdb34b5b5453e6be"><td class="memTemplItemLeft" align="right" valign="top">std::enable_if<(!traits::is_default_constructible< T >::value &&!traits::has_load_and_construct< T, Archive >::value)||std::is_abstract< T >::value, bool >::type </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#a0e8faa1bd3d8119fcdb34b5b5453e6be">cereal::polymorphic_detail::serialize_wrapper</a> (Archive &, std::shared_ptr< T > &, std::uint32_t const nameid)</td></tr>
|
|
<tr class="memdesc:a0e8faa1bd3d8119fcdb34b5b5453e6be"><td class="mdescLeft"> </td><td class="mdescRight">Serialize a shared_ptr if the 2nd msb in the nameid is set, and if we can actually construct the pointee. <a href="polymorphic_8hpp.html#a0e8faa1bd3d8119fcdb34b5b5453e6be">More...</a><br /></td></tr>
|
|
<tr class="separator:a0e8faa1bd3d8119fcdb34b5b5453e6be"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a9dac803441014030e0f686f535d72eeb"><td class="memTemplParams" colspan="2">template<class Archive , class T , class D > </td></tr>
|
|
<tr class="memitem:a9dac803441014030e0f686f535d72eeb"><td class="memTemplItemLeft" align="right" valign="top">std::enable_if<(!traits::is_default_constructible< T >::value &&!traits::has_load_and_construct< T, Archive >::value)||std::is_abstract< T >::value, bool >::type </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#a9dac803441014030e0f686f535d72eeb">cereal::polymorphic_detail::serialize_wrapper</a> (Archive &, std::unique_ptr< T, D > &, std::uint32_t const nameid)</td></tr>
|
|
<tr class="memdesc:a9dac803441014030e0f686f535d72eeb"><td class="mdescLeft"> </td><td class="mdescRight">Serialize a unique_ptr if the 2nd msb in the nameid is set, and if we can actually construct the pointee. <a href="polymorphic_8hpp.html#a9dac803441014030e0f686f535d72eeb">More...</a><br /></td></tr>
|
|
<tr class="separator:a9dac803441014030e0f686f535d72eeb"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a759a15c02fad55311de9e5dd645a7319"><td class="memTemplParams" colspan="2"><a id="a759a15c02fad55311de9e5dd645a7319"></a>
|
|
template<class Archive , class T > </td></tr>
|
|
<tr class="memitem:a759a15c02fad55311de9e5dd645a7319"><td class="memTemplItemLeft" align="right" valign="top">std::enable_if< std::is_polymorphic< T >::value &&std::is_abstract< T >::value, void >::type </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#a759a15c02fad55311de9e5dd645a7319">cereal::CEREAL_SAVE_FUNCTION_NAME</a> (Archive &ar, std::shared_ptr< T > const &ptr)</td></tr>
|
|
<tr class="memdesc:a759a15c02fad55311de9e5dd645a7319"><td class="mdescLeft"> </td><td class="mdescRight">Saving std::shared_ptr for polymorphic types, abstract. <br /></td></tr>
|
|
<tr class="separator:a759a15c02fad55311de9e5dd645a7319"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:aa6e1ce1157644fad605ade652112daf1"><td class="memTemplParams" colspan="2"><a id="aa6e1ce1157644fad605ade652112daf1"></a>
|
|
template<class Archive , class T > </td></tr>
|
|
<tr class="memitem:aa6e1ce1157644fad605ade652112daf1"><td class="memTemplItemLeft" align="right" valign="top">std::enable_if< std::is_polymorphic< T >::value &&!std::is_abstract< T >::value, void >::type </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#aa6e1ce1157644fad605ade652112daf1">cereal::CEREAL_SAVE_FUNCTION_NAME</a> (Archive &ar, std::shared_ptr< T > const &ptr)</td></tr>
|
|
<tr class="memdesc:aa6e1ce1157644fad605ade652112daf1"><td class="mdescLeft"> </td><td class="mdescRight">Saving std::shared_ptr for polymorphic types, not abstract. <br /></td></tr>
|
|
<tr class="separator:aa6e1ce1157644fad605ade652112daf1"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a162562abb32a0be716dbfb98f1a31a33"><td class="memTemplParams" colspan="2"><a id="a162562abb32a0be716dbfb98f1a31a33"></a>
|
|
template<class Archive , class T > </td></tr>
|
|
<tr class="memitem:a162562abb32a0be716dbfb98f1a31a33"><td class="memTemplItemLeft" align="right" valign="top">std::enable_if< std::is_polymorphic< T >::value, void >::type </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#a162562abb32a0be716dbfb98f1a31a33">cereal::CEREAL_LOAD_FUNCTION_NAME</a> (Archive &ar, std::shared_ptr< T > &ptr)</td></tr>
|
|
<tr class="memdesc:a162562abb32a0be716dbfb98f1a31a33"><td class="mdescLeft"> </td><td class="mdescRight">Loading std::shared_ptr for polymorphic types. <br /></td></tr>
|
|
<tr class="separator:a162562abb32a0be716dbfb98f1a31a33"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:af0fd3494d3937e25e00c63e3822e8037"><td class="memTemplParams" colspan="2"><a id="af0fd3494d3937e25e00c63e3822e8037"></a>
|
|
template<class Archive , class T > </td></tr>
|
|
<tr class="memitem:af0fd3494d3937e25e00c63e3822e8037"><td class="memTemplItemLeft" align="right" valign="top">std::enable_if< std::is_polymorphic< T >::value, void >::type </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#af0fd3494d3937e25e00c63e3822e8037">cereal::CEREAL_SAVE_FUNCTION_NAME</a> (Archive &ar, std::weak_ptr< T > const &ptr)</td></tr>
|
|
<tr class="memdesc:af0fd3494d3937e25e00c63e3822e8037"><td class="mdescLeft"> </td><td class="mdescRight">Saving std::weak_ptr for polymorphic types. <br /></td></tr>
|
|
<tr class="separator:af0fd3494d3937e25e00c63e3822e8037"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:aa0cbd30aefc13f4a54094593603db13c"><td class="memTemplParams" colspan="2"><a id="aa0cbd30aefc13f4a54094593603db13c"></a>
|
|
template<class Archive , class T > </td></tr>
|
|
<tr class="memitem:aa0cbd30aefc13f4a54094593603db13c"><td class="memTemplItemLeft" align="right" valign="top">std::enable_if< std::is_polymorphic< T >::value, void >::type </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#aa0cbd30aefc13f4a54094593603db13c">cereal::CEREAL_LOAD_FUNCTION_NAME</a> (Archive &ar, std::weak_ptr< T > &ptr)</td></tr>
|
|
<tr class="memdesc:aa0cbd30aefc13f4a54094593603db13c"><td class="mdescLeft"> </td><td class="mdescRight">Loading std::weak_ptr for polymorphic types. <br /></td></tr>
|
|
<tr class="separator:aa0cbd30aefc13f4a54094593603db13c"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:aba7690f06f7ad55613cec7ae757b1750"><td class="memTemplParams" colspan="2"><a id="aba7690f06f7ad55613cec7ae757b1750"></a>
|
|
template<class Archive , class T , class D > </td></tr>
|
|
<tr class="memitem:aba7690f06f7ad55613cec7ae757b1750"><td class="memTemplItemLeft" align="right" valign="top">std::enable_if< std::is_polymorphic< T >::value &&std::is_abstract< T >::value, void >::type </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#aba7690f06f7ad55613cec7ae757b1750">cereal::CEREAL_SAVE_FUNCTION_NAME</a> (Archive &ar, std::unique_ptr< T, D > const &ptr)</td></tr>
|
|
<tr class="memdesc:aba7690f06f7ad55613cec7ae757b1750"><td class="mdescLeft"> </td><td class="mdescRight">Saving std::unique_ptr for polymorphic types that are abstract. <br /></td></tr>
|
|
<tr class="separator:aba7690f06f7ad55613cec7ae757b1750"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:ab7296078465310c1af67d5674d7258c2"><td class="memTemplParams" colspan="2"><a id="ab7296078465310c1af67d5674d7258c2"></a>
|
|
template<class Archive , class T , class D > </td></tr>
|
|
<tr class="memitem:ab7296078465310c1af67d5674d7258c2"><td class="memTemplItemLeft" align="right" valign="top">std::enable_if< std::is_polymorphic< T >::value &&!std::is_abstract< T >::value, void >::type </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#ab7296078465310c1af67d5674d7258c2">cereal::CEREAL_SAVE_FUNCTION_NAME</a> (Archive &ar, std::unique_ptr< T, D > const &ptr)</td></tr>
|
|
<tr class="memdesc:ab7296078465310c1af67d5674d7258c2"><td class="mdescLeft"> </td><td class="mdescRight">Saving std::unique_ptr for polymorphic types, not abstract. <br /></td></tr>
|
|
<tr class="separator:ab7296078465310c1af67d5674d7258c2"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a8d1d69a4d25ed7715c105b14ed6f8957"><td class="memTemplParams" colspan="2"><a id="a8d1d69a4d25ed7715c105b14ed6f8957"></a>
|
|
template<class Archive , class T , class D > </td></tr>
|
|
<tr class="memitem:a8d1d69a4d25ed7715c105b14ed6f8957"><td class="memTemplItemLeft" align="right" valign="top">std::enable_if< std::is_polymorphic< T >::value, void >::type </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="polymorphic_8hpp.html#a8d1d69a4d25ed7715c105b14ed6f8957">cereal::CEREAL_LOAD_FUNCTION_NAME</a> (Archive &ar, std::unique_ptr< T, D > &ptr)</td></tr>
|
|
<tr class="memdesc:a8d1d69a4d25ed7715c105b14ed6f8957"><td class="mdescLeft"> </td><td class="mdescRight">Loading std::unique_ptr, case when user provides load_and_construct for polymorphic types. <br /></td></tr>
|
|
<tr class="separator:a8d1d69a4d25ed7715c105b14ed6f8957"><td class="memSeparator" colspan="2"> </td></tr>
|
|
</table>
|
|
<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
|
|
<div class="textblock"><p>Support for pointers to polymorphic base classes. </p>
|
|
</div><h2 class="groupheader">Macro Definition Documentation</h2>
|
|
<a id="a8e0d5df9830c0ed7c60451cf2f873ff5"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a8e0d5df9830c0ed7c60451cf2f873ff5">◆ </a></span>CEREAL_FORCE_DYNAMIC_INIT</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">#define CEREAL_FORCE_DYNAMIC_INIT</td>
|
|
<td>(</td>
|
|
<td class="paramtype"> </td>
|
|
<td class="paramname">LibName</td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<b>Value:</b><div class="fragment"><div class="line"> <span class="keyword">namespace </span>cereal { \</div>
|
|
<div class="line"> namespace detail { \</div>
|
|
<div class="line"> void <a class="code" href="static__object_8hpp.html#afde52a096f363ebe6869a9c0f9ef4cbb">CEREAL_DLL_EXPORT</a> dynamic_init_dummy_##LibName(); \</div>
|
|
<div class="line"> } <span class="comment">/* end detail */</span> \</div>
|
|
<div class="line"> } <span class="comment">/* end cereal */</span> \</div>
|
|
<div class="line"> namespace { \</div>
|
|
<div class="line"> struct dynamic_init_##LibName { \</div>
|
|
<div class="line"> dynamic_init_##LibName() { \</div>
|
|
<div class="line"> ::cereal::detail::dynamic_init_dummy_##LibName(); \</div>
|
|
<div class="line"> } \</div>
|
|
<div class="line"> } dynamic_init_instance_##LibName; \</div>
|
|
<div class="line"> } <span class="comment">/* end anonymous namespace */</span></div>
|
|
</div><!-- fragment --><p>Forces dynamic initialization of polymorphic support in a previously registered source file</p>
|
|
<dl class="section see"><dt>See also</dt><dd><a class="el" href="polymorphic_8hpp.html#a01ebe0f840ac20c307f64622384e4dae">CEREAL_REGISTER_DYNAMIC_INIT</a></dd></dl>
|
|
<p>See CEREAL_REGISTER_DYNAMIC_INIT for detailed explanation of how this macro should be used. The name used should match that for CEREAL_REGISTER_DYNAMIC_INIT. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a01ebe0f840ac20c307f64622384e4dae"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a01ebe0f840ac20c307f64622384e4dae">◆ </a></span>CEREAL_REGISTER_DYNAMIC_INIT</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">#define CEREAL_REGISTER_DYNAMIC_INIT</td>
|
|
<td>(</td>
|
|
<td class="paramtype"> </td>
|
|
<td class="paramname">LibName</td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<b>Value:</b><div class="fragment"><div class="line"> <span class="keyword">namespace </span>cereal { \</div>
|
|
<div class="line"> namespace detail { \</div>
|
|
<div class="line"> void <a class="code" href="static__object_8hpp.html#afde52a096f363ebe6869a9c0f9ef4cbb">CEREAL_DLL_EXPORT</a> dynamic_init_dummy_##LibName() {} \</div>
|
|
<div class="line"> } } <span class="comment">/* end namespaces */</span></div>
|
|
</div><!-- fragment --><p>Adds a way to force initialization of a translation unit containing calls to CEREAL_REGISTER_TYPE</p>
|
|
<p>In C++, dynamic initialization of non-local variables of a translation unit may be deferred until "the first odr-use of any function or variable
|
|
defined in the same translation unit as the variable to be initialized."</p>
|
|
<p>Informally, odr-use means that your program takes the address of or binds a reference directly to an object, which must have a definition.</p>
|
|
<p>Since polymorphic type support in cereal relies on the dynamic initialization of certain global objects happening before serialization is performed, it is important to ensure that something from files that call CEREAL_REGISTER_TYPE is odr-used before serialization occurs, otherwise the registration will never take place. This may often be the case when serialization is built as a shared library external from your main program.</p>
|
|
<p>This macro, with any name of your choosing, should be placed into the source file that contains calls to CEREAL_REGISTER_TYPE.</p>
|
|
<p>Its counterpart, CEREAL_FORCE_DYNAMIC_INIT, should be placed in its associated header file such that it is included in the translation units (source files) in which you want the registration to appear. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a5d730928a52a379ad0d6f2dcdee07953"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a5d730928a52a379ad0d6f2dcdee07953">◆ </a></span>CEREAL_REGISTER_POLYMORPHIC_RELATION</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">#define CEREAL_REGISTER_POLYMORPHIC_RELATION</td>
|
|
<td>(</td>
|
|
<td class="paramtype"> </td>
|
|
<td class="paramname">Base, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype"> </td>
|
|
<td class="paramname">Derived </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<b>Value:</b><div class="fragment"><div class="line"> <span class="keyword">namespace </span>cereal { \</div>
|
|
<div class="line"> namespace detail { \</div>
|
|
<div class="line"> template <> \</div>
|
|
<div class="line"> struct PolymorphicRelation<Base, Derived> \</div>
|
|
<div class="line"> { <span class="keyword">static</span> <span class="keywordtype">void</span> bind() { RegisterPolymorphicCaster<Base, Derived>::bind(); } }; \</div>
|
|
<div class="line"> } } <span class="comment">/* end namespaces */</span></div>
|
|
</div><!-- fragment -->
|
|
<p>Registers the base-derived relationship for a polymorphic type. </p>
|
|
<p>When polymorphic serialization occurs, cereal needs to know how to properly cast between derived and base types for the polymorphic type. Normally this happens automatically whenever <a class="el" href="structcereal_1_1base__class.html" title="Casts a derived class to its non-virtual base class in a way that safely supports abstract classes.">cereal::base_class</a> or <a class="el" href="structcereal_1_1virtual__base__class.html" title="Casts a derived class to its virtual base class in a way that allows cereal to track inheritance.">cereal::virtual_base_class</a> are used to serialize a base class. In cases where neither of these is ever called but a base class still exists, this explicit registration is required.</p>
|
|
<p>The Derived class should be the most derived type that will be serialized, and the Base type any possible base that has not been covered under a base class serialization that will be used to store a Derived pointer.</p>
|
|
<p>Placement of this is the same as for CEREAL_REGISTER_TYPE. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="aad63585dab771e2dea41bb102c4d7a4c"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#aad63585dab771e2dea41bb102c4d7a4c">◆ </a></span>CEREAL_REGISTER_TYPE</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">#define CEREAL_REGISTER_TYPE</td>
|
|
<td>(</td>
|
|
<td class="paramtype"> </td>
|
|
<td class="paramname"><em>...</em></td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<b>Value:</b><div class="fragment"><div class="line"> <span class="keyword">namespace </span>cereal { \</div>
|
|
<div class="line"> namespace detail { \</div>
|
|
<div class="line"> template <> \</div>
|
|
<div class="line"> struct binding_name<__VA_ARGS__> \</div>
|
|
<div class="line"> { \</div>
|
|
<div class="line"> CEREAL_STATIC_CONSTEXPR <span class="keywordtype">char</span> <span class="keyword">const</span> * name() { <span class="keywordflow">return</span> #__VA_ARGS__; } \</div>
|
|
<div class="line"> }; \</div>
|
|
<div class="line"> } } <span class="comment">/* end namespaces */</span> \</div>
|
|
<div class="line"> CEREAL_BIND_TO_ARCHIVES(__VA_ARGS__)</div>
|
|
</div><!-- fragment -->
|
|
<p>Registers a derived polymorphic type with cereal. </p>
|
|
<p>Polymorphic types must be registered before smart pointers to them can be serialized. Note that base classes do not need to be registered.</p>
|
|
<p>Registering a type lets cereal know how to properly serialize it when a smart pointer to a base object is used in conjunction with a derived class.</p>
|
|
<p>This assumes that all relevant archives have also previously been registered. Registration for archives is usually done in the header file in which they are defined. This means that type registration needs to happen after specific archives to be used are included.</p>
|
|
<p>It is recommended that type registration be done in the header file in which the type is declared.</p>
|
|
<p>Registration can also be placed in a source file, but this may require the use of the CEREAL_REGISTER_DYNAMIC_INIT macro (see below).</p>
|
|
<p>Registration may be called repeatedly for the same type in different translation units to add support for additional archives if they are not initially available (included and registered).</p>
|
|
<p>When building serialization support as a DLL on Windows, registration must happen in the header file. On Linux and Mac things should still work properly if placed in a source file, but see the above comments on registering in source files.</p>
|
|
<p>Polymorphic support in cereal requires RTTI to be enabled </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a84efbe4f256827ca26fe3d86d8bd528c"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a84efbe4f256827ca26fe3d86d8bd528c">◆ </a></span>CEREAL_REGISTER_TYPE_WITH_NAME</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">#define CEREAL_REGISTER_TYPE_WITH_NAME</td>
|
|
<td>(</td>
|
|
<td class="paramtype"> </td>
|
|
<td class="paramname">T, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype"> </td>
|
|
<td class="paramname">Name </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<b>Value:</b><div class="fragment"><div class="line"> <span class="keyword">namespace </span>cereal { \</div>
|
|
<div class="line"> namespace detail { \</div>
|
|
<div class="line"> template <> \</div>
|
|
<div class="line"> struct binding_name<T> \</div>
|
|
<div class="line"> { CEREAL_STATIC_CONSTEXPR <span class="keywordtype">char</span> <span class="keyword">const</span> * name() { <span class="keywordflow">return</span> Name; } }; \</div>
|
|
<div class="line"> } } <span class="comment">/* end namespaces */</span> \</div>
|
|
<div class="line"> CEREAL_BIND_TO_ARCHIVES(T)</div>
|
|
</div><!-- fragment --><p>Registers a polymorphic type with cereal, giving it a user defined name</p>
|
|
<p>In some cases the default name used with CEREAL_REGISTER_TYPE (the name of the type) may not be suitable. This macro allows any name to be associated with the type. The name should be unique </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a6a90af3fca239017978477a753225101"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a6a90af3fca239017978477a753225101">◆ </a></span>UNREGISTERED_POLYMORPHIC_EXCEPTION</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">#define UNREGISTERED_POLYMORPHIC_EXCEPTION</td>
|
|
<td>(</td>
|
|
<td class="paramtype"> </td>
|
|
<td class="paramname">LoadSave, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype"> </td>
|
|
<td class="paramname">Name </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<b>Value:</b><div class="fragment"><div class="line"> <span class="keywordflow">throw</span> <a class="code" href="structcereal_1_1Exception.html">cereal::Exception</a>(<span class="stringliteral">"Trying to "</span> #LoadSave <span class="stringliteral">" an unregistered polymorphic type ("</span> + Name + <span class="stringliteral">").\n"</span> \</div>
|
|
<div class="line"> <span class="stringliteral">"Make sure your type is registered with CEREAL_REGISTER_TYPE and that the archive "</span> \</div>
|
|
<div class="line"> <span class="stringliteral">"you are using was included (and registered with CEREAL_REGISTER_ARCHIVE) prior to calling CEREAL_REGISTER_TYPE.\n"</span> \</div>
|
|
<div class="line"> <span class="stringliteral">"If your type is already registered and you still see this error, you may need to use CEREAL_REGISTER_DYNAMIC_INIT."</span>);</div>
|
|
</div><!-- fragment -->
|
|
<p>Error message used for unregistered polymorphic types. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<h2 class="groupheader">Function Documentation</h2>
|
|
<a id="a0e8faa1bd3d8119fcdb34b5b5453e6be"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a0e8faa1bd3d8119fcdb34b5b5453e6be">◆ </a></span>serialize_wrapper() <span class="overload">[1/4]</span></h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<div class="memtemplate">
|
|
template<class Archive , class T > </div>
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">std::enable_if<(!traits::is_default_constructible<T>::value && !traits::has_load_and_construct<T, Archive>::value) || std::is_abstract<T>::value, bool>::type cereal::polymorphic_detail::serialize_wrapper </td>
|
|
<td>(</td>
|
|
<td class="paramtype">Archive & </td>
|
|
<td class="paramname">, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">std::shared_ptr< T > & </td>
|
|
<td class="paramname">, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">std::uint32_t const </td>
|
|
<td class="paramname"><em>nameid</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Serialize a shared_ptr if the 2nd msb in the nameid is set, and if we can actually construct the pointee. </p>
|
|
<p>This case is for when we can't actually construct the shared pointer. Normally this would be caught as the pointer itself is serialized, but since this is a polymorphic pointer, if we tried to serialize the pointer we'd end up back here recursively. So we have to catch the error here as well, if this was a polymorphic type serialized by its proper pointer type </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a9dac803441014030e0f686f535d72eeb"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a9dac803441014030e0f686f535d72eeb">◆ </a></span>serialize_wrapper() <span class="overload">[2/4]</span></h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<div class="memtemplate">
|
|
template<class Archive , class T , class D > </div>
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">std::enable_if<(!traits::is_default_constructible<T>::value && !traits::has_load_and_construct<T, Archive>::value) || std::is_abstract<T>::value, bool>::type cereal::polymorphic_detail::serialize_wrapper </td>
|
|
<td>(</td>
|
|
<td class="paramtype">Archive & </td>
|
|
<td class="paramname">, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">std::unique_ptr< T, D > & </td>
|
|
<td class="paramname">, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">std::uint32_t const </td>
|
|
<td class="paramname"><em>nameid</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Serialize a unique_ptr if the 2nd msb in the nameid is set, and if we can actually construct the pointee. </p>
|
|
<p>This case is for when we can't actually construct the unique pointer. Normally this would be caught as the pointer itself is serialized, but since this is a polymorphic pointer, if we tried to serialize the pointer we'd end up back here recursively. So we have to catch the error here as well, if this was a polymorphic type serialized by its proper pointer type </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a8d33747ce687e324440a360c1b8987b8"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a8d33747ce687e324440a360c1b8987b8">◆ </a></span>serialize_wrapper() <span class="overload">[3/4]</span></h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<div class="memtemplate">
|
|
template<class Archive , class T > </div>
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">std::enable_if<(traits::is_default_constructible<T>::value || traits::has_load_and_construct<T, Archive>::value) && !std::is_abstract<T>::value, bool>::type cereal::polymorphic_detail::serialize_wrapper </td>
|
|
<td>(</td>
|
|
<td class="paramtype">Archive & </td>
|
|
<td class="paramname"><em>ar</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">std::shared_ptr< T > & </td>
|
|
<td class="paramname"><em>ptr</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">std::uint32_t const </td>
|
|
<td class="paramname"><em>nameid</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Serialize a shared_ptr if the 2nd msb in the nameid is set, and if we can actually construct the pointee. </p>
|
|
<p>This check lets us try and skip doing polymorphic machinery if we can get away with using the derived class serialize function</p>
|
|
<p>Note that on MSVC 2013 preview, is_default_constructible<T> returns true for abstract classes with default constructors, but on clang/gcc this will return false. So we also need to check for that here. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a8c9e4b18c837d2487a4edcffe4c2a879"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a8c9e4b18c837d2487a4edcffe4c2a879">◆ </a></span>serialize_wrapper() <span class="overload">[4/4]</span></h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<div class="memtemplate">
|
|
template<class Archive , class T , class D > </div>
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">std::enable_if<(traits::is_default_constructible<T>::value || traits::has_load_and_construct<T, Archive>::value) && !std::is_abstract<T>::value, bool>::type cereal::polymorphic_detail::serialize_wrapper </td>
|
|
<td>(</td>
|
|
<td class="paramtype">Archive & </td>
|
|
<td class="paramname"><em>ar</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">std::unique_ptr< T, D > & </td>
|
|
<td class="paramname"><em>ptr</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">std::uint32_t const </td>
|
|
<td class="paramname"><em>nameid</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Serialize a unique_ptr if the 2nd msb in the nameid is set, and if we can actually construct the pointee. </p>
|
|
<p>This check lets us try and skip doing polymorphic machinery if we can get away with using the derived class serialize function </p>
|
|
|
|
</div>
|
|
</div>
|
|
</div><!-- contents -->
|
|
<div class="ttc" id="astatic__object_8hpp_html_afde52a096f363ebe6869a9c0f9ef4cbb"><div class="ttname"><a href="static__object_8hpp.html#afde52a096f363ebe6869a9c0f9ef4cbb">CEREAL_DLL_EXPORT</a></div><div class="ttdeci">#define CEREAL_DLL_EXPORT</div><div class="ttdoc">Prevent link optimization from removing non-referenced static objects.</div><div class="ttdef"><b>Definition:</b> static_object.hpp:51</div></div>
|
|
<div class="ttc" id="astructcereal_1_1Exception_html"><div class="ttname"><a href="structcereal_1_1Exception.html">cereal::Exception</a></div><div class="ttdoc">An exception class thrown when things go wrong at runtime.</div><div class="ttdef"><b>Definition:</b> helpers.hpp:48</div></div>
|
|
<!-- HTML footer for doxygen 1.8.3.1-->
|
|
<!-- start footer part -->
|
|
<hr class="footer"/><address class="footer"><small>
|
|
Generated on Sun Feb 27 2022 19:46:46 for cereal by  <a href="http://www.doxygen.org/index.html">
|
|
<img class="footer" src="doxygen.png" alt="doxygen"/>
|
|
</a> 1.8.17
|
|
</small></address>
|
|
<script>
|
|
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
|
|
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
|
|
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
|
|
})(window,document,'script','//www.google-analytics.com/analytics.js','ga');
|
|
ga('create', 'UA-42360142-1', 'uscilab.github.io');
|
|
ga('send', 'pageview');
|
|
</script>
|
|
</body>
|
|
</html>
|