factories.html 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583
  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0.1 Transitional//EN">
  2. <html>
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
  5. <title>Boost.Flyweight Documentation - Factories reference</title>
  6. <link rel="stylesheet" href="../style.css" type="text/css">
  7. <link rel="start" href="../index.html">
  8. <link rel="prev" href="tags.html">
  9. <link rel="up" href="index.html">
  10. <link rel="next" href="holders.html">
  11. </head>
  12. <body>
  13. <h1><img src="../../../../boost.png" alt="Boost logo" align=
  14. "middle" width="277" height="86">Boost.Flyweight
  15. Factories reference</h1>
  16. <div class="prev_link"><a href="tags.html"><img src="../prev.gif" alt="tags" border="0"><br>
  17. Tags
  18. </a></div>
  19. <div class="up_link"><a href="index.html"><img src="../up.gif" alt="Boost.Flyweight reference" border="0"><br>
  20. Boost.Flyweight reference
  21. </a></div>
  22. <div class="next_link"><a href="holders.html"><img src="../next.gif" alt="holders" border="0"><br>
  23. Holders
  24. </a></div><br clear="all" style="clear: all;">
  25. <hr>
  26. <h2>Contents</h2>
  27. <ul>
  28. <li><a href="#factory">Factories and factory specifiers</a></li>
  29. <li><a href="#factory_tag_synopsis">Header
  30. <code>"boost/flyweight/factory_tag.hpp"</code> synopsis</a>
  31. <ul>
  32. <li><a href="#is_factory">Class template <code>is_factory</code></a></li>
  33. <li><a href="#factory_construct">Class template <code>factory</code></a></li>
  34. </ul>
  35. </li>
  36. <li><a href="#hashed_factory_fwd_synopsis">Header
  37. <code>"boost/flyweight/hashed_factory_fwd.hpp"</code> synopsis</a>
  38. </li>
  39. <li><a href="#hashed_factory_synopsis">Header
  40. <code>"boost/flyweight/hashed_factory.hpp"</code> synopsis</a>
  41. <ul>
  42. <li><a href="#hashed_factory_class">Class template <code>hashed_factory_class</code></a></li>
  43. <li><a href="#hashed_factory">Class template <code>hashed_factory</code></a></li>
  44. </ul>
  45. </li>
  46. <li><a href="#set_factory_fwd_synopsis">Header
  47. <code>"boost/flyweight/set_factory_fwd.hpp"</code> synopsis</a>
  48. </li>
  49. <li><a href="#set_factory_synopsis">Header
  50. <code>"boost/flyweight/set_factory.hpp"</code> synopsis</a>
  51. <ul>
  52. <li><a href="#set_factory_class">Class template <code>set_factory_class</code></a></li>
  53. <li><a href="#set_factory">Class template <code>set_factory</code></a></li>
  54. </ul>
  55. </li>
  56. <li><a href="#assoc_container_factory_fwd_synopsis">Header
  57. <code>"boost/flyweight/assoc_container_factory_fwd.hpp"</code> synopsis</a>
  58. </li>
  59. <li><a href="#assoc_container_factory_synopsis">Header
  60. <code>"boost/flyweight/assoc_container_factory.hpp"</code> synopsis</a>
  61. <ul>
  62. <li><a href="#assoc_container_factory_class">Class template <code>assoc_container_factory_class</code></a></li>
  63. <li><a href="#assoc_container_factory">Class template <code>assoc_container_factory</code></a></li>
  64. </ul>
  65. </li>
  66. </ul>
  67. <h2><a name="factory">Factories and factory specifiers</a></h2>
  68. <p>
  69. Given a type <code>Key</code> and an
  70. <a href="https://boost.org/sgi/stl/Assignable.html"><code>Assignable</code></a>
  71. type <code>Entry</code> implicitly convertible to <code>const Key&amp;</code>, a
  72. <i>factory of <code>Entry</code> elements</i> (implicitly associated to
  73. <code>Key</code>) is a
  74. <a href="https://boost.org/sgi/stl/DefaultConstructible.html"><code>Default
  75. Constructible</code></a> entity able to store and retrieve immutable elements of
  76. type <code>Entry</code>. A factory is governed by an associated equivalence
  77. relation defined on <code>Key</code> so that no two
  78. <code>Entry</code> objects convertible to equivalent <code>Key</code>s
  79. can be stored simultaneously in the factory. Different factory types can
  80. use different equivalence relations.
  81. </p>
  82. <p>
  83. In the following table, <code>Factory</code> is a factory of elements
  84. of type <code>Entry</code>, <code>f</code> denotes an object of type <code>Factory</code>,
  85. <code>x</code> is an object of type <code>Entry</code> and <code>h</code> is a
  86. value of <code>Factory::handle_type</code>.
  87. </p>
  88. <p align="center">
  89. <table cellspacing="0">
  90. <caption><b>Factory requirements.</b></caption>
  91. <tr>
  92. <th align="center">expression</th>
  93. <th align="center">return type</th>
  94. <th align="center">assertion/note<br>pre/post-condition</th>
  95. </tr>
  96. <tr>
  97. <td><code>Factory::handle_type</code></td>
  98. <td>handle to elements of type <code>T</code><br>
  99. stored in the factory
  100. </td>
  101. <td><code>handle_type</code> is
  102. <a href="https://boost.org/sgi/stl/Assignable.html"><code>Assignable</code></a>
  103. and its copy and<br>
  104. assignment operations never throw an exception.
  105. </td>
  106. </tr>
  107. <tr class="odd_tr">
  108. <td><code>f.insert(x);</code></td>
  109. <td><code>handle_type</code></td>
  110. <td>Inserts a copy of <code>x</code> if there is no equivalent entry in <code>f</code>;<br>
  111. returns a handle to the inserted or equivalent element.
  112. </td>
  113. </tr>
  114. <tr>
  115. <td><code>f.erase(h);</code></td>
  116. <td><code>void</code></td>
  117. <td>Erases the element associated to <code>h</code>.<br>
  118. This operation does not throw.
  119. </td>
  120. </tr>
  121. <tr class="odd_tr">
  122. <td><code>f.entry(h);</code></td>
  123. <td><code>const Entry&amp;</code></td>
  124. <td>Returns a reference to the element associated to <code>h</code>.<br>
  125. This operation does not throw.
  126. </td>
  127. </tr>
  128. </table>
  129. </p>
  130. <p>
  131. Additionally to the basic thread safety guarantee which is implicitly assumed
  132. for most classes including the majority of components of the
  133. C++ standard library, it is required that the member function <code>entry</code>
  134. can be invoked simultaneously from different threads, even in the presence
  135. of concurrent accesses to <code>insert</code> and <code>erase</code> (as long
  136. as the entry returned by <code>entry</code> is not the one which is being
  137. erased).
  138. </p>
  139. <p>
  140. A type <code>S</code> is said to be a <i>factory specifier</i> if:
  141. <ol>
  142. <li>One of the following conditions is satisfied:
  143. <ol type="a">
  144. <li><a href="#is_factory"><code>is_factory&lt;S&gt;::type</code></a> is
  145. <a href="../../../mpl/doc/refmanual/bool.html"><code>boost::mpl::true_</code></a>,</li>
  146. <li><code>S</code> is of the form <a href="#factory_construct"><code>factory&lt;S'&gt;</code></a>.</li>
  147. </ol>
  148. </li>
  149. <li><code>S</code>, or <code>S'</code> if (b) applies, is an
  150. <a href="../../../mpl/doc/refmanual/lambda-expression.html"><code>MPL Lambda
  151. Expression</code></a> such that invoking it with types (<code>Entry</code>,
  152. <code>Key</code>) resolves to a factory type of <code>Entry</code> elements
  153. (implicitly associated to <code>Key</code>).
  154. </li>
  155. </ol>
  156. </p>
  157. <h2><a name="factory_tag_synopsis">Header
  158. <a href="../../../../boost/flyweight/factory_tag.hpp"><code>"boost/flyweight/factory_tag.hpp"</code></a> synopsis</a></h2>
  159. <blockquote><pre>
  160. <span class=keyword>namespace</span> <span class=identifier>boost</span><span class=special>{</span>
  161. <span class=keyword>namespace</span> <span class=identifier>flyweights</span><span class=special>{</span>
  162. <span class=keyword>struct</span> <span class=identifier>factory_marker</span><span class=special>;</span>
  163. <span class=keyword>template</span><span class=special>&lt;</span><span class=keyword>typename</span> <span class=identifier>T</span><span class=special>&gt;</span>
  164. <span class=keyword>struct</span> <span class=identifier>is_factory</span><span class=special>;</span>
  165. <span class=keyword>template</span><span class=special>&lt;</span><span class=keyword>typename</span> <span class=identifier>T</span><span class=special>&gt;</span>
  166. <span class=keyword>struct</span> <span class=identifier>factory</span><span class=special>;</span>
  167. <span class=special>}</span> <span class=comment>// namespace boost::flyweights</span>
  168. <span class=special>}</span> <span class=comment>// namespace boost</span>
  169. </pre></blockquote>
  170. <h3><a name="is_factory">Class template <code>is_factory</code></a></h3>
  171. <p>
  172. Unless specialized by the user, <code>is_factory&lt;T&gt;::type</code> is
  173. <a href="../../../mpl/doc/refmanual/bool.html"><code>boost::mpl::true_</code></a>
  174. if <code>T</code> is derived from <code>factory_marker</code>, and it is
  175. <a href="../../../mpl/doc/refmanual/bool.html"><code>boost::mpl::false_</code></a>
  176. otherwise.
  177. </p>
  178. <h3><a name="factory_construct">Class template <code>factory</code></a></h3>
  179. <p>
  180. <code>factory&lt;T&gt;</code> is a syntactic construct meant to indicate
  181. that <code>T</code> is a factory specifier without resorting to the
  182. mechanisms provided by the <code>is_factory</code> class template.
  183. </p>
  184. <h2><a name="hashed_factory_fwd_synopsis">Header
  185. <a href="../../../../boost/flyweight/hashed_factory_fwd.hpp"><code>"boost/flyweight/hashed_factory_fwd.hpp"</code></a> synopsis</a></h2>
  186. <blockquote><pre>
  187. <span class=keyword>namespace</span> <span class=identifier>boost</span><span class=special>{</span>
  188. <span class=keyword>namespace</span> <span class=identifier>flyweights</span><span class=special>{</span>
  189. <span class=keyword>template</span><span class=special>&lt;</span>
  190. <span class=keyword>typename</span> <span class=identifier>Entry</span><span class=special>,</span><span class=keyword>typename</span> <span class=identifier>Key</span><span class=special>,</span>
  191. <span class=keyword>typename</span> <span class=identifier>Hash</span><span class=special>=</span><b>implementation defined</b><span class=special>,</span>
  192. <span class=keyword>typename</span> <span class=identifier>Pred</span><span class=special>=</span><b>implementation defined</b><span class=special>,</span>
  193. <span class=keyword>typename</span> <span class=identifier>Allocator</span><span class=special>=</span><b>implementation defined</b>
  194. <span class=special>&gt;</span>
  195. <span class=keyword>class</span> <span class=identifier>hashed_factory_class</span><span class=special>;</span>
  196. <span class=keyword>template</span><span class=special>&lt;</span>
  197. <span class=keyword>typename</span> <span class=identifier>Hash</span><span class=special>=</span><b>implementation defined</b><span class=special>,</span>
  198. <span class=keyword>typename</span> <span class=identifier>Pred</span><span class=special>=</span><b>implementation defined</b><span class=special>,</span>
  199. <span class=keyword>typename</span> <span class=identifier>Allocator</span><span class=special>=</span><b>implementation defined</b>
  200. <span class=special>&gt;</span>
  201. <span class=keyword>struct</span> <span class=identifier>hashed_factory</span><span class=special>;</span>
  202. <span class=special>}</span> <span class=comment>// namespace boost::flyweights</span>
  203. <span class=special>}</span> <span class=comment>// namespace boost</span>
  204. </pre></blockquote>
  205. <p>
  206. <code>hashed_factory_fwd.hpp</code> forward declares the class templates
  207. <a href="#hashed_factory_class"><code>hashed_factory_class</code></a>
  208. and <a href="#hashed_factory"><code>hashed_factory</code></a>.
  209. </p>
  210. <h2><a name="hashed_factory_synopsis">Header
  211. <a href="../../../../boost/flyweight/hashed_factory.hpp"><code>"boost/flyweight/hashed_factory.hpp"</code></a> synopsis</a></h2>
  212. <h3><a name="hashed_factory_class">Class template <code>hashed_factory_class</code></a></h3>
  213. <p>
  214. <code>hashed_factory_class</code> is a <a href="#factory"><code>Factory</code></a>
  215. implemented with a hashed container.
  216. </p>
  217. <blockquote><pre>
  218. <span class=keyword>template</span><span class=special>&lt;</span>
  219. <span class=keyword>typename</span> <span class=identifier>Entry</span><span class=special>,</span><span class=keyword>typename</span> <span class=identifier>Key</span><span class=special>,</span>
  220. <span class=keyword>typename</span> <span class=identifier>Hash</span><span class=special>,</span><span class=keyword>typename</span> <span class=identifier>Pred</span><span class=special>,</span><span class=keyword>typename</span> <span class=identifier>Allocator</span>
  221. <span class=special>&gt;</span>
  222. <span class=keyword>class</span> <span class=identifier>hashed_factory_class</span>
  223. <span class=special>{</span>
  224. <span class=keyword>public</span><span class=special>:</span>
  225. <span class=keyword>typedef</span> <b>implementation defined</b> <span class=identifier>handle_type</span><span class=special>;</span>
  226. <span class=identifier>handle_type</span> <span class=identifier>insert</span><span class=special>(</span><span class=keyword>const</span> <span class=identifier>Entry</span><span class=special>&amp;</span> <span class=identifier>x</span><span class=special>);</span>
  227. <span class=keyword>void</span> <span class=identifier>erase</span><span class=special>(</span><span class=identifier>handle_type</span> <span class=identifier>h</span><span class=special>);</span>
  228. <span class=keyword>const</span> <span class=identifier>Entry</span><span class=special>&amp;</span> <span class=identifier>entry</span><span class=special>(</span><span class=identifier>handle_type</span> <span class=identifier>h</span><span class=special>);</span>
  229. <span class=special>};</span>
  230. </pre></blockquote>
  231. <p>
  232. <code>Hash</code> is a
  233. <a href="https://boost.org/sgi/stl/DefaultConstructible.html"><code>Default
  234. Constructible</code></a>
  235. <a href="https://boost.org/sgi/stl/UnaryFunction.html"><code>Unary Function</code></a>
  236. taking a single argument of type <code>Key</code> and returning a
  237. value of type <code>std::size_t</code> in the range
  238. <code>[0, std::numeric_limits&lt;std::size_t&gt;::max())</code>.
  239. <code>Pred</code> is a
  240. <a href="https://boost.org/sgi/stl/DefaultConstructible.html"><code>Default
  241. Constructible</code></a>
  242. <a href="https://boost.org/sgi/stl/BinaryPredicate.html">
  243. <code>Binary Predicate</code></a> inducing an equivalence relation
  244. on elements of <code>Key</code>. It is required that
  245. a <code>Hash</code> object return the same value for objects
  246. equivalent under <code>Pred</code>.
  247. The equivalence relation on <code>Key</code> associated to the factory is
  248. that induced by <code>Pred</code>.
  249. The default arguments for <code>Hash</code> and <code>Pred</code> are
  250. <a href="../../../functional/hash/index.html"><code>boost::hash&lt;Key&gt;</code></a>
  251. and <code>std::equal_to&lt;Key&gt;</code>, respectively.
  252. <code>Allocator</code> must be an allocator of <code>Entry</code> objects
  253. satisfying the associated C++ requirements at <b>[lib.allocator.requirements]</b>.
  254. The default argument is <code>std::allocator&lt;Entry&gt;</code>. The internal
  255. hashed container upon which <code>hashed_factory_class</code> is based is
  256. constructed with default initialized objects of type <code>Hash</code>,
  257. <code>Pred</code> and <code>Allocator</code>.
  258. </p>
  259. <h3><a name="hashed_factory">Class template <code>hashed_factory</code></a></h3>
  260. <p>
  261. <a href="#factory"><code>Factory Specifier</code></a> for <a href="#hashed_factory_class"><code>hashed_factory_class</code></a>.
  262. </p>
  263. <blockquote><pre>
  264. <span class=keyword>template</span><span class=special>&lt;</span><span class=keyword>typename</span> <span class=identifier>Hash</span><span class=special>,</span><span class=keyword>typename</span> <span class=identifier>Pred</span><span class=special>,</span><span class=keyword>typename</span> <span class=identifier>Allocator</span><span class=special>&gt;</span>
  265. <span class=keyword>struct</span> <span class=identifier>hashed_factory</span><span class=special>;</span>
  266. </pre></blockquote>
  267. <p>
  268. <code>hashed_factory&lt;Hash,Pred,Allocator&gt;</code> is an
  269. <a href="../../../mpl/doc/refmanual/metafunction-class.html"><code>MPL Metafunction
  270. Class</code></a> such that the type
  271. </p>
  272. <blockquote><pre>
  273. <span class=identifier>boost</span><span class=special>::</span><span class=identifier>mpl</span><span class=special>::</span><span class=identifier>apply</span><span class=special>&lt;</span>
  274. <span class=identifier>hashed_factory</span><span class=special>&lt;</span><span class=identifier>Hash</span><span class=special>,</span><span class=identifier>Pred</span><span class=special>,</span><span class=identifier>Allocator</span><span class=special>&gt;,</span>
  275. <span class=identifier>Entry</span><span class=special>,</span><span class=identifier>Key</span>
  276. <span class=special>&gt;::</span><span class=identifier>type</span>
  277. </pre></blockquote>
  278. <p>
  279. is the same as
  280. </p>
  281. <blockquote><pre>
  282. <span class=identifier>boost</span><span class=special>::</span><span class=identifier>mpl</span><span class=special>::</span><span class=identifier>apply</span><span class=special>&lt;</span>
  283. <span class=identifier>hashed_factory_class</span><span class=special>&lt;</span><span class=identifier>boost</span><span class=special>::</span><span class=identifier>mpl</span><span class=special>::</span><span class=identifier>_1</span><span class=special>,</span><span class=identifier>boost</span><span class=special>::</span><span class=identifier>mpl</span><span class=special>::</span><span class=identifier>_2</span><span class=special>,</span><span class=identifier>Hash</span><span class=special>,</span><span class=identifier>Pred</span><span class=special>,</span><span class=identifier>Allocator</span><span class=special>&gt;,</span>
  284. <span class=identifier>Entry</span><span class=special>,</span><span class=identifier>Key</span>
  285. <span class=special>&gt;::</span><span class=identifier>type</span>
  286. </pre></blockquote>
  287. <p>
  288. This implies that <code>Hash</code>, <code>Pred</code> and <code>Allocator</code>
  289. can be
  290. <a href="../../../mpl/doc/refmanual/placeholder-expression.html"><code>MPL
  291. Placeholder Expressions</code></a> resolving to the actual types used by
  292. <code>hashed_factory_class</code>.
  293. </p>
  294. <h2><a name="set_factory_fwd_synopsis">Header
  295. <a href="../../../../boost/flyweight/set_factory_fwd.hpp"><code>"boost/flyweight/set_factory_fwd.hpp"</code></a> synopsis</a></h2>
  296. <blockquote><pre>
  297. <span class=keyword>namespace</span> <span class=identifier>boost</span><span class=special>{</span>
  298. <span class=keyword>namespace</span> <span class=identifier>flyweights</span><span class=special>{</span>
  299. <span class=keyword>template</span><span class=special>&lt;</span>
  300. <span class=keyword>typename</span> <span class=identifier>Entry</span><span class=special>,</span><span class=keyword>typename</span> <span class=identifier>Key</span><span class=special>,</span>
  301. <span class=keyword>typename</span> <span class=identifier>Compare</span><span class=special>=</span><b>implementation defined</b><span class=special>,</span>
  302. <span class=keyword>typename</span> <span class=identifier>Allocator</span><span class=special>=</span><b>implementation defined</b>
  303. <span class=special>&gt;</span>
  304. <span class=keyword>class</span> <span class=identifier>set_factory_class</span><span class=special>;</span>
  305. <span class=keyword>template</span><span class=special>&lt;</span>
  306. <span class=keyword>typename</span> <span class=identifier>Compare</span><span class=special>=</span><b>implementation defined</b><span class=special>,</span>
  307. <span class=keyword>typename</span> <span class=identifier>Allocator</span><span class=special>=</span><b>implementation defined</b>
  308. <span class=special>&gt;</span>
  309. <span class=keyword>struct</span> <span class=identifier>set_factory</span><span class=special>;</span>
  310. <span class=special>}</span> <span class=comment>// namespace boost::flyweights</span>
  311. <span class=special>}</span> <span class=comment>// namespace boost</span>
  312. </pre></blockquote>
  313. <p>
  314. <code>set_factory_fwd.hpp</code> forward declares the class templates
  315. <a href="#set_factory_class"><code>set_factory_class</code></a>
  316. and <a href="#set_factory"><code>set_factory</code></a>.
  317. </p>
  318. <h2><a name="set_factory_synopsis">Header
  319. <a href="../../../../boost/flyweight/set_factory.hpp"><code>"boost/flyweight/set_factory.hpp"</code></a> synopsis</a></h2>
  320. <h3><a name="set_factory_class">Class template <code>set_factory_class</code></a></h3>
  321. <p>
  322. <code>set_factory_class</code> is a <a href="#factory"><code>Factory</code></a>
  323. implemented on top of an orderded associative container.
  324. </p>
  325. <blockquote><pre>
  326. <span class=keyword>template</span><span class=special>&lt;</span>
  327. <span class=keyword>typename</span> <span class=identifier>Entry</span><span class=special>,</span><span class=keyword>typename</span> <span class=identifier>Key</span><span class=special>,</span>
  328. <span class=keyword>typename</span> <span class=identifier>Compare</span><span class=special>,</span><span class=keyword>typename</span> <span class=identifier>Allocator</span>
  329. <span class=special>&gt;</span>
  330. <span class=keyword>class</span> <span class=identifier>set_factory_class</span>
  331. <span class=special>{</span>
  332. <span class=keyword>public</span><span class=special>:</span>
  333. <span class=keyword>typedef</span> <b>implementation defined</b> <span class=identifier>handle_type</span><span class=special>;</span>
  334. <span class=identifier>handle_type</span> <span class=identifier>insert</span><span class=special>(</span><span class=keyword>const</span> <span class=identifier>Entry</span><span class=special>&amp;</span> <span class=identifier>x</span><span class=special>);</span>
  335. <span class=keyword>void</span> <span class=identifier>erase</span><span class=special>(</span><span class=identifier>handle_type</span> <span class=identifier>h</span><span class=special>);</span>
  336. <span class=keyword>const</span> <span class=identifier>Entry</span><span class=special>&amp;</span> <span class=identifier>entry</span><span class=special>(</span><span class=identifier>handle_type</span> <span class=identifier>h</span><span class=special>);</span>
  337. <span class=special>};</span>
  338. </pre></blockquote>
  339. <p>
  340. <code>Compare</code> is a
  341. <a href="https://boost.org/sgi/stl/DefaultConstructible.html"><code>Default
  342. Constructible</code></a>
  343. <a href="https://boost.org/sgi/stl/StrictWeakOrdering.html">
  344. <code>Strict Weak Ordering</code></a> on <code>Key</code>. Two <code>Key</code>s
  345. <code>x</code> and <code>y</code> are considered equivalent if
  346. <code>!c(x,y)&amp;&amp;!c(y,x)</code> for <code>c</code> of type <code>Compare</code>.
  347. The default argument of <code>Compare</code> is <code>std::less&lt;Key&gt;</code>.
  348. <code>Allocator</code> must be an allocator of <code>Entry</code> objects
  349. satisfying the associated C++ requirements at <b>[lib.allocator.requirements]</b>.
  350. The default argument is <code>std::allocator&lt;Entry&gt;</code>. The internal
  351. container upon which <code>set_factory_class</code> is based is
  352. constructed with default initialized objects of type <code>Compare</code>
  353. and <code>Allocator</code>.
  354. </p>
  355. <h3><a name="set_factory">Class template <code>set_factory</code></a></h3>
  356. <p>
  357. <a href="#factory"><code>Factory Specifier</code></a> for <a href="#set_factory_class"><code>set_factory_class</code></a>.
  358. </p>
  359. <blockquote><pre>
  360. <span class=keyword>template</span><span class=special>&lt;</span><span class=keyword>typename</span> <span class=identifier>Compare</span><span class=special>,</span><span class=keyword>typename</span> <span class=identifier>Allocator</span><span class=special>&gt;</span>
  361. <span class=keyword>struct</span> <span class=identifier>set_factory</span><span class=special>;</span>
  362. </pre></blockquote>
  363. <p>
  364. <code>set_factory&lt;Compare,Allocator&gt;</code> is an
  365. <a href="../../../mpl/doc/refmanual/metafunction-class.html"><code>MPL Metafunction
  366. Class</code></a> such that the type
  367. </p>
  368. <blockquote><pre>
  369. <span class=identifier>boost</span><span class=special>::</span><span class=identifier>mpl</span><span class=special>::</span><span class=identifier>apply</span><span class=special>&lt;</span>
  370. <span class=identifier>set_factory</span><span class=special>&lt;</span><span class=identifier>Compare</span><span class=special>,</span><span class=identifier>Allocator</span><span class=special>&gt;,</span>
  371. <span class=identifier>Entry</span><span class=special>,</span><span class=identifier>Key</span>
  372. <span class=special>&gt;::</span><span class=identifier>type</span>
  373. </pre></blockquote>
  374. <p>
  375. is the same as
  376. </p>
  377. <blockquote><pre>
  378. <span class=identifier>boost</span><span class=special>::</span><span class=identifier>mpl</span><span class=special>::</span><span class=identifier>apply</span><span class=special>&lt;</span>
  379. <span class=identifier>set_factory_class</span><span class=special>&lt;</span><span class=identifier>boost</span><span class=special>::</span><span class=identifier>mpl</span><span class=special>::</span><span class=identifier>_1</span><span class=special>,</span><span class=identifier>boost</span><span class=special>::</span><span class=identifier>mpl</span><span class=special>::</span><span class=identifier>_2</span><span class=special>,</span><span class=identifier>Compare</span><span class=special>,</span><span class=identifier>Allocator</span><span class=special>&gt;,</span>
  380. <span class=identifier>Entry</span><span class=special>,</span><span class=identifier>Key</span>
  381. <span class=special>&gt;::</span><span class=identifier>type</span>
  382. </pre></blockquote>
  383. <p>
  384. This implies that <code>Compare</code> and <code>Allocator</code>
  385. can be
  386. <a href="../../../mpl/doc/refmanual/placeholder-expression.html"><code>MPL
  387. Placeholder Expressions</code></a> resolving to the actual types used by
  388. <code>set_factory_class</code>.
  389. </p>
  390. <h2><a name="assoc_container_factory_fwd_synopsis">Header
  391. <a href="../../../../boost/flyweight/assoc_container_factory_fwd.hpp"><code>"boost/flyweight/assoc_container_factory_fwd.hpp"</code></a> synopsis</a></h2>
  392. <blockquote><pre>
  393. <span class=keyword>namespace</span> <span class=identifier>boost</span><span class=special>{</span>
  394. <span class=keyword>namespace</span> <span class=identifier>flyweights</span><span class=special>{</span>
  395. <span class=keyword>template</span><span class=special>&lt;</span><span class=keyword>typename</span> <span class=identifier>Container</span><span class=special>&gt;</span>
  396. <span class=keyword>class</span> <span class=identifier>assoc_container_factory_class</span><span class=special>;</span>
  397. <span class=keyword>template</span><span class=special>&lt;</span><span class=keyword>typename</span> <span class=identifier>ContainerSpecifier</span><span class=special>&gt;</span>
  398. <span class=keyword>struct</span> <span class=identifier>assoc_container_factory</span><span class=special>;</span>
  399. <span class=special>}</span> <span class=comment>// namespace boost::flyweights</span>
  400. <span class=special>}</span> <span class=comment>// namespace boost</span>
  401. </pre></blockquote>
  402. <p>
  403. <code>assoc_container_factory_fwd.hpp</code> forward declares the class templates
  404. <a href="#assoc_container_factory_class"><code>assoc_container_factory_class</code></a>
  405. and <a href="#assoc_container_factory"><code>assoc_container_factory</code></a>.
  406. </p>
  407. <h2><a name="assoc_container_factory_synopsis">Header
  408. <a href="../../../../boost/flyweight/assoc_container_factory.hpp"><code>"boost/flyweight/assoc_container_factory.hpp"</code></a> synopsis</a></h2>
  409. <h3><a name="assoc_container_factory_class">Class template <code>assoc_container_factory_class</code></a></h3>
  410. <p>
  411. <code>assoc_container_factory_class</code> wraps a suitable associative container
  412. to provide a <a href="#factory"><code>Factory</code></a> interface.
  413. </p>
  414. <blockquote><pre>
  415. <span class=keyword>template</span><span class=special>&lt;</span><span class=keyword>typename</span> <span class=identifier>Container</span><span class=special>&gt;</span>
  416. <span class=keyword>class</span> <span class=identifier>assoc_container_factory_class</span>
  417. <span class=special>{</span>
  418. <span class=keyword>public</span><span class=special>:</span>
  419. <span class=keyword>typedef</span> <span class=keyword>typename</span> <span class=identifier>Container</span><span class=special>::</span><span class=identifier>iterator</span> <span class=identifier>handle_type</span><span class=special>;</span>
  420. <span class=identifier>handle_type</span> <span class=identifier>insert</span><span class=special>(</span><span class=keyword>const</span> <span class=keyword>typename</span> <span class=identifier>Container</span><span class=special>::</span><span class=identifier>value_type</span><span class=special>&amp;</span> <span class=identifier>x</span><span class=special>);</span>
  421. <span class=keyword>void</span> <span class=identifier>erase</span><span class=special>(</span><span class=identifier>handle_type</span> <span class=identifier>h</span><span class=special>);</span>
  422. <span class=keyword>const</span> <span class=keyword>typename</span> <span class=identifier>Container</span><span class=special>::</span><span class=identifier>value_type</span><span class=special>&amp;</span> <span class=identifier>entry</span><span class=special>(</span><span class=identifier>handle_type</span> <span class=identifier>h</span><span class=special>);</span>
  423. <span class=special>};</span>
  424. </pre></blockquote>
  425. <p>
  426. <code>Container</code> must be an (ordered or unordered) associative container
  427. such that
  428. <ol>
  429. <li><code>Container::key_type</code> is the same as
  430. <code>Container::value_type</code> (which is the entry type associated to
  431. the factory).
  432. </li>
  433. <li>Unique keys (rather than equivalent keys) are supported.</li>
  434. <li><code>Container</code> is <i>stable</i>, i.e. its iterators are not
  435. invalidated upon insert or erase operations.</li>
  436. </ol>
  437. The equivalence relation associated to <code>assoc_container_factory_class</code>
  438. is the one induced by <code>Container</code>. If equivalence of elements
  439. of <code>Container::value_type</code> is determined solely on the basis of a
  440. type <code>value_type'</code> to which <code>value_type</code> is
  441. implicitly convertible, then <code>assoc_container_factory_class</code> is
  442. a factory of entries of type <code>value_type</code> implicitly associated to
  443. <code>value_type'</code>. For example, the instantiation
  444. </p>
  445. <blockquote><pre>
  446. <span class=identifier>assoc_container_factory_class</span><span class=special>&lt;</span>
  447. <span class=identifier>std</span><span class=special>::</span><span class=identifier>set</span><span class=special>&lt;</span><span class=identifier>derived</span><span class=special>,</span><span class=identifier>std</span><span class=special>::</span><span class=identifier>less</span><span class=special>&lt;</span><span class=identifier>base</span><span class=special>&gt;</span> <span class=special>&gt;</span> <span class=comment>// derived inherits from base</span>
  448. <span class=special>&gt;</span>
  449. </pre></blockquote>
  450. <p>
  451. is a factory of <code>derived</code> elements implicitly associated to
  452. <code>base</code>.
  453. </p>
  454. <h3><a name="assoc_container_factory">Class template <code>assoc_container_factory</code></a></h3>
  455. <p>
  456. <a href="#factory"><code>Factory Specifier</code></a> for <a href="#assoc_container_factory_class"><code>assoc_container_factory_class</code></a>.
  457. </p>
  458. <blockquote><pre>
  459. <span class=keyword>template</span><span class=special>&lt;</span><span class=keyword>typename</span> <span class=identifier>ContainerSpecifier</span><span class=special>&gt;</span>
  460. <span class=keyword>struct</span> <span class=identifier>assoc_container_factory</span><span class=special>;</span>
  461. </pre></blockquote>
  462. <p>
  463. <code>ContainerSpecifier</code> must be an
  464. <a href="../../../mpl/doc/refmanual/lambda-expression.html"><code>MPL Lambda
  465. Expression</code></a> resolving, when invoked with (<code>Entry</code>,
  466. <code>Key</code>), to a type <code>Container</code> such that
  467. <code>assoc_container_factory_class&lt;Container&gt;</code> is a factory
  468. of <code>Entry</code> elements implicitly associated to <code>Key</code>.
  469. </p>
  470. <hr>
  471. <div class="prev_link"><a href="tags.html"><img src="../prev.gif" alt="tags" border="0"><br>
  472. Tags
  473. </a></div>
  474. <div class="up_link"><a href="index.html"><img src="../up.gif" alt="Boost.Flyweight reference" border="0"><br>
  475. Boost.Flyweight reference
  476. </a></div>
  477. <div class="next_link"><a href="holders.html"><img src="../next.gif" alt="holders" border="0"><br>
  478. Holders
  479. </a></div><br clear="all" style="clear: all;">
  480. <br>
  481. <p>Revised April 24th 2019</p>
  482. <p>&copy; Copyright 2006-2019 Joaqu&iacute;n M L&oacute;pez Mu&ntilde;oz.
  483. Distributed under the Boost Software
  484. License, Version 1.0. (See accompanying file <a href="../../../../LICENSE_1_0.txt">
  485. LICENSE_1_0.txt</a> or copy at <a href="http://www.boost.org/LICENSE_1_0.txt">
  486. http://www.boost.org/LICENSE_1_0.txt</a>)
  487. </p>
  488. </body>
  489. </html>