Struct Document

Source
pub struct Document<'a> {
    pub definitions: Vec<'a, Definition<'a>>,
    pub size_hint: usize,
}
Expand description

AST Root Node for a GraphQL query language document. This contains one or more definitions of fragments or operations.

Reference

Fields§

§definitions: Vec<'a, Definition<'a>>§size_hint: usize

A hint on how large the source text was from which this Document was parsed.

This gives an initial indication of the starting capacity of a String that will hold the stringified document.

Implementations§

Source§

impl<'a, 'b> Document<'a>

Source

pub fn is_empty(&self) -> bool

Checks whether this document contains any definitions.

Source

pub fn fragments( &'a self, ctx: &'a ASTContext, ) -> HashMap<&str, &'a FragmentDefinition<'a>, DefaultHashBuilder, &'a Bump>

Returns a Map keyed by all fragment names mapped to their fragment definitions. This is useful for manually traversing the document and resolving FragmentSpread nodes to their definitions.

Source

pub fn operation( &'a self, by_name: Option<&'b str>, ) -> Result<&'a OperationDefinition<'a>>

Finds an operation definition by name or the single operation contained in the document when None is passed.

Reference

Trait Implementations§

Source§

impl<'a> Clone for Document<'a>

Source§

fn clone(&self) -> Document<'a>

Returns a copy 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<'a> Debug for Document<'a>

Source§

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

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

impl<'a> DefaultIn<'a> for Document<'a>

Source§

fn default_in(arena: &'a Bump) -> Self

Source§

impl<'a> FoldDocument<'a> for Document<'a>

Source§

fn fold_operation<'b, F: Folder<'a>>( &'a self, ctx: &'a ASTContext, operation_name: Option<&'a str>, folder: &'b mut F, ) -> Result<&'a Self>

Folds a GraphQL document by a given operation instead. Instead of transforming the given document in its entirety fold_operation will start at the defined operation instead, transforming fragments only as they’re referred to via FragmentSpread nodes. This will create a new document that only refers to and contains the specified operation.

Source§

impl<'a> PartialEq for Document<'a>

Source§

fn eq(&self, other: &Document<'a>) -> 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<'a> PrintNode for Document<'a>

Source§

fn write_to_buffer(&self, level: usize, buffer: &mut dyn Write) -> Result

Write an AST node to a buffer implementing the Write trait. Read more
Source§

fn print(&self) -> String

Print an AST Node to source text as a String allocated on the heap. Read more
Source§

impl<'a> ValidateNode<'a> for Document<'a>

Source§

fn validate<Rule: ValidationRule<'a>>( &'a self, ctx: &'a ASTContext, ) -> Result<()>

Run the generic validation rule on the document node and return a result which errors if the validation rule fails on the current document. Read more
Source§

impl<'a> StructuralPartialEq for Document<'a>

Auto Trait Implementations§

§

impl<'a> Freeze for Document<'a>

§

impl<'a> !RefUnwindSafe for Document<'a>

§

impl<'a> !Send for Document<'a>

§

impl<'a> !Sync for Document<'a>

§

impl<'a> Unpin for Document<'a>

§

impl<'a> !UnwindSafe for Document<'a>

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<'a, T> FoldNode<'a> for T
where T: FoldNode<'a>,

Source§

fn fold<'b, F: Folder<'a>>( &'a self, ctx: &'a ASTContext, folder: &'b mut F, ) -> Result<&'a Self>

Visit the GraphQL AST node tree recursively in depth-first order and create a transformed copy of it using the given folder. The folder must implement the Folder trait. 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<'a, T> ParseNode<'a> for T
where T: ParseNode<'a>,

Source§

fn parse<T: ToString>(ctx: &'a ASTContext, source: T) -> Result<&'a Self>

Parse an input source text into the implementor’s AST Node structure and allocate the resulting AST into the current AST Context’s arena.
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.
Source§

impl<'a, T> VisitNode<'a> for T
where T: VisitNodeWithInfo<'a>,

Source§

fn visit<'b, C, V: Visitor<'a, C>>( &'a self, ctx: &'b mut C, visitor: &'b mut V, ) -> VisitFlow

Visit a GraphQL AST node tree recursively in depth-first order with a given visitor. Read more