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.
In some positions, types may not contain the +
character, to
disambiguate them. For example in the expression 1 as T
, T may not
contain a +
character.
This parser does not allow a +
, while the default parser does.
This method tests for self
and other
values to be equal, and is used by ==
. Read more
This method tests for !=
.
Performs copy-assignment from source
. Read more
Feeds this value into the given [Hasher
]. Read more
Feeds a slice of this type into the given [Hasher
]. Read more
Formats the value using the given formatter. 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
🔬 This is a nightly-only experimental API. (get_type_id
)
this method will likely be replaced by an associated static
Mutably borrows from an owned value. 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
)