Files
entt/dense__map_8hpp_source.html
2025-03-19 15:49:42 +01:00

1044 lines
195 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" lang="en-US">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=11"/>
<meta name="generator" content="Doxygen 1.13.2"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>EnTT: src/entt/container/dense_map.hpp Source File</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>
<script type="text/javascript" src="clipboard.js"></script>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript" src="cookie.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-awesome.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 id="projectrow">
<td id="projectalign">
<div id="projectname">EnTT<span id="projectnumber">&#160;3.15.0</span>
</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.13.2 -->
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
var searchBox = new SearchBox("searchBox", "search/",'.html');
/* @license-end */
</script>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
$(function() { codefold.init(0); });
/* @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:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
$(function() {
initMenu('',true,false,'search.php','Search',false);
$(function() { init_search(); });
});
/* @license-end */
</script>
<div id="main-nav"></div>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
$(function(){ initResizable(false); });
/* @license-end */
</script>
<!-- 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">
<div id="MSearchResults">
<div class="SRPage">
<div id="SRIndex">
<div id="SRResults"></div>
<div class="SRStatus" id="Loading">Loading...</div>
<div class="SRStatus" id="Searching">Searching...</div>
<div class="SRStatus" id="NoMatches">No Matches</div>
</div>
</div>
</div>
</div>
<div id="nav-path" class="navpath">
<ul>
<li class="navelem"><a class="el" href="dir_68267d1309a1af8e8297ef4c3efbcdba.html">src</a></li><li class="navelem"><a class="el" href="dir_66e9674e8206a335795995fa32a03c91.html">entt</a></li><li class="navelem"><a class="el" href="dir_7ec033ccd3859ebe4fcfc7c04a4d1ca0.html">container</a></li> </ul>
</div>
</div><!-- top -->
<div id="doc-content">
<div class="header">
<div class="headertitle"><div class="title">dense_map.hpp</div></div>
</div><!--header-->
<div class="contents">
<div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="preprocessor">#ifndef ENTT_CONTAINER_DENSE_MAP_HPP</span></div>
<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="preprocessor">#define ENTT_CONTAINER_DENSE_MAP_HPP</span></div>
<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span> </div>
<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="preprocessor">#include &lt;cmath&gt;</span></div>
<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="preprocessor">#include &lt;cstddef&gt;</span></div>
<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="preprocessor">#include &lt;functional&gt;</span></div>
<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="preprocessor">#include &lt;iterator&gt;</span></div>
<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span><span class="preprocessor">#include &lt;limits&gt;</span></div>
<div class="line"><a id="l00009" name="l00009"></a><span class="lineno"> 9</span><span class="preprocessor">#include &lt;memory&gt;</span></div>
<div class="line"><a id="l00010" name="l00010"></a><span class="lineno"> 10</span><span class="preprocessor">#include &lt;tuple&gt;</span></div>
<div class="line"><a id="l00011" name="l00011"></a><span class="lineno"> 11</span><span class="preprocessor">#include &lt;type_traits&gt;</span></div>
<div class="line"><a id="l00012" name="l00012"></a><span class="lineno"> 12</span><span class="preprocessor">#include &lt;utility&gt;</span></div>
<div class="line"><a id="l00013" name="l00013"></a><span class="lineno"> 13</span><span class="preprocessor">#include &lt;vector&gt;</span></div>
<div class="line"><a id="l00014" name="l00014"></a><span class="lineno"> 14</span><span class="preprocessor">#include &quot;../config/config.h&quot;</span></div>
<div class="line"><a id="l00015" name="l00015"></a><span class="lineno"> 15</span><span class="preprocessor">#include &quot;../core/bit.hpp&quot;</span></div>
<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="preprocessor">#include &quot;../core/compressed_pair.hpp&quot;</span></div>
<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="preprocessor">#include &quot;../core/iterator.hpp&quot;</span></div>
<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="preprocessor">#include &quot;../core/memory.hpp&quot;</span></div>
<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#include &quot;../core/type_traits.hpp&quot;</span></div>
<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span><span class="preprocessor">#include &quot;fwd.hpp&quot;</span></div>
<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span> </div>
<div class="foldopen" id="foldopen00022" data-start="{" data-end="}">
<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"><a class="line" href="namespaceentt.html"> 22</a></span><span class="keyword">namespace </span><a class="code hl_namespace" href="namespaceentt.html">entt</a> {</div>
<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span></div>
<div class="line"><a id="l00025" name="l00025"></a><span class="lineno"> 25</span><span class="keyword">namespace </span>internal {</div>
<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span> </div>
<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"> 27</span><span class="keyword">template</span>&lt;<span class="keyword">typename</span> Key, <span class="keyword">typename</span> Type&gt;</div>
<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"> 28</span><span class="keyword">struct </span>dense_map_node final {</div>
<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"> 29</span> <span class="keyword">using </span>value_type = std::pair&lt;Key, Type&gt;;</div>
<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"> 30</span> </div>
<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"> 31</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span>... Args&gt;</div>
<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span> dense_map_node(<span class="keyword">const</span> std::size_t pos, Args &amp;&amp;...args)</div>
<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span> : next{pos},</div>
<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span> element{std::forward&lt;Args&gt;(args)...} {}</div>
<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span> </div>
<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Allocator, <span class="keyword">typename</span>... Args&gt;</div>
<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"> 37</span> dense_map_node(std::allocator_arg_t, <span class="keyword">const</span> Allocator &amp;allocator, <span class="keyword">const</span> std::size_t pos, Args &amp;&amp;...args)</div>
<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"> 38</span> : next{pos},</div>
<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"> 39</span> element{<a class="code hl_function" href="namespaceentt.html#a12e4d0c58f9c4cc6f5513c39c530b9b7">entt::make_obj_using_allocator&lt;value_type&gt;</a>(allocator, std::forward&lt;Args&gt;(args)...)} {}</div>
<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"> 40</span> </div>
<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"> 41</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Allocator&gt;</div>
<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"> 42</span> dense_map_node(std::allocator_arg_t, <span class="keyword">const</span> Allocator &amp;allocator, <span class="keyword">const</span> dense_map_node &amp;other)</div>
<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"> 43</span> : next{other.next},</div>
<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"> 44</span> element{<a class="code hl_function" href="namespaceentt.html#a12e4d0c58f9c4cc6f5513c39c530b9b7">entt::make_obj_using_allocator&lt;value_type&gt;</a>(allocator, other.element)} {}</div>
<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"> 45</span> </div>
<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"> 46</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Allocator&gt;</div>
<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"> 47</span> dense_map_node(std::allocator_arg_t, <span class="keyword">const</span> Allocator &amp;allocator, dense_map_node &amp;&amp;other)</div>
<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span> : next{other.next},</div>
<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"> 49</span> element{<a class="code hl_function" href="namespaceentt.html#a12e4d0c58f9c4cc6f5513c39c530b9b7">entt::make_obj_using_allocator&lt;value_type&gt;</a>(allocator, std::move(other.element))} {}</div>
<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"> 50</span> </div>
<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"> 51</span> std::size_t next;</div>
<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"> 52</span> value_type element;</div>
<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"> 53</span>};</div>
<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span> </div>
<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"> 55</span><span class="keyword">template</span>&lt;<span class="keyword">typename</span> It&gt;</div>
<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"> 56</span><span class="keyword">class </span>dense_map_iterator final {</div>
<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"> 57</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span>&gt;</div>
<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"> 58</span> <span class="keyword">friend</span> <span class="keyword">class </span>dense_map_iterator;</div>
<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"> 59</span> </div>
<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"> 60</span> <span class="keyword">using </span>first_type = <span class="keyword">decltype</span>(std::as_const(std::declval&lt;It&gt;()-&gt;element.first));</div>
<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"> 61</span> <span class="keyword">using </span>second_type = <span class="keyword">decltype</span>((std::declval&lt;It&gt;()-&gt;element.second));</div>
<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"> 62</span> </div>
<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"> 63</span><span class="keyword">public</span>:</div>
<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"> 64</span> <span class="keyword">using </span>value_type = std::pair&lt;first_type, second_type&gt;;</div>
<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"> 65</span> <span class="keyword">using </span>pointer = <a class="code hl_struct" href="structentt_1_1input__iterator__pointer.html">input_iterator_pointer&lt;value_type&gt;</a>;</div>
<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"> 66</span> <span class="keyword">using </span>reference = value_type;</div>
<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span> <span class="keyword">using </span>difference_type = std::ptrdiff_t;</div>
<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"> 68</span> <span class="keyword">using </span>iterator_category = std::input_iterator_tag;</div>
<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"> 69</span> <span class="keyword">using </span>iterator_concept = std::random_access_iterator_tag;</div>
<div class="line"><a id="l00070" name="l00070"></a><span class="lineno"> 70</span> </div>
<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"> 71</span> <span class="keyword">constexpr</span> dense_map_iterator() noexcept</div>
<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"> 72</span> : it{} {}</div>
<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"> 73</span> </div>
<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"> 74</span> <span class="keyword">constexpr</span> dense_map_iterator(<span class="keyword">const</span> It iter) noexcept</div>
<div class="line"><a id="l00075" name="l00075"></a><span class="lineno"> 75</span> : it{iter} {}</div>
<div class="line"><a id="l00076" name="l00076"></a><span class="lineno"> 76</span> </div>
<div class="line"><a id="l00077" name="l00077"></a><span class="lineno"> 77</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Other, <span class="keyword">typename</span> = std::enable_if_t&lt;!std::is_same_v&lt;It, Other&gt; &amp;&amp; std::is_constructible_v&lt;It, Other&gt;&gt;&gt;</div>
<div class="line"><a id="l00078" name="l00078"></a><span class="lineno"> 78</span> <span class="keyword">constexpr</span> dense_map_iterator(<span class="keyword">const</span> dense_map_iterator&lt;Other&gt; &amp;other) noexcept</div>
<div class="line"><a id="l00079" name="l00079"></a><span class="lineno"> 79</span> : it{other.it} {}</div>
<div class="line"><a id="l00080" name="l00080"></a><span class="lineno"> 80</span> </div>
<div class="line"><a id="l00081" name="l00081"></a><span class="lineno"> 81</span> <span class="keyword">constexpr</span> dense_map_iterator &amp;operator++() <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"> 82</span> <span class="keywordflow">return</span> ++it, *<span class="keyword">this</span>;</div>
<div class="line"><a id="l00083" name="l00083"></a><span class="lineno"> 83</span> }</div>
<div class="line"><a id="l00084" name="l00084"></a><span class="lineno"> 84</span> </div>
<div class="line"><a id="l00085" name="l00085"></a><span class="lineno"> 85</span> <span class="keyword">constexpr</span> dense_map_iterator operator++(<span class="keywordtype">int</span>) <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00086" name="l00086"></a><span class="lineno"> 86</span> <span class="keyword">const</span> dense_map_iterator orig = *<span class="keyword">this</span>;</div>
<div class="line"><a id="l00087" name="l00087"></a><span class="lineno"> 87</span> <span class="keywordflow">return</span> ++(*this), orig;</div>
<div class="line"><a id="l00088" name="l00088"></a><span class="lineno"> 88</span> }</div>
<div class="line"><a id="l00089" name="l00089"></a><span class="lineno"> 89</span> </div>
<div class="line"><a id="l00090" name="l00090"></a><span class="lineno"> 90</span> <span class="keyword">constexpr</span> dense_map_iterator &amp;operator--() <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00091" name="l00091"></a><span class="lineno"> 91</span> <span class="keywordflow">return</span> --it, *<span class="keyword">this</span>;</div>
<div class="line"><a id="l00092" name="l00092"></a><span class="lineno"> 92</span> }</div>
<div class="line"><a id="l00093" name="l00093"></a><span class="lineno"> 93</span> </div>
<div class="line"><a id="l00094" name="l00094"></a><span class="lineno"> 94</span> <span class="keyword">constexpr</span> dense_map_iterator operator--(<span class="keywordtype">int</span>) <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00095" name="l00095"></a><span class="lineno"> 95</span> <span class="keyword">const</span> dense_map_iterator orig = *<span class="keyword">this</span>;</div>
<div class="line"><a id="l00096" name="l00096"></a><span class="lineno"> 96</span> <span class="keywordflow">return</span> operator--(), orig;</div>
<div class="line"><a id="l00097" name="l00097"></a><span class="lineno"> 97</span> }</div>
<div class="line"><a id="l00098" name="l00098"></a><span class="lineno"> 98</span> </div>
<div class="line"><a id="l00099" name="l00099"></a><span class="lineno"> 99</span> <span class="keyword">constexpr</span> dense_map_iterator &amp;operator+=(<span class="keyword">const</span> difference_type value) <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00100" name="l00100"></a><span class="lineno"> 100</span> it += value;</div>
<div class="line"><a id="l00101" name="l00101"></a><span class="lineno"> 101</span> <span class="keywordflow">return</span> *<span class="keyword">this</span>;</div>
<div class="line"><a id="l00102" name="l00102"></a><span class="lineno"> 102</span> }</div>
<div class="line"><a id="l00103" name="l00103"></a><span class="lineno"> 103</span> </div>
<div class="line"><a id="l00104" name="l00104"></a><span class="lineno"> 104</span> <span class="keyword">constexpr</span> dense_map_iterator <a class="code hl_function" href="namespaceentt.html#ab36ceb26049f62c07817a385e35395f6">operator+</a>(<span class="keyword">const</span> difference_type value) <span class="keyword">const</span> <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00105" name="l00105"></a><span class="lineno"> 105</span> dense_map_iterator copy = *<span class="keyword">this</span>;</div>
<div class="line"><a id="l00106" name="l00106"></a><span class="lineno"> 106</span> <span class="keywordflow">return</span> (copy += value);</div>
<div class="line"><a id="l00107" name="l00107"></a><span class="lineno"> 107</span> }</div>
<div class="line"><a id="l00108" name="l00108"></a><span class="lineno"> 108</span> </div>
<div class="line"><a id="l00109" name="l00109"></a><span class="lineno"> 109</span> <span class="keyword">constexpr</span> dense_map_iterator &amp;operator-=(<span class="keyword">const</span> difference_type value) <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00110" name="l00110"></a><span class="lineno"> 110</span> <span class="keywordflow">return</span> (*<span class="keyword">this</span> += -value);</div>
<div class="line"><a id="l00111" name="l00111"></a><span class="lineno"> 111</span> }</div>
<div class="line"><a id="l00112" name="l00112"></a><span class="lineno"> 112</span> </div>
<div class="line"><a id="l00113" name="l00113"></a><span class="lineno"> 113</span> <span class="keyword">constexpr</span> dense_map_iterator operator-(<span class="keyword">const</span> difference_type value) <span class="keyword">const</span> <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00114" name="l00114"></a><span class="lineno"> 114</span> <span class="keywordflow">return</span> (*<span class="keyword">this</span> + -value);</div>
<div class="line"><a id="l00115" name="l00115"></a><span class="lineno"> 115</span> }</div>
<div class="line"><a id="l00116" name="l00116"></a><span class="lineno"> 116</span> </div>
<div class="line"><a id="l00117" name="l00117"></a><span class="lineno"> 117</span> [[nodiscard]] <span class="keyword">constexpr</span> reference operator[](<span class="keyword">const</span> difference_type value) <span class="keyword">const</span> <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00118" name="l00118"></a><span class="lineno"> 118</span> <span class="keywordflow">return</span> {it[value].element.first, it[value].element.second};</div>
<div class="line"><a id="l00119" name="l00119"></a><span class="lineno"> 119</span> }</div>
<div class="line"><a id="l00120" name="l00120"></a><span class="lineno"> 120</span> </div>
<div class="line"><a id="l00121" name="l00121"></a><span class="lineno"> 121</span> [[nodiscard]] <span class="keyword">constexpr</span> pointer operator-&gt;() <span class="keyword">const</span> <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00122" name="l00122"></a><span class="lineno"> 122</span> <span class="keywordflow">return</span> operator*();</div>
<div class="line"><a id="l00123" name="l00123"></a><span class="lineno"> 123</span> }</div>
<div class="line"><a id="l00124" name="l00124"></a><span class="lineno"> 124</span> </div>
<div class="line"><a id="l00125" name="l00125"></a><span class="lineno"> 125</span> [[nodiscard]] <span class="keyword">constexpr</span> reference operator*() <span class="keyword">const</span> <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00126" name="l00126"></a><span class="lineno"> 126</span> <span class="keywordflow">return</span> operator[](0);</div>
<div class="line"><a id="l00127" name="l00127"></a><span class="lineno"> 127</span> }</div>
<div class="line"><a id="l00128" name="l00128"></a><span class="lineno"> 128</span> </div>
<div class="line"><a id="l00129" name="l00129"></a><span class="lineno"> 129</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Lhs, <span class="keyword">typename</span> Rhs&gt;</div>
<div class="line"><a id="l00130" name="l00130"></a><span class="lineno"> 130</span> <span class="keyword">friend</span> <span class="keyword">constexpr</span> std::ptrdiff_t operator-(<span class="keyword">const</span> dense_map_iterator&lt;Lhs&gt; &amp;, <span class="keyword">const</span> dense_map_iterator&lt;Rhs&gt; &amp;) <span class="keyword">noexcept</span>;</div>
<div class="line"><a id="l00131" name="l00131"></a><span class="lineno"> 131</span> </div>
<div class="line"><a id="l00132" name="l00132"></a><span class="lineno"> 132</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Lhs, <span class="keyword">typename</span> Rhs&gt;</div>
<div class="line"><a id="l00133" name="l00133"></a><span class="lineno"> 133</span> <span class="keyword">friend</span> <span class="keyword">constexpr</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="namespaceentt.html#af7c61951b721a1e3612cf536bd707501">operator==</a>(<span class="keyword">const</span> dense_map_iterator&lt;Lhs&gt; &amp;, <span class="keyword">const</span> dense_map_iterator&lt;Rhs&gt; &amp;) <span class="keyword">noexcept</span>;</div>
<div class="line"><a id="l00134" name="l00134"></a><span class="lineno"> 134</span> </div>
<div class="line"><a id="l00135" name="l00135"></a><span class="lineno"> 135</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Lhs, <span class="keyword">typename</span> Rhs&gt;</div>
<div class="line"><a id="l00136" name="l00136"></a><span class="lineno"> 136</span> <span class="keyword">friend</span> <span class="keyword">constexpr</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="namespaceentt.html#aa88e297d57dd5547afcde8dd291c4b8f">operator&lt;</a>(<span class="keyword">const</span> dense_map_iterator&lt;Lhs&gt; &amp;, <span class="keyword">const</span> dense_map_iterator&lt;Rhs&gt; &amp;) <span class="keyword">noexcept</span>;</div>
<div class="line"><a id="l00137" name="l00137"></a><span class="lineno"> 137</span> </div>
<div class="line"><a id="l00138" name="l00138"></a><span class="lineno"> 138</span><span class="keyword">private</span>:</div>
<div class="line"><a id="l00139" name="l00139"></a><span class="lineno"> 139</span> It it;</div>
<div class="line"><a id="l00140" name="l00140"></a><span class="lineno"> 140</span>};</div>
<div class="line"><a id="l00141" name="l00141"></a><span class="lineno"> 141</span> </div>
<div class="line"><a id="l00142" name="l00142"></a><span class="lineno"> 142</span><span class="keyword">template</span>&lt;<span class="keyword">typename</span> Lhs, <span class="keyword">typename</span> Rhs&gt;</div>
<div class="line"><a id="l00143" name="l00143"></a><span class="lineno"> 143</span>[[nodiscard]] <span class="keyword">constexpr</span> std::ptrdiff_t operator-(<span class="keyword">const</span> dense_map_iterator&lt;Lhs&gt; &amp;lhs, <span class="keyword">const</span> dense_map_iterator&lt;Rhs&gt; &amp;rhs) <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00144" name="l00144"></a><span class="lineno"> 144</span> <span class="keywordflow">return</span> lhs.it - rhs.it;</div>
<div class="line"><a id="l00145" name="l00145"></a><span class="lineno"> 145</span>}</div>
<div class="line"><a id="l00146" name="l00146"></a><span class="lineno"> 146</span> </div>
<div class="line"><a id="l00147" name="l00147"></a><span class="lineno"> 147</span><span class="keyword">template</span>&lt;<span class="keyword">typename</span> Lhs, <span class="keyword">typename</span> Rhs&gt;</div>
<div class="line"><a id="l00148" name="l00148"></a><span class="lineno"> 148</span>[[nodiscard]] <span class="keyword">constexpr</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="namespaceentt.html#af7c61951b721a1e3612cf536bd707501">operator==</a>(<span class="keyword">const</span> dense_map_iterator&lt;Lhs&gt; &amp;lhs, <span class="keyword">const</span> dense_map_iterator&lt;Rhs&gt; &amp;rhs) <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00149" name="l00149"></a><span class="lineno"> 149</span> <span class="keywordflow">return</span> lhs.it == rhs.it;</div>
<div class="line"><a id="l00150" name="l00150"></a><span class="lineno"> 150</span>}</div>
<div class="line"><a id="l00151" name="l00151"></a><span class="lineno"> 151</span> </div>
<div class="line"><a id="l00152" name="l00152"></a><span class="lineno"> 152</span><span class="keyword">template</span>&lt;<span class="keyword">typename</span> Lhs, <span class="keyword">typename</span> Rhs&gt;</div>
<div class="line"><a id="l00153" name="l00153"></a><span class="lineno"> 153</span>[[nodiscard]] <span class="keyword">constexpr</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="namespaceentt.html#ad9accc71a383509ada028f7fa2b767bf">operator!=</a>(<span class="keyword">const</span> dense_map_iterator&lt;Lhs&gt; &amp;lhs, <span class="keyword">const</span> dense_map_iterator&lt;Rhs&gt; &amp;rhs) <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00154" name="l00154"></a><span class="lineno"> 154</span> <span class="keywordflow">return</span> !(lhs == rhs);</div>
<div class="line"><a id="l00155" name="l00155"></a><span class="lineno"> 155</span>}</div>
<div class="line"><a id="l00156" name="l00156"></a><span class="lineno"> 156</span> </div>
<div class="line"><a id="l00157" name="l00157"></a><span class="lineno"> 157</span><span class="keyword">template</span>&lt;<span class="keyword">typename</span> Lhs, <span class="keyword">typename</span> Rhs&gt;</div>
<div class="line"><a id="l00158" name="l00158"></a><span class="lineno"> 158</span>[[nodiscard]] <span class="keyword">constexpr</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="namespaceentt.html#aa88e297d57dd5547afcde8dd291c4b8f">operator&lt;</a>(<span class="keyword">const</span> dense_map_iterator&lt;Lhs&gt; &amp;lhs, <span class="keyword">const</span> dense_map_iterator&lt;Rhs&gt; &amp;rhs) <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00159" name="l00159"></a><span class="lineno"> 159</span> <span class="keywordflow">return</span> lhs.it &lt; rhs.it;</div>
<div class="line"><a id="l00160" name="l00160"></a><span class="lineno"> 160</span>}</div>
<div class="line"><a id="l00161" name="l00161"></a><span class="lineno"> 161</span> </div>
<div class="line"><a id="l00162" name="l00162"></a><span class="lineno"> 162</span><span class="keyword">template</span>&lt;<span class="keyword">typename</span> Lhs, <span class="keyword">typename</span> Rhs&gt;</div>
<div class="line"><a id="l00163" name="l00163"></a><span class="lineno"> 163</span>[[nodiscard]] <span class="keyword">constexpr</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="namespaceentt.html#aec8131af000055ceab85646c14f234ad">operator&gt;</a>(<span class="keyword">const</span> dense_map_iterator&lt;Lhs&gt; &amp;lhs, <span class="keyword">const</span> dense_map_iterator&lt;Rhs&gt; &amp;rhs) <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00164" name="l00164"></a><span class="lineno"> 164</span> <span class="keywordflow">return</span> rhs &lt; lhs;</div>
<div class="line"><a id="l00165" name="l00165"></a><span class="lineno"> 165</span>}</div>
<div class="line"><a id="l00166" name="l00166"></a><span class="lineno"> 166</span> </div>
<div class="line"><a id="l00167" name="l00167"></a><span class="lineno"> 167</span><span class="keyword">template</span>&lt;<span class="keyword">typename</span> Lhs, <span class="keyword">typename</span> Rhs&gt;</div>
<div class="line"><a id="l00168" name="l00168"></a><span class="lineno"> 168</span>[[nodiscard]] <span class="keyword">constexpr</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="namespaceentt.html#a8c763e890bb00479a6a6aeae3b2a75f0">operator&lt;=</a>(<span class="keyword">const</span> dense_map_iterator&lt;Lhs&gt; &amp;lhs, <span class="keyword">const</span> dense_map_iterator&lt;Rhs&gt; &amp;rhs) <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00169" name="l00169"></a><span class="lineno"> 169</span> <span class="keywordflow">return</span> !(lhs &gt; rhs);</div>
<div class="line"><a id="l00170" name="l00170"></a><span class="lineno"> 170</span>}</div>
<div class="line"><a id="l00171" name="l00171"></a><span class="lineno"> 171</span> </div>
<div class="line"><a id="l00172" name="l00172"></a><span class="lineno"> 172</span><span class="keyword">template</span>&lt;<span class="keyword">typename</span> Lhs, <span class="keyword">typename</span> Rhs&gt;</div>
<div class="line"><a id="l00173" name="l00173"></a><span class="lineno"> 173</span>[[nodiscard]] <span class="keyword">constexpr</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="namespaceentt.html#adadb88dfb4278df554e7ffec5361ece4">operator&gt;=</a>(<span class="keyword">const</span> dense_map_iterator&lt;Lhs&gt; &amp;lhs, <span class="keyword">const</span> dense_map_iterator&lt;Rhs&gt; &amp;rhs) <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00174" name="l00174"></a><span class="lineno"> 174</span> <span class="keywordflow">return</span> !(lhs &lt; rhs);</div>
<div class="line"><a id="l00175" name="l00175"></a><span class="lineno"> 175</span>}</div>
<div class="line"><a id="l00176" name="l00176"></a><span class="lineno"> 176</span> </div>
<div class="line"><a id="l00177" name="l00177"></a><span class="lineno"> 177</span><span class="keyword">template</span>&lt;<span class="keyword">typename</span> It&gt;</div>
<div class="line"><a id="l00178" name="l00178"></a><span class="lineno"> 178</span><span class="keyword">class </span>dense_map_local_iterator final {</div>
<div class="line"><a id="l00179" name="l00179"></a><span class="lineno"> 179</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span>&gt;</div>
<div class="line"><a id="l00180" name="l00180"></a><span class="lineno"> 180</span> <span class="keyword">friend</span> <span class="keyword">class </span>dense_map_local_iterator;</div>
<div class="line"><a id="l00181" name="l00181"></a><span class="lineno"> 181</span> </div>
<div class="line"><a id="l00182" name="l00182"></a><span class="lineno"> 182</span> <span class="keyword">using </span>first_type = <span class="keyword">decltype</span>(std::as_const(std::declval&lt;It&gt;()-&gt;element.first));</div>
<div class="line"><a id="l00183" name="l00183"></a><span class="lineno"> 183</span> <span class="keyword">using </span>second_type = <span class="keyword">decltype</span>((std::declval&lt;It&gt;()-&gt;element.second));</div>
<div class="line"><a id="l00184" name="l00184"></a><span class="lineno"> 184</span> </div>
<div class="line"><a id="l00185" name="l00185"></a><span class="lineno"> 185</span><span class="keyword">public</span>:</div>
<div class="line"><a id="l00186" name="l00186"></a><span class="lineno"> 186</span> <span class="keyword">using </span>value_type = std::pair&lt;first_type, second_type&gt;;</div>
<div class="line"><a id="l00187" name="l00187"></a><span class="lineno"> 187</span> <span class="keyword">using </span>pointer = <a class="code hl_struct" href="structentt_1_1input__iterator__pointer.html">input_iterator_pointer&lt;value_type&gt;</a>;</div>
<div class="line"><a id="l00188" name="l00188"></a><span class="lineno"> 188</span> <span class="keyword">using </span>reference = value_type;</div>
<div class="line"><a id="l00189" name="l00189"></a><span class="lineno"> 189</span> <span class="keyword">using </span>difference_type = std::ptrdiff_t;</div>
<div class="line"><a id="l00190" name="l00190"></a><span class="lineno"> 190</span> <span class="keyword">using </span>iterator_category = std::input_iterator_tag;</div>
<div class="line"><a id="l00191" name="l00191"></a><span class="lineno"> 191</span> <span class="keyword">using </span>iterator_concept = std::forward_iterator_tag;</div>
<div class="line"><a id="l00192" name="l00192"></a><span class="lineno"> 192</span> </div>
<div class="line"><a id="l00193" name="l00193"></a><span class="lineno"> 193</span> <span class="keyword">constexpr</span> dense_map_local_iterator() noexcept</div>
<div class="line"><a id="l00194" name="l00194"></a><span class="lineno"> 194</span> : it{},</div>
<div class="line"><a id="l00195" name="l00195"></a><span class="lineno"> 195</span> offset{} {}</div>
<div class="line"><a id="l00196" name="l00196"></a><span class="lineno"> 196</span> </div>
<div class="line"><a id="l00197" name="l00197"></a><span class="lineno"> 197</span> <span class="keyword">constexpr</span> dense_map_local_iterator(It iter, <span class="keyword">const</span> std::size_t pos) noexcept</div>
<div class="line"><a id="l00198" name="l00198"></a><span class="lineno"> 198</span> : it{iter},</div>
<div class="line"><a id="l00199" name="l00199"></a><span class="lineno"> 199</span> offset{pos} {}</div>
<div class="line"><a id="l00200" name="l00200"></a><span class="lineno"> 200</span> </div>
<div class="line"><a id="l00201" name="l00201"></a><span class="lineno"> 201</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Other, <span class="keyword">typename</span> = std::enable_if_t&lt;!std::is_same_v&lt;It, Other&gt; &amp;&amp; std::is_constructible_v&lt;It, Other&gt;&gt;&gt;</div>
<div class="line"><a id="l00202" name="l00202"></a><span class="lineno"> 202</span> <span class="keyword">constexpr</span> dense_map_local_iterator(<span class="keyword">const</span> dense_map_local_iterator&lt;Other&gt; &amp;other) noexcept</div>
<div class="line"><a id="l00203" name="l00203"></a><span class="lineno"> 203</span> : it{other.it},</div>
<div class="line"><a id="l00204" name="l00204"></a><span class="lineno"> 204</span> offset{other.offset} {}</div>
<div class="line"><a id="l00205" name="l00205"></a><span class="lineno"> 205</span> </div>
<div class="line"><a id="l00206" name="l00206"></a><span class="lineno"> 206</span> <span class="keyword">constexpr</span> dense_map_local_iterator &amp;operator++() <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00207" name="l00207"></a><span class="lineno"> 207</span> <span class="keywordflow">return</span> (offset = it[<span class="keyword">static_cast&lt;</span>typename It::difference_type<span class="keyword">&gt;</span>(offset)].next), *<span class="keyword">this</span>;</div>
<div class="line"><a id="l00208" name="l00208"></a><span class="lineno"> 208</span> }</div>
<div class="line"><a id="l00209" name="l00209"></a><span class="lineno"> 209</span> </div>
<div class="line"><a id="l00210" name="l00210"></a><span class="lineno"> 210</span> <span class="keyword">constexpr</span> dense_map_local_iterator operator++(<span class="keywordtype">int</span>) <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00211" name="l00211"></a><span class="lineno"> 211</span> <span class="keyword">const</span> dense_map_local_iterator orig = *<span class="keyword">this</span>;</div>
<div class="line"><a id="l00212" name="l00212"></a><span class="lineno"> 212</span> <span class="keywordflow">return</span> ++(*this), orig;</div>
<div class="line"><a id="l00213" name="l00213"></a><span class="lineno"> 213</span> }</div>
<div class="line"><a id="l00214" name="l00214"></a><span class="lineno"> 214</span> </div>
<div class="line"><a id="l00215" name="l00215"></a><span class="lineno"> 215</span> [[nodiscard]] <span class="keyword">constexpr</span> pointer operator-&gt;() <span class="keyword">const</span> <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00216" name="l00216"></a><span class="lineno"> 216</span> <span class="keywordflow">return</span> operator*();</div>
<div class="line"><a id="l00217" name="l00217"></a><span class="lineno"> 217</span> }</div>
<div class="line"><a id="l00218" name="l00218"></a><span class="lineno"> 218</span> </div>
<div class="line"><a id="l00219" name="l00219"></a><span class="lineno"> 219</span> [[nodiscard]] <span class="keyword">constexpr</span> reference operator*() <span class="keyword">const</span> <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00220" name="l00220"></a><span class="lineno"> 220</span> <span class="keyword">const</span> <span class="keyword">auto</span> idx = <span class="keyword">static_cast&lt;</span>typename It::difference_type<span class="keyword">&gt;</span>(offset);</div>
<div class="line"><a id="l00221" name="l00221"></a><span class="lineno"> 221</span> <span class="keywordflow">return</span> {it[idx].element.first, it[idx].element.second};</div>
<div class="line"><a id="l00222" name="l00222"></a><span class="lineno"> 222</span> }</div>
<div class="line"><a id="l00223" name="l00223"></a><span class="lineno"> 223</span> </div>
<div class="line"><a id="l00224" name="l00224"></a><span class="lineno"> 224</span> [[nodiscard]] <span class="keyword">constexpr</span> std::size_t index() <span class="keyword">const</span> <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00225" name="l00225"></a><span class="lineno"> 225</span> <span class="keywordflow">return</span> offset;</div>
<div class="line"><a id="l00226" name="l00226"></a><span class="lineno"> 226</span> }</div>
<div class="line"><a id="l00227" name="l00227"></a><span class="lineno"> 227</span> </div>
<div class="line"><a id="l00228" name="l00228"></a><span class="lineno"> 228</span><span class="keyword">private</span>:</div>
<div class="line"><a id="l00229" name="l00229"></a><span class="lineno"> 229</span> It it;</div>
<div class="line"><a id="l00230" name="l00230"></a><span class="lineno"> 230</span> std::size_t offset;</div>
<div class="line"><a id="l00231" name="l00231"></a><span class="lineno"> 231</span>};</div>
<div class="line"><a id="l00232" name="l00232"></a><span class="lineno"> 232</span> </div>
<div class="line"><a id="l00233" name="l00233"></a><span class="lineno"> 233</span><span class="keyword">template</span>&lt;<span class="keyword">typename</span> Lhs, <span class="keyword">typename</span> Rhs&gt;</div>
<div class="line"><a id="l00234" name="l00234"></a><span class="lineno"> 234</span>[[nodiscard]] <span class="keyword">constexpr</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="namespaceentt.html#af7c61951b721a1e3612cf536bd707501">operator==</a>(<span class="keyword">const</span> dense_map_local_iterator&lt;Lhs&gt; &amp;lhs, <span class="keyword">const</span> dense_map_local_iterator&lt;Rhs&gt; &amp;rhs) <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00235" name="l00235"></a><span class="lineno"> 235</span> <span class="keywordflow">return</span> lhs.index() == rhs.index();</div>
<div class="line"><a id="l00236" name="l00236"></a><span class="lineno"> 236</span>}</div>
<div class="line"><a id="l00237" name="l00237"></a><span class="lineno"> 237</span> </div>
<div class="line"><a id="l00238" name="l00238"></a><span class="lineno"> 238</span><span class="keyword">template</span>&lt;<span class="keyword">typename</span> Lhs, <span class="keyword">typename</span> Rhs&gt;</div>
<div class="line"><a id="l00239" name="l00239"></a><span class="lineno"> 239</span>[[nodiscard]] <span class="keyword">constexpr</span> <span class="keywordtype">bool</span> <a class="code hl_function" href="namespaceentt.html#ad9accc71a383509ada028f7fa2b767bf">operator!=</a>(<span class="keyword">const</span> dense_map_local_iterator&lt;Lhs&gt; &amp;lhs, <span class="keyword">const</span> dense_map_local_iterator&lt;Rhs&gt; &amp;rhs) <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00240" name="l00240"></a><span class="lineno"> 240</span> <span class="keywordflow">return</span> !(lhs == rhs);</div>
<div class="line"><a id="l00241" name="l00241"></a><span class="lineno"> 241</span>}</div>
<div class="line"><a id="l00242" name="l00242"></a><span class="lineno"> 242</span> </div>
<div class="line"><a id="l00243" name="l00243"></a><span class="lineno"> 243</span>} <span class="comment">// namespace internal</span></div>
<div class="line"><a id="l00245" name="l00245"></a><span class="lineno"> 245</span></div>
<div class="line"><a id="l00259" name="l00259"></a><span class="lineno"> 259</span><span class="keyword">template</span>&lt;<span class="keyword">typename</span> Key, <span class="keyword">typename</span> Type, <span class="keyword">typename</span> Hash, <span class="keyword">typename</span> KeyEqual, <span class="keyword">typename</span> Allocator&gt;</div>
<div class="foldopen" id="foldopen00260" data-start="{" data-end="};">
<div class="line"><a id="l00260" name="l00260"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html"> 260</a></span><span class="keyword">class </span><a class="code hl_function" href="classentt_1_1dense__map.html#af163bec2cf56f3571000a5fc0145832f">dense_map</a> {</div>
<div class="line"><a id="l00261" name="l00261"></a><span class="lineno"> 261</span> <span class="keyword">static</span> <span class="keyword">constexpr</span> <span class="keywordtype">float</span> default_threshold = 0.875f;</div>
<div class="line"><a id="l00262" name="l00262"></a><span class="lineno"> 262</span> <span class="keyword">static</span> <span class="keyword">constexpr</span> std::size_t minimum_capacity = 8u;</div>
<div class="line"><a id="l00263" name="l00263"></a><span class="lineno"> 263</span> </div>
<div class="line"><a id="l00264" name="l00264"></a><span class="lineno"> 264</span> <span class="keyword">using </span>node_type = internal::dense_map_node&lt;Key, Type&gt;;</div>
<div class="line"><a id="l00265" name="l00265"></a><span class="lineno"> 265</span> <span class="keyword">using </span>alloc_traits = std::allocator_traits&lt;Allocator&gt;;</div>
<div class="line"><a id="l00266" name="l00266"></a><span class="lineno"> 266</span> <span class="keyword">static_assert</span>(std::is_same_v&lt;typename alloc_traits::value_type, std::pair&lt;const Key, Type&gt;&gt;, <span class="stringliteral">&quot;Invalid value type&quot;</span>);</div>
<div class="line"><a id="l00267" name="l00267"></a><span class="lineno"> 267</span> <span class="keyword">using </span>sparse_container_type = std::vector&lt;std::size_t, typename alloc_traits::template rebind_alloc&lt;std::size_t&gt;&gt;;</div>
<div class="line"><a id="l00268" name="l00268"></a><span class="lineno"> 268</span> <span class="keyword">using </span>packed_container_type = std::vector&lt;node_type, typename alloc_traits::template rebind_alloc&lt;node_type&gt;&gt;;</div>
<div class="line"><a id="l00269" name="l00269"></a><span class="lineno"> 269</span> </div>
<div class="line"><a id="l00270" name="l00270"></a><span class="lineno"> 270</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Other&gt;</div>
<div class="line"><a id="l00271" name="l00271"></a><span class="lineno"> 271</span> [[nodiscard]] std::size_t key_to_bucket(<span class="keyword">const</span> Other &amp;key) <span class="keyword">const</span> <span class="keyword">noexcept</span> {</div>
<div class="line"><a id="l00272" name="l00272"></a><span class="lineno"> 272</span> <span class="comment">// NOLINTNEXTLINE(cppcoreguidelines-pro-bounds-array-to-pointer-decay)</span></div>
<div class="line"><a id="l00273" name="l00273"></a><span class="lineno"> 273</span> <span class="keywordflow">return</span> <a class="code hl_function" href="namespaceentt.html#a1ae98eeee0b0cb3e94d97d08a74a06f0">fast_mod</a>(<span class="keyword">static_cast&lt;</span><a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a><span class="keyword">&gt;</span>(sparse.second()(key)), <a class="code hl_function" href="classentt_1_1dense__map.html#aee246b41534137f279a11eb5e225a6e5">bucket_count</a>());</div>
<div class="line"><a id="l00274" name="l00274"></a><span class="lineno"> 274</span> }</div>
<div class="line"><a id="l00275" name="l00275"></a><span class="lineno"> 275</span> </div>
<div class="line"><a id="l00276" name="l00276"></a><span class="lineno"> 276</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Other&gt;</div>
<div class="line"><a id="l00277" name="l00277"></a><span class="lineno"> 277</span> [[nodiscard]] <span class="keyword">auto</span> constrained_find(<span class="keyword">const</span> Other &amp;key, std::size_t <a class="code hl_function" href="classentt_1_1dense__map.html#a9a591d419dd5649e52907a3032f8c0b8">bucket</a>) {</div>
<div class="line"><a id="l00278" name="l00278"></a><span class="lineno"> 278</span> <span class="keywordflow">for</span>(<span class="keyword">auto</span> it = <a class="code hl_function" href="classentt_1_1dense__map.html#a7c0e7de10687bc1e810d67ba6a91396d">begin</a>(<a class="code hl_function" href="classentt_1_1dense__map.html#a9a591d419dd5649e52907a3032f8c0b8">bucket</a>), last = <a class="code hl_function" href="classentt_1_1dense__map.html#afa80b6dff4ba1f455fabec3ff197e8c5">end</a>(<a class="code hl_function" href="classentt_1_1dense__map.html#a9a591d419dd5649e52907a3032f8c0b8">bucket</a>); it != last; ++it) {</div>
<div class="line"><a id="l00279" name="l00279"></a><span class="lineno"> 279</span> <span class="keywordflow">if</span>(packed.second()(it-&gt;first, key)) {</div>
<div class="line"><a id="l00280" name="l00280"></a><span class="lineno"> 280</span> <span class="keywordflow">return</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a7c0e7de10687bc1e810d67ba6a91396d">begin</a>() + <span class="keyword">static_cast&lt;</span><a class="code hl_typedef" href="classentt_1_1dense__map.html#afe9ae8d1427ee98d662e7a7d635a6eff">difference_type</a><span class="keyword">&gt;</span>(it.index());</div>
<div class="line"><a id="l00281" name="l00281"></a><span class="lineno"> 281</span> }</div>
<div class="line"><a id="l00282" name="l00282"></a><span class="lineno"> 282</span> }</div>
<div class="line"><a id="l00283" name="l00283"></a><span class="lineno"> 283</span> </div>
<div class="line"><a id="l00284" name="l00284"></a><span class="lineno"> 284</span> <span class="keywordflow">return</span> <a class="code hl_function" href="classentt_1_1dense__map.html#afa80b6dff4ba1f455fabec3ff197e8c5">end</a>();</div>
<div class="line"><a id="l00285" name="l00285"></a><span class="lineno"> 285</span> }</div>
<div class="line"><a id="l00286" name="l00286"></a><span class="lineno"> 286</span> </div>
<div class="line"><a id="l00287" name="l00287"></a><span class="lineno"> 287</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Other&gt;</div>
<div class="line"><a id="l00288" name="l00288"></a><span class="lineno"> 288</span> [[nodiscard]] <span class="keyword">auto</span> constrained_find(<span class="keyword">const</span> Other &amp;key, std::size_t <a class="code hl_function" href="classentt_1_1dense__map.html#a9a591d419dd5649e52907a3032f8c0b8">bucket</a>)<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00289" name="l00289"></a><span class="lineno"> 289</span> <span class="keywordflow">for</span>(<span class="keyword">auto</span> it = <a class="code hl_function" href="classentt_1_1dense__map.html#a2cef5e32d1e4575669c9afcf6bcbedc5">cbegin</a>(<a class="code hl_function" href="classentt_1_1dense__map.html#a9a591d419dd5649e52907a3032f8c0b8">bucket</a>), last = <a class="code hl_function" href="classentt_1_1dense__map.html#a5123c811e7090df1a793e9bc1821d2e5">cend</a>(<a class="code hl_function" href="classentt_1_1dense__map.html#a9a591d419dd5649e52907a3032f8c0b8">bucket</a>); it != last; ++it) {</div>
<div class="line"><a id="l00290" name="l00290"></a><span class="lineno"> 290</span> <span class="keywordflow">if</span>(packed.second()(it-&gt;first, key)) {</div>
<div class="line"><a id="l00291" name="l00291"></a><span class="lineno"> 291</span> <span class="keywordflow">return</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a2cef5e32d1e4575669c9afcf6bcbedc5">cbegin</a>() + <span class="keyword">static_cast&lt;</span><a class="code hl_typedef" href="classentt_1_1dense__map.html#afe9ae8d1427ee98d662e7a7d635a6eff">difference_type</a><span class="keyword">&gt;</span>(it.index());</div>
<div class="line"><a id="l00292" name="l00292"></a><span class="lineno"> 292</span> }</div>
<div class="line"><a id="l00293" name="l00293"></a><span class="lineno"> 293</span> }</div>
<div class="line"><a id="l00294" name="l00294"></a><span class="lineno"> 294</span> </div>
<div class="line"><a id="l00295" name="l00295"></a><span class="lineno"> 295</span> <span class="keywordflow">return</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a5123c811e7090df1a793e9bc1821d2e5">cend</a>();</div>
<div class="line"><a id="l00296" name="l00296"></a><span class="lineno"> 296</span> }</div>
<div class="line"><a id="l00297" name="l00297"></a><span class="lineno"> 297</span> </div>
<div class="line"><a id="l00298" name="l00298"></a><span class="lineno"> 298</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Other, <span class="keyword">typename</span>... Args&gt;</div>
<div class="line"><a id="l00299" name="l00299"></a><span class="lineno"> 299</span> [[nodiscard]] <span class="keyword">auto</span> insert_or_do_nothing(Other &amp;&amp;key, Args &amp;&amp;...args) {</div>
<div class="line"><a id="l00300" name="l00300"></a><span class="lineno"> 300</span> <span class="keyword">const</span> <span class="keyword">auto</span> index = key_to_bucket(key);</div>
<div class="line"><a id="l00301" name="l00301"></a><span class="lineno"> 301</span> </div>
<div class="line"><a id="l00302" name="l00302"></a><span class="lineno"> 302</span> <span class="keywordflow">if</span>(<span class="keyword">auto</span> it = constrained_find(key, index); it != <a class="code hl_function" href="classentt_1_1dense__map.html#afa80b6dff4ba1f455fabec3ff197e8c5">end</a>()) {</div>
<div class="line"><a id="l00303" name="l00303"></a><span class="lineno"> 303</span> <span class="keywordflow">return</span> std::make_pair(it, <span class="keyword">false</span>);</div>
<div class="line"><a id="l00304" name="l00304"></a><span class="lineno"> 304</span> }</div>
<div class="line"><a id="l00305" name="l00305"></a><span class="lineno"> 305</span> </div>
<div class="line"><a id="l00306" name="l00306"></a><span class="lineno"> 306</span> packed.first().emplace_back(sparse.first()[index], std::piecewise_construct, std::forward_as_tuple(std::forward&lt;Other&gt;(key)), std::forward_as_tuple(std::forward&lt;Args&gt;(args)...));</div>
<div class="line"><a id="l00307" name="l00307"></a><span class="lineno"> 307</span> sparse.first()[index] = packed.first().size() - 1u;</div>
<div class="line"><a id="l00308" name="l00308"></a><span class="lineno"> 308</span> rehash_if_required();</div>
<div class="line"><a id="l00309" name="l00309"></a><span class="lineno"> 309</span> </div>
<div class="line"><a id="l00310" name="l00310"></a><span class="lineno"> 310</span> <span class="keywordflow">return</span> std::make_pair(--<a class="code hl_function" href="classentt_1_1dense__map.html#afa80b6dff4ba1f455fabec3ff197e8c5">end</a>(), <span class="keyword">true</span>);</div>
<div class="line"><a id="l00311" name="l00311"></a><span class="lineno"> 311</span> }</div>
<div class="line"><a id="l00312" name="l00312"></a><span class="lineno"> 312</span> </div>
<div class="line"><a id="l00313" name="l00313"></a><span class="lineno"> 313</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Other, <span class="keyword">typename</span> Arg&gt;</div>
<div class="line"><a id="l00314" name="l00314"></a><span class="lineno"> 314</span> [[nodiscard]] <span class="keyword">auto</span> insert_or_overwrite(Other &amp;&amp;key, Arg &amp;&amp;value) {</div>
<div class="line"><a id="l00315" name="l00315"></a><span class="lineno"> 315</span> <span class="keyword">const</span> <span class="keyword">auto</span> index = key_to_bucket(key);</div>
<div class="line"><a id="l00316" name="l00316"></a><span class="lineno"> 316</span> </div>
<div class="line"><a id="l00317" name="l00317"></a><span class="lineno"> 317</span> <span class="keywordflow">if</span>(<span class="keyword">auto</span> it = constrained_find(key, index); it != <a class="code hl_function" href="classentt_1_1dense__map.html#afa80b6dff4ba1f455fabec3ff197e8c5">end</a>()) {</div>
<div class="line"><a id="l00318" name="l00318"></a><span class="lineno"> 318</span> it-&gt;second = std::forward&lt;Arg&gt;(value);</div>
<div class="line"><a id="l00319" name="l00319"></a><span class="lineno"> 319</span> <span class="keywordflow">return</span> std::make_pair(it, <span class="keyword">false</span>);</div>
<div class="line"><a id="l00320" name="l00320"></a><span class="lineno"> 320</span> }</div>
<div class="line"><a id="l00321" name="l00321"></a><span class="lineno"> 321</span> </div>
<div class="line"><a id="l00322" name="l00322"></a><span class="lineno"> 322</span> packed.first().emplace_back(sparse.first()[index], std::forward&lt;Other&gt;(key), std::forward&lt;Arg&gt;(value));</div>
<div class="line"><a id="l00323" name="l00323"></a><span class="lineno"> 323</span> sparse.first()[index] = packed.first().size() - 1u;</div>
<div class="line"><a id="l00324" name="l00324"></a><span class="lineno"> 324</span> rehash_if_required();</div>
<div class="line"><a id="l00325" name="l00325"></a><span class="lineno"> 325</span> </div>
<div class="line"><a id="l00326" name="l00326"></a><span class="lineno"> 326</span> <span class="keywordflow">return</span> std::make_pair(--<a class="code hl_function" href="classentt_1_1dense__map.html#afa80b6dff4ba1f455fabec3ff197e8c5">end</a>(), <span class="keyword">true</span>);</div>
<div class="line"><a id="l00327" name="l00327"></a><span class="lineno"> 327</span> }</div>
<div class="line"><a id="l00328" name="l00328"></a><span class="lineno"> 328</span> </div>
<div class="line"><a id="l00329" name="l00329"></a><span class="lineno"> 329</span> <span class="keywordtype">void</span> move_and_pop(<span class="keyword">const</span> std::size_t pos) {</div>
<div class="line"><a id="l00330" name="l00330"></a><span class="lineno"> 330</span> <span class="keywordflow">if</span>(<span class="keyword">const</span> <span class="keyword">auto</span> last = <a class="code hl_function" href="classentt_1_1dense__map.html#a38b10511f585724b7eb6e5f9556dea21">size</a>() - 1u; pos != last) {</div>
<div class="line"><a id="l00331" name="l00331"></a><span class="lineno"> 331</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> *curr = &amp;sparse.first()[key_to_bucket(packed.first().back().element.first)];</div>
<div class="line"><a id="l00332" name="l00332"></a><span class="lineno"> 332</span> packed.first()[pos] = std::move(packed.first().back());</div>
<div class="line"><a id="l00333" name="l00333"></a><span class="lineno"> 333</span> <span class="keywordflow">for</span>(; *curr != last; curr = &amp;packed.first()[*curr].next) {}</div>
<div class="line"><a id="l00334" name="l00334"></a><span class="lineno"> 334</span> *curr = pos;</div>
<div class="line"><a id="l00335" name="l00335"></a><span class="lineno"> 335</span> }</div>
<div class="line"><a id="l00336" name="l00336"></a><span class="lineno"> 336</span> </div>
<div class="line"><a id="l00337" name="l00337"></a><span class="lineno"> 337</span> packed.first().pop_back();</div>
<div class="line"><a id="l00338" name="l00338"></a><span class="lineno"> 338</span> }</div>
<div class="line"><a id="l00339" name="l00339"></a><span class="lineno"> 339</span> </div>
<div class="line"><a id="l00340" name="l00340"></a><span class="lineno"> 340</span> <span class="keywordtype">void</span> rehash_if_required() {</div>
<div class="line"><a id="l00341" name="l00341"></a><span class="lineno"> 341</span> <span class="keywordflow">if</span>(<span class="keyword">const</span> <span class="keyword">auto</span> bc = <a class="code hl_function" href="classentt_1_1dense__map.html#aee246b41534137f279a11eb5e225a6e5">bucket_count</a>(); <a class="code hl_function" href="classentt_1_1dense__map.html#a38b10511f585724b7eb6e5f9556dea21">size</a>() &gt; <span class="keyword">static_cast&lt;</span><a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a><span class="keyword">&gt;</span>(<span class="keyword">static_cast&lt;</span><span class="keywordtype">float</span><span class="keyword">&gt;</span>(bc) * <a class="code hl_function" href="classentt_1_1dense__map.html#a54a2dd65d401a992fd91fb8a91faea86">max_load_factor</a>())) {</div>
<div class="line"><a id="l00342" name="l00342"></a><span class="lineno"> 342</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a7cea2e02e86eec9421ddaab64f15db6b">rehash</a>(bc * 2u);</div>
<div class="line"><a id="l00343" name="l00343"></a><span class="lineno"> 343</span> }</div>
<div class="line"><a id="l00344" name="l00344"></a><span class="lineno"> 344</span> }</div>
<div class="line"><a id="l00345" name="l00345"></a><span class="lineno"> 345</span> </div>
<div class="line"><a id="l00346" name="l00346"></a><span class="lineno"> 346</span><span class="keyword">public</span>:</div>
<div class="line"><a id="l00348" name="l00348"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#adc7feba2153b3764cc7789f31b926d78"> 348</a></span> <span class="keyword">using </span><a class="code hl_typedef" href="classentt_1_1dense__map.html#adc7feba2153b3764cc7789f31b926d78">allocator_type</a> = Allocator;</div>
<div class="line"><a id="l00350" name="l00350"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab"> 350</a></span> <span class="keyword">using </span><a class="code hl_typedef" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">key_type</a> = Key;</div>
<div class="line"><a id="l00352" name="l00352"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a7cdfe85f102518543b7a684c9e8e3bd3"> 352</a></span> <span class="keyword">using </span><a class="code hl_typedef" href="classentt_1_1dense__map.html#a7cdfe85f102518543b7a684c9e8e3bd3">mapped_type</a> = Type;</div>
<div class="line"><a id="l00354" name="l00354"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#aa53501af8bfd66b6bf45e8cfa844e180"> 354</a></span> <span class="keyword">using </span><a class="code hl_typedef" href="classentt_1_1dense__map.html#aa53501af8bfd66b6bf45e8cfa844e180">value_type</a> = std::pair&lt;const Key, Type&gt;;</div>
<div class="line"><a id="l00356" name="l00356"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1"> 356</a></span> <span class="keyword">using </span><a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> = std::size_t;</div>
<div class="line"><a id="l00358" name="l00358"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#afe9ae8d1427ee98d662e7a7d635a6eff"> 358</a></span> <span class="keyword">using </span><a class="code hl_typedef" href="classentt_1_1dense__map.html#afe9ae8d1427ee98d662e7a7d635a6eff">difference_type</a> = std::ptrdiff_t;</div>
<div class="line"><a id="l00360" name="l00360"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#ae62722d472417185388e952655b120e9"> 360</a></span> <span class="keyword">using </span><a class="code hl_typedef" href="classentt_1_1dense__map.html#ae62722d472417185388e952655b120e9">hasher</a> = Hash;</div>
<div class="line"><a id="l00362" name="l00362"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a41a26ee3be60abf7b5ecf16c99948086"> 362</a></span> <span class="keyword">using </span><a class="code hl_typedef" href="classentt_1_1dense__map.html#a41a26ee3be60abf7b5ecf16c99948086">key_equal</a> = KeyEqual;</div>
<div class="line"><a id="l00364" name="l00364"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#acc07b299f15a57db885089cc1a31322d"> 364</a></span> <span class="keyword">using </span><a class="code hl_typedef" href="classentt_1_1dense__map.html#acc07b299f15a57db885089cc1a31322d">iterator</a> = internal::dense_map_iterator&lt;typename packed_container_type::iterator&gt;;</div>
<div class="line"><a id="l00366" name="l00366"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a5c236223418b9ef327397424e2df24f8"> 366</a></span> <span class="keyword">using </span><a class="code hl_typedef" href="classentt_1_1dense__map.html#a5c236223418b9ef327397424e2df24f8">const_iterator</a> = internal::dense_map_iterator&lt;typename packed_container_type::const_iterator&gt;;</div>
<div class="line"><a id="l00368" name="l00368"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#ad05e437f37f277cbe5c6121e67a4e89a"> 368</a></span> <span class="keyword">using </span><a class="code hl_typedef" href="classentt_1_1dense__map.html#ad05e437f37f277cbe5c6121e67a4e89a">local_iterator</a> = internal::dense_map_local_iterator&lt;typename packed_container_type::iterator&gt;;</div>
<div class="line"><a id="l00370" name="l00370"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#ad699469dc43bfd00d9ea86c686afb394"> 370</a></span> <span class="keyword">using </span><a class="code hl_typedef" href="classentt_1_1dense__map.html#ad699469dc43bfd00d9ea86c686afb394">const_local_iterator</a> = internal::dense_map_local_iterator&lt;typename packed_container_type::const_iterator&gt;;</div>
<div class="line"><a id="l00371" name="l00371"></a><span class="lineno"> 371</span></div>
<div class="foldopen" id="foldopen00373" data-start="{" data-end="}">
<div class="line"><a id="l00373" name="l00373"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#af163bec2cf56f3571000a5fc0145832f"> 373</a></span> <a class="code hl_function" href="classentt_1_1dense__map.html#af163bec2cf56f3571000a5fc0145832f">dense_map</a>()</div>
<div class="line"><a id="l00374" name="l00374"></a><span class="lineno"> 374</span> : <a class="code hl_function" href="classentt_1_1dense__map.html#af163bec2cf56f3571000a5fc0145832f">dense_map</a>{minimum_capacity} {}</div>
</div>
<div class="line"><a id="l00375" name="l00375"></a><span class="lineno"> 375</span></div>
<div class="foldopen" id="foldopen00380" data-start="{" data-end="}">
<div class="line"><a id="l00380" name="l00380"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a096357c0bdb6342d7d304716e41fcea5"> 380</a></span> <span class="keyword">explicit</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a096357c0bdb6342d7d304716e41fcea5">dense_map</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#adc7feba2153b3764cc7789f31b926d78">allocator_type</a> &amp;allocator)</div>
<div class="line"><a id="l00381" name="l00381"></a><span class="lineno"> 381</span> : <a class="code hl_function" href="classentt_1_1dense__map.html#af163bec2cf56f3571000a5fc0145832f">dense_map</a>{minimum_capacity, <a class="code hl_typedef" href="classentt_1_1dense__map.html#ae62722d472417185388e952655b120e9">hasher</a>{}, <a class="code hl_typedef" href="classentt_1_1dense__map.html#a41a26ee3be60abf7b5ecf16c99948086">key_equal</a>{}, allocator} {}</div>
</div>
<div class="line"><a id="l00382" name="l00382"></a><span class="lineno"> 382</span></div>
<div class="foldopen" id="foldopen00389" data-start="{" data-end="}">
<div class="line"><a id="l00389" name="l00389"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a524c65b19c282b4a2bce0434facca4c5"> 389</a></span> <a class="code hl_function" href="classentt_1_1dense__map.html#a524c65b19c282b4a2bce0434facca4c5">dense_map</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> cnt, <span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#adc7feba2153b3764cc7789f31b926d78">allocator_type</a> &amp;allocator)</div>
<div class="line"><a id="l00390" name="l00390"></a><span class="lineno"> 390</span> : <a class="code hl_function" href="classentt_1_1dense__map.html#af163bec2cf56f3571000a5fc0145832f">dense_map</a>{cnt, <a class="code hl_typedef" href="classentt_1_1dense__map.html#ae62722d472417185388e952655b120e9">hasher</a>{}, <a class="code hl_typedef" href="classentt_1_1dense__map.html#a41a26ee3be60abf7b5ecf16c99948086">key_equal</a>{}, allocator} {}</div>
</div>
<div class="line"><a id="l00391" name="l00391"></a><span class="lineno"> 391</span></div>
<div class="foldopen" id="foldopen00399" data-start="{" data-end="}">
<div class="line"><a id="l00399" name="l00399"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#acb47beb8b4689e0e09e7527bd537f69b"> 399</a></span> <a class="code hl_function" href="classentt_1_1dense__map.html#acb47beb8b4689e0e09e7527bd537f69b">dense_map</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> cnt, <span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#ae62722d472417185388e952655b120e9">hasher</a> &amp;hash, <span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#adc7feba2153b3764cc7789f31b926d78">allocator_type</a> &amp;allocator)</div>
<div class="line"><a id="l00400" name="l00400"></a><span class="lineno"> 400</span> : <a class="code hl_function" href="classentt_1_1dense__map.html#af163bec2cf56f3571000a5fc0145832f">dense_map</a>{cnt, hash, <a class="code hl_typedef" href="classentt_1_1dense__map.html#a41a26ee3be60abf7b5ecf16c99948086">key_equal</a>{}, allocator} {}</div>
</div>
<div class="line"><a id="l00401" name="l00401"></a><span class="lineno"> 401</span></div>
<div class="foldopen" id="foldopen00410" data-start="{" data-end="}">
<div class="line"><a id="l00410" name="l00410"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a07183a6c046d3a3b2e7201bd63aa8efe"> 410</a></span> <span class="keyword">explicit</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a07183a6c046d3a3b2e7201bd63aa8efe">dense_map</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> cnt, <span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#ae62722d472417185388e952655b120e9">hasher</a> &amp;hash = <a class="code hl_typedef" href="classentt_1_1dense__map.html#ae62722d472417185388e952655b120e9">hasher</a>{}, <span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#a41a26ee3be60abf7b5ecf16c99948086">key_equal</a> &amp;equal = <a class="code hl_typedef" href="classentt_1_1dense__map.html#a41a26ee3be60abf7b5ecf16c99948086">key_equal</a>{}, <span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#adc7feba2153b3764cc7789f31b926d78">allocator_type</a> &amp;allocator = <a class="code hl_typedef" href="classentt_1_1dense__map.html#adc7feba2153b3764cc7789f31b926d78">allocator_type</a>{})</div>
<div class="line"><a id="l00411" name="l00411"></a><span class="lineno"> 411</span> : sparse{allocator, hash},</div>
<div class="line"><a id="l00412" name="l00412"></a><span class="lineno"> 412</span> packed{allocator, equal} {</div>
<div class="line"><a id="l00413" name="l00413"></a><span class="lineno"> 413</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a7cea2e02e86eec9421ddaab64f15db6b">rehash</a>(cnt);</div>
<div class="line"><a id="l00414" name="l00414"></a><span class="lineno"> 414</span> }</div>
</div>
<div class="line"><a id="l00415" name="l00415"></a><span class="lineno"> 415</span></div>
<div class="line"><a id="l00417" name="l00417"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#aaa72d92d87e8020e0ca5f035cd665d8b"> 417</a></span> <a class="code hl_function" href="classentt_1_1dense__map.html#aaa72d92d87e8020e0ca5f035cd665d8b">dense_map</a>(<span class="keyword">const</span> <a class="code hl_function" href="classentt_1_1dense__map.html#af163bec2cf56f3571000a5fc0145832f">dense_map</a> &amp;) = <span class="keywordflow">default</span>;</div>
<div class="line"><a id="l00418" name="l00418"></a><span class="lineno"> 418</span></div>
<div class="foldopen" id="foldopen00424" data-start="{" data-end="}">
<div class="line"><a id="l00424" name="l00424"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a8924f4faaa1879a84734ec58f11e6662"> 424</a></span> <a class="code hl_function" href="classentt_1_1dense__map.html#a8924f4faaa1879a84734ec58f11e6662">dense_map</a>(<span class="keyword">const</span> <a class="code hl_function" href="classentt_1_1dense__map.html#af163bec2cf56f3571000a5fc0145832f">dense_map</a> &amp;other, <span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#adc7feba2153b3764cc7789f31b926d78">allocator_type</a> &amp;allocator)</div>
<div class="line"><a id="l00425" name="l00425"></a><span class="lineno"> 425</span> : sparse{std::piecewise_construct, std::forward_as_tuple(other.sparse.first(), allocator), std::forward_as_tuple(other.sparse.second())},</div>
<div class="line"><a id="l00426" name="l00426"></a><span class="lineno"> 426</span> packed{std::piecewise_construct, std::forward_as_tuple(other.packed.first(), allocator), std::forward_as_tuple(other.packed.second())},</div>
<div class="line"><a id="l00427" name="l00427"></a><span class="lineno"> 427</span> threshold{other.threshold} {}</div>
</div>
<div class="line"><a id="l00428" name="l00428"></a><span class="lineno"> 428</span></div>
<div class="line"><a id="l00430" name="l00430"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#ad43ca6e61d09cd9f55c684c659dd74cc"> 430</a></span> <a class="code hl_function" href="classentt_1_1dense__map.html#ad43ca6e61d09cd9f55c684c659dd74cc">dense_map</a>(<a class="code hl_function" href="classentt_1_1dense__map.html#af163bec2cf56f3571000a5fc0145832f">dense_map</a> &amp;&amp;) noexcept = default;</div>
<div class="line"><a id="l00431" name="l00431"></a><span class="lineno"> 431</span></div>
<div class="foldopen" id="foldopen00437" data-start="{" data-end="}">
<div class="line"><a id="l00437" name="l00437"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a352da8efacf3d89715b5892e65b82f66"> 437</a></span> <a class="code hl_function" href="classentt_1_1dense__map.html#af163bec2cf56f3571000a5fc0145832f">dense_map</a>(<a class="code hl_function" href="classentt_1_1dense__map.html#af163bec2cf56f3571000a5fc0145832f">dense_map</a> &amp;&amp;other, const <a class="code hl_typedef" href="classentt_1_1dense__map.html#adc7feba2153b3764cc7789f31b926d78">allocator_type</a> &amp;allocator)</div>
<div class="line"><a id="l00438" name="l00438"></a><span class="lineno"> 438</span> : sparse{std::piecewise_construct, std::forward_as_tuple(std::move(other.sparse.first()), allocator), std::forward_as_tuple(std::move(other.sparse.second()))},</div>
<div class="line"><a id="l00439" name="l00439"></a><span class="lineno"> 439</span> packed{std::piecewise_construct, std::forward_as_tuple(std::move(other.packed.first()), allocator), std::forward_as_tuple(std::move(other.packed.second()))},</div>
<div class="line"><a id="l00440" name="l00440"></a><span class="lineno"> 440</span> threshold{other.threshold} {}</div>
</div>
<div class="line"><a id="l00441" name="l00441"></a><span class="lineno"> 441</span></div>
<div class="line"><a id="l00443" name="l00443"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#af2d0aa858937c74139ff7f48be924268"> 443</a></span> <a class="code hl_function" href="classentt_1_1dense__map.html#af2d0aa858937c74139ff7f48be924268">~dense_map</a>() = <span class="keywordflow">default</span>;</div>
<div class="line"><a id="l00444" name="l00444"></a><span class="lineno"> 444</span></div>
<div class="line"><a id="l00449" name="l00449"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a6ee333a078e7bc2b1035a911aff3b7ed"> 449</a></span> <a class="code hl_function" href="classentt_1_1dense__map.html#af163bec2cf56f3571000a5fc0145832f">dense_map</a> &amp;<a class="code hl_function" href="classentt_1_1dense__map.html#a6ee333a078e7bc2b1035a911aff3b7ed">operator=</a>(<span class="keyword">const</span> <a class="code hl_function" href="classentt_1_1dense__map.html#af163bec2cf56f3571000a5fc0145832f">dense_map</a> &amp;) = <span class="keywordflow">default</span>;</div>
<div class="line"><a id="l00450" name="l00450"></a><span class="lineno"> 450</span></div>
<div class="line"><a id="l00455" name="l00455"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a3decbf479ab29fe63161d66299ef20af"> 455</a></span> <a class="code hl_function" href="classentt_1_1dense__map.html#af163bec2cf56f3571000a5fc0145832f">dense_map</a> &amp;<a class="code hl_function" href="classentt_1_1dense__map.html#a3decbf479ab29fe63161d66299ef20af">operator=</a>(<a class="code hl_function" href="classentt_1_1dense__map.html#af163bec2cf56f3571000a5fc0145832f">dense_map</a> &amp;&amp;) noexcept = default;</div>
<div class="line"><a id="l00456" name="l00456"></a><span class="lineno"> 456</span></div>
<div class="foldopen" id="foldopen00461" data-start="{" data-end="}">
<div class="line"><a id="l00461" name="l00461"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a832dc73529e19f662f63c583a5fbd340"> 461</a></span> <span class="keywordtype">void</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a832dc73529e19f662f63c583a5fbd340">swap</a>(<a class="code hl_function" href="classentt_1_1dense__map.html#af163bec2cf56f3571000a5fc0145832f">dense_map</a> &amp;other) noexcept {</div>
<div class="line"><a id="l00462" name="l00462"></a><span class="lineno"> 462</span> <span class="keyword">using </span>std::swap;</div>
<div class="line"><a id="l00463" name="l00463"></a><span class="lineno"> 463</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a832dc73529e19f662f63c583a5fbd340">swap</a>(sparse, other.sparse);</div>
<div class="line"><a id="l00464" name="l00464"></a><span class="lineno"> 464</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a832dc73529e19f662f63c583a5fbd340">swap</a>(packed, other.packed);</div>
<div class="line"><a id="l00465" name="l00465"></a><span class="lineno"> 465</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a832dc73529e19f662f63c583a5fbd340">swap</a>(threshold, other.threshold);</div>
<div class="line"><a id="l00466" name="l00466"></a><span class="lineno"> 466</span> }</div>
</div>
<div class="line"><a id="l00467" name="l00467"></a><span class="lineno"> 467</span></div>
<div class="foldopen" id="foldopen00472" data-start="{" data-end="}">
<div class="line"><a id="l00472" name="l00472"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a9cd5632c26bf5281cfbbd7fbd9f85bf5"> 472</a></span> [[nodiscard]] <span class="keyword">constexpr</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#adc7feba2153b3764cc7789f31b926d78">allocator_type</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a9cd5632c26bf5281cfbbd7fbd9f85bf5">get_allocator</a>() const noexcept {</div>
<div class="line"><a id="l00473" name="l00473"></a><span class="lineno"> 473</span> <span class="keywordflow">return</span> sparse.first().get_allocator();</div>
<div class="line"><a id="l00474" name="l00474"></a><span class="lineno"> 474</span> }</div>
</div>
<div class="line"><a id="l00475" name="l00475"></a><span class="lineno"> 475</span></div>
<div class="foldopen" id="foldopen00483" data-start="{" data-end="}">
<div class="line"><a id="l00483" name="l00483"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a2cef5e32d1e4575669c9afcf6bcbedc5"> 483</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#a5c236223418b9ef327397424e2df24f8">const_iterator</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a2cef5e32d1e4575669c9afcf6bcbedc5">cbegin</a>() const noexcept {</div>
<div class="line"><a id="l00484" name="l00484"></a><span class="lineno"> 484</span> <span class="keywordflow">return</span> packed.first().begin();</div>
<div class="line"><a id="l00485" name="l00485"></a><span class="lineno"> 485</span> }</div>
</div>
<div class="line"><a id="l00486" name="l00486"></a><span class="lineno"> 486</span></div>
<div class="foldopen" id="foldopen00488" data-start="{" data-end="}">
<div class="line"><a id="l00488" name="l00488"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a7c0e7de10687bc1e810d67ba6a91396d"> 488</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#a5c236223418b9ef327397424e2df24f8">const_iterator</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a7c0e7de10687bc1e810d67ba6a91396d">begin</a>() const noexcept {</div>
<div class="line"><a id="l00489" name="l00489"></a><span class="lineno"> 489</span> <span class="keywordflow">return</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a2cef5e32d1e4575669c9afcf6bcbedc5">cbegin</a>();</div>
<div class="line"><a id="l00490" name="l00490"></a><span class="lineno"> 490</span> }</div>
</div>
<div class="line"><a id="l00491" name="l00491"></a><span class="lineno"> 491</span></div>
<div class="foldopen" id="foldopen00493" data-start="{" data-end="}">
<div class="line"><a id="l00493" name="l00493"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#afb7f0ff4d0988673a027ac0e0348b216"> 493</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#acc07b299f15a57db885089cc1a31322d">iterator</a> <a class="code hl_function" href="classentt_1_1dense__map.html#afb7f0ff4d0988673a027ac0e0348b216">begin</a>() noexcept {</div>
<div class="line"><a id="l00494" name="l00494"></a><span class="lineno"> 494</span> <span class="keywordflow">return</span> packed.first().begin();</div>
<div class="line"><a id="l00495" name="l00495"></a><span class="lineno"> 495</span> }</div>
</div>
<div class="line"><a id="l00496" name="l00496"></a><span class="lineno"> 496</span></div>
<div class="foldopen" id="foldopen00502" data-start="{" data-end="}">
<div class="line"><a id="l00502" name="l00502"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a5123c811e7090df1a793e9bc1821d2e5"> 502</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#a5c236223418b9ef327397424e2df24f8">const_iterator</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a5123c811e7090df1a793e9bc1821d2e5">cend</a>() const noexcept {</div>
<div class="line"><a id="l00503" name="l00503"></a><span class="lineno"> 503</span> <span class="keywordflow">return</span> packed.first().end();</div>
<div class="line"><a id="l00504" name="l00504"></a><span class="lineno"> 504</span> }</div>
</div>
<div class="line"><a id="l00505" name="l00505"></a><span class="lineno"> 505</span></div>
<div class="foldopen" id="foldopen00507" data-start="{" data-end="}">
<div class="line"><a id="l00507" name="l00507"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#afa80b6dff4ba1f455fabec3ff197e8c5"> 507</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#a5c236223418b9ef327397424e2df24f8">const_iterator</a> <a class="code hl_function" href="classentt_1_1dense__map.html#afa80b6dff4ba1f455fabec3ff197e8c5">end</a>() const noexcept {</div>
<div class="line"><a id="l00508" name="l00508"></a><span class="lineno"> 508</span> <span class="keywordflow">return</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a5123c811e7090df1a793e9bc1821d2e5">cend</a>();</div>
<div class="line"><a id="l00509" name="l00509"></a><span class="lineno"> 509</span> }</div>
</div>
<div class="line"><a id="l00510" name="l00510"></a><span class="lineno"> 510</span></div>
<div class="foldopen" id="foldopen00512" data-start="{" data-end="}">
<div class="line"><a id="l00512" name="l00512"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#afd4ff12e8b032e6ca5519557d07d1178"> 512</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#acc07b299f15a57db885089cc1a31322d">iterator</a> <a class="code hl_function" href="classentt_1_1dense__map.html#afd4ff12e8b032e6ca5519557d07d1178">end</a>() noexcept {</div>
<div class="line"><a id="l00513" name="l00513"></a><span class="lineno"> 513</span> <span class="keywordflow">return</span> packed.first().end();</div>
<div class="line"><a id="l00514" name="l00514"></a><span class="lineno"> 514</span> }</div>
</div>
<div class="line"><a id="l00515" name="l00515"></a><span class="lineno"> 515</span></div>
<div class="foldopen" id="foldopen00520" data-start="{" data-end="}">
<div class="line"><a id="l00520" name="l00520"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#ad6f1227e06bf48744b46b3fe251d72f2"> 520</a></span> [[nodiscard]] <span class="keywordtype">bool</span> <a class="code hl_function" href="classentt_1_1dense__map.html#ad6f1227e06bf48744b46b3fe251d72f2">empty</a>() const noexcept {</div>
<div class="line"><a id="l00521" name="l00521"></a><span class="lineno"> 521</span> <span class="keywordflow">return</span> packed.first().empty();</div>
<div class="line"><a id="l00522" name="l00522"></a><span class="lineno"> 522</span> }</div>
</div>
<div class="line"><a id="l00523" name="l00523"></a><span class="lineno"> 523</span></div>
<div class="foldopen" id="foldopen00528" data-start="{" data-end="}">
<div class="line"><a id="l00528" name="l00528"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a38b10511f585724b7eb6e5f9556dea21"> 528</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a38b10511f585724b7eb6e5f9556dea21">size</a>() const noexcept {</div>
<div class="line"><a id="l00529" name="l00529"></a><span class="lineno"> 529</span> <span class="keywordflow">return</span> packed.first().size();</div>
<div class="line"><a id="l00530" name="l00530"></a><span class="lineno"> 530</span> }</div>
</div>
<div class="line"><a id="l00531" name="l00531"></a><span class="lineno"> 531</span></div>
<div class="foldopen" id="foldopen00536" data-start="{" data-end="}">
<div class="line"><a id="l00536" name="l00536"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a45843ecba66cc9692ae4facac5461e4d"> 536</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a45843ecba66cc9692ae4facac5461e4d">max_size</a>() const noexcept {</div>
<div class="line"><a id="l00537" name="l00537"></a><span class="lineno"> 537</span> <span class="keywordflow">return</span> packed.first().max_size();</div>
<div class="line"><a id="l00538" name="l00538"></a><span class="lineno"> 538</span> }</div>
</div>
<div class="line"><a id="l00539" name="l00539"></a><span class="lineno"> 539</span></div>
<div class="foldopen" id="foldopen00541" data-start="{" data-end="}">
<div class="line"><a id="l00541" name="l00541"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a096c30be0af8e15902f5585c8d1208b7"> 541</a></span> <span class="keywordtype">void</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a096c30be0af8e15902f5585c8d1208b7">clear</a>() noexcept {</div>
<div class="line"><a id="l00542" name="l00542"></a><span class="lineno"> 542</span> sparse.first().clear();</div>
<div class="line"><a id="l00543" name="l00543"></a><span class="lineno"> 543</span> packed.first().clear();</div>
<div class="line"><a id="l00544" name="l00544"></a><span class="lineno"> 544</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a7cea2e02e86eec9421ddaab64f15db6b">rehash</a>(0u);</div>
<div class="line"><a id="l00545" name="l00545"></a><span class="lineno"> 545</span> }</div>
</div>
<div class="line"><a id="l00546" name="l00546"></a><span class="lineno"> 546</span></div>
<div class="foldopen" id="foldopen00554" data-start="{" data-end="}">
<div class="line"><a id="l00554" name="l00554"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#ada4ac1f5a3295d80d8bb4fa6387023db"> 554</a></span> std::pair&lt;iterator, bool&gt; <a class="code hl_function" href="classentt_1_1dense__map.html#ada4ac1f5a3295d80d8bb4fa6387023db">insert</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#aa53501af8bfd66b6bf45e8cfa844e180">value_type</a> &amp;value) {</div>
<div class="line"><a id="l00555" name="l00555"></a><span class="lineno"> 555</span> <span class="keywordflow">return</span> insert_or_do_nothing(value.first, value.second);</div>
<div class="line"><a id="l00556" name="l00556"></a><span class="lineno"> 556</span> }</div>
</div>
<div class="line"><a id="l00557" name="l00557"></a><span class="lineno"> 557</span></div>
<div class="foldopen" id="foldopen00559" data-start="{" data-end="}">
<div class="line"><a id="l00559" name="l00559"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a71e1a562a523572405bbf0a53bb8535d"> 559</a></span> std::pair&lt;iterator, bool&gt; <a class="code hl_function" href="classentt_1_1dense__map.html#a71e1a562a523572405bbf0a53bb8535d">insert</a>(<a class="code hl_typedef" href="classentt_1_1dense__map.html#aa53501af8bfd66b6bf45e8cfa844e180">value_type</a> &amp;&amp;value) {</div>
<div class="line"><a id="l00560" name="l00560"></a><span class="lineno"> 560</span> <span class="keywordflow">return</span> insert_or_do_nothing(std::move(value.first), std::move(value.second));</div>
<div class="line"><a id="l00561" name="l00561"></a><span class="lineno"> 561</span> }</div>
</div>
<div class="line"><a id="l00562" name="l00562"></a><span class="lineno"> 562</span></div>
<div class="line"><a id="l00567" name="l00567"></a><span class="lineno"> 567</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Arg&gt;</div>
<div class="line"><a id="l00568" name="l00568"></a><span class="lineno"> 568</span> std::enable_if_t&lt;std::is_constructible_v&lt;value_type, Arg &amp;&amp;&gt;, std::pair&lt;iterator, bool&gt;&gt;</div>
<div class="foldopen" id="foldopen00569" data-start="{" data-end="}">
<div class="line"><a id="l00569" name="l00569"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a92eced5574b8354b8357f79faf16fc23"> 569</a></span> <a class="code hl_function" href="classentt_1_1dense__map.html#a92eced5574b8354b8357f79faf16fc23">insert</a>(Arg &amp;&amp;value) {</div>
<div class="line"><a id="l00570" name="l00570"></a><span class="lineno"> 570</span> <span class="keywordflow">return</span> insert_or_do_nothing(std::forward&lt;Arg&gt;(value).first, std::forward&lt;Arg&gt;(value).second);</div>
<div class="line"><a id="l00571" name="l00571"></a><span class="lineno"> 571</span> }</div>
</div>
<div class="line"><a id="l00572" name="l00572"></a><span class="lineno"> 572</span></div>
<div class="line"><a id="l00579" name="l00579"></a><span class="lineno"> 579</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> It&gt;</div>
<div class="foldopen" id="foldopen00580" data-start="{" data-end="}">
<div class="line"><a id="l00580" name="l00580"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a3c94e139b8d65ac65df36161183a8a49"> 580</a></span> <span class="keywordtype">void</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a3c94e139b8d65ac65df36161183a8a49">insert</a>(It first, It last) {</div>
<div class="line"><a id="l00581" name="l00581"></a><span class="lineno"> 581</span> <span class="keywordflow">for</span>(; first != last; ++first) {</div>
<div class="line"><a id="l00582" name="l00582"></a><span class="lineno"> 582</span> <a class="code hl_function" href="classentt_1_1dense__map.html#ada4ac1f5a3295d80d8bb4fa6387023db">insert</a>(*first);</div>
<div class="line"><a id="l00583" name="l00583"></a><span class="lineno"> 583</span> }</div>
<div class="line"><a id="l00584" name="l00584"></a><span class="lineno"> 584</span> }</div>
</div>
<div class="line"><a id="l00585" name="l00585"></a><span class="lineno"> 585</span></div>
<div class="line"><a id="l00595" name="l00595"></a><span class="lineno"> 595</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Arg&gt;</div>
<div class="foldopen" id="foldopen00596" data-start="{" data-end="}">
<div class="line"><a id="l00596" name="l00596"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#aafff57a203cd3fc561320bad6eeea0c3"> 596</a></span> std::pair&lt;iterator, bool&gt; <a class="code hl_function" href="classentt_1_1dense__map.html#aafff57a203cd3fc561320bad6eeea0c3">insert_or_assign</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">key_type</a> &amp;key, Arg &amp;&amp;value) {</div>
<div class="line"><a id="l00597" name="l00597"></a><span class="lineno"> 597</span> <span class="keywordflow">return</span> insert_or_overwrite(key, std::forward&lt;Arg&gt;(value));</div>
<div class="line"><a id="l00598" name="l00598"></a><span class="lineno"> 598</span> }</div>
</div>
<div class="line"><a id="l00599" name="l00599"></a><span class="lineno"> 599</span></div>
<div class="line"><a id="l00601" name="l00601"></a><span class="lineno"> 601</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Arg&gt;</div>
<div class="foldopen" id="foldopen00602" data-start="{" data-end="}">
<div class="line"><a id="l00602" name="l00602"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a9a9522dcd518bd3d73769d80d35606db"> 602</a></span> std::pair&lt;iterator, bool&gt; <a class="code hl_function" href="classentt_1_1dense__map.html#a9a9522dcd518bd3d73769d80d35606db">insert_or_assign</a>(<a class="code hl_typedef" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">key_type</a> &amp;&amp;key, Arg &amp;&amp;value) {</div>
<div class="line"><a id="l00603" name="l00603"></a><span class="lineno"> 603</span> <span class="keywordflow">return</span> insert_or_overwrite(std::move(key), std::forward&lt;Arg&gt;(value));</div>
<div class="line"><a id="l00604" name="l00604"></a><span class="lineno"> 604</span> }</div>
</div>
<div class="line"><a id="l00605" name="l00605"></a><span class="lineno"> 605</span></div>
<div class="line"><a id="l00619" name="l00619"></a><span class="lineno"> 619</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span>... Args&gt;</div>
<div class="foldopen" id="foldopen00620" data-start="{" data-end="}">
<div class="line"><a id="l00620" name="l00620"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#ab0dfc292981ab6694cd4609879a80dbc"> 620</a></span> std::pair&lt;iterator, bool&gt; <a class="code hl_function" href="classentt_1_1dense__map.html#ab0dfc292981ab6694cd4609879a80dbc">emplace</a>([[maybe_unused]] Args &amp;&amp;...args) {</div>
<div class="line"><a id="l00621" name="l00621"></a><span class="lineno"> 621</span> <span class="keywordflow">if</span> <span class="keyword">constexpr</span>(<span class="keyword">sizeof</span>...(Args) == 0u) {</div>
<div class="line"><a id="l00622" name="l00622"></a><span class="lineno"> 622</span> <span class="keywordflow">return</span> insert_or_do_nothing(<a class="code hl_typedef" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">key_type</a>{});</div>
<div class="line"><a id="l00623" name="l00623"></a><span class="lineno"> 623</span> } <span class="keywordflow">else</span> <span class="keywordflow">if</span> <span class="keyword">constexpr</span>(<span class="keyword">sizeof</span>...(Args) == 1u) {</div>
<div class="line"><a id="l00624" name="l00624"></a><span class="lineno"> 624</span> <span class="keywordflow">return</span> insert_or_do_nothing(std::forward&lt;Args&gt;(args).first..., std::forward&lt;Args&gt;(args).second...);</div>
<div class="line"><a id="l00625" name="l00625"></a><span class="lineno"> 625</span> } <span class="keywordflow">else</span> <span class="keywordflow">if</span> <span class="keyword">constexpr</span>(<span class="keyword">sizeof</span>...(Args) == 2u) {</div>
<div class="line"><a id="l00626" name="l00626"></a><span class="lineno"> 626</span> <span class="keywordflow">return</span> insert_or_do_nothing(std::forward&lt;Args&gt;(args)...);</div>
<div class="line"><a id="l00627" name="l00627"></a><span class="lineno"> 627</span> } <span class="keywordflow">else</span> {</div>
<div class="line"><a id="l00628" name="l00628"></a><span class="lineno"> 628</span> <span class="keyword">auto</span> &amp;node = packed.first().emplace_back(packed.first().size(), std::forward&lt;Args&gt;(args)...);</div>
<div class="line"><a id="l00629" name="l00629"></a><span class="lineno"> 629</span> <span class="keyword">const</span> <span class="keyword">auto</span> index = key_to_bucket(node.element.first);</div>
<div class="line"><a id="l00630" name="l00630"></a><span class="lineno"> 630</span> </div>
<div class="line"><a id="l00631" name="l00631"></a><span class="lineno"> 631</span> <span class="keywordflow">if</span>(<span class="keyword">auto</span> it = constrained_find(node.element.first, index); it != <a class="code hl_function" href="classentt_1_1dense__map.html#afa80b6dff4ba1f455fabec3ff197e8c5">end</a>()) {</div>
<div class="line"><a id="l00632" name="l00632"></a><span class="lineno"> 632</span> packed.first().pop_back();</div>
<div class="line"><a id="l00633" name="l00633"></a><span class="lineno"> 633</span> <span class="keywordflow">return</span> std::make_pair(it, <span class="keyword">false</span>);</div>
<div class="line"><a id="l00634" name="l00634"></a><span class="lineno"> 634</span> }</div>
<div class="line"><a id="l00635" name="l00635"></a><span class="lineno"> 635</span> </div>
<div class="line"><a id="l00636" name="l00636"></a><span class="lineno"> 636</span> std::swap(node.next, sparse.first()[index]);</div>
<div class="line"><a id="l00637" name="l00637"></a><span class="lineno"> 637</span> rehash_if_required();</div>
<div class="line"><a id="l00638" name="l00638"></a><span class="lineno"> 638</span> </div>
<div class="line"><a id="l00639" name="l00639"></a><span class="lineno"> 639</span> <span class="keywordflow">return</span> std::make_pair(--<a class="code hl_function" href="classentt_1_1dense__map.html#afa80b6dff4ba1f455fabec3ff197e8c5">end</a>(), <span class="keyword">true</span>);</div>
<div class="line"><a id="l00640" name="l00640"></a><span class="lineno"> 640</span> }</div>
<div class="line"><a id="l00641" name="l00641"></a><span class="lineno"> 641</span> }</div>
</div>
<div class="line"><a id="l00642" name="l00642"></a><span class="lineno"> 642</span></div>
<div class="line"><a id="l00654" name="l00654"></a><span class="lineno"> 654</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span>... Args&gt;</div>
<div class="foldopen" id="foldopen00655" data-start="{" data-end="}">
<div class="line"><a id="l00655" name="l00655"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a53111b5614ea1d29d8396279ebfd7d3e"> 655</a></span> std::pair&lt;iterator, bool&gt; <a class="code hl_function" href="classentt_1_1dense__map.html#a53111b5614ea1d29d8396279ebfd7d3e">try_emplace</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">key_type</a> &amp;key, Args &amp;&amp;...args) {</div>
<div class="line"><a id="l00656" name="l00656"></a><span class="lineno"> 656</span> <span class="keywordflow">return</span> insert_or_do_nothing(key, std::forward&lt;Args&gt;(args)...);</div>
<div class="line"><a id="l00657" name="l00657"></a><span class="lineno"> 657</span> }</div>
</div>
<div class="line"><a id="l00658" name="l00658"></a><span class="lineno"> 658</span></div>
<div class="line"><a id="l00660" name="l00660"></a><span class="lineno"> 660</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span>... Args&gt;</div>
<div class="foldopen" id="foldopen00661" data-start="{" data-end="}">
<div class="line"><a id="l00661" name="l00661"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#ab2b0e98c01ad728022e5388535333fb1"> 661</a></span> std::pair&lt;iterator, bool&gt; <a class="code hl_function" href="classentt_1_1dense__map.html#ab2b0e98c01ad728022e5388535333fb1">try_emplace</a>(<a class="code hl_typedef" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">key_type</a> &amp;&amp;key, Args &amp;&amp;...args) {</div>
<div class="line"><a id="l00662" name="l00662"></a><span class="lineno"> 662</span> <span class="keywordflow">return</span> insert_or_do_nothing(std::move(key), std::forward&lt;Args&gt;(args)...);</div>
<div class="line"><a id="l00663" name="l00663"></a><span class="lineno"> 663</span> }</div>
</div>
<div class="line"><a id="l00664" name="l00664"></a><span class="lineno"> 664</span></div>
<div class="foldopen" id="foldopen00670" data-start="{" data-end="}">
<div class="line"><a id="l00670" name="l00670"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a83036e3f167d28ba9afa943271fb5587"> 670</a></span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#acc07b299f15a57db885089cc1a31322d">iterator</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a83036e3f167d28ba9afa943271fb5587">erase</a>(<a class="code hl_typedef" href="classentt_1_1dense__map.html#a5c236223418b9ef327397424e2df24f8">const_iterator</a> pos) {</div>
<div class="line"><a id="l00671" name="l00671"></a><span class="lineno"> 671</span> <span class="keyword">const</span> <span class="keyword">auto</span> diff = pos - <a class="code hl_function" href="classentt_1_1dense__map.html#a2cef5e32d1e4575669c9afcf6bcbedc5">cbegin</a>();</div>
<div class="line"><a id="l00672" name="l00672"></a><span class="lineno"> 672</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a83036e3f167d28ba9afa943271fb5587">erase</a>(pos-&gt;first);</div>
<div class="line"><a id="l00673" name="l00673"></a><span class="lineno"> 673</span> <span class="keywordflow">return</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a7c0e7de10687bc1e810d67ba6a91396d">begin</a>() + diff;</div>
<div class="line"><a id="l00674" name="l00674"></a><span class="lineno"> 674</span> }</div>
</div>
<div class="line"><a id="l00675" name="l00675"></a><span class="lineno"> 675</span></div>
<div class="foldopen" id="foldopen00682" data-start="{" data-end="}">
<div class="line"><a id="l00682" name="l00682"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a49bb9a8de8e27cff97395d4fc527ad04"> 682</a></span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#acc07b299f15a57db885089cc1a31322d">iterator</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a49bb9a8de8e27cff97395d4fc527ad04">erase</a>(<a class="code hl_typedef" href="classentt_1_1dense__map.html#a5c236223418b9ef327397424e2df24f8">const_iterator</a> first, <a class="code hl_typedef" href="classentt_1_1dense__map.html#a5c236223418b9ef327397424e2df24f8">const_iterator</a> last) {</div>
<div class="line"><a id="l00683" name="l00683"></a><span class="lineno"> 683</span> <span class="keyword">const</span> <span class="keyword">auto</span> dist = first - <a class="code hl_function" href="classentt_1_1dense__map.html#a2cef5e32d1e4575669c9afcf6bcbedc5">cbegin</a>();</div>
<div class="line"><a id="l00684" name="l00684"></a><span class="lineno"> 684</span> </div>
<div class="line"><a id="l00685" name="l00685"></a><span class="lineno"> 685</span> <span class="keywordflow">for</span>(<span class="keyword">auto</span> from = last - <a class="code hl_function" href="classentt_1_1dense__map.html#a2cef5e32d1e4575669c9afcf6bcbedc5">cbegin</a>(); from != dist; --from) {</div>
<div class="line"><a id="l00686" name="l00686"></a><span class="lineno"> 686</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a83036e3f167d28ba9afa943271fb5587">erase</a>(packed.first()[<span class="keyword">static_cast&lt;</span><a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a><span class="keyword">&gt;</span>(from) - 1u].element.first);</div>
<div class="line"><a id="l00687" name="l00687"></a><span class="lineno"> 687</span> }</div>
<div class="line"><a id="l00688" name="l00688"></a><span class="lineno"> 688</span> </div>
<div class="line"><a id="l00689" name="l00689"></a><span class="lineno"> 689</span> <span class="keywordflow">return</span> (<a class="code hl_function" href="classentt_1_1dense__map.html#a7c0e7de10687bc1e810d67ba6a91396d">begin</a>() + dist);</div>
<div class="line"><a id="l00690" name="l00690"></a><span class="lineno"> 690</span> }</div>
</div>
<div class="line"><a id="l00691" name="l00691"></a><span class="lineno"> 691</span></div>
<div class="foldopen" id="foldopen00697" data-start="{" data-end="}">
<div class="line"><a id="l00697" name="l00697"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a12d1730a14bac304cbd173c05cb2cbf2"> 697</a></span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a12d1730a14bac304cbd173c05cb2cbf2">erase</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">key_type</a> &amp;key) {</div>
<div class="line"><a id="l00698" name="l00698"></a><span class="lineno"> 698</span> <span class="keywordflow">for</span>(<a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> *curr = &amp;sparse.first()[key_to_bucket(key)]; *curr != (std::numeric_limits&lt;size_type&gt;::max)(); curr = &amp;packed.first()[*curr].next) {</div>
<div class="line"><a id="l00699" name="l00699"></a><span class="lineno"> 699</span> <span class="keywordflow">if</span>(packed.second()(packed.first()[*curr].element.first, key)) {</div>
<div class="line"><a id="l00700" name="l00700"></a><span class="lineno"> 700</span> <span class="keyword">const</span> <span class="keyword">auto</span> index = *curr;</div>
<div class="line"><a id="l00701" name="l00701"></a><span class="lineno"> 701</span> *curr = packed.first()[*curr].next;</div>
<div class="line"><a id="l00702" name="l00702"></a><span class="lineno"> 702</span> move_and_pop(index);</div>
<div class="line"><a id="l00703" name="l00703"></a><span class="lineno"> 703</span> <span class="keywordflow">return</span> 1u;</div>
<div class="line"><a id="l00704" name="l00704"></a><span class="lineno"> 704</span> }</div>
<div class="line"><a id="l00705" name="l00705"></a><span class="lineno"> 705</span> }</div>
<div class="line"><a id="l00706" name="l00706"></a><span class="lineno"> 706</span> </div>
<div class="line"><a id="l00707" name="l00707"></a><span class="lineno"> 707</span> <span class="keywordflow">return</span> 0u;</div>
<div class="line"><a id="l00708" name="l00708"></a><span class="lineno"> 708</span> }</div>
</div>
<div class="line"><a id="l00709" name="l00709"></a><span class="lineno"> 709</span></div>
<div class="foldopen" id="foldopen00715" data-start="{" data-end="}">
<div class="line"><a id="l00715" name="l00715"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a468bf103c5f4779ee24d002576150689"> 715</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#a7cdfe85f102518543b7a684c9e8e3bd3">mapped_type</a> &amp;<a class="code hl_function" href="classentt_1_1dense__map.html#a468bf103c5f4779ee24d002576150689">at</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">key_type</a> &amp;key) {</div>
<div class="line"><a id="l00716" name="l00716"></a><span class="lineno"> 716</span> <span class="keyword">auto</span> it = <a class="code hl_function" href="classentt_1_1dense__map.html#a77aa062268245a84c4c27dcc01839814">find</a>(key);</div>
<div class="line"><a id="l00717" name="l00717"></a><span class="lineno"> 717</span> ENTT_ASSERT(it != <a class="code hl_function" href="classentt_1_1dense__map.html#afa80b6dff4ba1f455fabec3ff197e8c5">end</a>(), <span class="stringliteral">&quot;Invalid key&quot;</span>);</div>
<div class="line"><a id="l00718" name="l00718"></a><span class="lineno"> 718</span> <span class="keywordflow">return</span> it-&gt;second;</div>
<div class="line"><a id="l00719" name="l00719"></a><span class="lineno"> 719</span> }</div>
</div>
<div class="line"><a id="l00720" name="l00720"></a><span class="lineno"> 720</span></div>
<div class="foldopen" id="foldopen00722" data-start="{" data-end="}">
<div class="line"><a id="l00722" name="l00722"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a413f21b4eee0336277f24de044fe8cb6"> 722</a></span> [[nodiscard]] <span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#a7cdfe85f102518543b7a684c9e8e3bd3">mapped_type</a> &amp;<a class="code hl_function" href="classentt_1_1dense__map.html#a413f21b4eee0336277f24de044fe8cb6">at</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">key_type</a> &amp;key)<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00723" name="l00723"></a><span class="lineno"> 723</span> <span class="keyword">auto</span> it = <a class="code hl_function" href="classentt_1_1dense__map.html#a77aa062268245a84c4c27dcc01839814">find</a>(key);</div>
<div class="line"><a id="l00724" name="l00724"></a><span class="lineno"> 724</span> ENTT_ASSERT(it != <a class="code hl_function" href="classentt_1_1dense__map.html#a5123c811e7090df1a793e9bc1821d2e5">cend</a>(), <span class="stringliteral">&quot;Invalid key&quot;</span>);</div>
<div class="line"><a id="l00725" name="l00725"></a><span class="lineno"> 725</span> <span class="keywordflow">return</span> it-&gt;second;</div>
<div class="line"><a id="l00726" name="l00726"></a><span class="lineno"> 726</span> }</div>
</div>
<div class="line"><a id="l00727" name="l00727"></a><span class="lineno"> 727</span></div>
<div class="foldopen" id="foldopen00733" data-start="{" data-end="}">
<div class="line"><a id="l00733" name="l00733"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a9b5784ca7ce9ab1ea46b303598f9987d"> 733</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#a7cdfe85f102518543b7a684c9e8e3bd3">mapped_type</a> &amp;<a class="code hl_function" href="classentt_1_1dense__map.html#a9b5784ca7ce9ab1ea46b303598f9987d">operator[]</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">key_type</a> &amp;key) {</div>
<div class="line"><a id="l00734" name="l00734"></a><span class="lineno"> 734</span> <span class="keywordflow">return</span> insert_or_do_nothing(key).first-&gt;second;</div>
<div class="line"><a id="l00735" name="l00735"></a><span class="lineno"> 735</span> }</div>
</div>
<div class="line"><a id="l00736" name="l00736"></a><span class="lineno"> 736</span></div>
<div class="foldopen" id="foldopen00742" data-start="{" data-end="}">
<div class="line"><a id="l00742" name="l00742"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a19e0c8cdb0eef57582ce061a631b0a56"> 742</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#a7cdfe85f102518543b7a684c9e8e3bd3">mapped_type</a> &amp;<a class="code hl_function" href="classentt_1_1dense__map.html#a19e0c8cdb0eef57582ce061a631b0a56">operator[]</a>(<a class="code hl_typedef" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">key_type</a> &amp;&amp;key) {</div>
<div class="line"><a id="l00743" name="l00743"></a><span class="lineno"> 743</span> <span class="keywordflow">return</span> insert_or_do_nothing(std::move(key)).first-&gt;second;</div>
<div class="line"><a id="l00744" name="l00744"></a><span class="lineno"> 744</span> }</div>
</div>
<div class="line"><a id="l00745" name="l00745"></a><span class="lineno"> 745</span></div>
<div class="foldopen" id="foldopen00751" data-start="{" data-end="}">
<div class="line"><a id="l00751" name="l00751"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a4b5f56217b3b8eae9ad34334df1a931d"> 751</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a4b5f56217b3b8eae9ad34334df1a931d">count</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">key_type</a> &amp;key)<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00752" name="l00752"></a><span class="lineno"> 752</span> <span class="keywordflow">return</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a77aa062268245a84c4c27dcc01839814">find</a>(key) != <a class="code hl_function" href="classentt_1_1dense__map.html#afa80b6dff4ba1f455fabec3ff197e8c5">end</a>();</div>
<div class="line"><a id="l00753" name="l00753"></a><span class="lineno"> 753</span> }</div>
</div>
<div class="line"><a id="l00754" name="l00754"></a><span class="lineno"> 754</span></div>
<div class="line"><a id="l00761" name="l00761"></a><span class="lineno"> 761</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Other&gt;</div>
<div class="line"><a id="l00762" name="l00762"></a><span class="lineno"> 762</span> [[nodiscard]] std::enable_if_t&lt;is_transparent_v&lt;hasher&gt; &amp;&amp; <a class="code hl_variable" href="namespaceentt.html#a5fd3998d86cc531f800d0104478771f4">is_transparent_v&lt;key_equal&gt;</a>, std::conditional_t&lt;false, Other, size_type&gt;&gt;</div>
<div class="foldopen" id="foldopen00763" data-start="{" data-end="}">
<div class="line"><a id="l00763" name="l00763"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a3858017ba66ff9989fe2427065dd6d97"> 763</a></span> <a class="code hl_function" href="classentt_1_1dense__map.html#a3858017ba66ff9989fe2427065dd6d97">count</a>(<span class="keyword">const</span> Other &amp;key)<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00764" name="l00764"></a><span class="lineno"> 764</span> <span class="keywordflow">return</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a77aa062268245a84c4c27dcc01839814">find</a>(key) != <a class="code hl_function" href="classentt_1_1dense__map.html#afa80b6dff4ba1f455fabec3ff197e8c5">end</a>();</div>
<div class="line"><a id="l00765" name="l00765"></a><span class="lineno"> 765</span> }</div>
</div>
<div class="line"><a id="l00766" name="l00766"></a><span class="lineno"> 766</span></div>
<div class="foldopen" id="foldopen00773" data-start="{" data-end="}">
<div class="line"><a id="l00773" name="l00773"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a77aa062268245a84c4c27dcc01839814"> 773</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#acc07b299f15a57db885089cc1a31322d">iterator</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a77aa062268245a84c4c27dcc01839814">find</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">key_type</a> &amp;key) {</div>
<div class="line"><a id="l00774" name="l00774"></a><span class="lineno"> 774</span> <span class="keywordflow">return</span> constrained_find(key, key_to_bucket(key));</div>
<div class="line"><a id="l00775" name="l00775"></a><span class="lineno"> 775</span> }</div>
</div>
<div class="line"><a id="l00776" name="l00776"></a><span class="lineno"> 776</span></div>
<div class="foldopen" id="foldopen00778" data-start="{" data-end="}">
<div class="line"><a id="l00778" name="l00778"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a5b47e5c447352298fca87921774c4a3d"> 778</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#a5c236223418b9ef327397424e2df24f8">const_iterator</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a5b47e5c447352298fca87921774c4a3d">find</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">key_type</a> &amp;key)<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00779" name="l00779"></a><span class="lineno"> 779</span> <span class="keywordflow">return</span> constrained_find(key, key_to_bucket(key));</div>
<div class="line"><a id="l00780" name="l00780"></a><span class="lineno"> 780</span> }</div>
</div>
<div class="line"><a id="l00781" name="l00781"></a><span class="lineno"> 781</span></div>
<div class="line"><a id="l00790" name="l00790"></a><span class="lineno"> 790</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Other&gt;</div>
<div class="line"><a id="l00791" name="l00791"></a><span class="lineno"> 791</span> [[nodiscard]] std::enable_if_t&lt;is_transparent_v&lt;hasher&gt; &amp;&amp; <a class="code hl_variable" href="namespaceentt.html#a5fd3998d86cc531f800d0104478771f4">is_transparent_v&lt;key_equal&gt;</a>, std::conditional_t&lt;false, Other, iterator&gt;&gt;</div>
<div class="foldopen" id="foldopen00792" data-start="{" data-end="}">
<div class="line"><a id="l00792" name="l00792"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#abf771ba10ee17109769cecd68f0991c5"> 792</a></span> <a class="code hl_function" href="classentt_1_1dense__map.html#abf771ba10ee17109769cecd68f0991c5">find</a>(<span class="keyword">const</span> Other &amp;key) {</div>
<div class="line"><a id="l00793" name="l00793"></a><span class="lineno"> 793</span> <span class="keywordflow">return</span> constrained_find(key, key_to_bucket(key));</div>
<div class="line"><a id="l00794" name="l00794"></a><span class="lineno"> 794</span> }</div>
</div>
<div class="line"><a id="l00795" name="l00795"></a><span class="lineno"> 795</span></div>
<div class="line"><a id="l00797" name="l00797"></a><span class="lineno"> 797</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Other&gt;</div>
<div class="line"><a id="l00798" name="l00798"></a><span class="lineno"> 798</span> [[nodiscard]] std::enable_if_t&lt;is_transparent_v&lt;hasher&gt; &amp;&amp; <a class="code hl_variable" href="namespaceentt.html#a5fd3998d86cc531f800d0104478771f4">is_transparent_v&lt;key_equal&gt;</a>, std::conditional_t&lt;false, Other, const_iterator&gt;&gt;</div>
<div class="foldopen" id="foldopen00799" data-start="{" data-end="}">
<div class="line"><a id="l00799" name="l00799"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a4c611a71d59737c941b1aaf29e64c9b7"> 799</a></span> <a class="code hl_function" href="classentt_1_1dense__map.html#a4c611a71d59737c941b1aaf29e64c9b7">find</a>(<span class="keyword">const</span> Other &amp;key)<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00800" name="l00800"></a><span class="lineno"> 800</span> <span class="keywordflow">return</span> constrained_find(key, key_to_bucket(key));</div>
<div class="line"><a id="l00801" name="l00801"></a><span class="lineno"> 801</span> }</div>
</div>
<div class="line"><a id="l00802" name="l00802"></a><span class="lineno"> 802</span></div>
<div class="foldopen" id="foldopen00809" data-start="{" data-end="}">
<div class="line"><a id="l00809" name="l00809"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a77b33cb48b4784e336d87246701b2024"> 809</a></span> [[nodiscard]] std::pair&lt;iterator, iterator&gt; <a class="code hl_function" href="classentt_1_1dense__map.html#a77b33cb48b4784e336d87246701b2024">equal_range</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">key_type</a> &amp;key) {</div>
<div class="line"><a id="l00810" name="l00810"></a><span class="lineno"> 810</span> <span class="keyword">const</span> <span class="keyword">auto</span> it = <a class="code hl_function" href="classentt_1_1dense__map.html#a77aa062268245a84c4c27dcc01839814">find</a>(key);</div>
<div class="line"><a id="l00811" name="l00811"></a><span class="lineno"> 811</span> <span class="keywordflow">return</span> {it, it + !(it == <a class="code hl_function" href="classentt_1_1dense__map.html#afa80b6dff4ba1f455fabec3ff197e8c5">end</a>())};</div>
<div class="line"><a id="l00812" name="l00812"></a><span class="lineno"> 812</span> }</div>
</div>
<div class="line"><a id="l00813" name="l00813"></a><span class="lineno"> 813</span></div>
<div class="foldopen" id="foldopen00815" data-start="{" data-end="}">
<div class="line"><a id="l00815" name="l00815"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#af76ed82791a0f50d0f7aa0bcec46105b"> 815</a></span> [[nodiscard]] std::pair&lt;const_iterator, const_iterator&gt; <a class="code hl_function" href="classentt_1_1dense__map.html#af76ed82791a0f50d0f7aa0bcec46105b">equal_range</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">key_type</a> &amp;key)<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00816" name="l00816"></a><span class="lineno"> 816</span> <span class="keyword">const</span> <span class="keyword">auto</span> it = <a class="code hl_function" href="classentt_1_1dense__map.html#a77aa062268245a84c4c27dcc01839814">find</a>(key);</div>
<div class="line"><a id="l00817" name="l00817"></a><span class="lineno"> 817</span> <span class="keywordflow">return</span> {it, it + !(it == <a class="code hl_function" href="classentt_1_1dense__map.html#a5123c811e7090df1a793e9bc1821d2e5">cend</a>())};</div>
<div class="line"><a id="l00818" name="l00818"></a><span class="lineno"> 818</span> }</div>
</div>
<div class="line"><a id="l00819" name="l00819"></a><span class="lineno"> 819</span></div>
<div class="line"><a id="l00828" name="l00828"></a><span class="lineno"> 828</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Other&gt;</div>
<div class="line"><a id="l00829" name="l00829"></a><span class="lineno"> 829</span> [[nodiscard]] std::enable_if_t&lt;is_transparent_v&lt;hasher&gt; &amp;&amp; <a class="code hl_variable" href="namespaceentt.html#a5fd3998d86cc531f800d0104478771f4">is_transparent_v&lt;key_equal&gt;</a>, std::conditional_t&lt;false, Other, std::pair&lt;iterator, iterator&gt;&gt;&gt;</div>
<div class="foldopen" id="foldopen00830" data-start="{" data-end="}">
<div class="line"><a id="l00830" name="l00830"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a3d747a3b187a97814603e41ad37bf26e"> 830</a></span> <a class="code hl_function" href="classentt_1_1dense__map.html#a3d747a3b187a97814603e41ad37bf26e">equal_range</a>(<span class="keyword">const</span> Other &amp;key) {</div>
<div class="line"><a id="l00831" name="l00831"></a><span class="lineno"> 831</span> <span class="keyword">const</span> <span class="keyword">auto</span> it = <a class="code hl_function" href="classentt_1_1dense__map.html#a77aa062268245a84c4c27dcc01839814">find</a>(key);</div>
<div class="line"><a id="l00832" name="l00832"></a><span class="lineno"> 832</span> <span class="keywordflow">return</span> {it, it + !(it == <a class="code hl_function" href="classentt_1_1dense__map.html#afa80b6dff4ba1f455fabec3ff197e8c5">end</a>())};</div>
<div class="line"><a id="l00833" name="l00833"></a><span class="lineno"> 833</span> }</div>
</div>
<div class="line"><a id="l00834" name="l00834"></a><span class="lineno"> 834</span></div>
<div class="line"><a id="l00836" name="l00836"></a><span class="lineno"> 836</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Other&gt;</div>
<div class="line"><a id="l00837" name="l00837"></a><span class="lineno"> 837</span> [[nodiscard]] std::enable_if_t&lt;is_transparent_v&lt;hasher&gt; &amp;&amp; <a class="code hl_variable" href="namespaceentt.html#a5fd3998d86cc531f800d0104478771f4">is_transparent_v&lt;key_equal&gt;</a>, std::conditional_t&lt;false, Other, std::pair&lt;const_iterator, const_iterator&gt;&gt;&gt;</div>
<div class="foldopen" id="foldopen00838" data-start="{" data-end="}">
<div class="line"><a id="l00838" name="l00838"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a973f2399943dc681e617bb8b46e9244c"> 838</a></span> <a class="code hl_function" href="classentt_1_1dense__map.html#a973f2399943dc681e617bb8b46e9244c">equal_range</a>(<span class="keyword">const</span> Other &amp;key)<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00839" name="l00839"></a><span class="lineno"> 839</span> <span class="keyword">const</span> <span class="keyword">auto</span> it = <a class="code hl_function" href="classentt_1_1dense__map.html#a77aa062268245a84c4c27dcc01839814">find</a>(key);</div>
<div class="line"><a id="l00840" name="l00840"></a><span class="lineno"> 840</span> <span class="keywordflow">return</span> {it, it + !(it == <a class="code hl_function" href="classentt_1_1dense__map.html#a5123c811e7090df1a793e9bc1821d2e5">cend</a>())};</div>
<div class="line"><a id="l00841" name="l00841"></a><span class="lineno"> 841</span> }</div>
</div>
<div class="line"><a id="l00842" name="l00842"></a><span class="lineno"> 842</span></div>
<div class="foldopen" id="foldopen00848" data-start="{" data-end="}">
<div class="line"><a id="l00848" name="l00848"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a4d884a2b7164b3df97d93dd2804222b0"> 848</a></span> [[nodiscard]] <span class="keywordtype">bool</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a4d884a2b7164b3df97d93dd2804222b0">contains</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">key_type</a> &amp;key)<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00849" name="l00849"></a><span class="lineno"> 849</span> <span class="keywordflow">return</span> (<a class="code hl_function" href="classentt_1_1dense__map.html#a77aa062268245a84c4c27dcc01839814">find</a>(key) != <a class="code hl_function" href="classentt_1_1dense__map.html#a5123c811e7090df1a793e9bc1821d2e5">cend</a>());</div>
<div class="line"><a id="l00850" name="l00850"></a><span class="lineno"> 850</span> }</div>
</div>
<div class="line"><a id="l00851" name="l00851"></a><span class="lineno"> 851</span></div>
<div class="line"><a id="l00859" name="l00859"></a><span class="lineno"> 859</span> <span class="keyword">template</span>&lt;<span class="keyword">typename</span> Other&gt;</div>
<div class="line"><a id="l00860" name="l00860"></a><span class="lineno"> 860</span> [[nodiscard]] std::enable_if_t&lt;is_transparent_v&lt;hasher&gt; &amp;&amp; <a class="code hl_variable" href="namespaceentt.html#a5fd3998d86cc531f800d0104478771f4">is_transparent_v&lt;key_equal&gt;</a>, std::conditional_t&lt;false, Other, bool&gt;&gt;</div>
<div class="foldopen" id="foldopen00861" data-start="{" data-end="}">
<div class="line"><a id="l00861" name="l00861"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a20be7fc1cde4a3ae47f22333e3220200"> 861</a></span> <a class="code hl_function" href="classentt_1_1dense__map.html#a20be7fc1cde4a3ae47f22333e3220200">contains</a>(<span class="keyword">const</span> Other &amp;key)<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00862" name="l00862"></a><span class="lineno"> 862</span> <span class="keywordflow">return</span> (<a class="code hl_function" href="classentt_1_1dense__map.html#a77aa062268245a84c4c27dcc01839814">find</a>(key) != <a class="code hl_function" href="classentt_1_1dense__map.html#a5123c811e7090df1a793e9bc1821d2e5">cend</a>());</div>
<div class="line"><a id="l00863" name="l00863"></a><span class="lineno"> 863</span> }</div>
</div>
<div class="line"><a id="l00864" name="l00864"></a><span class="lineno"> 864</span></div>
<div class="foldopen" id="foldopen00870" data-start="{" data-end="}">
<div class="line"><a id="l00870" name="l00870"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a9e9beebb937e95a40246455194c86c84"> 870</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#ad699469dc43bfd00d9ea86c686afb394">const_local_iterator</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a9e9beebb937e95a40246455194c86c84">cbegin</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> index)<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00871" name="l00871"></a><span class="lineno"> 871</span> <span class="keywordflow">return</span> {packed.first().begin(), sparse.first()[index]};</div>
<div class="line"><a id="l00872" name="l00872"></a><span class="lineno"> 872</span> }</div>
</div>
<div class="line"><a id="l00873" name="l00873"></a><span class="lineno"> 873</span></div>
<div class="foldopen" id="foldopen00879" data-start="{" data-end="}">
<div class="line"><a id="l00879" name="l00879"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a33900c670781f415f4eb0bfeb5be04a3"> 879</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#ad699469dc43bfd00d9ea86c686afb394">const_local_iterator</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a33900c670781f415f4eb0bfeb5be04a3">begin</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> index)<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00880" name="l00880"></a><span class="lineno"> 880</span> <span class="keywordflow">return</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a2cef5e32d1e4575669c9afcf6bcbedc5">cbegin</a>(index);</div>
<div class="line"><a id="l00881" name="l00881"></a><span class="lineno"> 881</span> }</div>
</div>
<div class="line"><a id="l00882" name="l00882"></a><span class="lineno"> 882</span></div>
<div class="foldopen" id="foldopen00888" data-start="{" data-end="}">
<div class="line"><a id="l00888" name="l00888"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a4b71476135fb7147c02ec7a801564c72"> 888</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#ad05e437f37f277cbe5c6121e67a4e89a">local_iterator</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a4b71476135fb7147c02ec7a801564c72">begin</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> index) {</div>
<div class="line"><a id="l00889" name="l00889"></a><span class="lineno"> 889</span> <span class="keywordflow">return</span> {packed.first().begin(), sparse.first()[index]};</div>
<div class="line"><a id="l00890" name="l00890"></a><span class="lineno"> 890</span> }</div>
</div>
<div class="line"><a id="l00891" name="l00891"></a><span class="lineno"> 891</span></div>
<div class="foldopen" id="foldopen00897" data-start="{" data-end="}">
<div class="line"><a id="l00897" name="l00897"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a8125ea2706a6208565a4d67f0e6efbed"> 897</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#ad699469dc43bfd00d9ea86c686afb394">const_local_iterator</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a8125ea2706a6208565a4d67f0e6efbed">cend</a>([[maybe_unused]] <span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> index)<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00898" name="l00898"></a><span class="lineno"> 898</span> <span class="keywordflow">return</span> {packed.first().begin(), (std::numeric_limits&lt;size_type&gt;::max)()};</div>
<div class="line"><a id="l00899" name="l00899"></a><span class="lineno"> 899</span> }</div>
</div>
<div class="line"><a id="l00900" name="l00900"></a><span class="lineno"> 900</span></div>
<div class="foldopen" id="foldopen00906" data-start="{" data-end="}">
<div class="line"><a id="l00906" name="l00906"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a3c36baa7b9aa7df7d3a07ca090319328"> 906</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#ad699469dc43bfd00d9ea86c686afb394">const_local_iterator</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a3c36baa7b9aa7df7d3a07ca090319328">end</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> index)<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00907" name="l00907"></a><span class="lineno"> 907</span> <span class="keywordflow">return</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a5123c811e7090df1a793e9bc1821d2e5">cend</a>(index);</div>
<div class="line"><a id="l00908" name="l00908"></a><span class="lineno"> 908</span> }</div>
</div>
<div class="line"><a id="l00909" name="l00909"></a><span class="lineno"> 909</span></div>
<div class="foldopen" id="foldopen00915" data-start="{" data-end="}">
<div class="line"><a id="l00915" name="l00915"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#ab971fb709972a0e26b95e4fdb89aa64e"> 915</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#ad05e437f37f277cbe5c6121e67a4e89a">local_iterator</a> <a class="code hl_function" href="classentt_1_1dense__map.html#ab971fb709972a0e26b95e4fdb89aa64e">end</a>([[maybe_unused]] <span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> index) {</div>
<div class="line"><a id="l00916" name="l00916"></a><span class="lineno"> 916</span> <span class="keywordflow">return</span> {packed.first().begin(), (std::numeric_limits&lt;size_type&gt;::max)()};</div>
<div class="line"><a id="l00917" name="l00917"></a><span class="lineno"> 917</span> }</div>
</div>
<div class="line"><a id="l00918" name="l00918"></a><span class="lineno"> 918</span></div>
<div class="foldopen" id="foldopen00923" data-start="{" data-end="}">
<div class="line"><a id="l00923" name="l00923"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#aee246b41534137f279a11eb5e225a6e5"> 923</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> <a class="code hl_function" href="classentt_1_1dense__map.html#aee246b41534137f279a11eb5e225a6e5">bucket_count</a>()<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00924" name="l00924"></a><span class="lineno"> 924</span> <span class="keywordflow">return</span> sparse.first().size();</div>
<div class="line"><a id="l00925" name="l00925"></a><span class="lineno"> 925</span> }</div>
</div>
<div class="line"><a id="l00926" name="l00926"></a><span class="lineno"> 926</span></div>
<div class="foldopen" id="foldopen00931" data-start="{" data-end="}">
<div class="line"><a id="l00931" name="l00931"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a4818548e35a239228a5fae77af01e7f5"> 931</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a4818548e35a239228a5fae77af01e7f5">max_bucket_count</a>()<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00932" name="l00932"></a><span class="lineno"> 932</span> <span class="keywordflow">return</span> sparse.first().max_size();</div>
<div class="line"><a id="l00933" name="l00933"></a><span class="lineno"> 933</span> }</div>
</div>
<div class="line"><a id="l00934" name="l00934"></a><span class="lineno"> 934</span></div>
<div class="foldopen" id="foldopen00940" data-start="{" data-end="}">
<div class="line"><a id="l00940" name="l00940"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#ae094f65cda09d80851306f6a4bba7b50"> 940</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> <a class="code hl_function" href="classentt_1_1dense__map.html#ae094f65cda09d80851306f6a4bba7b50">bucket_size</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> index)<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00941" name="l00941"></a><span class="lineno"> 941</span> <span class="keywordflow">return</span> <span class="keyword">static_cast&lt;</span><a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a><span class="keyword">&gt;</span>(std::distance(<a class="code hl_function" href="classentt_1_1dense__map.html#a7c0e7de10687bc1e810d67ba6a91396d">begin</a>(index), <a class="code hl_function" href="classentt_1_1dense__map.html#afa80b6dff4ba1f455fabec3ff197e8c5">end</a>(index)));</div>
<div class="line"><a id="l00942" name="l00942"></a><span class="lineno"> 942</span> }</div>
</div>
<div class="line"><a id="l00943" name="l00943"></a><span class="lineno"> 943</span></div>
<div class="foldopen" id="foldopen00949" data-start="{" data-end="}">
<div class="line"><a id="l00949" name="l00949"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a9a591d419dd5649e52907a3032f8c0b8"> 949</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> <a class="code hl_function" href="classentt_1_1dense__map.html#a9a591d419dd5649e52907a3032f8c0b8">bucket</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">key_type</a> &amp;key)<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00950" name="l00950"></a><span class="lineno"> 950</span> <span class="keywordflow">return</span> key_to_bucket(key);</div>
<div class="line"><a id="l00951" name="l00951"></a><span class="lineno"> 951</span> }</div>
</div>
<div class="line"><a id="l00952" name="l00952"></a><span class="lineno"> 952</span></div>
<div class="foldopen" id="foldopen00957" data-start="{" data-end="}">
<div class="line"><a id="l00957" name="l00957"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a0ebd2095ae61e1908572efa33dc3df56"> 957</a></span> [[nodiscard]] <span class="keywordtype">float</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a0ebd2095ae61e1908572efa33dc3df56">load_factor</a>()<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00958" name="l00958"></a><span class="lineno"> 958</span> <span class="keywordflow">return</span> <span class="keyword">static_cast&lt;</span><span class="keywordtype">float</span><span class="keyword">&gt;</span>(<a class="code hl_function" href="classentt_1_1dense__map.html#a38b10511f585724b7eb6e5f9556dea21">size</a>()) / <span class="keyword">static_cast&lt;</span><span class="keywordtype">float</span><span class="keyword">&gt;</span>(<a class="code hl_function" href="classentt_1_1dense__map.html#aee246b41534137f279a11eb5e225a6e5">bucket_count</a>());</div>
<div class="line"><a id="l00959" name="l00959"></a><span class="lineno"> 959</span> }</div>
</div>
<div class="line"><a id="l00960" name="l00960"></a><span class="lineno"> 960</span></div>
<div class="foldopen" id="foldopen00965" data-start="{" data-end="}">
<div class="line"><a id="l00965" name="l00965"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a54a2dd65d401a992fd91fb8a91faea86"> 965</a></span> [[nodiscard]] <span class="keywordtype">float</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a54a2dd65d401a992fd91fb8a91faea86">max_load_factor</a>()<span class="keyword"> const </span>{</div>
<div class="line"><a id="l00966" name="l00966"></a><span class="lineno"> 966</span> <span class="keywordflow">return</span> threshold;</div>
<div class="line"><a id="l00967" name="l00967"></a><span class="lineno"> 967</span> }</div>
</div>
<div class="line"><a id="l00968" name="l00968"></a><span class="lineno"> 968</span></div>
<div class="foldopen" id="foldopen00973" data-start="{" data-end="}">
<div class="line"><a id="l00973" name="l00973"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a608539db499acbc3a7548421ea5d8709"> 973</a></span> <span class="keywordtype">void</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a608539db499acbc3a7548421ea5d8709">max_load_factor</a>(<span class="keyword">const</span> <span class="keywordtype">float</span> value) {</div>
<div class="line"><a id="l00974" name="l00974"></a><span class="lineno"> 974</span> ENTT_ASSERT(value &gt; 0.f, <span class="stringliteral">&quot;Invalid load factor&quot;</span>);</div>
<div class="line"><a id="l00975" name="l00975"></a><span class="lineno"> 975</span> threshold = value;</div>
<div class="line"><a id="l00976" name="l00976"></a><span class="lineno"> 976</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a7cea2e02e86eec9421ddaab64f15db6b">rehash</a>(0u);</div>
<div class="line"><a id="l00977" name="l00977"></a><span class="lineno"> 977</span> }</div>
</div>
<div class="line"><a id="l00978" name="l00978"></a><span class="lineno"> 978</span></div>
<div class="foldopen" id="foldopen00984" data-start="{" data-end="}">
<div class="line"><a id="l00984" name="l00984"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a7cea2e02e86eec9421ddaab64f15db6b"> 984</a></span> <span class="keywordtype">void</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a7cea2e02e86eec9421ddaab64f15db6b">rehash</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> cnt) {</div>
<div class="line"><a id="l00985" name="l00985"></a><span class="lineno"> 985</span> <span class="keyword">auto</span> value = cnt &gt; minimum_capacity ? cnt : minimum_capacity;</div>
<div class="line"><a id="l00986" name="l00986"></a><span class="lineno"> 986</span> <span class="keyword">const</span> <span class="keyword">auto</span> cap = <span class="keyword">static_cast&lt;</span><a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a><span class="keyword">&gt;</span>(<span class="keyword">static_cast&lt;</span><span class="keywordtype">float</span><span class="keyword">&gt;</span>(<a class="code hl_function" href="classentt_1_1dense__map.html#a38b10511f585724b7eb6e5f9556dea21">size</a>()) / <a class="code hl_function" href="classentt_1_1dense__map.html#a54a2dd65d401a992fd91fb8a91faea86">max_load_factor</a>());</div>
<div class="line"><a id="l00987" name="l00987"></a><span class="lineno"> 987</span> value = value &gt; cap ? value : cap;</div>
<div class="line"><a id="l00988" name="l00988"></a><span class="lineno"> 988</span> </div>
<div class="line"><a id="l00989" name="l00989"></a><span class="lineno"> 989</span> <span class="keywordflow">if</span>(<span class="keyword">const</span> <span class="keyword">auto</span> sz = <a class="code hl_function" href="namespaceentt.html#a8f6fb41a1c8c0c5968bfca369e51a73e">next_power_of_two</a>(value); sz != <a class="code hl_function" href="classentt_1_1dense__map.html#aee246b41534137f279a11eb5e225a6e5">bucket_count</a>()) {</div>
<div class="line"><a id="l00990" name="l00990"></a><span class="lineno"> 990</span> sparse.first().resize(sz);</div>
<div class="line"><a id="l00991" name="l00991"></a><span class="lineno"> 991</span> </div>
<div class="line"><a id="l00992" name="l00992"></a><span class="lineno"> 992</span> <span class="keywordflow">for</span>(<span class="keyword">auto</span> &amp;&amp;elem: sparse.first()) {</div>
<div class="line"><a id="l00993" name="l00993"></a><span class="lineno"> 993</span> elem = (std::numeric_limits&lt;size_type&gt;::max)();</div>
<div class="line"><a id="l00994" name="l00994"></a><span class="lineno"> 994</span> }</div>
<div class="line"><a id="l00995" name="l00995"></a><span class="lineno"> 995</span> </div>
<div class="line"><a id="l00996" name="l00996"></a><span class="lineno"> 996</span> <span class="keywordflow">for</span>(<a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> pos{}, last = <a class="code hl_function" href="classentt_1_1dense__map.html#a38b10511f585724b7eb6e5f9556dea21">size</a>(); pos &lt; last; ++pos) {</div>
<div class="line"><a id="l00997" name="l00997"></a><span class="lineno"> 997</span> <span class="keyword">const</span> <span class="keyword">auto</span> index = key_to_bucket(packed.first()[pos].element.first);</div>
<div class="line"><a id="l00998" name="l00998"></a><span class="lineno"> 998</span> packed.first()[pos].next = std::exchange(sparse.first()[index], pos);</div>
<div class="line"><a id="l00999" name="l00999"></a><span class="lineno"> 999</span> }</div>
<div class="line"><a id="l01000" name="l01000"></a><span class="lineno"> 1000</span> }</div>
<div class="line"><a id="l01001" name="l01001"></a><span class="lineno"> 1001</span> }</div>
</div>
<div class="line"><a id="l01002" name="l01002"></a><span class="lineno"> 1002</span></div>
<div class="foldopen" id="foldopen01008" data-start="{" data-end="}">
<div class="line"><a id="l01008" name="l01008"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#a47084f57549451518ef81a0f7cbdae0e"> 1008</a></span> <span class="keywordtype">void</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a47084f57549451518ef81a0f7cbdae0e">reserve</a>(<span class="keyword">const</span> <a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a> cnt) {</div>
<div class="line"><a id="l01009" name="l01009"></a><span class="lineno"> 1009</span> packed.first().reserve(cnt);</div>
<div class="line"><a id="l01010" name="l01010"></a><span class="lineno"> 1010</span> <a class="code hl_function" href="classentt_1_1dense__map.html#a7cea2e02e86eec9421ddaab64f15db6b">rehash</a>(<span class="keyword">static_cast&lt;</span><a class="code hl_typedef" href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">size_type</a><span class="keyword">&gt;</span>(std::ceil(<span class="keyword">static_cast&lt;</span><span class="keywordtype">float</span><span class="keyword">&gt;</span>(cnt) / <a class="code hl_function" href="classentt_1_1dense__map.html#a54a2dd65d401a992fd91fb8a91faea86">max_load_factor</a>())));</div>
<div class="line"><a id="l01011" name="l01011"></a><span class="lineno"> 1011</span> }</div>
</div>
<div class="line"><a id="l01012" name="l01012"></a><span class="lineno"> 1012</span></div>
<div class="foldopen" id="foldopen01017" data-start="{" data-end="}">
<div class="line"><a id="l01017" name="l01017"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#afa1426bfb2ff55c9c4d0471303fcf6cc"> 1017</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#ae62722d472417185388e952655b120e9">hasher</a> <a class="code hl_function" href="classentt_1_1dense__map.html#afa1426bfb2ff55c9c4d0471303fcf6cc">hash_function</a>()<span class="keyword"> const </span>{</div>
<div class="line"><a id="l01018" name="l01018"></a><span class="lineno"> 1018</span> <span class="keywordflow">return</span> sparse.second();</div>
<div class="line"><a id="l01019" name="l01019"></a><span class="lineno"> 1019</span> }</div>
</div>
<div class="line"><a id="l01020" name="l01020"></a><span class="lineno"> 1020</span></div>
<div class="foldopen" id="foldopen01025" data-start="{" data-end="}">
<div class="line"><a id="l01025" name="l01025"></a><span class="lineno"><a class="line" href="classentt_1_1dense__map.html#ac2039886ad16466a4f9928dc737cd711"> 1025</a></span> [[nodiscard]] <a class="code hl_typedef" href="classentt_1_1dense__map.html#a41a26ee3be60abf7b5ecf16c99948086">key_equal</a> <a class="code hl_function" href="classentt_1_1dense__map.html#ac2039886ad16466a4f9928dc737cd711">key_eq</a>()<span class="keyword"> const </span>{</div>
<div class="line"><a id="l01026" name="l01026"></a><span class="lineno"> 1026</span> <span class="keywordflow">return</span> packed.second();</div>
<div class="line"><a id="l01027" name="l01027"></a><span class="lineno"> 1027</span> }</div>
</div>
<div class="line"><a id="l01028" name="l01028"></a><span class="lineno"> 1028</span> </div>
<div class="line"><a id="l01029" name="l01029"></a><span class="lineno"> 1029</span><span class="keyword">private</span>:</div>
<div class="line"><a id="l01030" name="l01030"></a><span class="lineno"> 1030</span> <a class="code hl_class" href="classentt_1_1compressed__pair.html">compressed_pair&lt;sparse_container_type, hasher&gt;</a> sparse;</div>
<div class="line"><a id="l01031" name="l01031"></a><span class="lineno"> 1031</span> <a class="code hl_class" href="classentt_1_1compressed__pair.html">compressed_pair&lt;packed_container_type, key_equal&gt;</a> packed;</div>
<div class="line"><a id="l01032" name="l01032"></a><span class="lineno"> 1032</span> <span class="keywordtype">float</span> threshold{default_threshold};</div>
<div class="line"><a id="l01033" name="l01033"></a><span class="lineno"> 1033</span>};</div>
</div>
<div class="line"><a id="l01034" name="l01034"></a><span class="lineno"> 1034</span> </div>
<div class="line"><a id="l01035" name="l01035"></a><span class="lineno"> 1035</span>} <span class="comment">// namespace entt</span></div>
</div>
<div class="line"><a id="l01036" name="l01036"></a><span class="lineno"> 1036</span></div>
<div class="line"><a id="l01038" name="l01038"></a><span class="lineno"> 1038</span><span class="keyword">namespace </span>std {</div>
<div class="line"><a id="l01039" name="l01039"></a><span class="lineno"> 1039</span> </div>
<div class="line"><a id="l01040" name="l01040"></a><span class="lineno"> 1040</span><span class="keyword">template</span>&lt;<span class="keyword">typename</span> Key, <span class="keyword">typename</span> Value, <span class="keyword">typename</span> Allocator&gt;</div>
<div class="line"><a id="l01041" name="l01041"></a><span class="lineno"> 1041</span><span class="keyword">struct </span>uses_allocator&lt;entt::internal::dense_map_node&lt;Key, Value&gt;, Allocator&gt;</div>
<div class="line"><a id="l01042" name="l01042"></a><span class="lineno"> 1042</span> : std::true_type {};</div>
<div class="line"><a id="l01043" name="l01043"></a><span class="lineno"> 1043</span> </div>
<div class="line"><a id="l01044" name="l01044"></a><span class="lineno"> 1044</span>} <span class="comment">// namespace std</span></div>
<div class="line"><a id="l01046" name="l01046"></a><span class="lineno"> 1046</span> </div>
<div class="line"><a id="l01047" name="l01047"></a><span class="lineno"> 1047</span><span class="preprocessor">#endif</span></div>
<div class="ttc" id="aclassentt_1_1compressed__pair_html"><div class="ttname"><a href="classentt_1_1compressed__pair.html">entt::compressed_pair</a></div><div class="ttdoc">A compressed pair.</div><div class="ttdef"><b>Definition</b> <a href="compressed__pair_8hpp_source.html#l00085">compressed_pair.hpp:87</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a07183a6c046d3a3b2e7201bd63aa8efe"><div class="ttname"><a href="classentt_1_1dense__map.html#a07183a6c046d3a3b2e7201bd63aa8efe">entt::dense_map::dense_map</a></div><div class="ttdeci">dense_map(const size_type cnt, const hasher &amp;hash=hasher{}, const key_equal &amp;equal=key_equal{}, const allocator_type &amp;allocator=allocator_type{})</div><div class="ttdoc">Constructs an empty container with a given allocator, hash function, compare function and user suppli...</div><div class="ttdef"><b>Definition</b> <a href="#l00410">dense_map.hpp:410</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a096357c0bdb6342d7d304716e41fcea5"><div class="ttname"><a href="classentt_1_1dense__map.html#a096357c0bdb6342d7d304716e41fcea5">entt::dense_map::dense_map</a></div><div class="ttdeci">dense_map(const allocator_type &amp;allocator)</div><div class="ttdoc">Constructs an empty container with a given allocator.</div><div class="ttdef"><b>Definition</b> <a href="#l00380">dense_map.hpp:380</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a096c30be0af8e15902f5585c8d1208b7"><div class="ttname"><a href="classentt_1_1dense__map.html#a096c30be0af8e15902f5585c8d1208b7">entt::dense_map::clear</a></div><div class="ttdeci">void clear() noexcept</div><div class="ttdoc">Clears the container.</div><div class="ttdef"><b>Definition</b> <a href="#l00541">dense_map.hpp:541</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a0ebd2095ae61e1908572efa33dc3df56"><div class="ttname"><a href="classentt_1_1dense__map.html#a0ebd2095ae61e1908572efa33dc3df56">entt::dense_map::load_factor</a></div><div class="ttdeci">float load_factor() const</div><div class="ttdoc">Returns the average number of elements per bucket.</div><div class="ttdef"><b>Definition</b> <a href="#l00957">dense_map.hpp:957</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a12d1730a14bac304cbd173c05cb2cbf2"><div class="ttname"><a href="classentt_1_1dense__map.html#a12d1730a14bac304cbd173c05cb2cbf2">entt::dense_map::erase</a></div><div class="ttdeci">size_type erase(const key_type &amp;key)</div><div class="ttdoc">Removes the element associated with a given key.</div><div class="ttdef"><b>Definition</b> <a href="#l00697">dense_map.hpp:697</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a19e0c8cdb0eef57582ce061a631b0a56"><div class="ttname"><a href="classentt_1_1dense__map.html#a19e0c8cdb0eef57582ce061a631b0a56">entt::dense_map::operator[]</a></div><div class="ttdeci">mapped_type &amp; operator[](key_type &amp;&amp;key)</div><div class="ttdoc">Accesses or inserts a given element.</div><div class="ttdef"><b>Definition</b> <a href="#l00742">dense_map.hpp:742</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a20be7fc1cde4a3ae47f22333e3220200"><div class="ttname"><a href="classentt_1_1dense__map.html#a20be7fc1cde4a3ae47f22333e3220200">entt::dense_map::contains</a></div><div class="ttdeci">std::enable_if_t&lt; is_transparent_v&lt; hasher &gt; &amp;&amp;is_transparent_v&lt; key_equal &gt;, std::conditional_t&lt; false, Other, bool &gt; &gt; contains(const Other &amp;key) const</div><div class="ttdoc">Checks if the container contains an element with a key that compares equivalent to a given value.</div><div class="ttdef"><b>Definition</b> <a href="#l00861">dense_map.hpp:861</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a2cef5e32d1e4575669c9afcf6bcbedc5"><div class="ttname"><a href="classentt_1_1dense__map.html#a2cef5e32d1e4575669c9afcf6bcbedc5">entt::dense_map::cbegin</a></div><div class="ttdeci">const_iterator cbegin() const noexcept</div><div class="ttdoc">Returns an iterator to the beginning.</div><div class="ttdef"><b>Definition</b> <a href="#l00483">dense_map.hpp:483</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a33900c670781f415f4eb0bfeb5be04a3"><div class="ttname"><a href="classentt_1_1dense__map.html#a33900c670781f415f4eb0bfeb5be04a3">entt::dense_map::begin</a></div><div class="ttdeci">const_local_iterator begin(const size_type index) const</div><div class="ttdoc">Returns an iterator to the beginning of a given bucket.</div><div class="ttdef"><b>Definition</b> <a href="#l00879">dense_map.hpp:879</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a3858017ba66ff9989fe2427065dd6d97"><div class="ttname"><a href="classentt_1_1dense__map.html#a3858017ba66ff9989fe2427065dd6d97">entt::dense_map::count</a></div><div class="ttdeci">std::enable_if_t&lt; is_transparent_v&lt; hasher &gt; &amp;&amp;is_transparent_v&lt; key_equal &gt;, std::conditional_t&lt; false, Other, size_type &gt; &gt; count(const Other &amp;key) const</div><div class="ttdoc">Returns the number of elements matching a key (either 1 or 0).</div><div class="ttdef"><b>Definition</b> <a href="#l00763">dense_map.hpp:763</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a38b10511f585724b7eb6e5f9556dea21"><div class="ttname"><a href="classentt_1_1dense__map.html#a38b10511f585724b7eb6e5f9556dea21">entt::dense_map::size</a></div><div class="ttdeci">size_type size() const noexcept</div><div class="ttdoc">Returns the number of elements in a container.</div><div class="ttdef"><b>Definition</b> <a href="#l00528">dense_map.hpp:528</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a38ef651a1992486e3d2151e7829777f1"><div class="ttname"><a href="classentt_1_1dense__map.html#a38ef651a1992486e3d2151e7829777f1">entt::dense_map::size_type</a></div><div class="ttdeci">std::size_t size_type</div><div class="ttdoc">Unsigned integer type.</div><div class="ttdef"><b>Definition</b> <a href="#l00356">dense_map.hpp:356</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a3c36baa7b9aa7df7d3a07ca090319328"><div class="ttname"><a href="classentt_1_1dense__map.html#a3c36baa7b9aa7df7d3a07ca090319328">entt::dense_map::end</a></div><div class="ttdeci">const_local_iterator end(const size_type index) const</div><div class="ttdoc">Returns an iterator to the end of a given bucket.</div><div class="ttdef"><b>Definition</b> <a href="#l00906">dense_map.hpp:906</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a3c94e139b8d65ac65df36161183a8a49"><div class="ttname"><a href="classentt_1_1dense__map.html#a3c94e139b8d65ac65df36161183a8a49">entt::dense_map::insert</a></div><div class="ttdeci">void insert(It first, It last)</div><div class="ttdoc">Inserts elements into the container, if their keys do not exist.</div><div class="ttdef"><b>Definition</b> <a href="#l00580">dense_map.hpp:580</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a3d747a3b187a97814603e41ad37bf26e"><div class="ttname"><a href="classentt_1_1dense__map.html#a3d747a3b187a97814603e41ad37bf26e">entt::dense_map::equal_range</a></div><div class="ttdeci">std::enable_if_t&lt; is_transparent_v&lt; hasher &gt; &amp;&amp;is_transparent_v&lt; key_equal &gt;, std::conditional_t&lt; false, Other, std::pair&lt; iterator, iterator &gt; &gt; &gt; equal_range(const Other &amp;key)</div><div class="ttdoc">Returns a range containing all elements that compare equivalent to a given key.</div><div class="ttdef"><b>Definition</b> <a href="#l00830">dense_map.hpp:830</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a3decbf479ab29fe63161d66299ef20af"><div class="ttname"><a href="classentt_1_1dense__map.html#a3decbf479ab29fe63161d66299ef20af">entt::dense_map::operator=</a></div><div class="ttdeci">dense_map &amp; operator=(dense_map &amp;&amp;) noexcept=default</div><div class="ttdoc">Default move assignment operator.</div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a413f21b4eee0336277f24de044fe8cb6"><div class="ttname"><a href="classentt_1_1dense__map.html#a413f21b4eee0336277f24de044fe8cb6">entt::dense_map::at</a></div><div class="ttdeci">const mapped_type &amp; at(const key_type &amp;key) const</div><div class="ttdoc">Accesses a given element with bounds checking.</div><div class="ttdef"><b>Definition</b> <a href="#l00722">dense_map.hpp:722</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a41a26ee3be60abf7b5ecf16c99948086"><div class="ttname"><a href="classentt_1_1dense__map.html#a41a26ee3be60abf7b5ecf16c99948086">entt::dense_map::key_equal</a></div><div class="ttdeci">KeyEqual key_equal</div><div class="ttdoc">Type of function to use to compare the keys for equality.</div><div class="ttdef"><b>Definition</b> <a href="#l00362">dense_map.hpp:362</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a45843ecba66cc9692ae4facac5461e4d"><div class="ttname"><a href="classentt_1_1dense__map.html#a45843ecba66cc9692ae4facac5461e4d">entt::dense_map::max_size</a></div><div class="ttdeci">size_type max_size() const noexcept</div><div class="ttdoc">Returns the maximum possible number of elements.</div><div class="ttdef"><b>Definition</b> <a href="#l00536">dense_map.hpp:536</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a468bf103c5f4779ee24d002576150689"><div class="ttname"><a href="classentt_1_1dense__map.html#a468bf103c5f4779ee24d002576150689">entt::dense_map::at</a></div><div class="ttdeci">mapped_type &amp; at(const key_type &amp;key)</div><div class="ttdoc">Accesses a given element with bounds checking.</div><div class="ttdef"><b>Definition</b> <a href="#l00715">dense_map.hpp:715</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a47084f57549451518ef81a0f7cbdae0e"><div class="ttname"><a href="classentt_1_1dense__map.html#a47084f57549451518ef81a0f7cbdae0e">entt::dense_map::reserve</a></div><div class="ttdeci">void reserve(const size_type cnt)</div><div class="ttdoc">Reserves space for at least the specified number of elements and regenerates the hash table.</div><div class="ttdef"><b>Definition</b> <a href="#l01008">dense_map.hpp:1008</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a4818548e35a239228a5fae77af01e7f5"><div class="ttname"><a href="classentt_1_1dense__map.html#a4818548e35a239228a5fae77af01e7f5">entt::dense_map::max_bucket_count</a></div><div class="ttdeci">size_type max_bucket_count() const</div><div class="ttdoc">Returns the maximum number of buckets.</div><div class="ttdef"><b>Definition</b> <a href="#l00931">dense_map.hpp:931</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a49bb9a8de8e27cff97395d4fc527ad04"><div class="ttname"><a href="classentt_1_1dense__map.html#a49bb9a8de8e27cff97395d4fc527ad04">entt::dense_map::erase</a></div><div class="ttdeci">iterator erase(const_iterator first, const_iterator last)</div><div class="ttdoc">Removes the given elements from a container.</div><div class="ttdef"><b>Definition</b> <a href="#l00682">dense_map.hpp:682</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a4b5f56217b3b8eae9ad34334df1a931d"><div class="ttname"><a href="classentt_1_1dense__map.html#a4b5f56217b3b8eae9ad34334df1a931d">entt::dense_map::count</a></div><div class="ttdeci">size_type count(const key_type &amp;key) const</div><div class="ttdoc">Returns the number of elements matching a key (either 1 or 0).</div><div class="ttdef"><b>Definition</b> <a href="#l00751">dense_map.hpp:751</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a4b71476135fb7147c02ec7a801564c72"><div class="ttname"><a href="classentt_1_1dense__map.html#a4b71476135fb7147c02ec7a801564c72">entt::dense_map::begin</a></div><div class="ttdeci">local_iterator begin(const size_type index)</div><div class="ttdoc">Returns an iterator to the beginning of a given bucket.</div><div class="ttdef"><b>Definition</b> <a href="#l00888">dense_map.hpp:888</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a4c611a71d59737c941b1aaf29e64c9b7"><div class="ttname"><a href="classentt_1_1dense__map.html#a4c611a71d59737c941b1aaf29e64c9b7">entt::dense_map::find</a></div><div class="ttdeci">std::enable_if_t&lt; is_transparent_v&lt; hasher &gt; &amp;&amp;is_transparent_v&lt; key_equal &gt;, std::conditional_t&lt; false, Other, const_iterator &gt; &gt; find(const Other &amp;key) const</div><div class="ttdoc">Finds an element with a given key.</div><div class="ttdef"><b>Definition</b> <a href="#l00799">dense_map.hpp:799</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a4d884a2b7164b3df97d93dd2804222b0"><div class="ttname"><a href="classentt_1_1dense__map.html#a4d884a2b7164b3df97d93dd2804222b0">entt::dense_map::contains</a></div><div class="ttdeci">bool contains(const key_type &amp;key) const</div><div class="ttdoc">Checks if the container contains an element with a given key.</div><div class="ttdef"><b>Definition</b> <a href="#l00848">dense_map.hpp:848</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a5123c811e7090df1a793e9bc1821d2e5"><div class="ttname"><a href="classentt_1_1dense__map.html#a5123c811e7090df1a793e9bc1821d2e5">entt::dense_map::cend</a></div><div class="ttdeci">const_iterator cend() const noexcept</div><div class="ttdoc">Returns an iterator to the end.</div><div class="ttdef"><b>Definition</b> <a href="#l00502">dense_map.hpp:502</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a524c65b19c282b4a2bce0434facca4c5"><div class="ttname"><a href="classentt_1_1dense__map.html#a524c65b19c282b4a2bce0434facca4c5">entt::dense_map::dense_map</a></div><div class="ttdeci">dense_map(const size_type cnt, const allocator_type &amp;allocator)</div><div class="ttdoc">Constructs an empty container with a given allocator and user supplied minimal number of buckets.</div><div class="ttdef"><b>Definition</b> <a href="#l00389">dense_map.hpp:389</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a53111b5614ea1d29d8396279ebfd7d3e"><div class="ttname"><a href="classentt_1_1dense__map.html#a53111b5614ea1d29d8396279ebfd7d3e">entt::dense_map::try_emplace</a></div><div class="ttdeci">std::pair&lt; iterator, bool &gt; try_emplace(const key_type &amp;key, Args &amp;&amp;...args)</div><div class="ttdoc">Inserts in-place if the key does not exist, does nothing if the key exists.</div><div class="ttdef"><b>Definition</b> <a href="#l00655">dense_map.hpp:655</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a54a2dd65d401a992fd91fb8a91faea86"><div class="ttname"><a href="classentt_1_1dense__map.html#a54a2dd65d401a992fd91fb8a91faea86">entt::dense_map::max_load_factor</a></div><div class="ttdeci">float max_load_factor() const</div><div class="ttdoc">Returns the maximum average number of elements per bucket.</div><div class="ttdef"><b>Definition</b> <a href="#l00965">dense_map.hpp:965</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a5b47e5c447352298fca87921774c4a3d"><div class="ttname"><a href="classentt_1_1dense__map.html#a5b47e5c447352298fca87921774c4a3d">entt::dense_map::find</a></div><div class="ttdeci">const_iterator find(const key_type &amp;key) const</div><div class="ttdoc">Finds an element with a given key.</div><div class="ttdef"><b>Definition</b> <a href="#l00778">dense_map.hpp:778</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a5c236223418b9ef327397424e2df24f8"><div class="ttname"><a href="classentt_1_1dense__map.html#a5c236223418b9ef327397424e2df24f8">entt::dense_map::const_iterator</a></div><div class="ttdeci">internal::dense_map_iterator&lt; typename packed_container_type::const_iterator &gt; const_iterator</div><div class="ttdoc">Constant input iterator type.</div><div class="ttdef"><b>Definition</b> <a href="#l00366">dense_map.hpp:366</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a608539db499acbc3a7548421ea5d8709"><div class="ttname"><a href="classentt_1_1dense__map.html#a608539db499acbc3a7548421ea5d8709">entt::dense_map::max_load_factor</a></div><div class="ttdeci">void max_load_factor(const float value)</div><div class="ttdoc">Sets the desired maximum average number of elements per bucket.</div><div class="ttdef"><b>Definition</b> <a href="#l00973">dense_map.hpp:973</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a6ee333a078e7bc2b1035a911aff3b7ed"><div class="ttname"><a href="classentt_1_1dense__map.html#a6ee333a078e7bc2b1035a911aff3b7ed">entt::dense_map::operator=</a></div><div class="ttdeci">dense_map &amp; operator=(const dense_map &amp;)=default</div><div class="ttdoc">Default copy assignment operator.</div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a71e1a562a523572405bbf0a53bb8535d"><div class="ttname"><a href="classentt_1_1dense__map.html#a71e1a562a523572405bbf0a53bb8535d">entt::dense_map::insert</a></div><div class="ttdeci">std::pair&lt; iterator, bool &gt; insert(value_type &amp;&amp;value)</div><div class="ttdoc">Inserts an element into the container, if the key does not exist.</div><div class="ttdef"><b>Definition</b> <a href="#l00559">dense_map.hpp:559</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a77aa062268245a84c4c27dcc01839814"><div class="ttname"><a href="classentt_1_1dense__map.html#a77aa062268245a84c4c27dcc01839814">entt::dense_map::find</a></div><div class="ttdeci">iterator find(const key_type &amp;key)</div><div class="ttdoc">Finds an element with a given key.</div><div class="ttdef"><b>Definition</b> <a href="#l00773">dense_map.hpp:773</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a77b33cb48b4784e336d87246701b2024"><div class="ttname"><a href="classentt_1_1dense__map.html#a77b33cb48b4784e336d87246701b2024">entt::dense_map::equal_range</a></div><div class="ttdeci">std::pair&lt; iterator, iterator &gt; equal_range(const key_type &amp;key)</div><div class="ttdoc">Returns a range containing all elements with a given key.</div><div class="ttdef"><b>Definition</b> <a href="#l00809">dense_map.hpp:809</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a7c0e7de10687bc1e810d67ba6a91396d"><div class="ttname"><a href="classentt_1_1dense__map.html#a7c0e7de10687bc1e810d67ba6a91396d">entt::dense_map::begin</a></div><div class="ttdeci">const_iterator begin() const noexcept</div><div class="ttdoc">Returns an iterator to the beginning.</div><div class="ttdef"><b>Definition</b> <a href="#l00488">dense_map.hpp:488</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a7cdfe85f102518543b7a684c9e8e3bd3"><div class="ttname"><a href="classentt_1_1dense__map.html#a7cdfe85f102518543b7a684c9e8e3bd3">entt::dense_map::mapped_type</a></div><div class="ttdeci">Type mapped_type</div><div class="ttdoc">Mapped type of the container.</div><div class="ttdef"><b>Definition</b> <a href="#l00352">dense_map.hpp:352</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a7cea2e02e86eec9421ddaab64f15db6b"><div class="ttname"><a href="classentt_1_1dense__map.html#a7cea2e02e86eec9421ddaab64f15db6b">entt::dense_map::rehash</a></div><div class="ttdeci">void rehash(const size_type cnt)</div><div class="ttdoc">Reserves at least the specified number of buckets and regenerates the hash table.</div><div class="ttdef"><b>Definition</b> <a href="#l00984">dense_map.hpp:984</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a8125ea2706a6208565a4d67f0e6efbed"><div class="ttname"><a href="classentt_1_1dense__map.html#a8125ea2706a6208565a4d67f0e6efbed">entt::dense_map::cend</a></div><div class="ttdeci">const_local_iterator cend(const size_type index) const</div><div class="ttdoc">Returns an iterator to the end of a given bucket.</div><div class="ttdef"><b>Definition</b> <a href="#l00897">dense_map.hpp:897</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a83036e3f167d28ba9afa943271fb5587"><div class="ttname"><a href="classentt_1_1dense__map.html#a83036e3f167d28ba9afa943271fb5587">entt::dense_map::erase</a></div><div class="ttdeci">iterator erase(const_iterator pos)</div><div class="ttdoc">Removes an element from a given position.</div><div class="ttdef"><b>Definition</b> <a href="#l00670">dense_map.hpp:670</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a832dc73529e19f662f63c583a5fbd340"><div class="ttname"><a href="classentt_1_1dense__map.html#a832dc73529e19f662f63c583a5fbd340">entt::dense_map&lt; id_type, std::shared_ptr&lt; base_type &gt;, identity, std::equal_to&lt;&gt;, typename alloc_traits::template rebind_alloc&lt; std::pair&lt; const id_type, std::shared_ptr&lt; base_type &gt; &gt; &gt; &gt;::swap</a></div><div class="ttdeci">void swap(dense_map &amp;other) noexcept</div><div class="ttdef"><b>Definition</b> <a href="#l00461">dense_map.hpp:461</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a8924f4faaa1879a84734ec58f11e6662"><div class="ttname"><a href="classentt_1_1dense__map.html#a8924f4faaa1879a84734ec58f11e6662">entt::dense_map::dense_map</a></div><div class="ttdeci">dense_map(const dense_map &amp;other, const allocator_type &amp;allocator)</div><div class="ttdoc">Allocator-extended copy constructor.</div><div class="ttdef"><b>Definition</b> <a href="#l00424">dense_map.hpp:424</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a92eced5574b8354b8357f79faf16fc23"><div class="ttname"><a href="classentt_1_1dense__map.html#a92eced5574b8354b8357f79faf16fc23">entt::dense_map::insert</a></div><div class="ttdeci">std::enable_if_t&lt; std::is_constructible_v&lt; value_type, Arg &amp;&amp; &gt;, std::pair&lt; iterator, bool &gt; &gt; insert(Arg &amp;&amp;value)</div><div class="ttdoc">Inserts an element into the container, if the key does not exist.</div><div class="ttdef"><b>Definition</b> <a href="#l00569">dense_map.hpp:569</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a973f2399943dc681e617bb8b46e9244c"><div class="ttname"><a href="classentt_1_1dense__map.html#a973f2399943dc681e617bb8b46e9244c">entt::dense_map::equal_range</a></div><div class="ttdeci">std::enable_if_t&lt; is_transparent_v&lt; hasher &gt; &amp;&amp;is_transparent_v&lt; key_equal &gt;, std::conditional_t&lt; false, Other, std::pair&lt; const_iterator, const_iterator &gt; &gt; &gt; equal_range(const Other &amp;key) const</div><div class="ttdoc">Returns a range containing all elements with a given key.</div><div class="ttdef"><b>Definition</b> <a href="#l00838">dense_map.hpp:838</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a9a591d419dd5649e52907a3032f8c0b8"><div class="ttname"><a href="classentt_1_1dense__map.html#a9a591d419dd5649e52907a3032f8c0b8">entt::dense_map::bucket</a></div><div class="ttdeci">size_type bucket(const key_type &amp;key) const</div><div class="ttdoc">Returns the bucket for a given key.</div><div class="ttdef"><b>Definition</b> <a href="#l00949">dense_map.hpp:949</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a9a9522dcd518bd3d73769d80d35606db"><div class="ttname"><a href="classentt_1_1dense__map.html#a9a9522dcd518bd3d73769d80d35606db">entt::dense_map::insert_or_assign</a></div><div class="ttdeci">std::pair&lt; iterator, bool &gt; insert_or_assign(key_type &amp;&amp;key, Arg &amp;&amp;value)</div><div class="ttdoc">Inserts an element into the container or assigns to the current element if the key already exists.</div><div class="ttdef"><b>Definition</b> <a href="#l00602">dense_map.hpp:602</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a9b5784ca7ce9ab1ea46b303598f9987d"><div class="ttname"><a href="classentt_1_1dense__map.html#a9b5784ca7ce9ab1ea46b303598f9987d">entt::dense_map::operator[]</a></div><div class="ttdeci">mapped_type &amp; operator[](const key_type &amp;key)</div><div class="ttdoc">Accesses or inserts a given element.</div><div class="ttdef"><b>Definition</b> <a href="#l00733">dense_map.hpp:733</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a9cd5632c26bf5281cfbbd7fbd9f85bf5"><div class="ttname"><a href="classentt_1_1dense__map.html#a9cd5632c26bf5281cfbbd7fbd9f85bf5">entt::dense_map::get_allocator</a></div><div class="ttdeci">constexpr allocator_type get_allocator() const noexcept</div><div class="ttdoc">Returns the associated allocator.</div><div class="ttdef"><b>Definition</b> <a href="#l00472">dense_map.hpp:472</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_a9e9beebb937e95a40246455194c86c84"><div class="ttname"><a href="classentt_1_1dense__map.html#a9e9beebb937e95a40246455194c86c84">entt::dense_map::cbegin</a></div><div class="ttdeci">const_local_iterator cbegin(const size_type index) const</div><div class="ttdoc">Returns an iterator to the beginning of a given bucket.</div><div class="ttdef"><b>Definition</b> <a href="#l00870">dense_map.hpp:870</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_aa53501af8bfd66b6bf45e8cfa844e180"><div class="ttname"><a href="classentt_1_1dense__map.html#aa53501af8bfd66b6bf45e8cfa844e180">entt::dense_map::value_type</a></div><div class="ttdeci">std::pair&lt; const Key, Type &gt; value_type</div><div class="ttdoc">Key-value type of the container.</div><div class="ttdef"><b>Definition</b> <a href="#l00354">dense_map.hpp:354</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_aaa72d92d87e8020e0ca5f035cd665d8b"><div class="ttname"><a href="classentt_1_1dense__map.html#aaa72d92d87e8020e0ca5f035cd665d8b">entt::dense_map::dense_map</a></div><div class="ttdeci">dense_map(const dense_map &amp;)=default</div><div class="ttdoc">Default copy constructor.</div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_aafff57a203cd3fc561320bad6eeea0c3"><div class="ttname"><a href="classentt_1_1dense__map.html#aafff57a203cd3fc561320bad6eeea0c3">entt::dense_map::insert_or_assign</a></div><div class="ttdeci">std::pair&lt; iterator, bool &gt; insert_or_assign(const key_type &amp;key, Arg &amp;&amp;value)</div><div class="ttdoc">Inserts an element into the container or assigns to the current element if the key already exists.</div><div class="ttdef"><b>Definition</b> <a href="#l00596">dense_map.hpp:596</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_ab0dfc292981ab6694cd4609879a80dbc"><div class="ttname"><a href="classentt_1_1dense__map.html#ab0dfc292981ab6694cd4609879a80dbc">entt::dense_map::emplace</a></div><div class="ttdeci">std::pair&lt; iterator, bool &gt; emplace(Args &amp;&amp;...args)</div><div class="ttdoc">Constructs an element in-place, if the key does not exist.</div><div class="ttdef"><b>Definition</b> <a href="#l00620">dense_map.hpp:620</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_ab2b0e98c01ad728022e5388535333fb1"><div class="ttname"><a href="classentt_1_1dense__map.html#ab2b0e98c01ad728022e5388535333fb1">entt::dense_map::try_emplace</a></div><div class="ttdeci">std::pair&lt; iterator, bool &gt; try_emplace(key_type &amp;&amp;key, Args &amp;&amp;...args)</div><div class="ttdoc">Inserts in-place if the key does not exist, does nothing if the key exists.</div><div class="ttdef"><b>Definition</b> <a href="#l00661">dense_map.hpp:661</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_ab971fb709972a0e26b95e4fdb89aa64e"><div class="ttname"><a href="classentt_1_1dense__map.html#ab971fb709972a0e26b95e4fdb89aa64e">entt::dense_map::end</a></div><div class="ttdeci">local_iterator end(const size_type index)</div><div class="ttdoc">Returns an iterator to the end of a given bucket.</div><div class="ttdef"><b>Definition</b> <a href="#l00915">dense_map.hpp:915</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_abf771ba10ee17109769cecd68f0991c5"><div class="ttname"><a href="classentt_1_1dense__map.html#abf771ba10ee17109769cecd68f0991c5">entt::dense_map::find</a></div><div class="ttdeci">std::enable_if_t&lt; is_transparent_v&lt; hasher &gt; &amp;&amp;is_transparent_v&lt; key_equal &gt;, std::conditional_t&lt; false, Other, iterator &gt; &gt; find(const Other &amp;key)</div><div class="ttdoc">Finds an element with a key that compares equivalent to a given key.</div><div class="ttdef"><b>Definition</b> <a href="#l00792">dense_map.hpp:792</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_ac2039886ad16466a4f9928dc737cd711"><div class="ttname"><a href="classentt_1_1dense__map.html#ac2039886ad16466a4f9928dc737cd711">entt::dense_map::key_eq</a></div><div class="ttdeci">key_equal key_eq() const</div><div class="ttdoc">Returns the function used to compare keys for equality.</div><div class="ttdef"><b>Definition</b> <a href="#l01025">dense_map.hpp:1025</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_acb47beb8b4689e0e09e7527bd537f69b"><div class="ttname"><a href="classentt_1_1dense__map.html#acb47beb8b4689e0e09e7527bd537f69b">entt::dense_map::dense_map</a></div><div class="ttdeci">dense_map(const size_type cnt, const hasher &amp;hash, const allocator_type &amp;allocator)</div><div class="ttdoc">Constructs an empty container with a given allocator, hash function and user supplied minimal number ...</div><div class="ttdef"><b>Definition</b> <a href="#l00399">dense_map.hpp:399</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_acc07b299f15a57db885089cc1a31322d"><div class="ttname"><a href="classentt_1_1dense__map.html#acc07b299f15a57db885089cc1a31322d">entt::dense_map::iterator</a></div><div class="ttdeci">internal::dense_map_iterator&lt; typename packed_container_type::iterator &gt; iterator</div><div class="ttdoc">Input iterator type.</div><div class="ttdef"><b>Definition</b> <a href="#l00364">dense_map.hpp:364</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_ad05e437f37f277cbe5c6121e67a4e89a"><div class="ttname"><a href="classentt_1_1dense__map.html#ad05e437f37f277cbe5c6121e67a4e89a">entt::dense_map::local_iterator</a></div><div class="ttdeci">internal::dense_map_local_iterator&lt; typename packed_container_type::iterator &gt; local_iterator</div><div class="ttdoc">Input iterator type.</div><div class="ttdef"><b>Definition</b> <a href="#l00368">dense_map.hpp:368</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_ad43ca6e61d09cd9f55c684c659dd74cc"><div class="ttname"><a href="classentt_1_1dense__map.html#ad43ca6e61d09cd9f55c684c659dd74cc">entt::dense_map::dense_map</a></div><div class="ttdeci">dense_map(dense_map &amp;&amp;) noexcept=default</div><div class="ttdoc">Default move constructor.</div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_ad699469dc43bfd00d9ea86c686afb394"><div class="ttname"><a href="classentt_1_1dense__map.html#ad699469dc43bfd00d9ea86c686afb394">entt::dense_map::const_local_iterator</a></div><div class="ttdeci">internal::dense_map_local_iterator&lt; typename packed_container_type::const_iterator &gt; const_local_iterator</div><div class="ttdoc">Constant input iterator type.</div><div class="ttdef"><b>Definition</b> <a href="#l00370">dense_map.hpp:370</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_ad6f1227e06bf48744b46b3fe251d72f2"><div class="ttname"><a href="classentt_1_1dense__map.html#ad6f1227e06bf48744b46b3fe251d72f2">entt::dense_map::empty</a></div><div class="ttdeci">bool empty() const noexcept</div><div class="ttdoc">Checks whether a container is empty.</div><div class="ttdef"><b>Definition</b> <a href="#l00520">dense_map.hpp:520</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_ada4ac1f5a3295d80d8bb4fa6387023db"><div class="ttname"><a href="classentt_1_1dense__map.html#ada4ac1f5a3295d80d8bb4fa6387023db">entt::dense_map::insert</a></div><div class="ttdeci">std::pair&lt; iterator, bool &gt; insert(const value_type &amp;value)</div><div class="ttdoc">Inserts an element into the container, if the key does not exist.</div><div class="ttdef"><b>Definition</b> <a href="#l00554">dense_map.hpp:554</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_adc7feba2153b3764cc7789f31b926d78"><div class="ttname"><a href="classentt_1_1dense__map.html#adc7feba2153b3764cc7789f31b926d78">entt::dense_map::allocator_type</a></div><div class="ttdeci">Allocator allocator_type</div><div class="ttdoc">Allocator type.</div><div class="ttdef"><b>Definition</b> <a href="#l00348">dense_map.hpp:348</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_ae094f65cda09d80851306f6a4bba7b50"><div class="ttname"><a href="classentt_1_1dense__map.html#ae094f65cda09d80851306f6a4bba7b50">entt::dense_map::bucket_size</a></div><div class="ttdeci">size_type bucket_size(const size_type index) const</div><div class="ttdoc">Returns the number of elements in a given bucket.</div><div class="ttdef"><b>Definition</b> <a href="#l00940">dense_map.hpp:940</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_ae62722d472417185388e952655b120e9"><div class="ttname"><a href="classentt_1_1dense__map.html#ae62722d472417185388e952655b120e9">entt::dense_map::hasher</a></div><div class="ttdeci">Hash hasher</div><div class="ttdoc">Type of function to use to hash the keys.</div><div class="ttdef"><b>Definition</b> <a href="#l00360">dense_map.hpp:360</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_aeb9e305df1fc9e886d6c761324dc15ab"><div class="ttname"><a href="classentt_1_1dense__map.html#aeb9e305df1fc9e886d6c761324dc15ab">entt::dense_map::key_type</a></div><div class="ttdeci">Key key_type</div><div class="ttdoc">Key type of the container.</div><div class="ttdef"><b>Definition</b> <a href="#l00350">dense_map.hpp:350</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_aee246b41534137f279a11eb5e225a6e5"><div class="ttname"><a href="classentt_1_1dense__map.html#aee246b41534137f279a11eb5e225a6e5">entt::dense_map::bucket_count</a></div><div class="ttdeci">size_type bucket_count() const</div><div class="ttdoc">Returns the number of buckets.</div><div class="ttdef"><b>Definition</b> <a href="#l00923">dense_map.hpp:923</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_af163bec2cf56f3571000a5fc0145832f"><div class="ttname"><a href="classentt_1_1dense__map.html#af163bec2cf56f3571000a5fc0145832f">entt::dense_map::dense_map</a></div><div class="ttdeci">dense_map()</div><div class="ttdoc">Default constructor.</div><div class="ttdef"><b>Definition</b> <a href="#l00373">dense_map.hpp:373</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_af2d0aa858937c74139ff7f48be924268"><div class="ttname"><a href="classentt_1_1dense__map.html#af2d0aa858937c74139ff7f48be924268">entt::dense_map::~dense_map</a></div><div class="ttdeci">~dense_map()=default</div><div class="ttdoc">Default destructor.</div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_af76ed82791a0f50d0f7aa0bcec46105b"><div class="ttname"><a href="classentt_1_1dense__map.html#af76ed82791a0f50d0f7aa0bcec46105b">entt::dense_map::equal_range</a></div><div class="ttdeci">std::pair&lt; const_iterator, const_iterator &gt; equal_range(const key_type &amp;key) const</div><div class="ttdoc">Returns a range containing all elements with a given key.</div><div class="ttdef"><b>Definition</b> <a href="#l00815">dense_map.hpp:815</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_afa1426bfb2ff55c9c4d0471303fcf6cc"><div class="ttname"><a href="classentt_1_1dense__map.html#afa1426bfb2ff55c9c4d0471303fcf6cc">entt::dense_map::hash_function</a></div><div class="ttdeci">hasher hash_function() const</div><div class="ttdoc">Returns the function used to hash the keys.</div><div class="ttdef"><b>Definition</b> <a href="#l01017">dense_map.hpp:1017</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_afa80b6dff4ba1f455fabec3ff197e8c5"><div class="ttname"><a href="classentt_1_1dense__map.html#afa80b6dff4ba1f455fabec3ff197e8c5">entt::dense_map::end</a></div><div class="ttdeci">const_iterator end() const noexcept</div><div class="ttdoc">Returns an iterator to the end.</div><div class="ttdef"><b>Definition</b> <a href="#l00507">dense_map.hpp:507</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_afb7f0ff4d0988673a027ac0e0348b216"><div class="ttname"><a href="classentt_1_1dense__map.html#afb7f0ff4d0988673a027ac0e0348b216">entt::dense_map::begin</a></div><div class="ttdeci">iterator begin() noexcept</div><div class="ttdoc">Returns an iterator to the beginning.</div><div class="ttdef"><b>Definition</b> <a href="#l00493">dense_map.hpp:493</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_afd4ff12e8b032e6ca5519557d07d1178"><div class="ttname"><a href="classentt_1_1dense__map.html#afd4ff12e8b032e6ca5519557d07d1178">entt::dense_map::end</a></div><div class="ttdeci">iterator end() noexcept</div><div class="ttdoc">Returns an iterator to the end.</div><div class="ttdef"><b>Definition</b> <a href="#l00512">dense_map.hpp:512</a></div></div>
<div class="ttc" id="aclassentt_1_1dense__map_html_afe9ae8d1427ee98d662e7a7d635a6eff"><div class="ttname"><a href="classentt_1_1dense__map.html#afe9ae8d1427ee98d662e7a7d635a6eff">entt::dense_map::difference_type</a></div><div class="ttdeci">std::ptrdiff_t difference_type</div><div class="ttdoc">Signed integer type.</div><div class="ttdef"><b>Definition</b> <a href="#l00358">dense_map.hpp:358</a></div></div>
<div class="ttc" id="anamespaceentt_html"><div class="ttname"><a href="namespaceentt.html">entt</a></div><div class="ttdoc">EnTT default namespace.</div><div class="ttdef"><b>Definition</b> <a href="#l00022">dense_map.hpp:22</a></div></div>
<div class="ttc" id="anamespaceentt_html_a12e4d0c58f9c4cc6f5513c39c530b9b7"><div class="ttname"><a href="namespaceentt.html#a12e4d0c58f9c4cc6f5513c39c530b9b7">entt::make_obj_using_allocator</a></div><div class="ttdeci">constexpr Type make_obj_using_allocator(const Allocator &amp;allocator, Args &amp;&amp;...args)</div><div class="ttdoc">Uses-allocator construction utility (waiting for C++20).</div><div class="ttdef"><b>Definition</b> <a href="memory_8hpp_source.html#l00219">memory.hpp:219</a></div></div>
<div class="ttc" id="anamespaceentt_html_a1ae98eeee0b0cb3e94d97d08a74a06f0"><div class="ttname"><a href="namespaceentt.html#a1ae98eeee0b0cb3e94d97d08a74a06f0">entt::fast_mod</a></div><div class="ttdeci">constexpr std::enable_if_t&lt; std::is_unsigned_v&lt; Type &gt;, Type &gt; fast_mod(const Type value, const std::size_t mod) noexcept</div><div class="ttdoc">Fast module utility function (powers of two only).</div><div class="ttdef"><b>Definition</b> <a href="bit_8hpp_source.html#l00063">bit.hpp:63</a></div></div>
<div class="ttc" id="anamespaceentt_html_a5fd3998d86cc531f800d0104478771f4"><div class="ttname"><a href="namespaceentt.html#a5fd3998d86cc531f800d0104478771f4">entt::is_transparent_v</a></div><div class="ttdeci">constexpr bool is_transparent_v</div><div class="ttdoc">Helper variable template.</div><div class="ttdef"><b>Definition</b> <a href="core_2type__traits_8hpp_source.html#l00737">type_traits.hpp:737</a></div></div>
<div class="ttc" id="anamespaceentt_html_a8c763e890bb00479a6a6aeae3b2a75f0"><div class="ttname"><a href="namespaceentt.html#a8c763e890bb00479a6a6aeae3b2a75f0">entt::operator&lt;=</a></div><div class="ttdeci">constexpr bool operator&lt;=(const basic_hashed_string&lt; Char &gt; &amp;lhs, const basic_hashed_string&lt; Char &gt; &amp;rhs) noexcept</div><div class="ttdoc">Compares two hashed strings.</div><div class="ttdef"><b>Definition</b> <a href="hashed__string_8hpp_source.html#l00257">hashed_string.hpp:257</a></div></div>
<div class="ttc" id="anamespaceentt_html_a8f6fb41a1c8c0c5968bfca369e51a73e"><div class="ttname"><a href="namespaceentt.html#a8f6fb41a1c8c0c5968bfca369e51a73e">entt::next_power_of_two</a></div><div class="ttdeci">constexpr std::enable_if_t&lt; std::is_unsigned_v&lt; Type &gt;, Type &gt; next_power_of_two(const Type value) noexcept</div><div class="ttdoc">Computes the smallest power of two greater than or equal to a value (waiting for C++20 and std::bit_c...</div><div class="ttdef"><b>Definition</b> <a href="bit_8hpp_source.html#l00043">bit.hpp:43</a></div></div>
<div class="ttc" id="anamespaceentt_html_aa88e297d57dd5547afcde8dd291c4b8f"><div class="ttname"><a href="namespaceentt.html#aa88e297d57dd5547afcde8dd291c4b8f">entt::operator&lt;</a></div><div class="ttdeci">constexpr bool operator&lt;(const basic_hashed_string&lt; Char &gt; &amp;lhs, const basic_hashed_string&lt; Char &gt; &amp;rhs) noexcept</div><div class="ttdoc">Compares two hashed strings.</div><div class="ttdef"><b>Definition</b> <a href="hashed__string_8hpp_source.html#l00244">hashed_string.hpp:244</a></div></div>
<div class="ttc" id="anamespaceentt_html_ab36ceb26049f62c07817a385e35395f6"><div class="ttname"><a href="namespaceentt.html#ab36ceb26049f62c07817a385e35395f6">entt::operator+</a></div><div class="ttdeci">constexpr type_list&lt; Type..., Other... &gt; operator+(type_list&lt; Type... &gt;, type_list&lt; Other... &gt;)</div><div class="ttdoc">Concatenates multiple type lists.</div><div class="ttdef"><b>Definition</b> <a href="core_2type__traits_8hpp_source.html#l00210">type_traits.hpp:210</a></div></div>
<div class="ttc" id="anamespaceentt_html_ad9accc71a383509ada028f7fa2b767bf"><div class="ttname"><a href="namespaceentt.html#ad9accc71a383509ada028f7fa2b767bf">entt::operator!=</a></div><div class="ttdeci">constexpr bool operator!=(const basic_hashed_string&lt; Char &gt; &amp;lhs, const basic_hashed_string&lt; Char &gt; &amp;rhs) noexcept</div><div class="ttdoc">Compares two hashed strings.</div><div class="ttdef"><b>Definition</b> <a href="hashed__string_8hpp_source.html#l00232">hashed_string.hpp:232</a></div></div>
<div class="ttc" id="anamespaceentt_html_adadb88dfb4278df554e7ffec5361ece4"><div class="ttname"><a href="namespaceentt.html#adadb88dfb4278df554e7ffec5361ece4">entt::operator&gt;=</a></div><div class="ttdeci">constexpr bool operator&gt;=(const basic_hashed_string&lt; Char &gt; &amp;lhs, const basic_hashed_string&lt; Char &gt; &amp;rhs) noexcept</div><div class="ttdoc">Compares two hashed strings.</div><div class="ttdef"><b>Definition</b> <a href="hashed__string_8hpp_source.html#l00283">hashed_string.hpp:283</a></div></div>
<div class="ttc" id="anamespaceentt_html_aec8131af000055ceab85646c14f234ad"><div class="ttname"><a href="namespaceentt.html#aec8131af000055ceab85646c14f234ad">entt::operator&gt;</a></div><div class="ttdeci">constexpr bool operator&gt;(const basic_hashed_string&lt; Char &gt; &amp;lhs, const basic_hashed_string&lt; Char &gt; &amp;rhs) noexcept</div><div class="ttdoc">Compares two hashed strings.</div><div class="ttdef"><b>Definition</b> <a href="hashed__string_8hpp_source.html#l00270">hashed_string.hpp:270</a></div></div>
<div class="ttc" id="anamespaceentt_html_af7c61951b721a1e3612cf536bd707501"><div class="ttname"><a href="namespaceentt.html#af7c61951b721a1e3612cf536bd707501">entt::operator==</a></div><div class="ttdeci">constexpr bool operator==(const basic_hashed_string&lt; Char &gt; &amp;lhs, const basic_hashed_string&lt; Char &gt; &amp;rhs) noexcept</div><div class="ttdoc">Compares two hashed strings.</div><div class="ttdef"><b>Definition</b> <a href="hashed__string_8hpp_source.html#l00220">hashed_string.hpp:220</a></div></div>
<div class="ttc" id="astructentt_1_1input__iterator__pointer_html"><div class="ttname"><a href="structentt_1_1input__iterator__pointer.html">entt::input_iterator_pointer</a></div><div class="ttdoc">Helper type to use as pointer with input iterators.</div><div class="ttdef"><b>Definition</b> <a href="iterator_8hpp_source.html#l00016">iterator.hpp:16</a></div></div>
</div><!-- fragment --></div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.13.2
</small></address>
</div><!-- doc-content -->
</body>
</html>