Skip to main content

CreateBuilder

Struct CreateBuilder 

Source
pub struct CreateBuilder { /* private fields */ }
Expand description

Build a create mutation. Writes a new .md file under folder with name name (the .md extension is appended automatically).

Frontmatter is composed in three layers, in order of precedence:

  1. Template — if template(path) is set, the template’s frontmatter is parsed as the base. Template body is preserved.
  2. --set overrides — anything set via set() overrides matching template fields.
  3. Schema defaults — when with_schema(schema) is supplied, every default: / default_expr: whose field isn’t already set by the template or --set is applied.

After composition, schema’s required: list is checked. Missing required fields surface as MutationErrors in the report, with the file NOT written.

Implementations§

Source§

impl CreateBuilder

Source

pub fn new(folder: impl Into<String>, name: impl Into<String>) -> Self

Source

pub fn template(self, path: impl Into<String>) -> Self

Path to a template file, relative to the vault root. The template’s frontmatter forms the base of the new note; its body is preserved.

Source

pub fn set(self, field: impl Into<String>, value: Value) -> Self

Set (or override) a frontmatter field. Layered on top of the template; layered under schema defaults.

Source

pub fn with_schema(self, schema: CollectionSchema) -> Self

Attach the collection schema for this folder. When set: default: / default_expr: fields are applied for any field the user didn’t supply, and required: is enforced before writing.

Source

pub fn write_options(self, opts: WriteOptions) -> Self

Source

pub fn fsync(self, yes: bool) -> Self

Source

pub fn plan(&self, vault: &Vault) -> Result<MutationReport>

Compute the planned change without writing.

Source

pub fn plan_with_content( &self, vault: &Vault, ) -> Result<(MutationReport, Option<String>)>

Plan and also return the file content that would be written. Used by the CLI’s --dry-run for create — the post-defaults frontmatter is the value of the preview.

Source

pub fn execute(self, vault: &Vault) -> Result<MutationReport>

Plan, then write the file atomically. Holds the vault-scoped lock so concurrent creates against the same vault serialise cleanly.

Trait Implementations§

Source§

impl Clone for CreateBuilder

Source§

fn clone(&self) -> CreateBuilder

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for CreateBuilder

Source§

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

Formats the value using the given formatter. 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, 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> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more