#[non_exhaustive]
pub enum Type {
Show 15 variants
Array(TypeArray),
BareFn(TypeBareFn),
Group(TypeGroup),
ImplTrait(TypeImplTrait),
Infer(TypeInfer),
Macro(TypeMacro),
Never(TypeNever),
Paren(TypeParen),
Path(TypePath),
Ptr(TypePtr),
Reference(TypeReference),
Slice(TypeSlice),
TraitObject(TypeTraitObject),
Tuple(TypeTuple),
Verbatim(TokenStream),
}Expand description
The possible types that a Rust value could have.
This type is available only if Syn is built with the "derive" or "full"
feature.
Syntax tree enum
This type is a syntax tree enum.
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Array(TypeArray)
A fixed size array type: [T; n].
BareFn(TypeBareFn)
A bare function type: fn(usize) -> bool.
Group(TypeGroup)
A type contained within invisible delimiters.
ImplTrait(TypeImplTrait)
An impl Bound1 + Bound2 + Bound3 type where Bound is a trait or
a lifetime.
Infer(TypeInfer)
Indication that a type should be inferred by the compiler: _.
Macro(TypeMacro)
A macro in the type position.
Never(TypeNever)
The never type: !.
Paren(TypeParen)
A parenthesized type equivalent to the inner type.
Path(TypePath)
A path like std::slice::Iter, optionally qualified with a
self-type as in <Vec<T> as SomeTrait>::Associated.
Ptr(TypePtr)
A raw pointer type: *const T or *mut T.
Reference(TypeReference)
A reference type: &'a T or &'a mut T.
Slice(TypeSlice)
A dynamically sized slice type: [T].
TraitObject(TypeTraitObject)
A trait object type dyn Bound1 + Bound2 + Bound3 where Bound is a
trait or a lifetime.
Tuple(TypeTuple)
A tuple type: (A, B, C, String).
Verbatim(TokenStream)
Tokens in type position not interpreted by Syn.
Implementations§
source§impl Type
impl Type
sourcepub fn without_plus(input: ParseStream<'_>) -> Result<Self>
pub fn without_plus(input: ParseStream<'_>) -> Result<Self>
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.