Skip to main content

Repository

Struct Repository 

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

A repository of Architecture Decision Records.

Implementations§

Source§

impl Repository

Source

pub fn open(root: impl Into<PathBuf>) -> Result<Self>

Open an existing repository at the given root.

Source

pub fn open_or_default(root: impl Into<PathBuf>) -> Self

Open a repository, or create default config if not found.

Source

pub fn init( root: impl Into<PathBuf>, adr_dir: Option<PathBuf>, ng: bool, ) -> Result<Self>

Initialize a new repository at the given root.

Source

pub fn root(&self) -> &Path

Get the repository root path.

Source

pub fn config(&self) -> &Config

Get the configuration.

Source

pub fn adr_path(&self) -> PathBuf

Get the full path to the ADR directory.

Source

pub fn with_template_format(self, format: TemplateFormat) -> Self

Set the template format.

Source

pub fn with_template_variant(self, variant: TemplateVariant) -> Self

Set the template variant.

Source

pub fn with_mode(self, mode: ConfigMode) -> Self

Override the configuration mode.

Source

pub fn with_custom_template(self, template: Template) -> Self

Set a custom template.

Source

pub fn list(&self) -> Result<Vec<Adr>>

List all ADRs in the repository.

Source

pub fn list_with_errors(&self) -> Result<(Vec<Adr>, Vec<(PathBuf, Error)>)>

List all ADRs, also returning parse errors for files that look like ADRs but failed to parse.

This is used by the doctor command to report files that could not be parsed (e.g., invalid frontmatter).

Source

pub fn next_number(&self) -> Result<u32>

Get the next available ADR number.

Source

pub fn get(&self, number: u32) -> Result<Adr>

Find an ADR by number.

Source

pub fn find(&self, query: &str) -> Result<Adr>

Find an ADR by query (number or fuzzy title match).

Source

pub fn create(&self, adr: &Adr) -> Result<PathBuf>

Create a new ADR.

Source

pub fn new_adr(&self, title: impl Into<String>) -> Result<(Adr, PathBuf)>

Create a new ADR with the given title.

Source

pub fn supersede( &self, title: impl Into<String>, superseded: u32, ) -> Result<(Adr, PathBuf)>

Create a new ADR that supersedes another.

Source

pub fn set_status( &self, number: u32, status: AdrStatus, superseded_by: Option<u32>, ) -> Result<PathBuf>

Change the status of an ADR.

If the new status is Superseded and superseded_by is provided, a superseded-by link will be added automatically.

Link two ADRs together.

Source

pub fn update(&self, adr: &Adr) -> Result<PathBuf>

Update an existing ADR.

Source

pub fn read_content(&self, adr: &Adr) -> Result<String>

Read the content of an ADR file.

Source

pub fn write_content(&self, adr: &Adr, content: &str) -> Result<PathBuf>

Write content to an ADR file.

Source

pub fn update_metadata(&self, adr: &Adr) -> Result<PathBuf>

Update only the metadata (status, links, tags) of an existing ADR file, preserving all other content byte-for-byte.

Trait Implementations§

Source§

impl Debug for Repository

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