Skip to main content

StyleRegistry

Struct StyleRegistry 

Source
pub struct StyleRegistry {
    pub version: String,
    pub styles: Vec<RegistryEntry>,
}
Expand description

A registry of citation styles with alias resolution.

Fields§

§version: String

Version identifier for the registry format.

§styles: Vec<RegistryEntry>

List of style entries in the registry.

Implementations§

Source§

impl StyleRegistry

Source

pub fn resolve(&self, name: &str) -> Option<&RegistryEntry>

Resolve a name or alias to the matching registry entry.

Checks id first, then searches aliases.

Source

pub fn all_ids(&self) -> impl Iterator<Item = &str>

All canonical style IDs in the registry.

Source

pub fn merge_over(&self, base: &StyleRegistry) -> StyleRegistry

Merge another registry over self (self wins on ID conflict).

Entries from base are included first. If an entry in self has the same ID as one in base, the entry from self replaces it. New entries from self are appended.

Source

pub fn from_slices(names: &[&str], aliases: &[(&str, &str)]) -> StyleRegistry

Build a registry from embedded style name and alias slices.

Used to construct the default registry from hardcoded embedded data.

Source

pub fn load_default() -> StyleRegistry

Load the embedded default registry from the compiled-in YAML data.

§Panics

Panics only if the embedded YAML is malformed (should never happen in a correctly built binary).

Source

pub fn load_from_file(path: &Path) -> Result<StyleRegistry, Box<dyn Error>>

Load a registry from a YAML file on disk.

§Errors

Returns an error if the file cannot be read or if the YAML cannot be parsed. Also returns an error if any entry does not have exactly one of builtin, path, or url.

Source

pub fn validate_sources(&self) -> Result<(), Box<dyn Error>>

Validate that each entry declares exactly one loadable style source.

§Errors

Returns an error if any entry has no source or multiple sources.

Trait Implementations§

Source§

impl Clone for StyleRegistry

Source§

fn clone(&self) -> StyleRegistry

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 StyleRegistry

Source§

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

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

impl<'de> Deserialize<'de> for StyleRegistry

Source§

fn deserialize<__D>( __deserializer: __D, ) -> Result<StyleRegistry, <__D as Deserializer<'de>>::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Serialize for StyleRegistry

Source§

fn serialize<__S>( &self, __serializer: __S, ) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. 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> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

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> Same for T

Source§

type Output = T

Should always be Self
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.