Quill

Struct Quill 

Source
pub struct Quill {
    pub metadata: HashMap<String, QuillValue>,
    pub name: String,
    pub backend: String,
    pub glue: Option<String>,
    pub example: Option<String>,
    pub schema: QuillValue,
    pub defaults: HashMap<String, QuillValue>,
    pub examples: HashMap<String, Vec<QuillValue>>,
    pub files: FileTreeNode,
}
Expand description

A quill template bundle.

Fields§

§metadata: HashMap<String, QuillValue>

Quill-specific metadata

§name: String

Name of the quill

§backend: String

Backend identifier (e.g., “typst”)

§glue: Option<String>

Glue template content (optional)

§example: Option<String>

Markdown template content (optional)

§schema: QuillValue

Field JSON schema (single source of truth for schema and defaults)

§defaults: HashMap<String, QuillValue>

Cached default values extracted from schema (for performance)

§examples: HashMap<String, Vec<QuillValue>>

Cached example values extracted from schema (for performance)

§files: FileTreeNode

In-memory file system (tree structure)

Implementations§

Source§

impl Quill

Source

pub fn from_path<P: AsRef<Path>>( path: P, ) -> Result<Self, Box<dyn StdError + Send + Sync>>

Create a Quill from a directory path

Source

pub fn from_tree( root: FileTreeNode, _default_name: Option<String>, ) -> Result<Self, Box<dyn StdError + Send + Sync>>

Create a Quill from a tree structure

This is the authoritative method for creating a Quill from an in-memory file tree.

§Arguments
  • root - The root node of the file tree
  • _default_name - Unused parameter kept for API compatibility (name always from Quill.toml)
§Errors

Returns an error if:

  • Quill.toml is not found in the file tree
  • Quill.toml is not valid UTF-8 or TOML
  • The glue file specified in Quill.toml is not found or not valid UTF-8
  • Validation fails
Source

pub fn from_json( json_str: &str, ) -> Result<Self, Box<dyn StdError + Send + Sync>>

Create a Quill from a JSON representation

Parses a JSON string into an in-memory file tree and validates it. The precise JSON contract is documented in designs/QUILL_DESIGN.md. The JSON format MUST have a root object with a files key. The optional metadata key provides additional metadata that overrides defaults.

Source

pub fn typst_packages(&self) -> Vec<String>

Get the list of typst packages to download, if specified in Quill.toml

Source

pub fn extract_defaults(&self) -> &HashMap<String, QuillValue>

Get default values from the cached schema defaults

Returns a reference to the pre-computed defaults HashMap that was extracted during Quill construction. This is more efficient than re-parsing the schema.

This is used by ParsedDocument::with_defaults() to apply default values to missing fields.

Source

pub fn extract_examples(&self) -> &HashMap<String, Vec<QuillValue>>

Get example values from the cached schema examples

Returns a reference to the pre-computed examples HashMap that was extracted during Quill construction. This is more efficient than re-parsing the schema.

Source

pub fn get_file<P: AsRef<Path>>(&self, path: P) -> Option<&[u8]>

Get file contents by path (relative to quill root)

Source

pub fn file_exists<P: AsRef<Path>>(&self, path: P) -> bool

Check if a file exists in memory

Source

pub fn dir_exists<P: AsRef<Path>>(&self, path: P) -> bool

Check if a directory exists in memory

Source

pub fn list_files<P: AsRef<Path>>(&self, path: P) -> Vec<String>

List files in a directory (non-recursive, returns file names only)

Source

pub fn list_subdirectories<P: AsRef<Path>>(&self, path: P) -> Vec<String>

List subdirectories in a directory (non-recursive, returns directory names only)

Source

pub fn list_directory<P: AsRef<Path>>(&self, dir_path: P) -> Vec<PathBuf>

List all files in a directory (returns paths relative to quill root)

Source

pub fn list_directories<P: AsRef<Path>>(&self, dir_path: P) -> Vec<PathBuf>

List all directories in a directory (returns paths relative to quill root)

Source

pub fn find_files<P: AsRef<Path>>(&self, pattern: P) -> Vec<PathBuf>

Get all files matching a pattern (supports glob-style wildcards)

Trait Implementations§

Source§

impl Clone for Quill

Source§

fn clone(&self) -> Quill

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

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl Freeze for Quill

§

impl RefUnwindSafe for Quill

§

impl Send for Quill

§

impl Sync for Quill

§

impl Unpin for Quill

§

impl UnwindSafe for Quill

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.
Source§

impl<T> DynFilter for T
where T: Send + Sync + 'static,

Source§

impl<T> ErasedDestructor for T
where T: 'static,