mcquery-rs/doc/syn/index.html

431 lines
66 KiB
HTML
Raw Normal View History

2021-01-08 20:01:01 +01:00
<!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 `syn` crate."><meta name="keywords" content="rust, rustlang, rust-lang, syn"><title>syn - Rust</title><link rel="stylesheet" type="text/css" href="../normalize.css"><link rel="stylesheet" type="text/css" href="../rustdoc.css" id="mainThemeStyle"><link rel="stylesheet" type="text/css" href="../light.css" id="themeStyle"><link rel="stylesheet" type="text/css" href="../dark.css" disabled ><link rel="stylesheet" type="text/css" href="../ayu.css" disabled ><script id="default-settings"></script><script src="../storage.js"></script><noscript><link rel="stylesheet" href="../noscript.css"></noscript><link rel="icon" type="image/svg+xml" href="../favicon.svg">
<link rel="alternate icon" type="image/png" href="../favicon-16x16.png">
<link rel="alternate icon" type="image/png" href="../favicon-32x32.png"><style type="text/css">#crate-search{background-image:url("../down-arrow.svg");}</style></head><body class="rustdoc mod"><!--[if lte IE 8]><div class="warning">This old browser is unsupported and will most likely display funky things.</div><![endif]--><nav class="sidebar"><div class="sidebar-menu">&#9776;</div><a href='../syn/index.html'><div class='logo-container rust-logo'><img src='../rust-logo.png' alt='logo'></div></a><p class="location">Crate syn</p><div class="block version"><p>Version 1.0.57</p></div><div class="sidebar-elems"><a id="all-types" href="all.html"><p>See all syn's items</p></a><div class="block items"><ul><li><a href="#modules">Modules</a></li><li><a href="#macros">Macros</a></li><li><a href="#structs">Structs</a></li><li><a href="#enums">Enums</a></li><li><a href="#functions">Functions</a></li><li><a href="#types">Type Definitions</a></li></ul></div><p class="location"></p><script>window.sidebarCurrent = {name: "syn", ty: "mod", relpath: "../"};</script></div></nav><div class="theme-picker"><button id="theme-picker" aria-label="Pick another theme!" aria-haspopup="menu"><img src="../brush.svg" width="18" alt="Pick another theme!"></button><div id="theme-choices" role="menu"></div></div><script src="../theme.js"></script><nav class="sub"><form class="search-form"><div class="search-container"><div><select id="crate-search"><option value="All crates">All crates</option></select><input class="search-input" name="search" disabled autocomplete="off" spellcheck="false" placeholder="Click or press S to search, ? for more options…" type="search"></div><span class="help-button">?</span>
<a id="settings-menu" href="../settings.html"><img src="../wheel.svg" width="18" alt="Change settings"></a></div></form></nav><section id="main" class="content"><h1 class="fqn"><span class="out-of-band"><span id="render-detail"><a id="toggle-all-docs" href="javascript:void(0)" title="collapse all docs">[<span class="inner">&#x2212;</span>]</a></span><a class="srclink" href="../src/syn/lib.rs.html#1-991" title="goto source code">[src]</a></span><span class="in-band">Crate <a class="mod" href="">syn</a></span></h1><div class="docblock"><p><a href="https://github.com/dtolnay/syn"><img src="https://img.shields.io/badge/github-8da0cb?style=for-the-badge&amp;labelColor=555555&amp;logo=github" alt="github" /></a><a href="https://crates.io/crates/syn"><img src="https://img.shields.io/badge/crates.io-fc8d62?style=for-the-badge&amp;labelColor=555555&amp;logo=rust" alt="crates-io" /></a><a href="../syn/index.html"><img src="https://img.shields.io/badge/docs.rs-66c2a5?style=for-the-badge&amp;labelColor=555555&amp;logoColor=white&amp;logo=" alt="docs-rs" /></a></p>
<br>
<p>Syn is a parsing library for parsing a stream of Rust tokens into a syntax
tree of Rust source code.</p>
<p>Currently this library is geared toward use in Rust procedural macros, but
contains some APIs that may be useful more generally.</p>
<ul>
<li>
<p><strong>Data structures</strong> — Syn provides a complete syntax tree that can
represent any valid Rust source code. The syntax tree is rooted at
<a href="../syn/struct.File.html"><code>syn::File</code></a> which represents a full source file, but there are other
entry points that may be useful to procedural macros including
<a href="../syn/enum.Item.html"><code>syn::Item</code></a>, <a href="../syn/enum.Expr.html"><code>syn::Expr</code></a> and <a href="../syn/enum.Type.html"><code>syn::Type</code></a>.</p>
</li>
<li>
<p><strong>Derives</strong> — Of particular interest to derive macros is
<a href="../syn/struct.DeriveInput.html"><code>syn::DeriveInput</code></a> which is any of the three legal input items to a
derive macro. An example below shows using this type in a library that can
derive implementations of a user-defined trait.</p>
</li>
<li>
<p><strong>Parsing</strong> — Parsing in Syn is built around <a href="../syn/parse/index.html">parser functions</a> with the
signature <code>fn(ParseStream) -&gt; Result&lt;T&gt;</code>. Every syntax tree node defined
by Syn is individually parsable and may be used as a building block for
custom syntaxes, or you may dream up your own brand new syntax without
involving any of our syntax tree types.</p>
</li>
<li>
<p><strong>Location information</strong> — Every token parsed by Syn is associated with a
<code>Span</code> that tracks line and column information back to the source of that
token. These spans allow a procedural macro to display detailed error
messages pointing to all the right places in the user's code. There is an
example of this below.</p>
</li>
<li>
<p><strong>Feature flags</strong> — Functionality is aggressively feature gated so your
procedural macros enable only what they need, and do not pay in compile
time for all the rest.</p>
</li>
</ul>
<br>
<h1 id="example-of-a-derive-macro" class="section-header"><a href="#example-of-a-derive-macro">Example of a derive macro</a></h1>
<p>The canonical derive macro using Syn looks like this. We write an ordinary
Rust function tagged with a <code>proc_macro_derive</code> attribute and the name of
the trait we are deriving. Any time that derive appears in the user's code,
the Rust compiler passes their data structure as tokens into our macro. We
get to execute arbitrary Rust code to figure out what to do with those
tokens, then hand some tokens back to the compiler to compile into the
user's crate.</p>
<pre><code class="language-toml">[dependencies]
syn = &quot;1.0&quot;
quote = &quot;1.0&quot;
[lib]
proc-macro = true
</code></pre>
<div class="example-wrap"><pre class="rust rust-example-rendered">
<span class="kw">use</span> <span class="ident">proc_macro</span>::<span class="ident">TokenStream</span>;
<span class="kw">use</span> <span class="ident">quote</span>::<span class="ident">quote</span>;
<span class="kw">use</span> <span class="ident">syn</span>::{<span class="ident">parse_macro_input</span>, <span class="ident">DeriveInput</span>};
<span class="attribute">#[<span class="ident">proc_macro_derive</span>(<span class="ident">MyMacro</span>)]</span>
<span class="kw">pub</span> <span class="kw">fn</span> <span class="ident">my_macro</span>(<span class="ident">input</span>: <span class="ident">TokenStream</span>) <span class="op">-</span><span class="op">&gt;</span> <span class="ident">TokenStream</span> {
<span class="comment">// Parse the input tokens into a syntax tree</span>
<span class="kw">let</span> <span class="ident">input</span> <span class="op">=</span> <span class="macro">parse_macro_input</span><span class="macro">!</span>(<span class="ident">input</span> <span class="kw">as</span> <span class="ident">DeriveInput</span>);
<span class="comment">// Build the output, possibly using quasi-quotation</span>
<span class="kw">let</span> <span class="ident">expanded</span> <span class="op">=</span> <span class="macro">quote</span><span class="macro">!</span> {
<span class="comment">// ...</span>
};
<span class="comment">// Hand the output tokens back to the compiler</span>
<span class="ident">TokenStream</span>::<span class="ident">from</span>(<span class="ident">expanded</span>)
}</pre></div>
<p>The <a href="https://github.com/dtolnay/syn/tree/master/examples/heapsize"><code>heapsize</code></a> example directory shows a complete working implementation
of a derive macro. It works on any Rust compiler 1.31+. The example derives
a <code>HeapSize</code> trait which computes an estimate of the amount of heap memory
owned by a value.</p>
<div class="example-wrap"><pre class="rust rust-example-rendered">
<span class="kw">pub</span> <span class="kw">trait</span> <span class="ident">HeapSize</span> {
<span class="doccomment">/// Total number of bytes of heap memory owned by `self`.</span>
<span class="kw">fn</span> <span class="ident">heap_size_of_children</span>(<span class="kw-2">&amp;</span><span class="self">self</span>) <span class="op">-</span><span class="op">&gt;</span> <span class="ident">usize</span>;
}</pre></div>
<p>The derive macro allows users to write <code>#[derive(HeapSize)]</code> on data
structures in their program.</p>
<div class="example-wrap"><pre class="rust rust-example-rendered">
<span class="attribute">#[<span class="ident">derive</span>(<span class="ident">HeapSize</span>)]</span>
<span class="kw">struct</span> <span class="ident">Demo</span><span class="op">&lt;</span><span class="lifetime">&#39;a</span>, <span class="ident">T</span>: <span class="question-mark">?</span><span class="ident">Sized</span><span class="op">&gt;</span> {
<span class="ident">a</span>: <span class="ident">Box</span><span class="op">&lt;</span><span class="ident">T</span><span class="op">&gt;</span>,
<span class="ident">b</span>: <span class="ident">u8</span>,
<span class="ident">c</span>: <span class="kw-2">&amp;</span><span class="lifetime">&#39;a</span> <span class="ident">str</span>,
<span class="ident">d</span>: <span class="ident">String</span>,
}</pre></div>
<p><br></p>
<h1 id="spans-and-error-reporting" class="section-header"><a href="#spans-and-error-reporting">Spans and error reporting</a></h1>
<p>The token-based procedural macro API provides great control over where the
compiler's error messages are displayed in user code. Consider the error the
user sees if one of their field types does not implement <code>HeapSize</code>.</p>
<div class="example-wrap"><pre class="rust rust-example-rendered">
<span class="attribute">#[<span class="ident">derive</span>(<span class="ident">HeapSize</span>)]</span>
<span class="kw">struct</span> <span class="ident">Broken</span> {
<span class="ident">ok</span>: <span class="ident">String</span>,
<span class="ident">bad</span>: <span class="ident">std</span>::<span class="ident">thread</span>::<span class="ident">Thread</span>,
}</pre></div>
<p>By tracking span information all the way through the expansion of a
procedural macro as shown in the <code>heapsize</code> example, token-based macros in
Syn are able to trigger errors that directly pinpoint the source of the
problem.</p>
<pre><code class="language-text">error[E0277]: the trait bound `std::thread::Thread: HeapSize` is not satisfied
--&gt; src/main.rs:7:5
|
7 | bad: std::thread::Thread,
| ^^^^^^^^^^^^^^^^^^^^^^^^ the trait `HeapSize` is not implemented for `Thread`
</code></pre>
<br>
<h1 id="parsing-a-custom-syntax" class="section-header"><a href="#parsing-a-custom-syntax">Parsing a custom syntax</a></h1>
<p>The <a href="https://github.com/dtolnay/syn/tree/master/examples/lazy-static"><code>lazy-static</code></a> example directory shows the implementation of a
<code>functionlike!(...)</code> procedural macro in which the input tokens are parsed
using Syn's parsing API.</p>
<p>The example reimplements the popular <code>lazy_static</code> crate from crates.io as a
procedural macro.</p>
<div class="example-wrap"><pre class="rust rust-example-rendered">
<span class="macro">lazy_static</span><span class="macro">!</span> {
<span class="kw">static</span> <span class="kw-2">ref</span> <span class="ident">USERNAME</span>: <span class="ident">Regex</span> <span class="op">=</span> <span class="ident">Regex</span>::<span class="ident">new</span>(<span class="string">&quot;^[a-z0-9_-]{3,16}$&quot;</span>).<span class="ident">unwrap</span>();
}</pre></div>
<p>The implementation shows how to trigger custom warnings and error messages
on the macro input.</p>
<pre><code class="language-text">warning: come on, pick a more creative name
--&gt; src/main.rs:10:16
|
10 | static ref FOO: String = &quot;lazy_static&quot;.to_owned();
| ^^^
</code></pre>
<br>
<h1 id="testing" class="section-header"><a href="#testing">Testing</a></h1>
<p>When testing macros, we often care not just that the macro can be used
successfully but also that when the macro is provided with invalid input it
produces maximally helpful error messages. Consider using the <a href="https://github.com/dtolnay/trybuild"><code>trybuild</code></a>
crate to write tests for errors that are emitted by your macro or errors
detected by the Rust compiler in the expanded code following misuse of the
macro. Such tests help avoid regressions from later refactors that
mistakenly make an error no longer trigger or be less helpful than it used
to be.</p>
<br>
<h1 id="debugging" class="section-header"><a href="#debugging">Debugging</a></h1>
<p>When developing a procedural macro it can be helpful to look at what the
generated code looks like. Use <code>cargo rustc -- -Zunstable-options --pretty=expanded</code> or the <a href="https://github.com/dtolnay/cargo-expand"><code>cargo expand</code></a> subcommand.</p>
<p>To show the expanded code for some crate that uses your procedural macro,
run <code>cargo expand</code> from that crate. To show the expanded code for one of
your own test cases, run <code>cargo expand --test the_test_case</code> where the last
argument is the name of the test file without the <code>.rs</code> extension.</p>
<p>This write-up by Brandon W Maister discusses debugging in more detail:
<a href="https://quodlibetor.github.io/posts/debugging-rusts-new-custom-derive-system/">Debugging Rust's new Custom Derive system</a>.</p>
<br>
<h1 id="optional-features" class="section-header"><a href="#optional-features">Optional features</a></h1>
<p>Syn puts a lot of functionality behind optional features in order to
optimize compile time for the most common use cases. The following features
are available.</p>
<ul>
<li><strong><code>derive</code></strong> <em>(enabled by default)</em> — Data structures for representing the
possible input to a derive macro, including structs and enums and types.</li>
<li><strong><code>full</code></strong> — Data structures for representing the syntax tree of all valid
Rust source code, including items and expressions.</li>
<li><strong><code>parsing</code></strong> <em>(enabled by default)</em> — Ability to parse input tokens into
a syntax tree node of a chosen type.</li>
<li><strong><code>printing</code></strong> <em>(enabled by default)</em> — Ability to print a syntax tree
node as tokens of Rust source code.</li>
<li><strong><code>visit</code></strong> — Trait for traversing a syntax tree.</li>
<li><strong><code>visit-mut</code></strong> — Trait for traversing and mutating in place a syntax
tree.</li>
<li><strong><code>fold</code></strong> — Trait for transforming an owned syntax tree.</li>
<li><strong><code>clone-impls</code></strong> <em>(enabled by default)</em> — Clone impls for all syntax tree
types.</li>
<li><strong><code>extra-traits</code></strong> — Debug, Eq, PartialEq, Hash impls for all syntax tree
types.</li>
<li><strong><code>proc-macro</code></strong> <em>(enabled by default)</em> — Runtime dependency on the
dynamic library libproc_macro from rustc toolchain.</li>
</ul>
</div><h2 id="modules" class="section-header"><a href="#modules">Modules</a></h2>
<table><tr class="module-item"><td><a class="mod" href="buffer/index.html" title="syn::buffer mod">buffer</a></td><td class="docblock-short"><p>A stably addressed token buffer supporting efficient traversal based on a
cheaply copyable cursor.</p>
</td></tr><tr class="module-item"><td><a class="mod" href="ext/index.html" title="syn::ext mod">ext</a></td><td class="docblock-short"><p>Extension traits to provide parsing methods on foreign types.</p>
</td></tr><tr class="module-item"><td><a class="mod" href="parse/index.html" title="syn::parse mod">parse</a></td><td class="docblock-short"><p>Parsing interface for parsing a token stream into a syntax tree node.</p>
</td></tr><tr class="module-item"><td><a class="mod" href="punctuated/index.html" title="syn::punctuated mod">punctuated</a></td><td class="docblock-short"><p>A punctuated sequence of syntax tree nodes separated by punctuation.</p>
</td></tr><tr class="module-item"><td><a class="mod" href="spanned/index.html" title="syn::spanned mod">spanned</a></td><td class="docblock-short"><p>A trait that can provide the <code>Span</code> of the complete contents of a syntax
tree node.</p>
</td></tr><tr class="module-item"><td><a class="mod" href="token/index.html" title="syn::token mod">token</a></td><td class="docblock-short"><p>Tokens representing Rust punctuation, keywords, and delimiters.</p>
</td></tr></table><h2 id="macros" class="section-header"><a href="#macros">Macros</a></h2>
<table><tr class="module-item"><td><a class="macro" href="macro.Token.html" title="syn::Token macro">Token</a></td><td class="docblock-short"><p>A type-macro that expands to the name of the Rust type representation of a
given token.</p>
</td></tr><tr class="module-item"><td><a class="macro" href="macro.braced.html" title="syn::braced macro">braced</a></td><td class="docblock-short"><p>Parse a set of curly braces and expose their content to subsequent parsers.</p>
</td></tr><tr class="module-item"><td><a class="macro" href="macro.bracketed.html" title="syn::bracketed macro">bracketed</a></td><td class="docblock-short"><p>Parse a set of square brackets and expose their content to subsequent
parsers.</p>
</td></tr><tr class="module-item"><td><a class="macro" href="macro.custom_keyword.html" title="syn::custom_keyword macro">custom_keyword</a></td><td class="docblock-short"><p>Define a type that supports parsing and printing a given identifier as if it
were a keyword.</p>
</td></tr><tr class="module-item"><td><a class="macro" href="macro.custom_punctuation.html" title="syn::custom_punctuation macro">custom_punctuation</a></td><td class="docblock-short"><p>Define a type that supports parsing and printing a multi-character symbol
as if it were a punctuation token.</p>
</td></tr><tr class="module-item"><td><a class="macro" href="macro.parenthesized.html" title="syn::parenthesized macro">parenthesized</a></td><td class="docblock-short"><p>Parse a set of parentheses and expose their content to subsequent parsers.</p>
</td></tr><tr class="module-item"><td><a class="macro" href="macro.parse_macro_input.html" title="syn::parse_macro_input macro">parse_macro_input</a></td><td class="docblock-short"><p>Parse the input TokenStream of a macro, triggering a compile error if the
tokens fail to parse.</p>
</td></tr><tr class="module-item"><td><a class="macro" href="macro.parse_quote.html" title="syn::parse_quote macro">parse_quote</a></td><td class="docblock-short"><p>Quasi-quotation macro that accepts input like the <a href="https://docs.rs/quote/1.0/quote/index.html"><code>quote!</code></a> macro but uses
type inference to figure out a return type for those tokens.</p>
</td></tr></table><h2 id="structs" class="section-header"><a href="#structs">Structs</a></h2>
<table><tr class="module-item"><td><a class="struct" href="struct.Abi.html" title="syn::Abi struct">Abi</a></td><td class="docblock-short"><p>The binary interface of a function: <code>extern &quot;C&quot;</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.AngleBracketedGenericArguments.html" title="syn::AngleBracketedGenericArguments struct">AngleBracketedGenericArguments</a></td><td class="docblock-short"><p>Angle bracketed arguments of a path segment: the <code>&lt;K, V&gt;</code> in <code>HashMap&lt;K, V&gt;</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Arm.html" title="syn::Arm struct">Arm</a></td><td class="docblock-short"><p>One arm of a <code>match</code> expression: <code>0...10 =&gt; { return true; }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Attribute.html" title="syn::Attribute struct">Attribute</a></td><td class="docblock-short"><p>An attribute like <code>#[repr(transparent)]</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.BareFnArg.html" title="syn::BareFnArg struct">BareFnArg</a></td><td class="docblock-short"><p>An argument in a function type: the <code>usize</code> in <code>fn(usize) -&gt; bool</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Binding.html" title="syn::Binding struct">Binding</a></td><td class="docblock-short"><p>A binding (equality constraint) on an associated type: <code>Item = u8</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Block.html" title="syn::Block struct">Block</a></td><td class="docblock-short"><p>A braced block containing Rust statements.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.BoundLifetimes.html" title="syn::BoundLifetimes struct">BoundLifetimes</a></td><td class="docblock-short"><p>A set of bound lifetimes: <code>for&lt;'a, 'b, 'c&gt;</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ConstParam.html" title="syn::ConstParam struct">ConstParam</a></td><td class="docblock-short"><p>A const generic parameter: <code>const LENGTH: usize</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Constraint.html" title="syn::Constraint struct">Constraint</a></td><td class="docblock-short"><p>An associated type bound: <code>Iterator&lt;Item: Display&gt;</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.DataEnum.html" title="syn::DataEnum struct">DataEnum</a></td><td class="docblock-short"><p>An enum input to a <code>proc_macro_derive</code> macro.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.DataStruct.html" title="syn::DataStruct struct">DataStruct</a></td><td class="docblock-short"><p>A struct input to a <code>proc_macro_derive</code> macro.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.DataUnion.html" title="syn::DataUnion struct">DataUnion</a></td><td class="docblock-short"><p>An untagged union input to a <code>proc_macro_derive</code> macro.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.DeriveInput.html" title="syn::DeriveInput struct">DeriveInput</a></td><td class="docblock-short"><p>Data structure sent to a <code>proc_macro_derive</code> macro.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Error.html" title="syn::Error struct">Error</a></td><td class="docblock-short"><p>Error returned when a Syn parser cannot parse the input tokens.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprArray.html" title="syn::ExprArray struct">ExprArray</a></td><td class="docblock-short"><p>A slice literal expression: <code>[a, b, c, d]</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprAssign.html" title="syn::ExprAssign struct">ExprAssign</a></td><td class="docblock-short"><p>An assignment expression: <code>a = compute()</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprAssignOp.html" title="syn::ExprAssignOp struct">ExprAssignOp</a></td><td class="docblock-short"><p>A compound assignment expression: <code>counter += 1</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprAsync.html" title="syn::ExprAsync struct">ExprAsync</a></td><td class="docblock-short"><p>An async block: <code>async { ... }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprAwait.html" title="syn::ExprAwait struct">ExprAwait</a></td><td class="docblock-short"><p>An await expression: <code>fut.await</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprBinary.html" title="syn::ExprBinary struct">ExprBinary</a></td><td class="docblock-short"><p>A binary operation: <code>a + b</code>, <code>a * b</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprBlock.html" title="syn::ExprBlock struct">ExprBlock</a></td><td class="docblock-short"><p>A blocked scope: <code>{ ... }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprBox.html" title="syn::ExprBox struct">ExprBox</a></td><td class="docblock-short"><p>A box expression: <code>box f</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprBreak.html" title="syn::ExprBreak struct">ExprBreak</a></td><td class="docblock-short"><p>A <code>break</code>, with an optional label to break and an optional
expression.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprCall.html" title="syn::ExprCall struct">ExprCall</a></td><td class="docblock-short"><p>A function call expression: <code>invoke(a, b)</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprCast.html" title="syn::ExprCast struct">ExprCast</a></td><td class="docblock-short"><p>A cast expression: <code>foo as f64</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprClosure.html" title="syn::ExprClosure struct">ExprClosure</a></td><td class="docblock-short"><p>A closure expression: <code>|a, b| a + b</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprContinue.html" title="syn::ExprContinue struct">ExprContinue</a></td><td class="docblock-short"><p>A <code>continue</code>, with an optional label.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprField.html" title="syn::ExprField struct">ExprField</a></td><td class="docblock-short"><p>Access of a named struct field (<code>obj.k</code>) or unnamed tuple struct
field (<code>obj.0</code>).</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprForLoop.html" title="syn::ExprForLoop struct">ExprForLoop</a></td><td class="docblock-short"><p>A for loop: <code>for pat in expr { ... }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprGroup.html" title="syn::ExprGroup struct">ExprGroup</a></td><td class="docblock-short"><p>An expression contained within invisible delimiters.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprIf.html" title="syn::ExprIf struct">ExprIf</a></td><td class="docblock-short"><p>An <code>if</code> expression with an optional <code>else</code> block: <code>if expr { ... } else { ... }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprIndex.html" title="syn::ExprIndex struct">ExprIndex</a></td><td class="docblock-short"><p>A square bracketed indexing expression: <code>vector[2]</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprLet.html" title="syn::ExprLet struct">ExprLet</a></td><td class="docblock-short"><p>A <code>let</code> guard: <code>let Some(x) = opt</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprLit.html" title="syn::ExprLit struct">ExprLit</a></td><td class="docblock-short"><p>A literal in place of an expression: <code>1</code>, <code>&quot;foo&quot;</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprLoop.html" title="syn::ExprLoop struct">ExprLoop</a></td><td class="docblock-short"><p>Conditionless loop: <code>loop { ... }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprMacro.html" title="syn::ExprMacro struct">ExprMacro</a></td><td class="docblock-short"><p>A macro invocation expression: <code>format!(&quot;{}&quot;, q)</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprMatch.html" title="syn::ExprMatch struct">ExprMatch</a></td><td class="docblock-short"><p>A <code>match</code> expression: <code>match n { Some(n) =&gt; {}, None =&gt; {} }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprMethodCall.html" title="syn::ExprMethodCall struct">ExprMethodCall</a></td><td class="docblock-short"><p>A method call expression: <code>x.foo::&lt;T&gt;(a, b)</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprParen.html" title="syn::ExprParen struct">ExprParen</a></td><td class="docblock-short"><p>A parenthesized expression: <code>(a + b)</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprPath.html" title="syn::ExprPath struct">ExprPath</a></td><td class="docblock-short"><p>A path like <code>std::mem::replace</code> possibly containing generic
parameters and a qualified self-type.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprRange.html" title="syn::ExprRange struct">ExprRange</a></td><td class="docblock-short"><p>A range expression: <code>1..2</code>, <code>1..</code>, <code>..2</code>, <code>1..=2</code>, <code>..=2</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprReference.html" title="syn::ExprReference struct">ExprReference</a></td><td class="docblock-short"><p>A referencing operation: <code>&amp;a</code> or <code>&amp;mut a</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprRepeat.html" title="syn::ExprRepeat struct">ExprRepeat</a></td><td class="docblock-short"><p>An array literal constructed from one repeated element: <code>[0u8; N]</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprReturn.html" title="syn::ExprReturn struct">ExprReturn</a></td><td class="docblock-short"><p>A <code>return</code>, with an optional value to be returned.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprStruct.html" title="syn::ExprStruct struct">ExprStruct</a></td><td class="docblock-short"><p>A struct literal expression: <code>Point { x: 1, y: 1 }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprTry.html" title="syn::ExprTry struct">ExprTry</a></td><td class="docblock-short"><p>A try-expression: <code>expr?</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprTryBlock.html" title="syn::ExprTryBlock struct">ExprTryBlock</a></td><td class="docblock-short"><p>A try block: <code>try { ... }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprTuple.html" title="syn::ExprTuple struct">ExprTuple</a></td><td class="docblock-short"><p>A tuple expression: <code>(a, b, c, d)</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprType.html" title="syn::ExprType struct">ExprType</a></td><td class="docblock-short"><p>A type ascription expression: <code>foo: f64</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprUnary.html" title="syn::ExprUnary struct">ExprUnary</a></td><td class="docblock-short"><p>A unary operation: <code>!x</code>, <code>*x</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprUnsafe.html" title="syn::ExprUnsafe struct">ExprUnsafe</a></td><td class="docblock-short"><p>An unsafe block: <code>unsafe { ... }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprWhile.html" title="syn::ExprWhile struct">ExprWhile</a></td><td class="docblock-short"><p>A while loop: <code>while expr { ... }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ExprYield.html" title="syn::ExprYield struct">ExprYield</a></td><td class="docblock-short"><p>A yield expression: <code>yield expr</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Field.html" title="syn::Field struct">Field</a></td><td class="docblock-short"><p>A field of a struct or enum variant.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.FieldPat.html" title="syn::FieldPat struct">FieldPat</a></td><td class="docblock-short"><p>A single field in a struct pattern.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.FieldValue.html" title="syn::FieldValue struct">FieldValue</a></td><td class="docblock-short"><p>A field-value pair in a struct literal.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.FieldsNamed.html" title="syn::FieldsNamed struct">FieldsNamed</a></td><td class="docblock-short"><p>Named fields of a struct or struct variant such as <code>Point { x: f64, y: f64 }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.FieldsUnnamed.html" title="syn::FieldsUnnamed struct">FieldsUnnamed</a></td><td class="docblock-short"><p>Unnamed fields of a tuple struct or tuple variant such as <code>Some(T)</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.File.html" title="syn::File struct">File</a></td><td class="docblock-short"><p>A complete file of Rust source code.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ForeignItemFn.html" title="syn::ForeignItemFn struct">ForeignItemFn</a></td><td class="docblock-short"><p>A foreign function in an <code>extern</code> block.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ForeignItemMacro.html" title="syn::ForeignItemMacro struct">ForeignItemMacro</a></td><td class="docblock-short"><p>A macro invocation within an extern block.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ForeignItemStatic.html" title="syn::ForeignItemStatic struct">ForeignItemStatic</a></td><td class="docblock-short"><p>A foreign static item in an <code>extern</code> block: <code>static ext: u8</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ForeignItemType.html" title="syn::ForeignItemType struct">ForeignItemType</a></td><td class="docblock-short"><p>A foreign type in an <code>extern</code> block: <code>type void</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Generics.html" title="syn::Generics struct">Generics</a></td><td class="docblock-short"><p>Lifetimes and type parameters attached to a declaration of a function,
enum, trait, etc.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Ident.html" title="syn::Ident struct">Ident</a></td><td class="docblock-short"><p>A word of Rust code, which may be a keyword or legal variable name.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ImplGenerics.html" title="syn::ImplGenerics struct">ImplGenerics</a></td><td class="docblock-short"><p>Returned by <code>Generics::split_for_impl</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ImplItemConst.html" title="syn::ImplItemConst struct">ImplItemConst</a></td><td class="docblock-short"><p>An associated constant within an impl block.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ImplItemMacro.html" title="syn::ImplItemMacro struct">ImplItemMacro</a></td><td class="docblock-short"><p>A macro invocation within an impl block.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ImplItemMethod.html" title="syn::ImplItemMethod struct">ImplItemMethod</a></td><td class="docblock-short"><p>A method within an impl block.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ImplItemType.html" title="syn::ImplItemType struct">ImplItemType</a></td><td class="docblock-short"><p>An associated type within an impl block.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Index.html" title="syn::Index struct">Index</a></td><td class="docblock-short"><p>The index of an unnamed tuple struct field.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ItemConst.html" title="syn::ItemConst struct">ItemConst</a></td><td class="docblock-short"><p>A constant item: <code>const MAX: u16 = 65535</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ItemEnum.html" title="syn::ItemEnum struct">ItemEnum</a></td><td class="docblock-short"><p>An enum definition: <code>enum Foo&lt;A, B&gt; { A(A), B(B) }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ItemExternCrate.html" title="syn::ItemExternCrate struct">ItemExternCrate</a></td><td class="docblock-short"><p>An <code>extern crate</code> item: <code>extern crate serde</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ItemFn.html" title="syn::ItemFn struct">ItemFn</a></td><td class="docblock-short"><p>A free-standing function: <code>fn process(n: usize) -&gt; Result&lt;()&gt; { ... }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ItemForeignMod.html" title="syn::ItemForeignMod struct">ItemForeignMod</a></td><td class="docblock-short"><p>A block of foreign items: <code>extern &quot;C&quot; { ... }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ItemImpl.html" title="syn::ItemImpl struct">ItemImpl</a></td><td class="docblock-short"><p>An impl block providing trait or associated items: <code>impl&lt;A&gt; Trait for Data&lt;A&gt; { ... }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ItemMacro.html" title="syn::ItemMacro struct">ItemMacro</a></td><td class="docblock-short"><p>A macro invocation, which includes <code>macro_rules!</code> definitions.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ItemMacro2.html" title="syn::ItemMacro2 struct">ItemMacro2</a></td><td class="docblock-short"><p>A 2.0-style declarative macro introduced by the <code>macro</code> keyword.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ItemMod.html" title="syn::ItemMod struct">ItemMod</a></td><td class="docblock-short"><p>A module or module declaration: <code>mod m</code> or <code>mod m { ... }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ItemStatic.html" title="syn::ItemStatic struct">ItemStatic</a></td><td class="docblock-short"><p>A static item: <code>static BIKE: Shed = Shed(42)</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ItemStruct.html" title="syn::ItemStruct struct">ItemStruct</a></td><td class="docblock-short"><p>A struct definition: <code>struct Foo&lt;A&gt; { x: A }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ItemTrait.html" title="syn::ItemTrait struct">ItemTrait</a></td><td class="docblock-short"><p>A trait definition: <code>pub trait Iterator { ... }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ItemTraitAlias.html" title="syn::ItemTraitAlias struct">ItemTraitAlias</a></td><td class="docblock-short"><p>A trait alias: <code>pub trait SharableIterator = Iterator + Sync</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ItemType.html" title="syn::ItemType struct">ItemType</a></td><td class="docblock-short"><p>A type alias: <code>type Result&lt;T&gt; = std::result::Result&lt;T, MyError&gt;</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ItemUnion.html" title="syn::ItemUnion struct">ItemUnion</a></td><td class="docblock-short"><p>A union definition: <code>union Foo&lt;A, B&gt; { x: A, y: B }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ItemUse.html" title="syn::ItemUse struct">ItemUse</a></td><td class="docblock-short"><p>A use declaration: <code>use std::collections::HashMap</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Label.html" title="syn::Label struct">Label</a></td><td class="docblock-short"><p>A lifetime labeling a <code>for</code>, <code>while</code>, or <code>loop</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Lifetime.html" title="syn::Lifetime struct">Lifetime</a></td><td class="docblock-short"><p>A Rust lifetime: <code>'a</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.LifetimeDef.html" title="syn::LifetimeDef struct">LifetimeDef</a></td><td class="docblock-short"><p>A lifetime definition: <code>'a: 'b + 'c + 'd</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.LitBool.html" title="syn::LitBool struct">LitBool</a></td><td class="docblock-short"><p>A boolean literal: <code>true</code> or <code>false</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.LitByte.html" title="syn::LitByte struct">LitByte</a></td><td class="docblock-short"><p>A byte literal: <code>b'f'</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.LitByteStr.html" title="syn::LitByteStr struct">LitByteStr</a></td><td class="docblock-short"><p>A byte string literal: <code>b&quot;foo&quot;</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.LitChar.html" title="syn::LitChar struct">LitChar</a></td><td class="docblock-short"><p>A character literal: <code>'a'</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.LitFloat.html" title="syn::LitFloat struct">LitFloat</a></td><td class="docblock-short"><p>A floating point literal: <code>1f64</code> or <code>1.0e10f64</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.LitInt.html" title="syn::LitInt struct">LitInt</a></td><td class="docblock-short"><p>An integer literal: <code>1</code> or <code>1u16</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.LitStr.html" title="syn::LitStr struct">LitStr</a></td><td class="docblock-short"><p>A UTF-8 string literal: <code>&quot;foo&quot;</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Local.html" title="syn::Local struct">Local</a></td><td class="docblock-short"><p>A local <code>let</code> binding: <code>let x: u64 = s.parse()?</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Macro.html" title="syn::Macro struct">Macro</a></td><td class="docblock-short"><p>A macro invocation: <code>println!(&quot;{}&quot;, mac)</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.MetaList.html" title="syn::MetaList struct">MetaList</a></td><td class="docblock-short"><p>A structured list within an attribute, like <code>derive(Copy, Clone)</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.MetaNameValue.html" title="syn::MetaNameValue struct">MetaNameValue</a></td><td class="docblock-short"><p>A name-value pair within an attribute, like <code>feature = &quot;nightly&quot;</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.MethodTurbofish.html" title="syn::MethodTurbofish struct">MethodTurbofish</a></td><td class="docblock-short"><p>The <code>::&lt;&gt;</code> explicit type parameters passed to a method call:
<code>parse::&lt;u64&gt;()</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.ParenthesizedGenericArguments.html" title="syn::ParenthesizedGenericArguments struct">ParenthesizedGenericArguments</a></td><td class="docblock-short"><p>Arguments of a function path segment: the <code>(A, B) -&gt; C</code> in <code>Fn(A,B) -&gt; C</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PatBox.html" title="syn::PatBox struct">PatBox</a></td><td class="docblock-short"><p>A box pattern: <code>box v</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PatIdent.html" title="syn::PatIdent struct">PatIdent</a></td><td class="docblock-short"><p>A pattern that binds a new variable: <code>ref mut binding @ SUBPATTERN</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PatLit.html" title="syn::PatLit struct">PatLit</a></td><td class="docblock-short"><p>A literal pattern: <code>0</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PatMacro.html" title="syn::PatMacro struct">PatMacro</a></td><td class="docblock-short"><p>A macro in pattern position.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PatOr.html" title="syn::PatOr struct">PatOr</a></td><td class="docblock-short"><p>A pattern that matches any one of a set of cases.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PatPath.html" title="syn::PatPath struct">PatPath</a></td><td class="docblock-short"><p>A path pattern like <code>Color::Red</code>, optionally qualified with a
self-type.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PatRange.html" title="syn::PatRange struct">PatRange</a></td><td class="docblock-short"><p>A range pattern: <code>1..=2</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PatReference.html" title="syn::PatReference struct">PatReference</a></td><td class="docblock-short"><p>A reference pattern: <code>&amp;mut var</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PatRest.html" title="syn::PatRest struct">PatRest</a></td><td class="docblock-short"><p>The dots in a tuple or slice pattern: <code>[0, 1, ..]</code></p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PatSlice.html" title="syn::PatSlice struct">PatSlice</a></td><td class="docblock-short"><p>A dynamically sized slice pattern: <code>[a, b, ref i @ .., y, z]</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PatStruct.html" title="syn::PatStruct struct">PatStruct</a></td><td class="docblock-short"><p>A struct or struct variant pattern: <code>Variant { x, y, .. }</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PatTuple.html" title="syn::PatTuple struct">PatTuple</a></td><td class="docblock-short"><p>A tuple pattern: <code>(a, b)</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PatTupleStruct.html" title="syn::PatTupleStruct struct">PatTupleStruct</a></td><td class="docblock-short"><p>A tuple struct or tuple variant pattern: <code>Variant(x, y, .., z)</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PatType.html" title="syn::PatType struct">PatType</a></td><td class="docblock-short"><p>A type ascription pattern: <code>foo: f64</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PatWild.html" title="syn::PatWild struct">PatWild</a></td><td class="docblock-short"><p>A pattern that matches any value: <code>_</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Path.html" title="syn::Path struct">Path</a></td><td class="docblock-short"><p>A path at which a named item is exported (e.g. <code>std::collections::HashMap</code>).</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PathSegment.html" title="syn::PathSegment struct">PathSegment</a></td><td class="docblock-short"><p>A segment of a path together with any path arguments on that segment.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PredicateEq.html" title="syn::PredicateEq struct">PredicateEq</a></td><td class="docblock-short"><p>An equality predicate in a <code>where</code> clause (unsupported).</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PredicateLifetime.html" title="syn::PredicateLifetime struct">PredicateLifetime</a></td><td class="docblock-short"><p>A lifetime predicate in a <code>where</code> clause: <code>'a: 'b + 'c</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.PredicateType.html" title="syn::PredicateType struct">PredicateType</a></td><td class="docblock-short"><p>A type predicate in a <code>where</code> clause: <code>for&lt;'c&gt; Foo&lt;'c&gt;: Trait&lt;'c&gt;</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.QSelf.html" title="syn::QSelf struct">QSelf</a></td><td class="docblock-short"><p>The explicit Self type in a qualified path: the <code>T</code> in <code>&lt;T as Display&gt;::fmt</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Receiver.html" title="syn::Receiver struct">Receiver</a></td><td class="docblock-short"><p>The <code>self</code> argument of an associated method, whether taken by value
or by reference.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Signature.html" title="syn::Signature struct">Signature</a></td><td class="docblock-short"><p>A function signature in a trait or implementation: <code>unsafe fn initialize(&amp;self)</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TraitBound.html" title="syn::TraitBound struct">TraitBound</a></td><td class="docblock-short"><p>A trait used as a bound on a type parameter.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TraitItemConst.html" title="syn::TraitItemConst struct">TraitItemConst</a></td><td class="docblock-short"><p>An associated constant within the definition of a trait.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TraitItemMacro.html" title="syn::TraitItemMacro struct">TraitItemMacro</a></td><td class="docblock-short"><p>A macro invocation within the definition of a trait.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TraitItemMethod.html" title="syn::TraitItemMethod struct">TraitItemMethod</a></td><td class="docblock-short"><p>A trait method within the definition of a trait.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TraitItemType.html" title="syn::TraitItemType struct">TraitItemType</a></td><td class="docblock-short"><p>An associated type within the definition of a trait.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Turbofish.html" title="syn::Turbofish struct">Turbofish</a></td><td class="docblock-short"><p>Returned by <code>TypeGenerics::as_turbofish</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TypeArray.html" title="syn::TypeArray struct">TypeArray</a></td><td class="docblock-short"><p>A fixed size array type: <code>[T; n]</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TypeBareFn.html" title="syn::TypeBareFn struct">TypeBareFn</a></td><td class="docblock-short"><p>A bare function type: <code>fn(usize) -&gt; bool</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TypeGenerics.html" title="syn::TypeGenerics struct">TypeGenerics</a></td><td class="docblock-short"><p>Returned by <code>Generics::split_for_impl</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TypeGroup.html" title="syn::TypeGroup struct">TypeGroup</a></td><td class="docblock-short"><p>A type contained within invisible delimiters.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TypeImplTrait.html" title="syn::TypeImplTrait struct">TypeImplTrait</a></td><td class="docblock-short"><p>An <code>impl Bound1 + Bound2 + Bound3</code> type where <code>Bound</code> is a trait or
a lifetime.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TypeInfer.html" title="syn::TypeInfer struct">TypeInfer</a></td><td class="docblock-short"><p>Indication that a type should be inferred by the compiler: <code>_</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TypeMacro.html" title="syn::TypeMacro struct">TypeMacro</a></td><td class="docblock-short"><p>A macro in the type position.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TypeNever.html" title="syn::TypeNever struct">TypeNever</a></td><td class="docblock-short"><p>The never type: <code>!</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TypeParam.html" title="syn::TypeParam struct">TypeParam</a></td><td class="docblock-short"><p>A generic type parameter: <code>T: Into&lt;String&gt;</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TypeParen.html" title="syn::TypeParen struct">TypeParen</a></td><td class="docblock-short"><p>A parenthesized type equivalent to the inner type.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TypePath.html" title="syn::TypePath struct">TypePath</a></td><td class="docblock-short"><p>A path like <code>std::slice::Iter</code>, optionally qualified with a
self-type as in <code>&lt;Vec&lt;T&gt; as SomeTrait&gt;::Associated</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TypePtr.html" title="syn::TypePtr struct">TypePtr</a></td><td class="docblock-short"><p>A raw pointer type: <code>*const T</code> or <code>*mut T</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TypeReference.html" title="syn::TypeReference struct">TypeReference</a></td><td class="docblock-short"><p>A reference type: <code>&amp;'a T</code> or <code>&amp;'a mut T</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TypeSlice.html" title="syn::TypeSlice struct">TypeSlice</a></td><td class="docblock-short"><p>A dynamically sized slice type: <code>[T]</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TypeTraitObject.html" title="syn::TypeTraitObject struct">TypeTraitObject</a></td><td class="docblock-short"><p>A trait object type <code>Bound1 + Bound2 + Bound3</code> where <code>Bound</code> is a
trait or a lifetime.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.TypeTuple.html" title="syn::TypeTuple struct">TypeTuple</a></td><td class="docblock-short"><p>A tuple type: <code>(A, B, C, String)</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.UseGlob.html" title="syn::UseGlob struct">UseGlob</a></td><td class="docblock-short"><p>A glob import in a <code>use</code> item: <code>*</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.UseGroup.html" title="syn::UseGroup struct">UseGroup</a></td><td class="docblock-short"><p>A braced group of imports in a <code>use</code> item: <code>{A, B, C}</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.UseName.html" title="syn::UseName struct">UseName</a></td><td class="docblock-short"><p>An identifier imported by a <code>use</code> item: <code>HashMap</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.UsePath.html" title="syn::UsePath struct">UsePath</a></td><td class="docblock-short"><p>A path prefix of imports in a <code>use</code> item: <code>std::...</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.UseRename.html" title="syn::UseRename struct">UseRename</a></td><td class="docblock-short"><p>An renamed identifier imported by a <code>use</code> item: <code>HashMap as Map</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Variadic.html" title="syn::Variadic struct">Variadic</a></td><td class="docblock-short"><p>The variadic argument of a foreign function.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.Variant.html" title="syn::Variant struct">Variant</a></td><td class="docblock-short"><p>An enum variant.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.VisCrate.html" title="syn::VisCrate struct">VisCrate</a></td><td class="docblock-short"><p>A crate-level visibility: <code>crate</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.VisPublic.html" title="syn::VisPublic struct">VisPublic</a></td><td class="docblock-short"><p>A public visibility level: <code>pub</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.VisRestricted.html" title="syn::VisRestricted struct">VisRestricted</a></td><td class="docblock-short"><p>A visibility level restricted to some path: <code>pub(self)</code> or
<code>pub(super)</code> or <code>pub(crate)</code> or <code>pub(in some::module)</code>.</p>
</td></tr><tr class="module-item"><td><a class="struct" href="struct.WhereClause.html" title="syn::WhereClause struct">WhereClause</a></td><td class="docblock-short"><p>A <code>where</code> clause in a definition: <code>where T: Deserialize&lt;'de&gt;, D: 'static</code>.</p>
</td></tr></table><h2 id="enums" class="section-header"><a href="#enums">Enums</a></h2>
<table><tr class="module-item"><td><a class="enum" href="enum.AttrStyle.html" title="syn::AttrStyle enum">AttrStyle</a></td><td class="docblock-short"><p>Distinguishes between attributes that decorate an item and attributes
that are contained within an item.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.BinOp.html" title="syn::BinOp enum">BinOp</a></td><td class="docblock-short"><p>A binary operator: <code>+</code>, <code>+=</code>, <code>&amp;</code>.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.Data.html" title="syn::Data enum">Data</a></td><td class="docblock-short"><p>The storage of a struct, enum or union data structure.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.Expr.html" title="syn::Expr enum">Expr</a></td><td class="docblock-short"><p>A Rust expression.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.Fields.html" title="syn::Fields enum">Fields</a></td><td class="docblock-short"><p>Data stored within an enum variant or struct.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.FnArg.html" title="syn::FnArg enum">FnArg</a></td><td class="docblock-short"><p>An argument in a function signature: the <code>n: usize</code> in <code>fn f(n: usize)</code>.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.ForeignItem.html" title="syn::ForeignItem enum">ForeignItem</a></td><td class="docblock-short"><p>An item within an <code>extern</code> block.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.GenericArgument.html" title="syn::GenericArgument enum">GenericArgument</a></td><td class="docblock-short"><p>An individual generic argument, like <code>'a</code>, <code>T</code>, or <code>Item = T</code>.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.GenericMethodArgument.html" title="syn::GenericMethodArgument enum">GenericMethodArgument</a></td><td class="docblock-short"><p>An individual generic argument to a method, like <code>T</code>.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.GenericParam.html" title="syn::GenericParam enum">GenericParam</a></td><td class="docblock-short"><p>A generic type parameter, lifetime, or const generic: <code>T: Into&lt;String&gt;</code>,
<code>'a: 'b</code>, <code>const LEN: usize</code>.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.ImplItem.html" title="syn::ImplItem enum">ImplItem</a></td><td class="docblock-short"><p>An item within an impl block.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.Item.html" title="syn::Item enum">Item</a></td><td class="docblock-short"><p>Things that can appear directly inside of a module or scope.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.Lit.html" title="syn::Lit enum">Lit</a></td><td class="docblock-short"><p>A Rust literal such as a string or integer or boolean.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.MacroDelimiter.html" title="syn::MacroDelimiter enum">MacroDelimiter</a></td><td class="docblock-short"><p>A grouping token that surrounds a macro body: <code>m!(...)</code> or <code>m!{...}</code> or <code>m![...]</code>.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.Member.html" title="syn::Member enum">Member</a></td><td class="docblock-short"><p>A struct or tuple struct field accessed in a struct literal or field
expression.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.Meta.html" title="syn::Meta enum">Meta</a></td><td class="docblock-short"><p>Content of a compile-time structured attribute.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.NestedMeta.html" title="syn::NestedMeta enum">NestedMeta</a></td><td class="docblock-short"><p>Element of a compile-time attribute list.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.Pat.html" title="syn::Pat enum">Pat</a></td><td class="docblock-short"><p>A pattern in a local binding, function signature, match expression, or
various other places.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.PathArguments.html" title="syn::PathArguments enum">PathArguments</a></td><td class="docblock-short"><p>Angle bracketed or parenthesized arguments of a path segment.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.RangeLimits.html" title="syn::RangeLimits enum">RangeLimits</a></td><td class="docblock-short"><p>Limit types of a range, inclusive or exclusive.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.ReturnType.html" title="syn::ReturnType enum">ReturnType</a></td><td class="docblock-short"><p>Return type of a function signature.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.Stmt.html" title="syn::Stmt enum">Stmt</a></td><td class="docblock-short"><p>A statement, usually ending in a semicolon.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.StrStyle.html" title="syn::StrStyle enum">StrStyle</a></td><td class="docblock-short"><p>The style of a string literal, either plain quoted or a raw string like
<code>r##&quot;data&quot;##</code>.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.TraitBoundModifier.html" title="syn::TraitBoundModifier enum">TraitBoundModifier</a></td><td class="docblock-short"><p>A modifier on a trait bound, currently only used for the <code>?</code> in
<code>?Sized</code>.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.TraitItem.html" title="syn::TraitItem enum">TraitItem</a></td><td class="docblock-short"><p>An item declaration within the definition of a trait.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.Type.html" title="syn::Type enum">Type</a></td><td class="docblock-short"><p>The possible types that a Rust value could have.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.TypeParamBound.html" title="syn::TypeParamBound enum">TypeParamBound</a></td><td class="docblock-short"><p>A trait or lifetime used as a bound on a type parameter.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.UnOp.html" title="syn::UnOp enum">UnOp</a></td><td class="docblock-short"><p>A unary operator: <code>*</code>, <code>!</code>, <code>-</code>.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.UseTree.html" title="syn::UseTree enum">UseTree</a></td><td class="docblock-short"><p>A suffix of an import tree in a <code>use</code> item: <code>Type as Renamed</code> or <code>*</code>.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.Visibility.html" title="syn::Visibility enum">Visibility</a></td><td class="docblock-short"><p>The visibility level of an item: inherited or <code>pub</code> or
<code>pub(restricted)</code>.</p>
</td></tr><tr class="module-item"><td><a class="enum" href="enum.WherePredicate.html" title="syn::WherePredicate enum">WherePredicate</a></td><td class="docblock-short"><p>A single predicate in a <code>where</code> clause: <code>T: Deserialize&lt;'de&gt;</code>.</p>
</td></tr></table><h2 id="functions" class="section-header"><a href="#functions">Functions</a></h2>
<table><tr class="module-item"><td><a class="fn" href="fn.parse.html" title="syn::parse fn">parse</a></td><td class="docblock-short"><p>Parse tokens of source code into the chosen syntax tree node.</p>
</td></tr><tr class="module-item"><td><a class="fn" href="fn.parse2.html" title="syn::parse2 fn">parse2</a></td><td class="docblock-short"><p>Parse a proc-macro2 token stream into the chosen syntax tree node.</p>
</td></tr><tr class="module-item"><td><a class="fn" href="fn.parse_file.html" title="syn::parse_file fn">parse_file</a></td><td class="docblock-short"><p>Parse the content of a file of Rust code.</p>
</td></tr><tr class="module-item"><td><a class="fn" href="fn.parse_str.html" title="syn::parse_str fn">parse_str</a></td><td class="docblock-short"><p>Parse a string of Rust code into the chosen syntax tree node.</p>
</td></tr></table><h2 id="types" class="section-header"><a href="#types">Type Definitions</a></h2>
<table><tr class="module-item"><td><a class="type" href="type.AttributeArgs.html" title="syn::AttributeArgs type">AttributeArgs</a></td><td class="docblock-short"><p>Conventional argument type associated with an invocation of an attribute
macro.</p>
</td></tr><tr class="module-item"><td><a class="type" href="type.Result.html" title="syn::Result type">Result</a></td><td class="docblock-short"><p>The result of a Syn parser.</p>
</td></tr></table></section><section id="search" class="content hidden"></section><section class="footer"></section><script>window.rootPath = "../";window.currentCrate = "syn";</script><script src="../main.js"></script><script defer src="../search-index.js"></script></body></html>