Enum Token

Source
pub enum Token {
    RootBegin {
        tag: Tag,
        count: u32,
    },
    RootEnd,
    Label(LabelIndex),
    StructBegin {
        tag: Tag,
        count: u32,
    },
    StructEnd,
    ListBegin(u32),
    ListEnd,
    ItemBegin {
        tag: Tag,
        count: u32,
        index: u32,
    },
    ItemEnd,
    Value(SimpleValueRef),
}
Expand description

Возможные виды событий, которые могут возникнуть при чтении GFF файла. Отражают появление в потоке значений из файла и структурных единиц (списков, структур, …)

Variants§

§

RootBegin

Событие о начале разбора GFF-читателем структуры с индексом 0 в GFF файле.

Возникает после чтения заголовка файла, и позиционирования на начало первой (с индексом 0) структуры, но перед ее чтением. Следующим событием может быть:

  • RootEnd: если корневая структура не содержит полей
  • StructBegin: если первым полем корневой структуры является значение с типом Struct
  • ListBegin: если первым полем корневой структуры является значение с типом List
  • Value: если первым полем корневой структуры является значение с любым другим типом

Fields

§tag: Tag

Уникальный (по задумке) идентификатор типа структуры в файле. На самом деле движок, похоже, не проверяет уникальность этих значений

§count: u32

Количество полей в данной структуре

§

RootEnd

Событие об окончании разбора GFF-читателем структуры с индексом 0 в GFF файле, что сигнализирует о завершении файла.

Это последнее событие при чтении файла, после него следующих событий не будет

§

Label(LabelIndex)

Событие о начале разбора поля в структуре. После данного события возникают события:

  • StructBegin: если полем структуры является значение с типом Struct
  • ListBegin: если полем структуры является значение с типом List
  • Value: если полем структуры является значение с любым другим типом
§

StructBegin

Событие о начале разбора GFF-читателем любой структуры, кроме самой первой (для нее используется событие RootBegin).

Возникает после позиционирования на начало любой структуры, кроме первой (с индексом 0), но перед ее чтением. Следующим событием может быть:

  • StructBegin: если первым полем структуры является значение с типом Struct
  • ListBegin: если первым полем структуры является значение с типом List
  • Value: если первым полем структуры является значение с любым другим типом

Fields

§tag: Tag

Уникальный (по задумке) идентификатор типа структуры в файле. На самом деле движок, похоже, не проверяет уникальность этих значений

§count: u32

Количество полей в данной структуре

§

StructEnd

Событие об окончании разбора GFF-читателем любой структуры, кроме самой первой (для нее используется событие FileEnd)

§

ListBegin(u32)

Событие о начале разбора GFF-читателем списка объектов структуры. В параметре содержится количество записей в списке.

Список всегда содержит набор структур, поэтому разбор каждой записи предваряется событием ItemBegin и завершается событием ItemEnd

§

ListEnd

Событие об окончании разбора GFF-читателем списка объектов

§

ItemBegin

Событие о начале разбора GFF-читателем любой структуры внутри списка. В отличие от обычных, такие структуры не имеют метки.

Возникает после позиционирования на начало любой структуры списка. Следующим событием может быть:

  • ItemEnd: если структура списка не содержит полей
  • StructBegin: если первым полем структуры списка является поле с типом Struct
  • ListBegin: если первым полем структуры списка является поле с типом List
  • Value: если первым полем структуры списка является поле с любым другим типом

Fields

§tag: Tag

Уникальный (по задумке) идентификатор типа структуры в файле. На самом деле движок, похоже, не проверяет уникальность этих значений

§count: u32

Количество полей в данной структуре

§index: u32

Номер элемента в списке

§

ItemEnd

Событие об окончании разбора GFF-читателем любой структуры списка

§

Value(SimpleValueRef)

Поле, представляющее примитивное (не имеющее структуры) значение, хранимое в файле

Trait Implementations§

Source§

impl Clone for Token

Source§

fn clone(&self) -> Token

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 Token

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl Freeze for Token

§

impl RefUnwindSafe for Token

§

impl Send for Token

§

impl Sync for Token

§

impl Unpin for Token

§

impl UnwindSafe for Token

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.