Rust-for-Arduboy/docs/doc/critical_section/struct.Mutex.html

101 lines
No EOL
26 KiB
HTML
Raw 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="A mutex based on critical sections."><title>Mutex in critical_section - Rust</title><link rel="preload" as="font" type="font/woff2" crossorigin href="../static.files/SourceSerif4-Regular-46f98efaafac5295.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-a2c9cd1067f8b328.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-cb6f1f67f1bcd037.css" id="mainThemeStyle"><meta name="rustdoc-vars" data-root-path="../" data-static-root-path="../static.files/" data-current-crate="critical_section" data-themes="" data-resource-suffix="" data-rustdoc-version="1.73.0-nightly (500647fd8 2023-07-27)" data-channel="nightly" data-search-js="search-6dfdfced5eff6596.js" data-settings-js="settings-de11bff964e9d4e5.js" data-settings-css="settings-8c76f75bfb6bd192.css" data-theme-light-css="light-6d2c9675f3d09c26.css" data-theme-dark-css="dark-45ceb8f2e522f4d1.css" data-theme-ayu-css="ayu-fd19013d6ce078bf.css" ><script src="../static.files/storage-db41da1a38ea3cb8.js"></script><script defer src="sidebar-items.js"></script><script defer src="../static.files/main-0795b7d26be81095.js"></script><noscript><link rel="stylesheet" media="(prefers-color-scheme:light)" href="../static.files/light-6d2c9675f3d09c26.css"><link rel="stylesheet" media="(prefers-color-scheme:dark)" href="../static.files/dark-45ceb8f2e522f4d1.css"><link rel="stylesheet" href="../static.files/noscript-cffde32267a19fd6.css"></noscript><link rel="alternate icon" type="image/png" href="../static.files/favicon-16x16-8b506e7a72182f1c.png"><link rel="alternate icon" type="image/png" href="../static.files/favicon-32x32-422f7d1d52889060.png"><link rel="icon" type="image/svg+xml" href="../static.files/favicon-2c020d218678b618.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="logo-container" href="../critical_section/index.html"><img class="rust-logo" src="../static.files/rust-logo-151179464ae7ed46.svg" alt="logo"></a><h2></h2></nav><nav class="sidebar"><a class="logo-container" href="../critical_section/index.html"><img class="rust-logo" src="../static.files/rust-logo-151179464ae7ed46.svg" alt="logo"></a><h2 class="location"><a href="#">Mutex</a></h2><div class="sidebar-elems"><section><h3><a href="#implementations">Methods</a></h3><ul class="block"><li><a href="#method.borrow">borrow</a></li><li><a href="#method.borrow_ref">borrow_ref</a></li><li><a href="#method.borrow_ref_mut">borrow_ref_mut</a></li><li><a href="#method.get_mut">get_mut</a></li><li><a href="#method.into_inner">into_inner</a></li><li><a href="#method.new">new</a></li><li><a href="#method.replace">replace</a></li><li><a href="#method.replace_with">replace_with</a></li><li><a href="#method.take">take</a></li></ul><h3><a href="#trait-implementations">Trait Implementations</a></h3><ul class="block"><li><a href="#impl-Debug-for-Mutex%3CT%3E">Debug</a></li><li><a href="#impl-Sync-for-Mutex%3CT%3E">Sync</a></li></ul><h3><a href="#synthetic-implementations">Auto Trait Implementations</a></h3><ul class="block"><li><a href="#impl-RefUnwindSafe-for-Mutex%3CT%3E">!RefUnwindSafe</a></li><li><a href="#impl-Send-for-Mutex%3CT%3E">Send</a></li><li><a href="#impl-Unpin-for-Mutex%3CT%3E">Unpin</a></li><li><a href="#impl-UnwindSafe-for-Mutex%3CT%3E">UnwindSafe</a></li></ul><h3><a href="#blanket-implementations">Blanket Implementations</a></h3><ul class="block"><li><a href="#impl-Any-for-Mutex%3CT%3E">Any</a></li><li><a href="#impl-Borrow%3CT%3E-for-Mutex%3CT%3E">Borrow&lt;T&gt;</a></li><li><a href="#impl-BorrowMut%3CT%3E-for-Mutex%3CT%3E">BorrowMut&lt;T&gt;</a></li><li><a href="#impl-From%3CT%3E-for-Mutex%3CT%3E">From&lt;T&gt;</a></li><li><a href="#impl-Into%3CU%3E-for-Mutex%3CT%3E">Into&lt;U&gt;</a></li><li><a href="#impl-TryFrom%3CU%3E-for-Mutex%3CT%3E">TryFrom&lt;U&gt;</a></li><li><a href="#impl-TryInto%3CU%3E-for-Mutex%3CT%3E">TryInto&lt;U&gt;</a></li></ul></section><h2><a href="index.html">In critical_section</a></h2></div></nav><main><div class="width-limiter"><nav class="sub"><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-7b819b6101059cd0.svg"></a></div></form></nav><section id="main-content" class="content"><div class="main-heading"><h1>Struct <a href="index.html">critical_section</a>::<wbr><a class="struct" href="#">Mutex</a><button id="copy-path" title="Copy item path to clipboard"><img src="../static.files/clipboard-7571035ce49a181d.svg" width="19" height="18" alt="Copy item path"></button></h1><span class="out-of-band"><a class="src" href="../src/critical_section/mutex.rs.html#74-76">source</a> · <button id="toggle-all-docs" title="collapse all docs">[<span>&#x2212;</span>]</button></span></div><pre class="rust item-decl"><code>pub struct Mutex&lt;T&gt; { /* private fields */ }</code></pre><details class="toggle top-doc" open><summary class="hideme"><span>Expand description</span></summary><div class="docblock"><p>A mutex based on critical sections.</p>
<h2 id="example"><a href="#example">Example</a></h2>
<div class="example-wrap"><pre class="rust rust-example-rendered"><code>
<span class="kw">static </span>FOO: Mutex&lt;Cell&lt;i32&gt;&gt; = Mutex::new(Cell::new(<span class="number">42</span>));
<span class="kw">fn </span>main() {
critical_section::with(|cs| {
FOO.borrow(cs).set(<span class="number">43</span>);
});
}
<span class="kw">fn </span>interrupt_handler() {
<span class="kw">let </span>_x = critical_section::with(|cs| FOO.borrow(cs).get());
}</code></pre></div>
<h2 id="design"><a href="#design">Design</a></h2>
<p><a href="https://doc.rust-lang.org/std/sync/struct.Mutex.html"><code>std::sync::Mutex</code></a> has two purposes. It converts types that are [<code>Send</code>]
but not [<code>Sync</code>] into types that are both; and it provides
<a href="https://doc.rust-lang.org/reference/interior-mutability.html">interior mutability</a>. <code>critical_section::Mutex</code>, on the other hand, only adds
<code>Sync</code>. It does <em>not</em> provide interior mutability.</p>
<p>This was a conscious design choice. It is possible to create multiple
<a href="struct.CriticalSection.html" title="struct critical_section::CriticalSection"><code>CriticalSection</code></a> tokens, either by nesting critical sections or <code>Copy</code>ing
an existing token. As a result, it would not be sound for <a href="struct.Mutex.html#method.borrow" title="method critical_section::Mutex::borrow"><code>Mutex::borrow</code></a>
to return <code>&amp;mut T</code>, because there would be nothing to prevent calling
<code>borrow</code> multiple times to create aliased <code>&amp;mut T</code> references.</p>
<p>The solution is to include a runtime check to ensure that each resource is
borrowed only once. This is what <code>std::sync::Mutex</code> does. However, this is
a runtime cost that may not be required in all circumstances. For instance,
<code>Mutex&lt;Cell&lt;T&gt;&gt;</code> never needs to create <code>&amp;mut T</code> or equivalent.</p>
<p>If <code>&amp;mut T</code> is needed, the simplest solution is to use <code>Mutex&lt;RefCell&lt;T&gt;&gt;</code>,
which is the closest analogy to <code>std::sync::Mutex</code>. [<code>RefCell</code>] inserts the
exact runtime check necessary to guarantee that the <code>&amp;mut T</code> reference is
unique.</p>
<p>To reduce verbosity when using <code>Mutex&lt;RefCell&lt;T&gt;&gt;</code>, we reimplement some of
<code>RefCell</code>s methods on it directly.</p>
<div class="example-wrap"><pre class="rust rust-example-rendered"><code>
<span class="kw">static </span>FOO: Mutex&lt;RefCell&lt;i32&gt;&gt; = Mutex::new(RefCell::new(<span class="number">42</span>));
<span class="kw">fn </span>main() {
critical_section::with(|cs| {
<span class="comment">// Instead of calling this
</span><span class="kw">let _ </span>= FOO.borrow(cs).take();
<span class="comment">// Call this
</span><span class="kw">let _ </span>= FOO.take(cs);
<span class="comment">// `RefCell::borrow` and `RefCell::borrow_mut` are renamed to
// `borrow_ref` and `borrow_ref_mut` to avoid name collisions
</span><span class="kw">let _</span>: <span class="kw-2">&amp;mut </span>i32 = <span class="kw-2">&amp;mut *</span>FOO.borrow_ref_mut(cs);
})
}</code></pre></div>
</div></details><h2 id="implementations" class="small-section-header">Implementations<a href="#implementations" class="anchor">§</a></h2><div id="implementations-list"><details class="toggle implementors-toggle" open><summary><section id="impl-Mutex%3CT%3E" class="impl"><a class="src rightside" href="../src/critical_section/mutex.rs.html#78-109">source</a><a href="#impl-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; <a class="struct" href="struct.Mutex.html" title="struct critical_section::Mutex">Mutex</a>&lt;T&gt;</h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.new" class="method"><a class="src rightside" href="../src/critical_section/mutex.rs.html#81-85">source</a><h4 class="code-header">pub const fn <a href="#method.new" class="fn">new</a>(value: T) -&gt; Self</h4></section></summary><div class="docblock"><p>Creates a new mutex.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="method.get_mut" class="method"><a class="src rightside" href="../src/critical_section/mutex.rs.html#94-96">source</a><h4 class="code-header">pub fn <a href="#method.get_mut" class="fn">get_mut</a>(&amp;mut self) -&gt; &amp;mut T</h4></section></summary><div class="docblock"><p>Gets a mutable reference to the contained value when the mutex is already uniquely borrowed.</p>
<p>This does not require locking or a critical section since it takes <code>&amp;mut self</code>, which
guarantees unique ownership already. Care must be taken when using this method to
<strong>unsafely</strong> access <code>static mut</code> variables, appropriate fences must be used to prevent
unwanted optimizations.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="method.into_inner" class="method"><a class="src rightside" href="../src/critical_section/mutex.rs.html#100-102">source</a><h4 class="code-header">pub fn <a href="#method.into_inner" class="fn">into_inner</a>(self) -&gt; T</h4></section></summary><div class="docblock"><p>Unwraps the contained value, consuming the mutex.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="method.borrow" class="method"><a class="src rightside" href="../src/critical_section/mutex.rs.html#106-108">source</a><h4 class="code-header">pub fn <a href="#method.borrow" class="fn">borrow</a>&lt;'cs&gt;(&amp;'cs self, _cs: <a class="struct" href="struct.CriticalSection.html" title="struct critical_section::CriticalSection">CriticalSection</a>&lt;'cs&gt;) -&gt; &amp;'cs T</h4></section></summary><div class="docblock"><p>Borrows the data for the duration of the critical section.</p>
</div></details></div></details><details class="toggle implementors-toggle" open><summary><section id="impl-Mutex%3CRefCell%3CT%3E%3E" class="impl"><a class="src rightside" href="../src/critical_section/mutex.rs.html#111-170">source</a><a href="#impl-Mutex%3CRefCell%3CT%3E%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; <a class="struct" href="struct.Mutex.html" title="struct critical_section::Mutex">Mutex</a>&lt;RefCell&lt;T&gt;&gt;</h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.replace" class="method"><a class="src rightside" href="../src/critical_section/mutex.rs.html#122-124">source</a><h4 class="code-header">pub fn <a href="#method.replace" class="fn">replace</a>&lt;'cs&gt;(&amp;'cs self, cs: <a class="struct" href="struct.CriticalSection.html" title="struct critical_section::CriticalSection">CriticalSection</a>&lt;'cs&gt;, t: T) -&gt; T</h4></section></summary><div class="docblock"><p>Borrow the data and call [<code>RefCell::replace</code>]</p>
<p>This is equivalent to <code>self.borrow(cs).replace(t)</code></p>
<h5 id="panics"><a href="#panics">Panics</a></h5>
<p>This call could panic. See the documentation for [<code>RefCell::replace</code>]
for more details.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="method.replace_with" class="method"><a class="src rightside" href="../src/critical_section/mutex.rs.html#136-141">source</a><h4 class="code-header">pub fn <a href="#method.replace_with" class="fn">replace_with</a>&lt;'cs, F&gt;(&amp;'cs self, cs: <a class="struct" href="struct.CriticalSection.html" title="struct critical_section::CriticalSection">CriticalSection</a>&lt;'cs&gt;, f: F) -&gt; T<span class="where fmt-newline">where
F: FnOnce(&amp;mut T) -&gt; T,</span></h4></section></summary><div class="docblock"><p>Borrow the data and call [<code>RefCell::replace_with</code>]</p>
<p>This is equivalent to <code>self.borrow(cs).replace_with(f)</code></p>
<h5 id="panics-1"><a href="#panics-1">Panics</a></h5>
<p>This call could panic. See the documentation for
[<code>RefCell::replace_with</code>] for more details.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="method.borrow_ref" class="method"><a class="src rightside" href="../src/critical_section/mutex.rs.html#153-155">source</a><h4 class="code-header">pub fn <a href="#method.borrow_ref" class="fn">borrow_ref</a>&lt;'cs&gt;(&amp;'cs self, cs: <a class="struct" href="struct.CriticalSection.html" title="struct critical_section::CriticalSection">CriticalSection</a>&lt;'cs&gt;) -&gt; Ref&lt;'cs, T&gt;</h4></section></summary><div class="docblock"><p>Borrow the data and call [<code>RefCell::borrow</code>]</p>
<p>This is equivalent to <code>self.borrow(cs).borrow()</code></p>
<h5 id="panics-2"><a href="#panics-2">Panics</a></h5>
<p>This call could panic. See the documentation for [<code>RefCell::borrow</code>]
for more details.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="method.borrow_ref_mut" class="method"><a class="src rightside" href="../src/critical_section/mutex.rs.html#167-169">source</a><h4 class="code-header">pub fn <a href="#method.borrow_ref_mut" class="fn">borrow_ref_mut</a>&lt;'cs&gt;(
&amp;'cs self,
cs: <a class="struct" href="struct.CriticalSection.html" title="struct critical_section::CriticalSection">CriticalSection</a>&lt;'cs&gt;
) -&gt; RefMut&lt;'cs, T&gt;</h4></section></summary><div class="docblock"><p>Borrow the data and call [<code>RefCell::borrow_mut</code>]</p>
<p>This is equivalent to <code>self.borrow(cs).borrow_mut()</code></p>
<h5 id="panics-3"><a href="#panics-3">Panics</a></h5>
<p>This call could panic. See the documentation for [<code>RefCell::borrow_mut</code>]
for more details.</p>
</div></details></div></details><details class="toggle implementors-toggle" open><summary><section id="impl-Mutex%3CRefCell%3CT%3E%3E-1" class="impl"><a class="src rightside" href="../src/critical_section/mutex.rs.html#172-186">source</a><a href="#impl-Mutex%3CRefCell%3CT%3E%3E-1" class="anchor">§</a><h3 class="code-header">impl&lt;T: Default&gt; <a class="struct" href="struct.Mutex.html" title="struct critical_section::Mutex">Mutex</a>&lt;RefCell&lt;T&gt;&gt;</h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.take" class="method"><a class="src rightside" href="../src/critical_section/mutex.rs.html#183-185">source</a><h4 class="code-header">pub fn <a href="#method.take" class="fn">take</a>&lt;'cs&gt;(&amp;'cs self, cs: <a class="struct" href="struct.CriticalSection.html" title="struct critical_section::CriticalSection">CriticalSection</a>&lt;'cs&gt;) -&gt; T</h4></section></summary><div class="docblock"><p>Borrow the data and call [<code>RefCell::take</code>]</p>
<p>This is equivalent to <code>self.borrow(cs).take()</code></p>
<h5 id="panics-4"><a href="#panics-4">Panics</a></h5>
<p>This call could panic. See the documentation for [<code>RefCell::take</code>]
for more details.</p>
</div></details></div></details></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="toggle implementors-toggle" open><summary><section id="impl-Debug-for-Mutex%3CT%3E" class="impl"><a class="src rightside" href="../src/critical_section/mutex.rs.html#73">source</a><a href="#impl-Debug-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T: Debug&gt; Debug for <a class="struct" href="struct.Mutex.html" title="struct critical_section::Mutex">Mutex</a>&lt;T&gt;</h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.fmt" class="method trait-impl"><a class="src rightside" href="../src/critical_section/mutex.rs.html#73">source</a><a href="#method.fmt" class="anchor">§</a><h4 class="code-header">fn <a class="fn">fmt</a>(&amp;self, f: &amp;mut Formatter&lt;'_&gt;) -&gt; Result</h4></section></summary><div class='docblock'>Formats the value using the given formatter. <a>Read more</a></div></details></div></details><section id="impl-Sync-for-Mutex%3CT%3E" class="impl"><a class="src rightside" href="../src/critical_section/mutex.rs.html#191">source</a><a href="#impl-Sync-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; Sync for <a class="struct" href="struct.Mutex.html" title="struct critical_section::Mutex">Mutex</a>&lt;T&gt;<span class="where fmt-newline">where
T: Send,</span></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-Mutex%3CT%3E" class="impl"><a href="#impl-RefUnwindSafe-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; !RefUnwindSafe for <a class="struct" href="struct.Mutex.html" title="struct critical_section::Mutex">Mutex</a>&lt;T&gt;</h3></section><section id="impl-Send-for-Mutex%3CT%3E" class="impl"><a href="#impl-Send-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; Send for <a class="struct" href="struct.Mutex.html" title="struct critical_section::Mutex">Mutex</a>&lt;T&gt;<span class="where fmt-newline">where
T: Send,</span></h3></section><section id="impl-Unpin-for-Mutex%3CT%3E" class="impl"><a href="#impl-Unpin-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; Unpin for <a class="struct" href="struct.Mutex.html" title="struct critical_section::Mutex">Mutex</a>&lt;T&gt;<span class="where fmt-newline">where
T: Unpin,</span></h3></section><section id="impl-UnwindSafe-for-Mutex%3CT%3E" class="impl"><a href="#impl-UnwindSafe-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; UnwindSafe for <a class="struct" href="struct.Mutex.html" title="struct critical_section::Mutex">Mutex</a>&lt;T&gt;<span class="where fmt-newline">where
T: UnwindSafe,</span></h3></section></div><h2 id="blanket-implementations" class="small-section-header">Blanket Implementations<a href="#blanket-implementations" class="anchor">§</a></h2><div id="blanket-implementations-list"><details class="toggle implementors-toggle"><summary><section id="impl-Any-for-Mutex%3CT%3E" class="impl"><a href="#impl-Any-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; Any for T<span class="where fmt-newline">where
T: 'static + ?Sized,</span></h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.type_id" class="method trait-impl"><a href="#method.type_id" class="anchor">§</a><h4 class="code-header">fn <a class="fn">type_id</a>(&amp;self) -&gt; TypeId</h4></section></summary><div class='docblock'>Gets the <code>TypeId</code> of <code>self</code>. <a>Read more</a></div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-Borrow%3CT%3E-for-Mutex%3CT%3E" class="impl"><a href="#impl-Borrow%3CT%3E-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; Borrow&lt;T&gt; for T<span class="where fmt-newline">where
T: ?Sized,</span></h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.borrow-1" class="method trait-impl"><a href="#method.borrow-1" class="anchor">§</a><h4 class="code-header">fn <a class="fn">borrow</a>(&amp;self) -&gt; &amp;T</h4></section></summary><div class='docblock'>Immutably borrows from an owned value. <a>Read more</a></div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-BorrowMut%3CT%3E-for-Mutex%3CT%3E" class="impl"><a href="#impl-BorrowMut%3CT%3E-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; BorrowMut&lt;T&gt; for T<span class="where fmt-newline">where
T: ?Sized,</span></h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.borrow_mut" class="method trait-impl"><a href="#method.borrow_mut" class="anchor">§</a><h4 class="code-header">fn <a class="fn">borrow_mut</a>(&amp;mut self) -&gt; &amp;mut T</h4></section></summary><div class='docblock'>Mutably borrows from an owned value. <a>Read more</a></div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-From%3CT%3E-for-Mutex%3CT%3E" class="impl"><a href="#impl-From%3CT%3E-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; From&lt;T&gt; for T</h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.from" class="method trait-impl"><a href="#method.from" class="anchor">§</a><h4 class="code-header">fn <a class="fn">from</a>(t: T) -&gt; T</h4></section></summary><div class="docblock"><p>Returns the argument unchanged.</p>
</div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-Into%3CU%3E-for-Mutex%3CT%3E" class="impl"><a href="#impl-Into%3CU%3E-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T, U&gt; Into&lt;U&gt; for T<span class="where fmt-newline">where
U: From&lt;T&gt;,</span></h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.into" class="method trait-impl"><a href="#method.into" class="anchor">§</a><h4 class="code-header">fn <a class="fn">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>[From]&lt;T&gt; for U</code> chooses to do.</p>
</div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-TryFrom%3CU%3E-for-Mutex%3CT%3E" class="impl"><a href="#impl-TryFrom%3CU%3E-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T, U&gt; TryFrom&lt;U&gt; for T<span class="where fmt-newline">where
U: Into&lt;T&gt;,</span></h3></section></summary><div class="impl-items"><details class="toggle" open><summary><section id="associatedtype.Error" class="associatedtype trait-impl"><a href="#associatedtype.Error" class="anchor">§</a><h4 class="code-header">type <a class="associatedtype">Error</a> = Infallible</h4></section></summary><div class='docblock'>The type returned in the event of a conversion error.</div></details><details class="toggle method-toggle" open><summary><section id="method.try_from" class="method trait-impl"><a href="#method.try_from" class="anchor">§</a><h4 class="code-header">fn <a class="fn">try_from</a>(value: U) -&gt; Result&lt;T, &lt;T as TryFrom&lt;U&gt;&gt;::Error&gt;</h4></section></summary><div class='docblock'>Performs the conversion.</div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-TryInto%3CU%3E-for-Mutex%3CT%3E" class="impl"><a href="#impl-TryInto%3CU%3E-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T, U&gt; TryInto&lt;U&gt; for T<span class="where fmt-newline">where
U: TryFrom&lt;T&gt;,</span></h3></section></summary><div class="impl-items"><details class="toggle" open><summary><section id="associatedtype.Error-1" class="associatedtype trait-impl"><a href="#associatedtype.Error-1" class="anchor">§</a><h4 class="code-header">type <a class="associatedtype">Error</a> = &lt;U as TryFrom&lt;T&gt;&gt;::Error</h4></section></summary><div class='docblock'>The type returned in the event of a conversion error.</div></details><details class="toggle method-toggle" open><summary><section id="method.try_into" class="method trait-impl"><a href="#method.try_into" class="anchor">§</a><h4 class="code-header">fn <a class="fn">try_into</a>(self) -&gt; Result&lt;U, &lt;U as TryFrom&lt;T&gt;&gt;::Error&gt;</h4></section></summary><div class='docblock'>Performs the conversion.</div></details></div></details></div></section></div></main></body></html>