SyntaxType

Enum SyntaxType 

Source
pub enum SyntaxType {
Show 25 variants Keyword, Punctuation, Operator, Number, Boolean, Comment, Parameter, LayoutQualifier, UncheckedIdent, Ident, UnresolvedIdent, Invalid, ObjectMacro, FunctionMacro, Directive, DirectiveConcat, DirectiveHash, DirectiveName, DirectiveVersion, DirectiveProfile, DirectiveExtName, DirectiveExtBehaviour, DirectiveLineNumber, DirectiveError, DirectivePragma,
}
Expand description

The type of syntax highlighting token.

For semantic highlighting purposes, any UncheckedIdent tokens must be name-resolved into a more concrete identifier type. This functionality is currently waiting on the analyzer module.

Variants§

§

Keyword

A keyword.

§

Punctuation

A punctuation symbol.

§

Operator

An operator symbol.

§

Number

A number.

§

Boolean

A boolean.

§

Comment

A comment.

§

Parameter

A function or function-like macro parameter.

§

LayoutQualifier

A valid layout qualifier identifier.

§

UncheckedIdent

An identifier which has not gone through name resolution yet.

§

Ident

An identifier which has not gone through name resolution and never will. This token is only used for any identifiers within macro bodies.

§

UnresolvedIdent

An unresolved identifier. This could be an unresolved variable identifier, an unresolved type name, or an illegal layout qualifier identifier.

§

Invalid

An invalid character.

§

ObjectMacro

An object-like macro identifier. This is used at the macro definition, and at any call sites.

§

FunctionMacro

A function-like macro identifier. This is used at the macro definition, and at any call sites.

§

Directive

A general bit of text in a directive.

§

DirectiveConcat

The macro concatenation operator (##).

§

DirectiveHash

The hash # symbol in a directive.

§

DirectiveName

The name of the directive, e.g. version or ifdef.

§

DirectiveVersion

The GLSL version in a #version directive.

§

DirectiveProfile

The GLSL profile in a #version directive.

§

DirectiveExtName

The extension name in a #extension directive.

§

DirectiveExtBehaviour

The extension behaviour in a #extension directive.

§

DirectiveLineNumber

The line number in a #line directive.

§

DirectiveError

The message in an #error directive.

§

DirectivePragma

The compiler option in a #pragma directive.

Trait Implementations§

Source§

impl Clone for SyntaxType

Source§

fn clone(&self) -> SyntaxType

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for SyntaxType

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl PartialEq for SyntaxType

Source§

fn eq(&self, other: &SyntaxType) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Copy for SyntaxType

Source§

impl Eq for SyntaxType

Source§

impl StructuralPartialEq for SyntaxType

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

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

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.