<!DOCTYPE html><htmllang="en"><head><metacharset="utf-8"><metaname="viewport"content="width=device-width, initial-scale=1.0"><metaname="generator"content="rustdoc"><metaname="description"content="API documentation for the Rust `Elf` struct in crate `goblin`."><metaname="keywords"content="rust, rustlang, rust-lang, Elf"><title>goblin::elf::Elf - Rust</title><linkrel="stylesheet"type="text/css"href="../../normalize.css"><linkrel="stylesheet"type="text/css"href="../../rustdoc.css"id="mainThemeStyle"><linkrel="stylesheet"type="text/css"href="../../dark.css"><linkrel="stylesheet"type="text/css"href="../../light.css"id="themeStyle"><scriptsrc="../../storage.js"></script><noscript><linkrel="stylesheet"href="../../noscript.css"></noscript><linkrel="shortcut icon"href="../../favicon.ico"><styletype="text/css">#crate-search{background-image:url("../../down-arrow.svg");}</style></head><bodyclass="rustdoc struct"><!--[if lte IE 8]><div class="warning">This old browser is unsupported and will most likely display funky things.</div><![endif]--><navclass="sidebar"><divclass="sidebar-menu">☰</div><ahref='../../goblin/index.html'><divclass='logo-container'><imgsrc='../../rust-logo.png'alt='logo'></div></a><pclass='location'>Struct Elf</p><divclass="sidebar-elems"><divclass="block items"><aclass="sidebar-title"href="#fields">Fields</a><divclass="sidebar-links"><ahref="#structfield.header">header</a><ahref="#structfield.program_headers">program_headers</a><ahref="#structfield.section_headers">section_headers</a><ahref="#structfield.shdr_strtab">shdr_strtab</a><ahref="#structfield.dynstrtab">dynstrtab</a><ahref="#structfield.dynsyms">dynsyms</a><ahref="#structfield.syms">syms</a><ahref="#structfield.strtab">strtab</a><ahref="#structfield.dynamic">dynamic</a><ahref="#structfield.dynrelas">dynrelas</a><ahref="#structfield.dynrels">dynrels</a><ahref="#structfield.pltrelocs">pltrelocs</a><ahref="#structfield.shdr_relocs">shdr_relocs</a><ahref="#structfield.soname">soname</a><ahref="#structfield.interpreter">interpreter</a><ahref="#structfield.libraries">libraries</a><ahref="#structfield.is_64">is_64</a><ahref="#structfield.is_lib">is_lib</a><ahref="#structfield.entry">entry</a><ahref="#structfield.little_endian">little_endian</a></div><aclass="sidebar-title"href="#methods">Methods</a><divclass="sidebar-links"><ahref="#method.is_object_file">is_object_file</a><ahref="#method.iter_note_headers">iter_note_headers</a><ahref="#method.iter_note_sections">iter_note_sections</a><ahref="#method.parse">parse</a></div><aclass="sidebar-title"href="#implementations">Trait Implementations</a><divclass="sidebar-links"><ahref="#impl-Debug">Debug</a><ahref="#impl-TryFromCtx%3C%27a%2C%20(usize%2C%20Endian)%2C%20%5Bu8%5D%3E">TryFromCtx<'a, (usize, Endian), [u8]></a></div><aclass="sidebar-title"href="#synthetic-implementations">Auto Trait Implementations</a><divclass="sidebar-links"><ahref="#impl-RefUnwindSafe">RefUnwindSafe</a><ahref="#impl-Send">Send</a><ahref="#impl-Sync">Sync</a><ahref="#impl-Unpin">Unpin</a><ahref="#impl-UnwindSafe">UnwindSafe</a></div><aclass="sidebar-title"href="#blanket-implementations">Blanket Implementations</a><divclass="sidebar-links"><ahref="#impl-Any">Any</a><ahref="#impl-Borrow%3CT%3E">Borrow<T></a><ahref="#impl-BorrowMut%3CT%3E">BorrowMut<T></a><ahref="#impl-From%3CT%3E">From<T></a><ahref="#impl-Into%3CU%3E">Into<U></a><ahref="#impl-TryFrom%3CU%3E">TryFrom<U></a><ahref="#impl-TryInto%3CU%3E">TryInto<U></a></div></div><pclass='location'><ahref='../index.html'>goblin</a>::<wbr><ahref='index.html'>elf</a></p><script>window.sidebarCurrent={name:'Elf',ty:'struct',relpath:''};</script><scriptdefersrc="sidebar-items.js"></script></div></nav><divclass="theme-picker"><buttonid="theme-picker"aria-label="Pick another theme!"><imgsrc="../../brush.svg"width="18"alt="Pick another theme!"></button><divid="theme-choices"></div></div><scriptsrc="../../theme.js"></script><navclass="sub
}</pre></div><divclass='docblock'><p>An ELF binary. The underlying data structures are read according to the headers byte order and container size (32 or 64).</p>
Fields<ahref='#fields'class='anchor'></a></h2><spanid="structfield.header"class="structfield small-section-header"><ahref="#structfield.header"class="anchor field"></a><codeid="header.v">header: <aclass="type"href="../../goblin/elf/type.Header.html"title="type goblin::elf::Header">Header</a></code></span><divclass='docblock'><p>The ELF header, which provides a rudimentary index into the rest of the binary</p>
</div><spanid="structfield.program_headers"class="structfield small-section-header"><ahref="#structfield.program_headers"class="anchor field"></a><codeid="program_headers.v">program_headers: <aclass="type"href="../../goblin/elf/type.ProgramHeaders.html"title="type goblin::elf::ProgramHeaders">ProgramHeaders</a></code></span><divclass='docblock'><p>The program headers; they primarily tell the kernel and the dynamic linker
how to load this binary</p>
</div><spanid="structfield.section_headers"class="structfield small-section-header"><ahref="#structfield.section_headers"class="anchor field"></a><codeid="section_headers.v">section_headers: <aclass="type"href="../../goblin/elf/type.SectionHeaders.html"title="type goblin::elf::SectionHeaders">SectionHeaders</a></code></span><divclass='docblock'><p>The sections headers. These are strippable, never count on them being
This is what the dynamic linker uses to dynamically load and link your binary,
or find imported symbols for binaries which dynamically link against your library</p>
</div><spanid="structfield.syms"class="structfield small-section-header"><ahref="#structfield.syms"class="anchor field"></a><codeid="syms.v">syms: <aclass="type"href="../../goblin/elf/type.Symtab.html"title="type goblin::elf::Symtab">Symtab</a><'a></code></span><divclass='docblock'><p>The debugging symbol table</p>
</div><spanid="structfield.strtab"class="structfield small-section-header"><ahref="#structfield.strtab"class="anchor field"></a><codeid="strtab.v">strtab: <aclass="struct"href="../../goblin/strtab/struct.Strtab.html"title="struct goblin::strtab::Strtab">Strtab</a><'a></code></span><divclass='docblock'><p>The string table for the symbol table</p>
</div><spanid="structfield.dynamic"class="structfield small-section-header"><ahref="#structfield.dynamic"class="anchor field"></a><codeid="dynamic.v">dynamic: <aclass="enum"href="https://doc.rust-lang.org/nightly/core/option/enum.Option.html"title="enum core::option::Option">Option</a><<aclass="type"href="../../goblin/elf/type.Dynamic.html"title="type goblin::elf::Dynamic">Dynamic</a>></code></span><divclass='docblock'><p>Contains dynamic linking information, with the _DYNAMIC array + a preprocessed DynamicInfo for that array</p>
</div><spanid="structfield.dynrelas"class="structfield small-section-header"><ahref="#structfield.dynrelas"class="anchor field"></a><codeid="dynrelas.v">dynrelas: <aclass="type"href="../../goblin/elf/type.RelocSection.html"title="type goblin::elf::RelocSection">RelocSection</a><'a></code></span><divclass='docblock'><p>The dynamic relocation entries (strings, copy-data, etc.) with an addend</p>
</div><spanid="structfield.dynrels"class="structfield small-section-header"><ahref="#structfield.dynrels"class="anchor field"></a><codeid="dynrels.v">dynrels: <aclass="type"href="../../goblin/elf/type.RelocSection.html"title="type goblin::elf::RelocSection">RelocSection</a><'a></code></span><divclass='docblock'><p>The dynamic relocation entries without an addend</p>
</div><spanid="structfield.pltrelocs"class="structfield small-section-header"><ahref="#structfield.pltrelocs"class="anchor field"></a><codeid="pltrelocs.v">pltrelocs: <aclass="type"href="../../goblin/elf/type.RelocSection.html"title="type goblin::elf::RelocSection">RelocSection</a><'a></code></span><divclass='docblock'><p>The plt relocation entries (procedure linkage table). For 32-bit binaries these are usually Rel (no addend)</p>
</div><spanid="structfield.shdr_relocs"class="structfield small-section-header"><ahref="#structfield.shdr_relocs"class="anchor field"></a><codeid="shdr_relocs.v">shdr_relocs: <aclass="struct"href="https://doc.rust-lang.org/nightly/alloc/vec/struct.Vec.html"title="struct alloc::vec::Vec">Vec</a><<aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.tuple.html">(</a><aclass="type"href="../../goblin/elf/type.ShdrIdx.html"title="type goblin::elf::ShdrIdx">ShdrIdx</a>, <aclass="type"href="../../goblin/elf/type.RelocSection.html"title="type goblin::elf::RelocSection">RelocSection</a><'a><aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.tuple.html">)</a>></code></span><divclass='docblock'><p>Section relocations by section index (only present if this is a relocatable object file)</p>
</div><spanid="structfield.soname"class="structfield small-section-header"><ahref="#structfield.soname"class="anchor field"></a><codeid="soname.v">soname: <aclass="enum"href="https://doc.rust-lang.org/nightly/core/option/enum.Option.html"title="enum core::option::Option">Option</a><&'a <aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.str.html">str</a>></code></span><divclass='docblock'><p>The binary's soname, if it has one</p>
</div><spanid="structfield.interpreter"class="structfield small-section-header"><ahref="#structfield.interpreter"class="anchor field"></a><codeid="interpreter.v">interpreter: <aclass="enum"href="https://doc.rust-lang.org/nightly/core/option/enum.Option.html"title="enum core::option::Option">Option</a><&'a <aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.str.html">str</a>></code></span><divclass='docblock'><p>The binary's program interpreter (e.g., dynamic linker), if it has one</p>
</div><spanid="structfield.libraries"class="structfield small-section-header"><ahref="#structfield.libraries"class="anchor field"></a><codeid="libraries.v">libraries: <aclass="struct"href="https://doc.rust-lang.org/nightly/alloc/vec/struct.Vec.html"title="struct alloc::vec::Vec">Vec</a><&'a <aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.str.html">str</a>></code></span><divclass='docblock'><p>A list of this binary's dynamic libraries it uses, if there are any</p>
</div><spanid="structfield.is_64"class="structfield small-section-header"><ahref="#structfield.is_64"class="anchor field"></a><codeid="is_64.v">is_64: <aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.bool.html">bool</a></code></span><spanid="structfield.is_lib"class="structfield small-section-header"><ahref="#structfield.is_lib"class="anchor field"></a><codeid="is_lib.v">is_lib: <aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.bool.html">bool</a></code></span><divclass='docblock'><p>Whether this is a shared object or not</p>
</div><spanid="structfield.entry"class="structfield small-section-header"><ahref="#structfield.entry"class="anchor field"></a><codeid="entry.v">entry: <aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.u64.html">u64</a></code></span><divclass='docblock'><p>The binaries entry point address, if it has one</p>
</div><spanid="structfield.little_endian"class="structfield small-section-header"><ahref="#structfield.little_endian"class="anchor field"></a><codeid="little_endian.v">little_endian: <aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.bool.html">bool</a></code></span><divclass='docblock'><p>Whether the binary is little endian or not</p>
</div><h2id='methods'class='small-section-header'>Methods<ahref='#methods'class='anchor'></a></h2><h3id='impl'class='impl'><codeclass='in-band'>impl<'a><aclass="struct"href="../../goblin/elf/struct.Elf.html"title="struct goblin::elf::Elf">Elf</a><'a></code><ahref='#impl'class='anchor'></a><aclass='srclink'href='../../src/goblin/elf/mod.rs.html#135-338'title='goto source code'>[src]</a></h3><divclass='impl-items'><h4id='method.iter_note_headers'class="method"><codeid='iter_note_headers.v'>pub fn <ahref='#method.iter_note_headers'class='fnname'>iter_note_headers</a>(&self, data: <aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.slice.html">&'a [</a><aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.u8.html">u8</a><aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.slice.html">]</a>) -><aclass="enum"href="https://doc.rust-lang.org/nightly/core/option/enum.Option.html"title="enum core::option::Option">Option</a><<aclass="struct"href="../../goblin/elf/note/struct.NoteIterator.html"title="struct goblin::elf::note::NoteIterator">NoteIterator</a><'a>></code><aclass='srclink'href='../../src/goblin/elf/mod.rs.html#137-161'title='goto source code'>[src]</a></h4><divclass='docblock'><p>Try to iterate notes in PT_NOTE program headers; returns <code>None</code> if there aren't any note headers in this binary</p>
</div><h4id='method.iter_note_sections'class="method"><codeid='iter_note_sections.v'>pub fn <ahref='#method.iter_note_sections'class='fnname'>iter_note_sections</a>(<br> &self, <br> data: <aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.slice.html">&'a [</a><aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.u8.html">u8</a><aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.slice.html">]</a>, <br> section_name: <aclass="enum"href="https://doc.rust-lang.org/nightly/core/option/enum.Option.html"title="enum core::option::Option">Option</a><&<aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.str.html">str</a>><br>) -><aclass="enum"href="https://doc.rust-lang.org/nightly/core/option/enum.Option.html"title="enum core::option::Option">Option</a><<aclass="struct"href="../../goblin/elf/note/struct.NoteIterator.html"title="struct goblin::elf::note::NoteIterator">NoteIterator</a><'a>></code><aclass='srclink'href='../../src/goblin/elf/mod.rs.html#165-200'title='goto source code'>[src]</a></h4><divclass='docblock'><p>Try to iterate notes in SHT_NOTE sections; returns <code>None</code> if there aren't any note sections in this binary</p>
<p>If a section_name is given, only the section with the according name is iterated.</p>
</div><h4id='method.is_object_file'class="method"><codeid='is_object_file.v'>pub fn <ahref='#method.is_object_file'class='fnname'>is_object_file</a>(&self) -><aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.bool.html">bool</a></code><aclass='srclink'href='../../src/goblin/elf/mod.rs.html#201-203'title='goto source code'>[src]</a></h4><h4id='method.parse'class="method"><codeid='parse.v'>pub fn <ahref='#method.parse'class='fnname'>parse</a>(bytes: <aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.slice.html">&'a [</a><aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.u8.html">u8</a><aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.slice.html">]</a>) -><aclass="type"href="../../goblin/error/type.Result.html"title="type goblin::error::Result">Result</a><Self></code><aclass='srclink'href='../../src/goblin/elf/mod.rs.html#205-337'title='goto source code'>[src]</a></h4><divclass='docblock'><p>Parses the contents of the byte stream in <code>bytes</code>, and maybe returns a unified binary</p>
</div></div><h2id='implementations'class='small-section-header'>Trait Implementations<ahref='#implementations'class='anchor'></a></h2><divid='implementations-list'><h3id='impl-Debug'class='impl'><codeclass='in-band'>impl<'a><aclass="trait"href="https://doc.rust-lang.org/nightly/core/fmt/trait.Debug.html"title="trait core::fmt::Debug">Debug</a> for <aclass="struct"href="../../goblin/elf/struct.Elf.html"title="struct goblin::elf::Elf">Elf</a><'a></code><ahref='#impl-Debug'class='anchor'></a><aclass='srclink'href='../../src/goblin/elf/mod.rs.html#86'title='goto source code'>[src]</a></h3><divclass='impl-items'><h4id='method.fmt'class="method hidden"><codeid='fmt.v'>fn <ahref='https://doc.rust-lang.org/nightly/core/fmt/trait.Debug.html#tymethod.fmt'class='fnname'>fmt</a>(&self, f: &mut <aclass="struct"href="https://doc.rust-lang.org/nightly/core/fmt/struct.Formatter.html"title="struct core::fmt::Formatter">Formatter</a>) -><aclass="type"href="https://doc.rust-lang.org/nightly/core/fmt/type.Result.html"title="type core::fmt::Result">Result</a></code><aclass='srclink'href='../../src/goblin/elf/mod.rs.html#86'title='goto source code'>[src]</a></h4><divclass='docblock hidden'><p>Formats the value using the given formatter. <ahref="https://doc.rust-lang.org/nightly/core/fmt/trait.Debug.html#tymethod.fmt">Read more</a></p>
</div></div><h3id='impl-From%3CT%3E'class='impl'><codeclass='in-band'>impl<T><aclass="trait"href="https://doc.rust-lang.org/nightly/core/convert/trait.From.html"title="trait core::convert::From">From</a><T> for T</code><ahref='#impl-From%3CT%3E'class='anchor'></a><aclass='srclink'href='https://doc.rust-lang.org/nightly/src/core/convert.rs.html#552-554'title='goto source code'>[src]</a></h3><divclass='impl-items'><h4id='method.from'class="method hidden"><codeid='from.v'>fn <ahref='https://doc.rust-lang.org/nightly/core/convert/trait.From.html#tymethod.from'class='fnname'>from</a>(t: T) -> T</code><aclass='srclink'href='https://doc.rust-lang.org/nightly/src/core/convert.rs.html#553'title='goto source code'>[src]</a></h4><divclass='docblock hidden'><p>Performs the conversion.</p>
</div></div><h3id='impl-TryFrom%3CU%3E'class='impl'><codeclass='in-band'>impl<T, U><aclass="trait"href="https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html"title="trait core::convert::TryFrom">TryFrom</a><U> for T <spanclass="where fmt-newline">where<br> U: <aclass="trait"href="https://doc.rust-lang.org/nightly/core/convert/trait.Into.html"title="trait core::convert::Into">Into</a><T>, </span></code><ahref='#impl-TryFrom%3CU%3E'class='anchor'></a><aclass='srclink'href='https://doc.rust-lang.org/nightly/src/core/convert.rs.html#571-577'title='goto source code'>[src]</a></h3><divclass='impl-items'><h4id='associatedtype.Error-1'class="type"><codeid='Error.t-1'>type <ahref='https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html#associatedtype.Error'class="type">Error</a> = <aclass="enum"href="https://doc.rust-lang.org/nightly/core/convert/enum.Infallible.html"title="enum core::convert::Infallible">Infallible</a></code></h4><divclass='docblock'><p>The type returned in the event of a conversion error.</p>
</div><h4id='method.try_from'class="method hidden"><codeid='try_from.v'>fn <ahref='https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html#tymethod.try_from'class='fnname'>try_from</a>(value: U) -><aclass="enum"href="https://doc.rust-lang.org/nightly/core/result/enum.Result.html"title="enum core::result::Result">Result</a><T, <T as <aclass="trait"href="https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html"title="trait core::convert::TryFrom">TryFrom</a><U>>::<aclass="type"href="https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html#associatedtype.Error"title="type core::convert::TryFrom::Error">Error</a>></code><aclass='srclink'href='https://doc.rust-lang.org/nightly/src/core/convert.rs.html#574-576'title='goto source code'>[src]</a></h4><divclass='docblock hidden'><p>Performs the conversion.</p>
</div></div><h3id='impl-TryInto%3CU%3E'class='impl'><codeclass='in-band'>impl<T, U><aclass="trait"href="https://doc.rust-lang.org/nightly/core/convert/trait.TryInto.html"title="trait core::convert::TryInto">TryInto</a><U> for T <spanclass="where fmt-newline">where<br> U: <aclass="trait"href="https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html"title="trait core::convert::TryFrom">TryFrom</a><T>, </span></code><ahref='#impl-TryInto%3CU%3E'class='anchor'></a><aclass='srclink'href='https://doc.rust-lang.org/nightly/src/core/convert.rs.html#559-566'title='goto source code'>[src]</a></h3><divclass='impl-items'><h4id='associatedtype.Error-2'class="type"><codeid='Error.t-2'>type <ahref='https://doc.rust-lang.org/nightly/core/convert/trait.TryInto.html#associatedtype.Error'class="type">Error</a> = <U as <aclass="trait"href="https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html"title="trait core::convert::TryFrom">TryFrom</a><T>>::<aclass="type"href="https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html#associatedtype.Error"title="type core::convert::TryFrom::Error">Error</a></code></h4><divclass='docblock'><p>The type returned in the event of a conversion error.</p>
</div><h4id='method.try_into'class="method hidden"><codeid='try_into.v'>fn <ahref='https://doc.rust-lang.org/nightly/core/convert/trait.TryInto.html#tymethod.try_into'class='fnname'>try_into</a>(self) -><aclass="enum"href="https://doc.rust-lang.org/nightly/core/result/enum.Result.html"title="enum core::result::Result">Result</a><U, <U as <aclass="trait"href="https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html"title="trait core::convert::TryFrom">TryFrom</a><T>>::<aclass="type"href="https://doc.rust-lang.org/nightly/core/convert/trait.TryFrom.html#associatedtype.Error"title="type core::convert::TryFrom::Error">Error</a>></code><aclass='srclink'href='https://doc.rust-lang.org/nightly/src/core/convert.rs.html#563-565'title='goto source code'>[src]</a></h4><divclass='docblock hidden'><p>Performs the conversion.</p>
</div></div><h3id='impl-BorrowMut%3CT%3E'class='impl'><codeclass='in-band'>impl<T><aclass="trait"href="https://doc.rust-lang.org/nightly/core/borrow/trait.BorrowMut.html"title="trait core::borrow::BorrowMut">BorrowMut</a><T> for T <spanclass="where fmt-newline">where<br> T: ?<aclass="trait"href="https://doc.rust-lang.org/nightly/core/marker/trait.Sized.html"title="trait core::marker::Sized">Sized</a>, </span></code><ahref='#impl-BorrowMut%3CT%3E'class='anchor'></a><aclass='srclink'href='https://doc.rust-lang.org/nightly/src/core/borrow.rs.html#218-220'title='goto source code'>[src]</a></h3><divclass='impl-items'><h4id='method.borrow_mut'class="method hidden"><codeid='borrow_mut.v'>fn <ahref='https://doc.rust-lang.org/nightly/core/borrow/trait.BorrowMut.html#tymethod.borrow_mut'class='fnname'>borrow_mut</a>(&mut self) -><aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.reference.html">&mut </a>T</code><aclass='srclink'href='https://doc.rust-lang.org/nightly/src/core/borrow.rs.html#219'title='goto source code'>[src]</a></h4><divclass='docblock hidden'><p>Mutably borrows from an owned value. <ahref="https://doc.rust-lang.org/nightly/core/borrow/trait.BorrowMut.html#tymethod.borrow_mut">Read more</a></p>
</div></div><h3id='impl-Borrow%3CT%3E'class='impl'><codeclass='in-band'>impl<T><aclass="trait"href="https://doc.rust-lang.org/nightly/core/borrow/trait.Borrow.html"title="trait core::borrow::Borrow">Borrow</a><T> for T <spanclass="where fmt-newline">where<br> T: ?<aclass="trait"href="https://doc.rust-lang.org/nightly/core/marker/trait.Sized.html"title="trait core::marker::Sized">Sized</a>, </span></code><ahref='#impl-Borrow%3CT%3E'class='anchor'></a><aclass='srclink'href='https://doc.rust-lang.org/nightly/src/core/borrow.rs.html#213-215'title='goto source code'>[src]</a></h3><divclass='impl-items'><h4id='method.borrow'class="method hidden"><codeid='borrow.v'>fn <ahref='https://doc.rust-lang.org/nightly/core/borrow/trait.Borrow.html#tymethod.borrow'class='fnname'>borrow</a>(&self) -><aclass="primitive"href="https://doc.rust-lang.org/nightly/std/primitive.reference.html">&</a>T</code><aclass='srclink'href='https://doc.rust-lang.org/nightly/src/core/borrow.rs.html#214'title='goto source code'>[src]</a></h4><divclass='docblock hidden'><p>Immutably borrows from an owned value. <ahref="https://doc.rust-lang.org/nightly/core/borrow/trait.Borrow.html#tymethod.borrow">Read more</a></p>
</div></div><h3id='impl-Any'class='impl'><codeclass='in-band'>impl<T><aclass="trait"href="https://doc.rust-lang.org/nightly/core/any/trait.Any.html"title="trait core::any::Any">Any</a> for T <spanclass="where fmt-newline">where<br> T: 'static + ?<aclass="trait"href="https://doc.rust-lang.org/nightly/core/marker/trait.Sized.html"title="trait core::marker::Sized">Sized</a>, </span></code><ahref='#impl-Any'class='anchor'></a><aclass='srclink'href='https://doc.rust-lang.org/nightly/src/core/any.rs.html#100-102'title='goto source code'>[src]</a></h3><divclass='impl-items'><h4id='method.type_id'class="method hidden"><codeid='type_id.v'>fn <ahref='https://doc.rust-lang.org/nightly/core/any/trait.Any.html#tymethod.type_id'class='fnname'>type_id</a>(&self) -><aclass="struct"href="https://doc.rust-lang.org/nightly/core/any/struct.TypeId.html"title="struct core::any::TypeId">TypeId</a></code><aclass='srclink'href='https://doc.rust-lang.org/nightly/src/core/any.rs.html#101'title='goto source code'>[src]</a></h4><divclass='docblock hidden'><p>Gets the <code>TypeId</code> of <code>self</code>. <ahref="https://doc.rust-lang.org/nightly/core/any/trait.Any.html#tymethod.type_id">Read more</a></p>
</div></div></div></section><sectionid="search"class="content hidden"></section><sectionclass="footer"></section><asideid="help"class="hidden"><div><h1class="hidden">Help</h1><divclass="shortcuts"><h2>Keyboard Shortcuts</h2><dl><dt><kbd>?</kbd></dt><dd>Show this help dialog</dd><dt><kbd>S</kbd></dt><dd>Focus the search field</dd><dt><kbd>↑</kbd></dt><dd>Move up in search results</dd><dt><kbd>↓</kbd></dt><dd>Move down in search results</dd><dt><kbd>↹</kbd></dt><dd>Switch tab</dd><dt><kbd>⏎</kbd></dt><dd>Go to active search result</dd><dt><kbd>+</kbd></dt><dd>Expand all sections</dd><dt><kbd>-</kbd></dt><dd>Collapse all sections</dd></dl></div><divclass="infos"><h2>Search Tricks</h2><p>Prefix searches with a type followed by a colon (e.g., <code>fn:</code>) to restrict the search to a given type.</p><p>Accepted types are: <code>fn</code>, <code>mod</code>, <code>struct</code>, <code>enum</code>, <code>trait</code>, <code>type</code>, <code>macro</code>, and <code>const</code>.</p><p>Search functions by type signature (e.g., <code>vec -> usize</code> or <code>* -> vec</code>)</p><p>Search multiple things at once by splitting your query with comma (e.g., <code>str,u8</code> or <code>String,struct:Vec,test</code>)</p></div></div></aside><script>window.rootPath="../../";window.currentCrate="goblin";</script><scriptsrc="../../aliases.js"></script><scriptsrc="../../main.js"></script><scriptdefersrc="../../search-index.js"></script></body></html>