Skip to main content

StringValue

Struct StringValue 

Source
pub struct StringValue<'src> {
    pub is_block: bool,
    pub span: ByteSpan,
    pub syntax: Option<Box<StringValueSyntax<'src>>>,
    pub value: Cow<'src, str>,
}
Expand description

A GraphQL string value.

Per the String Value section of the spec, string values may be quoted strings or block strings. This struct contains the processed string after escape-sequence resolution and block-string indentation stripping. Borrows from source when no transformation was needed; owned when escapes were resolved or block-string stripping produced a non-contiguous result.

Fields§

§is_block: bool

Whether this string was written as a block string ("""...""") rather than a quoted string ("..."). Both forms produce the same semantic value after processing, but tools (formatters, schema differs) may need to preserve or inspect the original form.

§span: ByteSpan§syntax: Option<Box<StringValueSyntax<'src>>>§value: Cow<'src, str>

The processed string value after escape-sequence resolution and block-string indentation stripping.

Implementations§

Source§

impl StringValue<'_>

Source

pub fn append_source(&self, sink: &mut String, source: Option<&str>)

Source

pub fn byte_span(&self) -> ByteSpan

Returns this string value’s byte-offset span within the source text.

The returned ByteSpan can be resolved to line/column positions via source_span() or ByteSpan::resolve().

Source

pub fn source_span(&self, source_map: &SourceMap<'_>) -> Option<SourceSpan>

Resolves this string value’s position to line/column coordinates using the given SourceMap.

Returns None if the byte offsets cannot be resolved (e.g. the span was synthetically constructed without valid position data).

Trait Implementations§

Source§

impl AstNode for StringValue<'_>

Source§

fn append_source(&self, sink: &mut String, source: Option<&str>)

Source§

fn byte_span(&self) -> ByteSpan

Returns this string value’s byte-offset span within the source text.

The returned ByteSpan can be resolved to line/column positions via source_span() or ByteSpan::resolve().

Source§

fn source_span(&self, source_map: &SourceMap<'_>) -> Option<SourceSpan>

Resolves this string value’s position to line/column coordinates using the given SourceMap.

Returns None if the byte offsets cannot be resolved (e.g. the span was synthetically constructed without valid position data).

Source§

fn to_source(&self, source: Option<&str>) -> String

Return this node as a source string. Read more
Source§

impl<'src> Clone for StringValue<'src>

Source§

fn clone(&self) -> StringValue<'src>

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<'src> Debug for StringValue<'src>

Source§

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

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

impl<'src> PartialEq for StringValue<'src>

Source§

fn eq(&self, other: &StringValue<'src>) -> 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<'src> StructuralPartialEq for StringValue<'src>

Auto Trait Implementations§

§

impl<'src> Freeze for StringValue<'src>

§

impl<'src> RefUnwindSafe for StringValue<'src>

§

impl<'src> Send for StringValue<'src>

§

impl<'src> Sync for StringValue<'src>

§

impl<'src> Unpin for StringValue<'src>

§

impl<'src> UnsafeUnpin for StringValue<'src>

§

impl<'src> UnwindSafe for StringValue<'src>

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.