automerge/src/automerge/columnar/column_range/generic/group.rs.html
2023-03-09 15:11:59 +00:00

279 lines
No EOL
16 KiB
HTML
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta name="generator" content="rustdoc"><meta name="description" content="Source of the Rust file `automerge/src/columnar/column_range/generic/group.rs`."><meta name="keywords" content="rust, rustlang, rust-lang"><title>group.rs - source</title><link rel="preload" as="font" type="font/woff2" crossorigin href="../../../../../static.files/SourceSerif4-Regular-1f7d512b176f0f72.ttf.woff2"><link rel="preload" as="font" type="font/woff2" crossorigin href="../../../../../static.files/FiraSans-Regular-018c141bf0843ffd.woff2"><link rel="preload" as="font" type="font/woff2" crossorigin href="../../../../../static.files/FiraSans-Medium-8f9a781e4970d388.woff2"><link rel="preload" as="font" type="font/woff2" crossorigin href="../../../../../static.files/SourceCodePro-Regular-562dcc5011b6de7d.ttf.woff2"><link rel="preload" as="font" type="font/woff2" crossorigin href="../../../../../static.files/SourceSerif4-Bold-124a1ca42af929b6.ttf.woff2"><link rel="preload" as="font" type="font/woff2" crossorigin href="../../../../../static.files/SourceCodePro-Semibold-d899c5a5c4aeb14a.ttf.woff2"><link rel="stylesheet" href="../../../../../static.files/normalize-76eba96aa4d2e634.css"><link rel="stylesheet" href="../../../../../static.files/rustdoc-93196c7a1c3542a8.css" id="mainThemeStyle"><link rel="stylesheet" id="themeStyle" href="../../../../../static.files/light-4743e13df3dfe8c4.css"><link rel="stylesheet" disabled href="../../../../../static.files/dark-0e1b889528bd466b.css"><link rel="stylesheet" disabled href="../../../../../static.files/ayu-65289d5d067c7c66.css"><script id="default-settings" ></script><script src="../../../../../static.files/storage-d43fa987303ecbbb.js"></script><script defer src="../../../../../static.files/source-script-ea63cb6500f71309.js"></script><script defer src="../../../../../source-files.js"></script><script defer src="../../../../../static.files/main-3367e395607fafc1.js"></script><noscript><link rel="stylesheet" href="../../../../../static.files/noscript-13285aec31fa243e.css"></noscript><link rel="icon" href="https:///raw.githubusercontent.com/automerge/automerge-rs/main/img/favicon.ico"></head><body class="rustdoc source"><!--[if lte IE 11]><div class="warning">This old browser is unsupported and will most likely display funky things.</div><![endif]--><nav class="sidebar"></nav><main><nav class="sub"><a class="sub-logo-container" href="../../../../../automerge/index.html">
<img src="https://raw.githubusercontent.com/automerge/automerge-rs/main/img/brandmark.svg" alt="logo"></a><form class="search-form"><span></span><input class="search-input" name="search" aria-label="Run search in the documentation" autocomplete="off" spellcheck="false" placeholder="Click or press S to search, ? for more options…" type="search"><div id="help-button" title="help" tabindex="-1"><a href="../../../../../help.html">?</a></div><div id="settings-menu" tabindex="-1"><a href="../../../../../settings.html" title="settings"><img width="22" height="22" alt="Change settings" src="../../../../../static.files/wheel-5ec35bf9ca753509.svg"></a></div></form></nav><section id="main-content" class="content"><div class="example-wrap"><pre class="src-line-numbers"><a href="#1" id="1">1</a>
<a href="#2" id="2">2</a>
<a href="#3" id="3">3</a>
<a href="#4" id="4">4</a>
<a href="#5" id="5">5</a>
<a href="#6" id="6">6</a>
<a href="#7" id="7">7</a>
<a href="#8" id="8">8</a>
<a href="#9" id="9">9</a>
<a href="#10" id="10">10</a>
<a href="#11" id="11">11</a>
<a href="#12" id="12">12</a>
<a href="#13" id="13">13</a>
<a href="#14" id="14">14</a>
<a href="#15" id="15">15</a>
<a href="#16" id="16">16</a>
<a href="#17" id="17">17</a>
<a href="#18" id="18">18</a>
<a href="#19" id="19">19</a>
<a href="#20" id="20">20</a>
<a href="#21" id="21">21</a>
<a href="#22" id="22">22</a>
<a href="#23" id="23">23</a>
<a href="#24" id="24">24</a>
<a href="#25" id="25">25</a>
<a href="#26" id="26">26</a>
<a href="#27" id="27">27</a>
<a href="#28" id="28">28</a>
<a href="#29" id="29">29</a>
<a href="#30" id="30">30</a>
<a href="#31" id="31">31</a>
<a href="#32" id="32">32</a>
<a href="#33" id="33">33</a>
<a href="#34" id="34">34</a>
<a href="#35" id="35">35</a>
<a href="#36" id="36">36</a>
<a href="#37" id="37">37</a>
<a href="#38" id="38">38</a>
<a href="#39" id="39">39</a>
<a href="#40" id="40">40</a>
<a href="#41" id="41">41</a>
<a href="#42" id="42">42</a>
<a href="#43" id="43">43</a>
<a href="#44" id="44">44</a>
<a href="#45" id="45">45</a>
<a href="#46" id="46">46</a>
<a href="#47" id="47">47</a>
<a href="#48" id="48">48</a>
<a href="#49" id="49">49</a>
<a href="#50" id="50">50</a>
<a href="#51" id="51">51</a>
<a href="#52" id="52">52</a>
<a href="#53" id="53">53</a>
<a href="#54" id="54">54</a>
<a href="#55" id="55">55</a>
<a href="#56" id="56">56</a>
<a href="#57" id="57">57</a>
<a href="#58" id="58">58</a>
<a href="#59" id="59">59</a>
<a href="#60" id="60">60</a>
<a href="#61" id="61">61</a>
<a href="#62" id="62">62</a>
<a href="#63" id="63">63</a>
<a href="#64" id="64">64</a>
<a href="#65" id="65">65</a>
<a href="#66" id="66">66</a>
<a href="#67" id="67">67</a>
<a href="#68" id="68">68</a>
<a href="#69" id="69">69</a>
<a href="#70" id="70">70</a>
<a href="#71" id="71">71</a>
<a href="#72" id="72">72</a>
<a href="#73" id="73">73</a>
<a href="#74" id="74">74</a>
<a href="#75" id="75">75</a>
<a href="#76" id="76">76</a>
<a href="#77" id="77">77</a>
<a href="#78" id="78">78</a>
<a href="#79" id="79">79</a>
<a href="#80" id="80">80</a>
<a href="#81" id="81">81</a>
<a href="#82" id="82">82</a>
<a href="#83" id="83">83</a>
<a href="#84" id="84">84</a>
<a href="#85" id="85">85</a>
<a href="#86" id="86">86</a>
<a href="#87" id="87">87</a>
<a href="#88" id="88">88</a>
<a href="#89" id="89">89</a>
<a href="#90" id="90">90</a>
<a href="#91" id="91">91</a>
<a href="#92" id="92">92</a>
<a href="#93" id="93">93</a>
<a href="#94" id="94">94</a>
<a href="#95" id="95">95</a>
<a href="#96" id="96">96</a>
<a href="#97" id="97">97</a>
<a href="#98" id="98">98</a>
<a href="#99" id="99">99</a>
<a href="#100" id="100">100</a>
<a href="#101" id="101">101</a>
<a href="#102" id="102">102</a>
<a href="#103" id="103">103</a>
<a href="#104" id="104">104</a>
<a href="#105" id="105">105</a>
<a href="#106" id="106">106</a>
<a href="#107" id="107">107</a>
<a href="#108" id="108">108</a>
<a href="#109" id="109">109</a>
<a href="#110" id="110">110</a>
<a href="#111" id="111">111</a>
<a href="#112" id="112">112</a>
<a href="#113" id="113">113</a>
<a href="#114" id="114">114</a>
<a href="#115" id="115">115</a>
<a href="#116" id="116">116</a>
<a href="#117" id="117">117</a>
<a href="#118" id="118">118</a>
<a href="#119" id="119">119</a>
<a href="#120" id="120">120</a>
<a href="#121" id="121">121</a>
<a href="#122" id="122">122</a>
<a href="#123" id="123">123</a>
<a href="#124" id="124">124</a>
<a href="#125" id="125">125</a>
<a href="#126" id="126">126</a>
<a href="#127" id="127">127</a>
<a href="#128" id="128">128</a>
<a href="#129" id="129">129</a>
<a href="#130" id="130">130</a>
<a href="#131" id="131">131</a>
<a href="#132" id="132">132</a>
<a href="#133" id="133">133</a>
<a href="#134" id="134">134</a>
<a href="#135" id="135">135</a>
<a href="#136" id="136">136</a>
<a href="#137" id="137">137</a>
<a href="#138" id="138">138</a>
</pre><pre class="rust"><code><span class="kw">use </span>std::ops::Range;
<span class="kw">use super</span>::{CellValue, SimpleColIter, SimpleColRange, SimpleValue};
<span class="kw">use </span><span class="kw">crate</span>::columnar::{
column_range::{RleRange, ValueIter, ValueRange},
encoding::{col_error::DecodeColumnError, RleDecoder},
};
<span class="doccomment">/// A group column range is one with a &quot;num&quot; column and zero or more &quot;grouped&quot; columns. The &quot;num&quot;
/// column contains RLE encoded u64s, each `u64` represents the number of values to read from each
/// of the grouped columns in order to produce a `CellValue::Group` for the current row.
</span><span class="attr">#[derive(Debug, Clone)]
</span><span class="kw">pub</span>(<span class="kw">crate</span>) <span class="kw">struct </span>GroupRange {
<span class="kw">pub</span>(<span class="kw">crate</span>) num: RleRange&lt;u64&gt;,
<span class="kw">pub</span>(<span class="kw">crate</span>) values: Vec&lt;GroupedColumnRange&gt;,
}
<span class="kw">impl </span>GroupRange {
<span class="kw">pub</span>(<span class="kw">crate</span>) <span class="kw">fn </span>new(num: RleRange&lt;u64&gt;, values: Vec&lt;GroupedColumnRange&gt;) -&gt; <span class="self">Self </span>{
<span class="self">Self </span>{ num, values }
}
<span class="attr">#[allow(dead_code)]
</span><span class="kw">pub</span>(<span class="kw">crate</span>) <span class="kw">fn </span>iter&lt;<span class="lifetime">&#39;a</span>&gt;(<span class="kw-2">&amp;</span><span class="self">self</span>, data: <span class="kw-2">&amp;</span><span class="lifetime">&#39;a </span>[u8]) -&gt; GroupIter&lt;<span class="lifetime">&#39;a</span>&gt; {
GroupIter {
num: <span class="self">self</span>.num.decoder(data),
values: <span class="self">self</span>.values.iter().map(|v| v.iter(data)).collect(),
}
}
<span class="kw">pub</span>(<span class="kw">crate</span>) <span class="kw">fn </span>range(<span class="kw-2">&amp;</span><span class="self">self</span>) -&gt; Range&lt;usize&gt; {
<span class="kw">let </span>start = <span class="self">self</span>.num.start();
<span class="kw">let </span>end = <span class="self">self
</span>.values
.last()
.map(|v| v.range().end)
.unwrap_or_else(|| <span class="self">self</span>.num.end());
start..end
}
}
<span class="doccomment">/// The type of ranges which can be the &quot;grouped&quot; columns in a `GroupRange`
</span><span class="attr">#[derive(Debug, Clone)]
</span><span class="kw">pub</span>(<span class="kw">crate</span>) <span class="kw">enum </span>GroupedColumnRange {
Value(ValueRange),
Simple(SimpleColRange),
}
<span class="kw">impl </span>GroupedColumnRange {
<span class="kw">fn </span>iter&lt;<span class="lifetime">&#39;a</span>&gt;(<span class="kw-2">&amp;</span><span class="self">self</span>, data: <span class="kw-2">&amp;</span><span class="lifetime">&#39;a </span>[u8]) -&gt; GroupedColIter&lt;<span class="lifetime">&#39;a</span>&gt; {
<span class="kw">match </span><span class="self">self </span>{
<span class="self">Self</span>::Value(vr) =&gt; GroupedColIter::Value(vr.iter(data)),
<span class="self">Self</span>::Simple(sc) =&gt; GroupedColIter::Simple(sc.iter(data)),
}
}
<span class="kw">pub</span>(<span class="kw">crate</span>) <span class="kw">fn </span>range(<span class="kw-2">&amp;</span><span class="self">self</span>) -&gt; Range&lt;usize&gt; {
<span class="kw">match </span><span class="self">self </span>{
<span class="self">Self</span>::Value(vr) =&gt; vr.range(),
<span class="self">Self</span>::Simple(s) =&gt; s.range(),
}
}
}
<span class="attr">#[derive(Debug, Clone)]
</span><span class="kw">pub</span>(<span class="kw">crate</span>) <span class="kw">struct </span>GroupIter&lt;<span class="lifetime">&#39;a</span>&gt; {
num: RleDecoder&lt;<span class="lifetime">&#39;a</span>, u64&gt;,
values: Vec&lt;GroupedColIter&lt;<span class="lifetime">&#39;a</span>&gt;&gt;,
}
<span class="kw">impl</span>&lt;<span class="lifetime">&#39;a</span>&gt; GroupIter&lt;<span class="lifetime">&#39;a</span>&gt; {
<span class="kw">fn </span>try_next(<span class="kw-2">&amp;mut </span><span class="self">self</span>) -&gt; <span class="prelude-ty">Result</span>&lt;<span class="prelude-ty">Option</span>&lt;CellValue&gt;, DecodeColumnError&gt; {
<span class="kw">let </span>num = <span class="self">self
</span>.num
.next()
.transpose()
.map_err(|e| DecodeColumnError::decode_raw(<span class="string">&quot;num&quot;</span>, e))<span class="question-mark">?</span>;
<span class="kw">match </span>num {
<span class="prelude-val">None </span>=&gt; <span class="prelude-val">Ok</span>(<span class="prelude-val">None</span>),
<span class="prelude-val">Some</span>(<span class="prelude-val">None</span>) =&gt; <span class="prelude-val">Err</span>(DecodeColumnError::unexpected_null(<span class="string">&quot;num&quot;</span>)),
<span class="prelude-val">Some</span>(<span class="prelude-val">Some</span>(num)) =&gt; {
<span class="kw">let </span><span class="kw-2">mut </span>row = Vec::new();
<span class="kw">for _ in </span><span class="number">0</span>..num {
<span class="kw">let </span><span class="kw-2">mut </span>inner_row = Vec::new();
<span class="kw">for </span>(index, value_col) <span class="kw">in </span><span class="self">self</span>.values.iter_mut().enumerate() {
<span class="kw">match </span>value_col.next().transpose()<span class="question-mark">? </span>{
<span class="prelude-val">None </span>=&gt; {
<span class="kw">return </span><span class="prelude-val">Err</span>(DecodeColumnError::unexpected_null(<span class="macro">format!</span>(
<span class="string">&quot;col {}&quot;</span>,
index
)))
}
<span class="prelude-val">Some</span>(v) =&gt; {
inner_row.push(v);
}
}
}
row.push(inner_row);
}
<span class="prelude-val">Ok</span>(<span class="prelude-val">Some</span>(CellValue::Group(row)))
}
}
}
}
<span class="kw">impl</span>&lt;<span class="lifetime">&#39;a</span>&gt; Iterator <span class="kw">for </span>GroupIter&lt;<span class="lifetime">&#39;a</span>&gt; {
<span class="kw">type </span>Item = <span class="prelude-ty">Result</span>&lt;CellValue, DecodeColumnError&gt;;
<span class="kw">fn </span>next(<span class="kw-2">&amp;mut </span><span class="self">self</span>) -&gt; <span class="prelude-ty">Option</span>&lt;<span class="self">Self</span>::Item&gt; {
<span class="self">self</span>.try_next().transpose()
}
}
<span class="attr">#[derive(Debug, Clone)]
</span><span class="kw">enum </span>GroupedColIter&lt;<span class="lifetime">&#39;a</span>&gt; {
Value(ValueIter&lt;<span class="lifetime">&#39;a</span>&gt;),
Simple(SimpleColIter&lt;<span class="lifetime">&#39;a</span>&gt;),
}
<span class="kw">impl</span>&lt;<span class="lifetime">&#39;a</span>&gt; GroupedColIter&lt;<span class="lifetime">&#39;a</span>&gt; {
<span class="kw">fn </span>try_next(<span class="kw-2">&amp;mut </span><span class="self">self</span>) -&gt; <span class="prelude-ty">Result</span>&lt;<span class="prelude-ty">Option</span>&lt;SimpleValue&gt;, DecodeColumnError&gt; {
<span class="kw">match </span><span class="self">self </span>{
<span class="self">Self</span>::Value(viter) =&gt; <span class="prelude-val">Ok</span>(viter.next().transpose()<span class="question-mark">?</span>.map(SimpleValue::Value)),
<span class="self">Self</span>::Simple(siter) =&gt; siter
.next()
.transpose()
.map_err(|e| DecodeColumnError::decode_raw(<span class="string">&quot;a simple column&quot;</span>, e)),
}
}
}
<span class="kw">impl</span>&lt;<span class="lifetime">&#39;a</span>&gt; Iterator <span class="kw">for </span>GroupedColIter&lt;<span class="lifetime">&#39;a</span>&gt; {
<span class="kw">type </span>Item = <span class="prelude-ty">Result</span>&lt;SimpleValue, DecodeColumnError&gt;;
<span class="kw">fn </span>next(<span class="kw-2">&amp;mut </span><span class="self">self</span>) -&gt; <span class="prelude-ty">Option</span>&lt;<span class="self">Self</span>::Item&gt; {
<span class="self">self</span>.try_next().transpose()
}
}
</code></pre></div>
</section></main><div id="rustdoc-vars" data-root-path="../../../../../" data-static-root-path="../../../../../static.files/" data-current-crate="automerge" data-themes="" data-resource-suffix="" data-rustdoc-version="1.68.0 (2c8cc3432 2023-03-06)" data-search-js="search-98d53477a794af0b.js" data-settings-js="settings-c3c521c753752a1a.js" data-settings-css="settings-08ddfdda51b8ee2e.css" ></div></body></html>