Enum syn::Lit

source ·
pub enum Lit {
    Str(LitStr),
    ByteStr(LitByteStr),
    Byte(LitByte),
    Char(LitChar),
    Int(LitInt),
    Float(LitFloat),
    Bool(LitBool),
    Verbatim(LitVerbatim),
}
Expand description

A Rust literal such as a string or integer or boolean.

This type is available if Syn is built with the "derive" or "full" feature.

Syntax tree enum

This type is a syntax tree enum.

Variants

Str(LitStr)

A UTF-8 string literal: "foo".

This type is available if Syn is built with the "derive" or "full" feature.

ByteStr(LitByteStr)

A byte string literal: b"foo".

This type is available if Syn is built with the "derive" or "full" feature.

Byte(LitByte)

A byte literal: b'f'.

This type is available if Syn is built with the "derive" or "full" feature.

Char(LitChar)

A character literal: 'a'.

This type is available if Syn is built with the "derive" or "full" feature.

Int(LitInt)

An integer literal: 1 or 1u16.

Holds up to 64 bits of data. Use LitVerbatim for any larger integer literal.

This type is available if Syn is built with the "derive" or "full" feature.

Float(LitFloat)

A floating point literal: 1f64 or 1.0e10f64.

Must be finite. May not be infinte or NaN.

This type is available if Syn is built with the "derive" or "full" feature.

Bool(LitBool)

A boolean literal: true or false.

This type is available if Syn is built with the "derive" or "full" feature.

Verbatim(LitVerbatim)

A raw token literal not interpreted by Syn, possibly because it represents an integer larger than 64 bits.

This type is available if Syn is built with the "derive" or "full" feature.

Implementations

Interpret a Syn literal from a proc-macro2 literal.

Not all proc-macro2 literals are valid Syn literals. In particular, doc comments are considered by proc-macro2 to be literals but in Syn they are Attribute.

Panics

Panics if the input is a doc comment literal.

Trait Implementations

Returns a copy of the value. Read more
Performs copy-assignment from source. Read more
Formats the value using the given formatter. Read more
Converts to this type from the input type.
Converts to this type from the input type.
Converts to this type from the input type.
Converts to this type from the input type.
Converts to this type from the input type.
Converts to this type from the input type.
Converts to this type from the input type.
Converts to this type from the input type.
Converts to this type from the input type.
Feeds this value into the given Hasher. Read more
Feeds a slice of this type into the given Hasher. Read more
This method tests for self and other values to be equal, and is used by ==. Read more
This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason. Read more
Write self to the given TokenStream. Read more
Convert self directly into a TokenStream object. Read more

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Returns a Span covering the complete contents of this syntax tree node, or Span::call_site() if this node is empty. Read more
The resulting type after obtaining ownership.
Creates owned data from borrowed data, usually by cloning. Read more
Uses borrowed data to replace owned data, usually by cloning. Read more
The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion error.
Performs the conversion.