pub enum Type {
Slice(TypeSlice),
Array(TypeArray),
Ptr(TypePtr),
Reference(TypeReference),
BareFn(TypeBareFn),
Never(TypeNever),
Tuple(TypeTuple),
Path(TypePath),
TraitObject(TypeTraitObject),
ImplTrait(TypeImplTrait),
Paren(TypeParen),
Group(TypeGroup),
Infer(TypeInfer),
Macro(TypeMacro),
Verbatim(TypeVerbatim),
}
The possible types that a Rust value could have.
This type is available if Syn is built with the "derive"
or "full"
feature.
This type is a syntax tree enum.
A dynamically sized slice type: [T]
.
This type is available if Syn is built with the "derive"
or
"full"
feature.
A fixed size array type: [T; n]
.
This type is available if Syn is built with the "derive"
or
"full"
feature.
A raw pointer type: *const T
or *mut T
.
This type is available if Syn is built with the "derive"
or
"full"
feature.
A reference type: &'a T
or &'a mut T
.
This type is available if Syn is built with the "derive"
or
"full"
feature.
A bare function type: fn(usize) -> bool
.
This type is available if Syn is built with the "derive"
or
"full"
feature.
The never type: !
.
This type is available if Syn is built with the "derive"
or
"full"
feature.
A tuple type: (A, B, C, String)
.
This type is available if Syn is built with the "derive"
or
"full"
feature.
A path like std::slice::Iter
, optionally qualified with a
self-type as in <Vec<T> as SomeTrait>::Associated
.
Type arguments are stored in the Path itself.
This type is available if Syn is built with the "derive"
or
"full"
feature.
A trait object type Bound1 + Bound2 + Bound3
where Bound
is a
trait or a lifetime.
This type is available if Syn is built with the "derive"
or
"full"
feature.
An impl Bound1 + Bound2 + Bound3
type where Bound
is a trait or
a lifetime.
This type is available if Syn is built with the "derive"
or
"full"
feature.
A parenthesized type equivalent to the inner type.
This type is available if Syn is built with the "derive"
or
"full"
feature.
A type contained within invisible delimiters.
This type is available if Syn is built with the "derive"
or
"full"
feature.
Indication that a type should be inferred by the compiler: _
.
This type is available if Syn is built with the "derive"
or
"full"
feature.
A macro in the type position.
This type is available if Syn is built with the "derive"
or
"full"
feature.
Tokens in type position not interpreted by Syn.
This type is available if Syn is built with the "derive"
or
"full"
feature.
A short name of the type being parsed. Read more
Formats the value using the given formatter. Read more
This method tests for self
and other
values to be equal, and is used by ==
. Read more
This method tests for !=
.
Feeds this value into the given [Hasher
]. Read more
Feeds a slice of this type into the given [Hasher
]. Read more
Performs copy-assignment from source
. Read more
Write self
to the given TokenStream
. Read more
Convert self
directly into a TokenStream
object. Read more
Returns a Span
covering the complete contents of this syntax tree node, or [Span::call_site()
] if this node is empty. Read more
Creates owned data from borrowed data, usually by cloning. Read more
🔬 This is a nightly-only experimental API. (toowned_clone_into
)
recently added
Uses borrowed data to replace owned data, usually by cloning. Read more
🔬 This is a nightly-only experimental API. (try_from
)
The type returned in the event of a conversion error.
🔬 This is a nightly-only experimental API. (try_from
)
Immutably borrows from an owned value. Read more
[+]
[+]
type Error = <U as TryFrom<T>>::Error
🔬 This is a nightly-only experimental API. (try_from
)
The type returned in the event of a conversion error.
[−]
🔬 This is a nightly-only experimental API. (try_from
)
[+]
[−]
🔬 This is a nightly-only experimental API. (get_type_id
)
this method will likely be replaced by an associated static
[+]
[−]
🔬 This is a nightly-only experimental API. (rustc_private
)
this crate is being loaded from the sysroot, an unstable location; did you mean to load this crate from crates.io via Cargo.toml
instead?
Create an error for a missing method specialization. Defaults to panicking with type, trait & method names. S
is the encoder/decoder state type, T
is the type being encoded/decoded, and the arguments are the names of the trait and method that should've been overridden. Read more