jsonc_parser::cst

Enum CstNode

Source
pub enum CstNode {
    Container(CstContainerNode),
    Leaf(CstLeafNode),
}
Expand description

All the different kinds of nodes that can appear in the CST.

Variants§

Implementations§

Source§

impl CstNode

Source

pub fn parent(&self) -> Option<CstContainerNode>

Parent of the node.

Returns None if this node has become disconnected from the tree by being removed.

Source

pub fn ancestors(&self) -> impl Iterator<Item = CstContainerNode>

An iterator of ancestors of this node.

Source

pub fn child_index(&self) -> usize

Current child index of the node within the children of the parent node.

Source

pub fn previous_sibling(&self) -> Option<CstNode>

Node that comes before this one that shares the same parent.

Source

pub fn previous_siblings(&self) -> impl Iterator<Item = CstNode>

Siblings coming before this node. This does not include cousins.

Source

pub fn next_sibling(&self) -> Option<CstNode>

Node that comes after this one that shares the same parent.

Source

pub fn next_siblings(&self) -> impl Iterator<Item = CstNode>

Siblings coming after this node. This does not include cousins.

Source

pub fn indent_text(&self) -> Option<String>

Returns the indentation text if it can be determined.

Source

pub fn trailing_comma(&self) -> Option<CstToken>

Gets the trailing comma token of the node, if it exists.

Source

pub fn uses_trailing_commas(&self) -> bool

Infers if the node or appropriate ancestor uses trailing commas.

Source

pub fn root_node(&self) -> Option<CstRootNode>

Gets the root node.

Returns None if this node has become disconnected from the tree by being removed.

Source

pub fn is_trivia(&self) -> bool

Gets if this node is comments, whitespace, newlines, or a non-literal token (ex. brace, colon).

Source

pub fn leading_comments_same_line(&self) -> impl Iterator<Item = CstComment>

Comments that become before this one on the same line.

Source

pub fn trailing_comments_same_line(&self) -> impl Iterator<Item = CstComment>

Comments that come after this one on the same line.

Only returns owned trailing comments on the same line and not if owned by the next node.

Source

pub fn is_newline(&self) -> bool

If this node is a newline.

Source

pub fn is_comma(&self) -> bool

If this node is a comma.

Source

pub fn is_comment(&self) -> bool

If this node is a comment.

Source

pub fn is_token(&self) -> bool

If this node is a token.

Source

pub fn is_whitespace(&self) -> bool

If this node is whitespace.

Source

pub fn token_char(&self) -> Option<char>

Token char of the node if it’s a token.

Source

pub fn children(&self) -> Vec<CstNode>

Children of this node.

Source

pub fn children_exclude_trivia_and_tokens(&self) -> Vec<CstNode>

Children of the current node excluding comments, whitespace, newlines, and tokens.

Source

pub fn child_at_index(&self, index: usize) -> Option<CstNode>

Child at the specified index.

Source

pub fn element_index(&self) -> Option<usize>

Gets the array element index of this node if its parent is an array.

Returns None when the parent is not an array.

Source

pub fn as_root_node(&self) -> Option<CstRootNode>

Node if it’s the root node.

Source

pub fn as_object(&self) -> Option<CstObject>

Node if it’s an object.

Source

pub fn as_array(&self) -> Option<CstArray>

Node if it’s an array.

Source

pub fn as_object_prop(&self) -> Option<CstObjectProp>

Node if it’s an object property.

Source

pub fn as_boolean_lit(&self) -> Option<CstBooleanLit>

Node if it’s a boolean literal.

Source

pub fn as_null_keyword(&self) -> Option<CstNullKeyword>

Node if it’s a null keyword.

Source

pub fn as_number_lit(&self) -> Option<CstNumberLit>

Node if it’s a number literal.

Source

pub fn as_string_lit(&self) -> Option<CstStringLit>

Node if it’s a string literal.

Source

pub fn as_word_lit(&self) -> Option<CstWordLit>

Node if it’s a word literal.

Source

pub fn as_token(&self) -> Option<CstToken>

Node if it’s a token.

Source

pub fn as_newline(&self) -> Option<CstNewline>

Node if it’s a newline.

Source

pub fn as_whitespace(&self) -> Option<CstWhitespace>

Node if it’s whitespace.

Source

pub fn as_comment(&self) -> Option<CstComment>

Node if it’s a comment.

Source

pub fn remove(self)

Removes the node from the JSON.

Note: Removing certain nodes may cause syntax errors.

Trait Implementations§

Source§

impl Clone for CstNode

Source§

fn clone(&self) -> CstNode

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 Debug for CstNode

Source§

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

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

impl Display for CstNode

Source§

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

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

impl From<CstArray> for CstNode

Source§

fn from(value: CstArray) -> Self

Converts to this type from the input type.
Source§

impl From<CstBooleanLit> for CstNode

Source§

fn from(value: CstBooleanLit) -> Self

Converts to this type from the input type.
Source§

impl From<CstComment> for CstNode

Source§

fn from(value: CstComment) -> Self

Converts to this type from the input type.
Source§

impl From<CstContainerNode> for CstNode

Source§

fn from(value: CstContainerNode) -> Self

Converts to this type from the input type.
Source§

impl From<CstLeafNode> for CstNode

Source§

fn from(value: CstLeafNode) -> Self

Converts to this type from the input type.
Source§

impl From<CstNewline> for CstNode

Source§

fn from(value: CstNewline) -> Self

Converts to this type from the input type.
Source§

impl From<CstNullKeyword> for CstNode

Source§

fn from(value: CstNullKeyword) -> Self

Converts to this type from the input type.
Source§

impl From<CstNumberLit> for CstNode

Source§

fn from(value: CstNumberLit) -> Self

Converts to this type from the input type.
Source§

impl From<CstObject> for CstNode

Source§

fn from(value: CstObject) -> Self

Converts to this type from the input type.
Source§

impl From<CstObjectProp> for CstNode

Source§

fn from(value: CstObjectProp) -> Self

Converts to this type from the input type.
Source§

impl From<CstRootNode> for CstNode

Source§

fn from(value: CstRootNode) -> Self

Converts to this type from the input type.
Source§

impl From<CstStringLit> for CstNode

Source§

fn from(value: CstStringLit) -> Self

Converts to this type from the input type.
Source§

impl From<CstToken> for CstNode

Source§

fn from(value: CstToken) -> Self

Converts to this type from the input type.
Source§

impl From<CstWhitespace> for CstNode

Source§

fn from(value: CstWhitespace) -> Self

Converts to this type from the input type.
Source§

impl From<CstWordLit> for CstNode

Source§

fn from(value: CstWordLit) -> Self

Converts to this type from the input type.
Source§

impl From<ObjectPropName> for CstNode

Source§

fn from(value: ObjectPropName) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

§

impl Freeze for CstNode

§

impl !RefUnwindSafe for CstNode

§

impl !Send for CstNode

§

impl !Sync for CstNode

§

impl Unpin for CstNode

§

impl !UnwindSafe for CstNode

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, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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> ToString for T
where T: Display + ?Sized,

Source§

default fn to_string(&self) -> String

Converts the given value to a String. 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.