Struct libyml::yaml::YamlDocumentT

source ·
#[non_exhaustive]
#[repr(C)]
pub struct YamlDocumentT { pub nodes: YamlStackT<YamlNodeT>, pub version_directive: *mut YamlVersionDirectiveT, pub tag_directives: UnnamedYamlDocumentTTagDirectives, pub start_implicit: bool, pub end_implicit: bool, pub start_mark: YamlMarkT, pub end_mark: YamlMarkT, }
Expand description

The document structure.

Fields (Non-exhaustive)§

This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.
§nodes: YamlStackT<YamlNodeT>

The document nodes.

§version_directive: *mut YamlVersionDirectiveT

The version directive.

§tag_directives: UnnamedYamlDocumentTTagDirectives

The list of tag directives.

§start_implicit: bool

Is the document start indicator implicit?

§end_implicit: bool

Is the document end indicator implicit?

§start_mark: YamlMarkT

The beginning of the document.

§end_mark: YamlMarkT

The end of the document.

Implementations§

source§

impl YamlDocumentT

source

pub unsafe fn cleanup(&mut self)

Cleans up resources used by YamlDocumentT. This includes deallocating memory for version directives, tag directives, and nodes if they were allocated dynamically.

§Safety

This function is unsafe because it assumes that all pointers (e.g., version_directive, tag directives, and nodes) are either valid or null. It will attempt to free allocated memory, so the caller must ensure that:

  1. The struct has been initialized properly.
  2. No other code retains pointers to the data being freed here.
  3. This method is not called concurrently with any operations that read from or write to the pointed-to data.
  4. The memory management strategy (allocation and deallocation) is correctly paired. For instance, if libc::malloc is used to allocate, libc::free should be used to deallocate.

Trait Implementations§

source§

impl Clone for YamlDocumentT

source§

fn clone(&self) -> YamlDocumentT

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 YamlDocumentT

source§

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

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

impl Default for YamlDocumentT

source§

fn default() -> Self

Returns the “default value” for a type. Read more

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,

§

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

§

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

§

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.