abstreet/rustdoc/headless/struct.MAP.html

154 lines
49 KiB
HTML
Raw Normal View History

<!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="API documentation for the Rust `MAP` struct in crate `headless`."><meta name="keywords" content="rust, rustlang, rust-lang, MAP"><title>MAP in headless - Rust</title><link rel="preload" as="font" type="font/woff2" crossorigin href="../SourceSerif4-Regular.ttf.woff2"><link rel="preload" as="font" type="font/woff2" crossorigin href="../FiraSans-Regular.woff2"><link rel="preload" as="font" type="font/woff2" crossorigin href="../FiraSans-Medium.woff2"><link rel="preload" as="font" type="font/woff2" crossorigin href="../SourceCodePro-Regular.ttf.woff2"><link rel="preload" as="font" type="font/woff2" crossorigin href="../SourceSerif4-Bold.ttf.woff2"><link rel="preload" as="font" type="font/woff2" crossorigin href="../SourceCodePro-Semibold.ttf.woff2"><link rel="stylesheet" href="../normalize.css"><link rel="stylesheet" href="../rustdoc.css" id="mainThemeStyle"><link rel="stylesheet" href="../ayu.css" disabled><link rel="stylesheet" href="../dark.css" disabled><link rel="stylesheet" href="../light.css" id="themeStyle"><script id="default-settings" ></script><script src="../storage.js"></script><script defer src="sidebar-items.js"></script><script defer src="../main.js"></script><noscript><link rel="stylesheet" href="../noscript.css"></noscript><link rel="alternate icon" type="image/png" href="../favicon-16x16.png"><link rel="alternate icon" type="image/png" href="../favicon-32x32.png"><link rel="icon" type="image/svg+xml" href="../favicon.svg"></head><body class="rustdoc struct"><!--[if lte IE 11]><div class="warning">This old browser is unsupported and will most likely display funky things.</div><![endif]--><nav class="mobile-topbar"><button class="sidebar-menu-toggle">&#9776;</button><a class="sidebar-logo" href="../headless/index.html"><div class="logo-container"><img class="rust-logo" src="../rust-logo.svg" alt="logo"></div></a><h2 class="location"></h2></nav><nav class="sidebar"><a class="sidebar-logo" href="../headless/index.html"><div class="logo-container"><img class="rust-logo" src="../rust-logo.svg" alt="logo"></div></a><h2 class="location"><a href="#">MAP</a></h2><div class="sidebar-elems"><section><div class="block"><h3 class="sidebar-title"><a href="#fields">Fields</a></h3><ul><li><a href="#structfield.__private_field">__private_field</a></li></ul></div><div class="block"><h3 class="sidebar-title"><a href="#deref-methods-RwLock%3CMap%3E">Methods from Deref&lt;Target=RwLock&lt;Map&gt;&gt;</a></h3><ul><li><a href="#method.clear_poison">clear_poison</a></li><li><a href="#method.is_poisoned">is_poisoned</a></li><li><a href="#method.read">read</a></li><li><a href="#method.try_read">try_read</a></li><li><a href="#method.try_write">try_write</a></li><li><a href="#method.write">write</a></li></ul></div><div class="block"><h3 class="sidebar-title"><a href="#trait-implementations">Trait Implementations</a></h3><ul><li><a href="#impl-Deref-for-MAP">Deref</a></li><li><a href="#impl-LazyStatic-for-MAP">LazyStatic</a></li></ul></div><div class="block"><h3 class="sidebar-title"><a href="#synthetic-implementations">Auto Trait Implementations</a></h3><ul><li><a href="#impl-RefUnwindSafe-for-MAP">RefUnwindSafe</a></li><li><a href="#impl-Send-for-MAP">Send</a></li><li><a href="#impl-Sync-for-MAP">Sync</a></li><li><a href="#impl-Unpin-for-MAP">Unpin</a></li><li><a href="#impl-UnwindSafe-for-MAP">UnwindSafe</a></li></ul></div><div class="block"><h3 class="sidebar-title"><a href="#blanket-implementations">Blanket Implementations</a></h3><ul><li><a href="#impl-Any-for-MAP">Any</a></li><li><a href="#impl-Borrow%3CT%3E-for-MAP">Borrow&lt;T&gt;</a></li><li><a href="#impl-BorrowMut%3CT%3E-for-MAP">BorrowMut&lt;T&gt;</a></li><li><a href="#impl-Downcast-for-MAP">Downcast</a></li><li><a href="#impl-DowncastSync-for-MAP">DowncastSync</a></li><li><a href="#impl-From%3CT%3E-for-MAP">From&lt;T&gt;</a></li><li><a href="#impl-Instrument-for-MAP">Ins
pub(crate) __private_field: <a class="primitive" href="https://doc.rust-lang.org/1.65.0/std/primitive.unit.html">()</a>,
}</code></pre></div><h2 id="fields" class="fields small-section-header">Fields<a href="#fields" class="anchor"></a></h2><span id="structfield.__private_field" class="structfield small-section-header"><a href="#structfield.__private_field" class="anchor field"></a><code>__private_field: <a class="primitive" href="https://doc.rust-lang.org/1.65.0/std/primitive.unit.html">()</a></code></span><h2 id="deref-methods-RwLock%3CMap%3E" class="small-section-header"><span>Methods from <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/ops/deref/trait.Deref.html" title="trait core::ops::deref::Deref">Deref</a>&lt;Target = <a class="struct" href="https://doc.rust-lang.org/1.65.0/std/sync/rwlock/struct.RwLock.html" title="struct std::sync::rwlock::RwLock">RwLock</a>&lt;Map&gt;&gt;</span><a href="#deref-methods-RwLock%3CMap%3E" class="anchor"></a></h2><div id="deref-methods-RwLock%3CMap%3E-1"><div class="impl-items"><details class="rustdoc-toggle method-toggle" open><summary><section id="method.read" class="method has-srclink"><span class="rightside"><span class="since" title="Stable since Rust version 1.0.0">1.0.0</span> · <a class="srclink" href="https://doc.rust-lang.org/1.65.0/src/std/sync/rwlock.rs.html#210">source</a></span><h4 class="code-header">pub fn <a href="#method.read" class="fnname">read</a>(<br>&nbsp;&nbsp;&nbsp;&nbsp;&amp;self<br>) -&gt; <a class="enum" href="https://doc.rust-lang.org/1.65.0/core/result/enum.Result.html" title="enum core::result::Result">Result</a>&lt;<a class="struct" href="https://doc.rust-lang.org/1.65.0/std/sync/rwlock/struct.RwLockReadGuard.html" title="struct std::sync::rwlock::RwLockReadGuard">RwLockReadGuard</a>&lt;'_, T&gt;, <a class="struct" href="https://doc.rust-lang.org/1.65.0/std/sync/poison/struct.PoisonError.html" title="struct std::sync::poison::PoisonError">PoisonError</a>&lt;<a class="struct" href="https://doc.rust-lang.org/1.65.0/std/sync/rwlock/struct.RwLockReadGuard.html" title="struct std::sync::rwlock::RwLockReadGuard">RwLockReadGuard</a>&lt;'_, T&gt;&gt;&gt;</h4></section></summary><div class="docblock"><p>Locks this rwlock with shared read access, blocking the current thread
until it can be acquired.</p>
<p>The calling thread will be blocked until there are no more writers which
hold the lock. There may be other readers currently inside the lock when
this method returns. This method does not provide any guarantees with
respect to the ordering of whether contentious readers or writers will
acquire the lock first.</p>
<p>Returns an RAII guard which will release this threads shared access
once it is dropped.</p>
<h5 id="errors"><a href="#errors">Errors</a></h5>
<p>This function will return an error if the RwLock is poisoned. An RwLock
is poisoned whenever a writer panics while holding an exclusive lock.
The failure will occur immediately after the lock has been acquired.</p>
<h5 id="panics"><a href="#panics">Panics</a></h5>
<p>This function might panic when called if the lock is already held by the current thread.</p>
<h5 id="examples"><a href="#examples">Examples</a></h5>
<div class="example-wrap"><pre class="rust rust-example-rendered"><code><span class="kw">use </span>std::sync::{Arc, RwLock};
<span class="kw">use </span>std::thread;
<span class="kw">let </span>lock = Arc::new(RwLock::new(<span class="number">1</span>));
<span class="kw">let </span>c_lock = Arc::clone(<span class="kw-2">&amp;</span>lock);
<span class="kw">let </span>n = lock.read().unwrap();
<span class="macro">assert_eq!</span>(<span class="kw-2">*</span>n, <span class="number">1</span>);
thread::spawn(<span class="kw">move </span>|| {
<span class="kw">let </span>r = c_lock.read();
<span class="macro">assert!</span>(r.is_ok());
}).join().unwrap();</code></pre></div>
</div></details><details class="rustdoc-toggle method-toggle" open><summary><section id="method.try_read" class="method has-srclink"><span class="rightside"><span class="since" title="Stable since Rust version 1.0.0">1.0.0</span> · <a class="srclink" href="https://doc.rust-lang.org/1.65.0/src/std/sync/rwlock.rs.html#255">source</a></span><h4 class="code-header">pub fn <a href="#method.try_read" class="fnname">try_read</a>(<br>&nbsp;&nbsp;&nbsp;&nbsp;&amp;self<br>) -&gt; <a class="enum" href="https://doc.rust-lang.org/1.65.0/core/result/enum.Result.html" title="enum core::result::Result">Result</a>&lt;<a class="struct" href="https://doc.rust-lang.org/1.65.0/std/sync/rwlock/struct.RwLockReadGuard.html" title="struct std::sync::rwlock::RwLockReadGuard">RwLockReadGuard</a>&lt;'_, T&gt;, <a class="enum" href="https://doc.rust-lang.org/1.65.0/std/sync/poison/enum.TryLockError.html" title="enum std::sync::poison::TryLockError">TryLockError</a>&lt;<a class="struct" href="https://doc.rust-lang.org/1.65.0/std/sync/rwlock/struct.RwLockReadGuard.html" title="struct std::sync::rwlock::RwLockReadGuard">RwLockReadGuard</a>&lt;'_, T&gt;&gt;&gt;</h4></section></summary><div class="docblock"><p>Attempts to acquire this rwlock with shared read access.</p>
<p>If the access could not be granted at this time, then <code>Err</code> is returned.
Otherwise, an RAII guard is returned which will release the shared access
when it is dropped.</p>
<p>This function does not block.</p>
<p>This function does not provide any guarantees with respect to the ordering
of whether contentious readers or writers will acquire the lock first.</p>
<h5 id="errors-1"><a href="#errors-1">Errors</a></h5>
<p>This function will return the <a href="https://doc.rust-lang.org/1.65.0/std/sync/poison/enum.TryLockError.html#variant.Poisoned"><code>Poisoned</code></a> error if the RwLock is poisoned.
An RwLock is poisoned whenever a writer panics while holding an exclusive
lock. <code>Poisoned</code> will only be returned if the lock would have otherwise been
acquired.</p>
<p>This function will return the <a href="https://doc.rust-lang.org/1.65.0/std/sync/poison/enum.TryLockError.html#variant.WouldBlock"><code>WouldBlock</code></a> error if the RwLock could not
be acquired because it was already locked exclusively.</p>
<h5 id="examples-1"><a href="#examples-1">Examples</a></h5>
<div class="example-wrap"><pre class="rust rust-example-rendered"><code><span class="kw">use </span>std::sync::RwLock;
<span class="kw">let </span>lock = RwLock::new(<span class="number">1</span>);
<span class="kw">match </span>lock.try_read() {
<span class="prelude-val">Ok</span>(n) =&gt; <span class="macro">assert_eq!</span>(<span class="kw-2">*</span>n, <span class="number">1</span>),
<span class="prelude-val">Err</span>(<span class="kw">_</span>) =&gt; <span class="macro">unreachable!</span>(),
};</code></pre></div>
</div></details><details class="rustdoc-toggle method-toggle" open><summary><section id="method.write" class="method has-srclink"><span class="rightside"><span class="since" title="Stable since Rust version 1.0.0">1.0.0</span> · <a class="srclink" href="https://doc.rust-lang.org/1.65.0/src/std/sync/rwlock.rs.html#298">source</a></span><h4 class="code-header">pub fn <a href="#method.write" class="fnname">write</a>(<br>&nbsp;&nbsp;&nbsp;&nbsp;&amp;self<br>) -&gt; <a class="enum" href="https://doc.rust-lang.org/1.65.0/core/result/enum.Result.html" title="enum core::result::Result">Result</a>&lt;<a class="struct" href="https://doc.rust-lang.org/1.65.0/std/sync/rwlock/struct.RwLockWriteGuard.html" title="struct std::sync::rwlock::RwLockWriteGuard">RwLockWriteGuard</a>&lt;'_, T&gt;, <a class="struct" href="https://doc.rust-lang.org/1.65.0/std/sync/poison/struct.PoisonError.html" title="struct std::sync::poison::PoisonError">PoisonError</a>&lt;<a class="struct" href="https://doc.rust-lang.org/1.65.0/std/sync/rwlock/struct.RwLockWriteGuard.html" title="struct std::sync::rwlock::RwLockWriteGuard">RwLockWriteGuard</a>&lt;'_, T&gt;&gt;&gt;</h4></section></summary><div class="docblock"><p>Locks this rwlock with exclusive write access, blocking the current
thread until it can be acquired.</p>
<p>This function will not return while other writers or other readers
currently have access to the lock.</p>
<p>Returns an RAII guard which will drop the write access of this rwlock
when dropped.</p>
<h5 id="errors-2"><a href="#errors-2">Errors</a></h5>
<p>This function will return an error if the RwLock is poisoned. An RwLock
is poisoned whenever a writer panics while holding an exclusive lock.
An error will be returned when the lock is acquired.</p>
<h5 id="panics-1"><a href="#panics-1">Panics</a></h5>
<p>This function might panic when called if the lock is already held by the current thread.</p>
<h5 id="examples-2"><a href="#examples-2">Examples</a></h5>
<div class="example-wrap"><pre class="rust rust-example-rendered"><code><span class="kw">use </span>std::sync::RwLock;
<span class="kw">let </span>lock = RwLock::new(<span class="number">1</span>);
<span class="kw">let </span><span class="kw-2">mut </span>n = lock.write().unwrap();
<span class="kw-2">*</span>n = <span class="number">2</span>;
<span class="macro">assert!</span>(lock.try_read().is_err());</code></pre></div>
</div></details><details class="rustdoc-toggle method-toggle" open><summary><section id="method.try_write" class="method has-srclink"><span class="rightside"><span class="since" title="Stable since Rust version 1.0.0">1.0.0</span> · <a class="srclink" href="https://doc.rust-lang.org/1.65.0/src/std/sync/rwlock.rs.html#344">source</a></span><h4 class="code-header">pub fn <a href="#method.try_write" class="fnname">try_write</a>(<br>&nbsp;&nbsp;&nbsp;&nbsp;&amp;self<br>) -&gt; <a class="enum" href="https://doc.rust-lang.org/1.65.0/core/result/enum.Result.html" title="enum core::result::Result">Result</a>&lt;<a class="struct" href="https://doc.rust-lang.org/1.65.0/std/sync/rwlock/struct.RwLockWriteGuard.html" title="struct std::sync::rwlock::RwLockWriteGuard">RwLockWriteGuard</a>&lt;'_, T&gt;, <a class="enum" href="https://doc.rust-lang.org/1.65.0/std/sync/poison/enum.TryLockError.html" title="enum std::sync::poison::TryLockError">TryLockError</a>&lt;<a class="struct" href="https://doc.rust-lang.org/1.65.0/std/sync/rwlock/struct.RwLockWriteGuard.html" title="struct std::sync::rwlock::RwLockWriteGuard">RwLockWriteGuard</a>&lt;'_, T&gt;&gt;&gt;</h4></section></summary><div class="docblock"><p>Attempts to lock this rwlock with exclusive write access.</p>
<p>If the lock could not be acquired at this time, then <code>Err</code> is returned.
Otherwise, an RAII guard is returned which will release the lock when
it is dropped.</p>
<p>This function does not block.</p>
<p>This function does not provide any guarantees with respect to the ordering
of whether contentious readers or writers will acquire the lock first.</p>
<h5 id="errors-3"><a href="#errors-3">Errors</a></h5>
<p>This function will return the <a href="https://doc.rust-lang.org/1.65.0/std/sync/poison/enum.TryLockError.html#variant.Poisoned"><code>Poisoned</code></a> error if the RwLock is
poisoned. An RwLock is poisoned whenever a writer panics while holding
an exclusive lock. <code>Poisoned</code> will only be returned if the lock would have
otherwise been acquired.</p>
<p>This function will return the <a href="https://doc.rust-lang.org/1.65.0/std/sync/poison/enum.TryLockError.html#variant.WouldBlock"><code>WouldBlock</code></a> error if the RwLock could not
be acquired because it was already locked exclusively.</p>
<h5 id="examples-3"><a href="#examples-3">Examples</a></h5>
<div class="example-wrap"><pre class="rust rust-example-rendered"><code><span class="kw">use </span>std::sync::RwLock;
<span class="kw">let </span>lock = RwLock::new(<span class="number">1</span>);
<span class="kw">let </span>n = lock.read().unwrap();
<span class="macro">assert_eq!</span>(<span class="kw-2">*</span>n, <span class="number">1</span>);
<span class="macro">assert!</span>(lock.try_write().is_err());</code></pre></div>
</div></details><details class="rustdoc-toggle method-toggle" open><summary><section id="method.is_poisoned" class="method has-srclink"><span class="rightside"><span class="since" title="Stable since Rust version 1.2.0">1.2.0</span> · <a class="srclink" href="https://doc.rust-lang.org/1.65.0/src/std/sync/rwlock.rs.html#377">source</a></span><h4 class="code-header">pub fn <a href="#method.is_poisoned" class="fnname">is_poisoned</a>(&amp;self) -&gt; <a class="primitive" href="https://doc.rust-lang.org/1.65.0/std/primitive.bool.html">bool</a></h4></section></summary><div class="docblock"><p>Determines whether the lock is poisoned.</p>
<p>If another thread is active, the lock can still become poisoned at any
time. You should not trust a <code>false</code> value for program correctness
without additional synchronization.</p>
<h5 id="examples-4"><a href="#examples-4">Examples</a></h5>
<div class="example-wrap"><pre class="rust rust-example-rendered"><code><span class="kw">use </span>std::sync::{Arc, RwLock};
<span class="kw">use </span>std::thread;
<span class="kw">let </span>lock = Arc::new(RwLock::new(<span class="number">0</span>));
<span class="kw">let </span>c_lock = Arc::clone(<span class="kw-2">&amp;</span>lock);
<span class="kw">let _ </span>= thread::spawn(<span class="kw">move </span>|| {
<span class="kw">let </span>_lock = c_lock.write().unwrap();
<span class="macro">panic!</span>(); <span class="comment">// the lock gets poisoned
</span>}).join();
<span class="macro">assert_eq!</span>(lock.is_poisoned(), <span class="bool-val">true</span>);</code></pre></div>
</div></details><details class="rustdoc-toggle method-toggle" open><summary><section id="method.clear_poison" class="method has-srclink"><a class="srclink rightside" href="https://doc.rust-lang.org/1.65.0/src/std/sync/rwlock.rs.html#416">source</a><h4 class="code-header">pub fn <a href="#method.clear_poison" class="fnname">clear_poison</a>(&amp;self)</h4></section><span class="item-info"><div class="stab unstable"><span class="emoji">🔬</span><span>This is a nightly-only experimental API. (<code>mutex_unpoison</code>)</span></div></span></summary><div class="docblock"><p>Clear the poisoned state from a lock</p>
<p>If the lock is poisoned, it will remain poisoned until this function is called. This allows
recovering from a poisoned state and marking that it has recovered. For example, if the
value is overwritten by a known-good value, then the mutex can be marked as un-poisoned. Or
possibly, the value could be inspected to determine if it is in a consistent state, and if
so the poison is removed.</p>
<h5 id="examples-5"><a href="#examples-5">Examples</a></h5>
<div class="example-wrap"><pre class="rust rust-example-rendered"><code><span class="attribute">#![feature(mutex_unpoison)]
</span><span class="kw">use </span>std::sync::{Arc, RwLock};
<span class="kw">use </span>std::thread;
<span class="kw">let </span>lock = Arc::new(RwLock::new(<span class="number">0</span>));
<span class="kw">let </span>c_lock = Arc::clone(<span class="kw-2">&amp;</span>lock);
<span class="kw">let _ </span>= thread::spawn(<span class="kw">move </span>|| {
<span class="kw">let </span>_lock = c_lock.write().unwrap();
<span class="macro">panic!</span>(); <span class="comment">// the mutex gets poisoned
</span>}).join();
<span class="macro">assert_eq!</span>(lock.is_poisoned(), <span class="bool-val">true</span>);
<span class="kw">let </span>guard = lock.write().unwrap_or_else(|<span class="kw-2">mut </span>e| {
<span class="kw-2">**</span>e.get_mut() = <span class="number">1</span>;
lock.clear_poison();
e.into_inner()
});
<span class="macro">assert_eq!</span>(lock.is_poisoned(), <span class="bool-val">false</span>);
<span class="macro">assert_eq!</span>(<span class="kw-2">*</span>guard, <span class="number">1</span>);</code></pre></div>
</div></details></div></div><h2 id="trait-implementations" class="small-section-header">Trait Implementations<a href="#trait-implementations" class="anchor"></a></h2><div id="trait-implementations-list"><details class="rustdoc-toggle implementors-toggle" open><summary><section id="impl-Deref-for-MAP" class="impl has-srclink"><a class="srclink rightside" href="../src/headless/main.rs.html#39-51">source</a><a href="#impl-Deref-for-MAP" class="anchor"></a><h3 class="code-header in-band">impl <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/ops/deref/trait.Deref.html" title="trait core::ops::deref::Deref">Deref</a> for <a class="struct" href="struct.MAP.html" title="struct headless::MAP">MAP</a></h3></section></summary><div class="impl-items"><details class="rustdoc-toggle" open><summary><section id="associatedtype.Target" class="associatedtype trait-impl has-srclink"><a href="#associatedtype.Target" class="anchor"></a><h4 class="code-header">type <a href="https://doc.rust-lang.org/1.65.0/core/ops/deref/trait.Deref.html#associatedtype.Target" class="associatedtype">Target</a> = <a class="struct" href="https://doc.rust-lang.org/1.65.0/std/sync/rwlock/struct.RwLock.html" title="struct std::sync::rwlock::RwLock">RwLock</a>&lt;Map&gt;</h4></section></summary><div class='docblock'>The resulting type after dereferencing.</div></details><details class="rustdoc-toggle method-toggle" open><summary><section id="method.deref" class="method trait-impl has-srclink"><a class="srclink rightside" href="../src/headless/main.rs.html#39-51">source</a><a href="#method.deref" class="anchor"></a><h4 class="code-header">fn <a href="https://doc.rust-lang.org/1.65.0/core/ops/deref/trait.Deref.html#tymethod.deref" class="fnname">deref</a>(&amp;self) -&gt; &amp;<a class="struct" href="https://doc.rust-lang.org/1.65.0/std/sync/rwlock/struct.RwLock.html" title="struct std::sync::rwlock::RwLock">RwLock</a>&lt;Map&gt;</h4></section></summary><div class='docblock'>Dereferences the value.</div></details></div></details><section id="impl-LazyStatic-for-MAP" class="impl has-srclink"><a class="srclink rightside" href="../src/headless/main.rs.html#39-51">source</a><a href="#impl-LazyStatic-for-MAP" class="anchor"></a><h3 class="code-header in-band">impl <a class="trait" href="https://docs.rs/lazy_static/1.4.0/lazy_static/trait.LazyStatic.html" title="trait lazy_static::LazyStatic">LazyStatic</a> for <a class="struct" href="struct.MAP.html" title="struct headless::MAP">MAP</a></h3></section></div><h2 id="synthetic-implementations" class="small-section-header">Auto Trait Implementations<a href="#synthetic-implementations" class="anchor"></a></h2><div id="synthetic-implementations-list"><section id="impl-RefUnwindSafe-for-MAP" class="impl has-srclink"><a href="#impl-RefUnwindSafe-for-MAP" class="anchor"></a><h3 class="code-header in-band">impl <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/panic/unwind_safe/trait.RefUnwindSafe.html" title="trait core::panic::unwind_safe::RefUnwindSafe">RefUnwindSafe</a> for <a class="struct" href="struct.MAP.html" title="struct headless::MAP">MAP</a></h3></section><section id="impl-Send-for-MAP" class="impl has-srclink"><a href="#impl-Send-for-MAP" class="anchor"></a><h3 class="code-header in-band">impl <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/marker/trait.Send.html" title="trait core::marker::Send">Send</a> for <a class="struct" href="struct.MAP.html" title="struct headless::MAP">MAP</a></h3></section><section id="impl-Sync-for-MAP" class="impl has-srclink"><a href="#impl-Sync-for-MAP" class="anchor"></a><h3 class="code-header in-band">impl <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/marker/trait.Sync.html" title="trait core::marker::Sync">Sync</a> for <a class="struct" href="struct.MAP.html" title="struct headless::MAP">MAP</a></h3></section><section id="impl-Unpin-for-MAP" class="impl has-srclink"><a href="#impl-Unpin-for-MAP" class="anchor"></a><h3 class="code-header in-band">impl <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/marker/trait.Unpin.html
then be further <code>downcast</code> into <code>Box&lt;ConcreteType&gt;</code> where <code>ConcreteType</code> implements <code>Trait</code>. <a>Read more</a></div></details><details class="rustdoc-toggle method-toggle" open><summary><section id="method.into_any_rc" class="method trait-impl has-srclink"><a href="#method.into_any_rc" class="anchor"></a><h4 class="code-header">fn <a class="fnname">into_any_rc</a>(self: <a class="struct" href="https://doc.rust-lang.org/1.65.0/alloc/rc/struct.Rc.html" title="struct alloc::rc::Rc">Rc</a>&lt;T&gt;) -&gt; <a class="struct" href="https://doc.rust-lang.org/1.65.0/alloc/rc/struct.Rc.html" title="struct alloc::rc::Rc">Rc</a>&lt;dyn <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/any/trait.Any.html" title="trait core::any::Any">Any</a> + 'static&gt;</h4></section></summary><div class='docblock'>Convert <code>Rc&lt;Trait&gt;</code> (where <code>Trait: Downcast</code>) to <code>Rc&lt;Any&gt;</code>. <code>Rc&lt;Any&gt;</code> can then be
further <code>downcast</code> into <code>Rc&lt;ConcreteType&gt;</code> where <code>ConcreteType</code> implements <code>Trait</code>. <a>Read more</a></div></details><details class="rustdoc-toggle method-toggle" open><summary><section id="method.as_any" class="method trait-impl has-srclink"><a href="#method.as_any" class="anchor"></a><h4 class="code-header">fn <a class="fnname">as_any</a>(&amp;self) -&gt; &amp;(dyn <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/any/trait.Any.html" title="trait core::any::Any">Any</a> + 'static)</h4></section></summary><div class='docblock'>Convert <code>&amp;Trait</code> (where <code>Trait: Downcast</code>) to <code>&amp;Any</code>. This is needed since Rust cannot
generate <code>&amp;Any</code>s vtable from <code>&amp;Trait</code>s. <a>Read more</a></div></details><details class="rustdoc-toggle method-toggle" open><summary><section id="method.as_any_mut" class="method trait-impl has-srclink"><a href="#method.as_any_mut" class="anchor"></a><h4 class="code-header">fn <a class="fnname">as_any_mut</a>(&amp;mut self) -&gt; &amp;mut (dyn <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/any/trait.Any.html" title="trait core::any::Any">Any</a> + 'static)</h4></section></summary><div class='docblock'>Convert <code>&amp;mut Trait</code> (where <code>Trait: Downcast</code>) to <code>&amp;Any</code>. This is needed since Rust cannot
generate <code>&amp;mut Any</code>s vtable from <code>&amp;mut Trait</code>s. <a>Read more</a></div></details></div></details><details class="rustdoc-toggle implementors-toggle"><summary><section id="impl-DowncastSync-for-MAP" class="impl has-srclink"><a href="#impl-DowncastSync-for-MAP" class="anchor"></a><h3 class="code-header in-band">impl&lt;T&gt; DowncastSync for T<span class="where fmt-newline">where<br>&nbsp;&nbsp;&nbsp;&nbsp;T: <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/any/trait.Any.html" title="trait core::any::Any">Any</a> + <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/marker/trait.Send.html" title="trait core::marker::Send">Send</a> + <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/marker/trait.Sync.html" title="trait core::marker::Sync">Sync</a>,</span></h3></section></summary><div class="impl-items"><details class="rustdoc-toggle method-toggle" open><summary><section id="method.into_any_arc" class="method trait-impl has-srclink"><a href="#method.into_any_arc" class="anchor"></a><h4 class="code-header">fn <a class="fnname">into_any_arc</a>(self: <a class="struct" href="https://doc.rust-lang.org/1.65.0/alloc/sync/struct.Arc.html" title="struct alloc::sync::Arc">Arc</a>&lt;T&gt;) -&gt; <a class="struct" href="https://doc.rust-lang.org/1.65.0/alloc/sync/struct.Arc.html" title="struct alloc::sync::Arc">Arc</a>&lt;dyn <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/any/trait.Any.html" title="trait core::any::Any">Any</a> + <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/marker/trait.Send.html" title="trait core::marker::Send">Send</a> + <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/marker/trait.Sync.html" title="trait core::marker::Sync">Sync</a> + 'static&gt;</h4></section></summary><div class='docblock'>Convert <code>Arc&lt;Trait&gt;</code> (where <code>Trait: Downcast</code>) to <code>Arc&lt;Any&gt;</code>. <code>Arc&lt;Any&gt;</code> can then be
further <code>downcast</code> into <code>Arc&lt;ConcreteType&gt;</code> where <code>ConcreteType</code> implements <code>Trait</code>. <a>Read more</a></div></details></div></details><details class="rustdoc-toggle implementors-toggle"><summary><section id="impl-From%3CT%3E-for-MAP" class="impl has-srclink"><a class="srclink rightside" href="https://doc.rust-lang.org/1.65.0/src/core/convert/mod.rs.html#559">source</a><a href="#impl-From%3CT%3E-for-MAP" class="anchor"></a><h3 class="code-header in-band">impl&lt;T&gt; <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/convert/trait.From.html" title="trait core::convert::From">From</a>&lt;T&gt; for T</h3></section></summary><div class="impl-items"><details class="rustdoc-toggle method-toggle" open><summary><section id="method.from" class="method trait-impl has-srclink"><span class="rightside"><span class="since" title="const unstable">const: <a href="https://github.com/rust-lang/rust/issues/88674" title="Tracking issue for const_convert">unstable</a></span> · <a class="srclink" href="https://doc.rust-lang.org/1.65.0/src/core/convert/mod.rs.html#562">source</a></span><a href="#method.from" class="anchor"></a><h4 class="code-header">fn <a href="https://doc.rust-lang.org/1.65.0/core/convert/trait.From.html#tymethod.from" class="fnname">from</a>(t: T) -&gt; T</h4></section></summary><div class="docblock"><p>Returns the argument unchanged.</p>
</div></details></div></details><details class="rustdoc-toggle implementors-toggle"><summary><section id="impl-Instrument-for-MAP" class="impl has-srclink"><a class="srclink rightside" href="https://docs.rs/tracing/0.1.26/src/tracing/instrument.rs.html#155">source</a><a href="#impl-Instrument-for-MAP" class="anchor"></a><h3 class="code-header in-band">impl&lt;T&gt; <a class="trait" href="https://docs.rs/tracing/0.1.26/tracing/instrument/trait.Instrument.html" title="trait tracing::instrument::Instrument">Instrument</a> for T</h3></section></summary><div class="impl-items"><details class="rustdoc-toggle method-toggle" open><summary><section id="method.instrument" class="method trait-impl has-srclink"><a class="srclink rightside" href="https://docs.rs/tracing/0.1.26/src/tracing/instrument.rs.html#38">source</a><a href="#method.instrument" class="anchor"></a><h4 class="code-header">fn <a href="https://docs.rs/tracing/0.1.26/tracing/instrument/trait.Instrument.html#method.instrument" class="fnname">instrument</a>(self, span: <a class="struct" href="https://docs.rs/tracing/0.1.26/tracing/span/struct.Span.html" title="struct tracing::span::Span">Span</a>) -&gt; <a class="struct" href="https://docs.rs/tracing/0.1.26/tracing/instrument/struct.Instrumented.html" title="struct tracing::instrument::Instrumented">Instrumented</a>&lt;Self&gt;</h4></section></summary><div class='docblock'>Instruments this type with the provided <code>Span</code>, returning an
<code>Instrumented</code> wrapper. <a href="https://docs.rs/tracing/0.1.26/tracing/instrument/trait.Instrument.html#method.instrument">Read more</a></div></details><details class="rustdoc-toggle method-toggle" open><summary><section id="method.in_current_span" class="method trait-impl has-srclink"><a class="srclink rightside" href="https://docs.rs/tracing/0.1.26/src/tracing/instrument.rs.html#74">source</a><a href="#method.in_current_span" class="anchor"></a><h4 class="code-header">fn <a href="https://docs.rs/tracing/0.1.26/tracing/instrument/trait.Instrument.html#method.in_current_span" class="fnname">in_current_span</a>(self) -&gt; <a class="struct" href="https://docs.rs/tracing/0.1.26/tracing/instrument/struct.Instrumented.html" title="struct tracing::instrument::Instrumented">Instrumented</a>&lt;Self&gt;</h4></section></summary><div class='docblock'>Instruments this type with the <a href="../struct.Span.html#method.current">current</a> <code>Span</code>, returning an
<code>Instrumented</code> wrapper. <a href="https://docs.rs/tracing/0.1.26/tracing/instrument/trait.Instrument.html#method.in_current_span">Read more</a></div></details></div></details><details class="rustdoc-toggle implementors-toggle"><summary><section id="impl-Into%3CU%3E-for-MAP" class="impl has-srclink"><a class="srclink rightside" href="https://doc.rust-lang.org/1.65.0/src/core/convert/mod.rs.html#543">source</a><a href="#impl-Into%3CU%3E-for-MAP" class="anchor"></a><h3 class="code-header in-band">impl&lt;T, U&gt; <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/convert/trait.Into.html" title="trait core::convert::Into">Into</a>&lt;U&gt; for T<span class="where fmt-newline">where<br>&nbsp;&nbsp;&nbsp;&nbsp;U: <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/convert/trait.From.html" title="trait core::convert::From">From</a>&lt;T&gt;,</span></h3></section></summary><div class="impl-items"><details class="rustdoc-toggle method-toggle" open><summary><section id="method.into" class="method trait-impl has-srclink"><span class="rightside"><span class="since" title="const unstable">const: <a href="https://github.com/rust-lang/rust/issues/88674" title="Tracking issue for const_convert">unstable</a></span> · <a class="srclink" href="https://doc.rust-lang.org/1.65.0/src/core/convert/mod.rs.html#551">source</a></span><a href="#method.into" class="anchor"></a><h4 class="code-header">fn <a href="https://doc.rust-lang.org/1.65.0/core/convert/trait.Into.html#tymethod.into" class="fnname">into</a>(self) -&gt; U</h4></section></summary><div class="docblock"><p>Calls <code>U::from(self)</code>.</p>
<p>That is, this conversion is whatever the implementation of
<code><a href="https://doc.rust-lang.org/1.65.0/core/convert/trait.From.html" title="From">From</a>&lt;T&gt; for U</code> chooses to do.</p>
</div></details></div></details><details class="rustdoc-toggle implementors-toggle"><summary><section id="impl-TryFrom%3CU%3E-for-MAP" class="impl has-srclink"><a class="srclink rightside" href="https://doc.rust-lang.org/1.65.0/src/core/convert/mod.rs.html#601">source</a><a href="#impl-TryFrom%3CU%3E-for-MAP" class="anchor"></a><h3 class="code-header in-band">impl&lt;T, U&gt; <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/convert/trait.TryFrom.html" title="trait core::convert::TryFrom">TryFrom</a>&lt;U&gt; for T<span class="where fmt-newline">where<br>&nbsp;&nbsp;&nbsp;&nbsp;U: <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/convert/trait.Into.html" title="trait core::convert::Into">Into</a>&lt;T&gt;,</span></h3></section></summary><div class="impl-items"><details class="rustdoc-toggle" open><summary><section id="associatedtype.Error-1" class="associatedtype trait-impl has-srclink"><a href="#associatedtype.Error-1" class="anchor"></a><h4 class="code-header">type <a href="https://doc.rust-lang.org/1.65.0/core/convert/trait.TryFrom.html#associatedtype.Error" class="associatedtype">Error</a> = <a class="enum" href="https://doc.rust-lang.org/1.65.0/core/convert/enum.Infallible.html" title="enum core::convert::Infallible">Infallible</a></h4></section></summary><div class='docblock'>The type returned in the event of a conversion error.</div></details><details class="rustdoc-toggle method-toggle" open><summary><section id="method.try_from" class="method trait-impl has-srclink"><span class="rightside"><span class="since" title="const unstable">const: <a href="https://github.com/rust-lang/rust/issues/88674" title="Tracking issue for const_convert">unstable</a></span> · <a class="srclink" href="https://doc.rust-lang.org/1.65.0/src/core/convert/mod.rs.html#607">source</a></span><a href="#method.try_from" class="anchor"></a><h4 class="code-header">fn <a href="https://doc.rust-lang.org/1.65.0/core/convert/trait.TryFrom.html#tymethod.try_from" class="fnname">try_from</a>(value: U) -&gt; <a class="enum" href="https://doc.rust-lang.org/1.65.0/core/result/enum.Result.html" title="enum core::result::Result">Result</a>&lt;T, &lt;T as <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/convert/trait.TryFrom.html" title="trait core::convert::TryFrom">TryFrom</a>&lt;U&gt;&gt;::<a class="associatedtype" href="https://doc.rust-lang.org/1.65.0/core/convert/trait.TryFrom.html#associatedtype.Error" title="type core::convert::TryFrom::Error">Error</a>&gt;</h4></section></summary><div class='docblock'>Performs the conversion.</div></details></div></details><details class="rustdoc-toggle implementors-toggle"><summary><section id="impl-TryInto%3CU%3E-for-MAP" class="impl has-srclink"><a class="srclink rightside" href="https://doc.rust-lang.org/1.65.0/src/core/convert/mod.rs.html#586">source</a><a href="#impl-TryInto%3CU%3E-for-MAP" class="anchor"></a><h3 class="code-header in-band">impl&lt;T, U&gt; <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/convert/trait.TryInto.html" title="trait core::convert::TryInto">TryInto</a>&lt;U&gt; for T<span class="where fmt-newline">where<br>&nbsp;&nbsp;&nbsp;&nbsp;U: <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/convert/trait.TryFrom.html" title="trait core::convert::TryFrom">TryFrom</a>&lt;T&gt;,</span></h3></section></summary><div class="impl-items"><details class="rustdoc-toggle" open><summary><section id="associatedtype.Error" class="associatedtype trait-impl has-srclink"><a href="#associatedtype.Error" class="anchor"></a><h4 class="code-header">type <a href="https://doc.rust-lang.org/1.65.0/core/convert/trait.TryInto.html#associatedtype.Error" class="associatedtype">Error</a> = &lt;U as <a class="trait" href="https://doc.rust-lang.org/1.65.0/core/convert/trait.TryFrom.html" title="trait core::convert::TryFrom">TryFrom</a>&lt;T&gt;&gt;::<a class="associatedtype" href="https://doc.rust-lang.org/1.65.0/core/convert/trait.TryFrom.html#associatedtype.Error" title="type core::convert::TryFrom::Error">Error</a></h4></section></summary><div class='docbloc