jsonc_parser::cst

Struct CstRootNode

Source
pub struct CstRootNode(/* private fields */);
Expand description

Root node in the file.

The root node contains one value, whitespace, and comments.

Implementations§

Source§

impl CstRootNode

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 children(&self) -> Vec<CstNode>

Children of the current 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>

Gets the child at the specified index.

Source§

impl CstRootNode

Source

pub fn parse( text: &str, parse_options: &ParseOptions, ) -> Result<Self, ParseError>

Parses the text into a CST.

WARNING: You MUST not drop the root node for the duration of using the CST or a panic could occur in certain scenarios. This is because the CST uses weak references for ancestors and if the root node is dropped then the weak reference will be lost and the CST will panic to prevent bugs when a descendant node attempts to access an ancestor that was dropped.

use jsonc_parser::cst::CstRootNode;
use jsonc_parser::ParseOptions;
use jsonc_parser::json;

let json_text = r#"{
  // comment
  "data": 123
}"#;

let root = CstRootNode::parse(json_text, &ParseOptions::default()).unwrap();
let root_obj = root.object_value_or_set();

root_obj.get("data").unwrap().set_value(json!({
  "nested": true
}));
root_obj.append("new_key", json!([456, 789, false]));

assert_eq!(root.to_string(), r#"{
  // comment
  "data": {
    "nested": true
  },
  "new_key": [456, 789, false]
}"#);
Source

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

Computes the single indentation text of the file.

Source

pub fn newline_kind(&self) -> CstNewlineKind

Newline kind used within the JSON text.

Source

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

Gets the root value found in the file.

Source

pub fn set_value(&self, root_value: CstInputValue)

Sets potentially replacing the root value found in the JSON document.

Source

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

Gets the root value if its an object.

Source

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

Gets or creates the root value as an object, returns Some if successful or None if the root value already exists and is not an object.

Note: Use .object_value_or_set() to overwrite the root value when it’s not an object.

Source

pub fn object_value_or_set(&self) -> CstObject

Gets the root value if it’s an object or sets the root value as an object.

Note: Use .object_value_or_create() to not overwrite the root value when it’s not an object.

Source

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

Gets the value if its an array.

Source

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

Gets or creates the root value as an object, returns Some if successful or None if the root value already exists and is not an object.

Note: Use .array_value_or_set() to overwrite the root value when it’s not an array.

Source

pub fn array_value_or_set(&self) -> CstArray

Gets the root value if it’s an object or sets the root value as an object.

Note: Use .array_value_or_create() to not overwrite the root value when it’s not an object.

Source

pub fn set_trailing_commas(&self, mode: TrailingCommaMode)

Ensures this object’s values use trailing commas.

Note: This does not cause future values to use trailing commas. That will always be determined based on whether the file uses trailing commas or not, so it’s probably best to do this last.

Source

pub fn clear_children(&self)

Clears all the children from the root node making it empty.

Trait Implementations§

Source§

impl Clone for CstRootNode

Source§

fn clone(&self) -> CstRootNode

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 CstRootNode

Source§

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

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

impl Display for CstRootNode

Source§

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

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

impl From<CstRootNode> for CstContainerNode

Source§

fn from(value: CstRootNode) -> 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.

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, 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.