pub struct Adr { /* private fields */ }
Expand description
An ADR (Architecture Decision Record) documents architectural decisions
Implementations§
Source§impl Adr
impl Adr
Sourcepub fn new(
number: u32,
title: String,
decision_maker: String,
decision_date: Option<DateTime<Utc>>,
parent_id: Option<DocumentId>,
tags: Vec<Tag>,
archived: bool,
) -> Result<Self, DocumentValidationError>
pub fn new( number: u32, title: String, decision_maker: String, decision_date: Option<DateTime<Utc>>, parent_id: Option<DocumentId>, tags: Vec<Tag>, archived: bool, ) -> Result<Self, DocumentValidationError>
Create a new ADR document with content rendered from template
Sourcepub fn from_parts(
number: u32,
title: String,
decision_maker: String,
decision_date: Option<DateTime<Utc>>,
metadata: DocumentMetadata,
content: DocumentContent,
parent_id: Option<DocumentId>,
tags: Vec<Tag>,
archived: bool,
) -> Self
pub fn from_parts( number: u32, title: String, decision_maker: String, decision_date: Option<DateTime<Utc>>, metadata: DocumentMetadata, content: DocumentContent, parent_id: Option<DocumentId>, tags: Vec<Tag>, archived: bool, ) -> Self
Create an ADR document from existing data (used when loading from file)
pub fn number(&self) -> u32
pub fn decision_maker(&self) -> &str
pub fn decision_date(&self) -> Option<DateTime<Utc>>
Sourcepub async fn from_file<P: AsRef<Path>>(
path: P,
) -> Result<Self, DocumentValidationError>
pub async fn from_file<P: AsRef<Path>>( path: P, ) -> Result<Self, DocumentValidationError>
Create an ADR document by reading and parsing a file
Sourcepub fn from_content(raw_content: &str) -> Result<Self, DocumentValidationError>
pub fn from_content(raw_content: &str) -> Result<Self, DocumentValidationError>
Create an ADR document from raw file content string
Sourcepub async fn to_file<P: AsRef<Path>>(
&self,
path: P,
) -> Result<(), DocumentValidationError>
pub async fn to_file<P: AsRef<Path>>( &self, path: P, ) -> Result<(), DocumentValidationError>
Write the ADR document to a file
Sourcepub fn to_content(&self) -> Result<String, DocumentValidationError>
pub fn to_content(&self) -> Result<String, DocumentValidationError>
Convert the ADR document to its markdown string representation using templates
Trait Implementations§
Source§impl Document for Adr
impl Document for Adr
Source§fn id(&self) -> DocumentId
fn id(&self) -> DocumentId
ADRs have special ID format: number-slug
Source§fn document_type(&self) -> DocumentType
fn document_type(&self) -> DocumentType
Get the document type
Source§fn metadata(&self) -> &DocumentMetadata
fn metadata(&self) -> &DocumentMetadata
Get the document metadata
Source§fn content(&self) -> &DocumentContent
fn content(&self) -> &DocumentContent
Get the document content
Source§fn core(&self) -> &DocumentCore
fn core(&self) -> &DocumentCore
Get access to the core document data
Source§fn can_transition_to(&self, phase: Phase) -> bool
fn can_transition_to(&self, phase: Phase) -> bool
Check if this document can transition to the given phase
Source§fn parent_id(&self) -> Option<&DocumentId>
fn parent_id(&self) -> Option<&DocumentId>
Get the parent document ID if this document has a parent
Source§fn blocked_by(&self) -> &[DocumentId]
fn blocked_by(&self) -> &[DocumentId]
Get IDs of documents that block this one
Source§fn validate(&self) -> Result<(), DocumentValidationError>
fn validate(&self) -> Result<(), DocumentValidationError>
Validate the document according to its type-specific rules
Source§fn exit_criteria_met(&self) -> bool
fn exit_criteria_met(&self) -> bool
Check if exit criteria are met
Source§fn template(&self) -> DocumentTemplate
fn template(&self) -> DocumentTemplate
Get the template for rendering this document type
Source§fn frontmatter_template(&self) -> &'static str
fn frontmatter_template(&self) -> &'static str
Get the frontmatter template for this document type
Source§fn content_template(&self) -> &'static str
fn content_template(&self) -> &'static str
Get the content template for this document type
Source§fn acceptance_criteria_template(&self) -> &'static str
fn acceptance_criteria_template(&self) -> &'static str
Get the acceptance criteria template for this document type
Source§fn transition_phase(
&mut self,
target_phase: Option<Phase>,
) -> Result<Phase, DocumentValidationError>
fn transition_phase( &mut self, target_phase: Option<Phase>, ) -> Result<Phase, DocumentValidationError>
Transition to the next phase in sequence, or to a specific phase if provided
Source§fn core_mut(&mut self) -> &mut DocumentCore
fn core_mut(&mut self) -> &mut DocumentCore
Get mutable access to the document core (needed for updates)
Get the document tags
Source§fn phase(&self) -> Result<Phase, DocumentValidationError>
fn phase(&self) -> Result<Phase, DocumentValidationError>
Get the current phase of the document (parsed from tags)
Source§fn update_section(
&mut self,
content: &str,
heading: &str,
append: bool,
) -> Result<(), DocumentValidationError>
fn update_section( &mut self, content: &str, heading: &str, append: bool, ) -> Result<(), DocumentValidationError>
Update a specific section (H2 heading) in the document content
Source§fn update_content_body(
&mut self,
new_body: String,
) -> Result<(), DocumentValidationError>
fn update_content_body( &mut self, new_body: String, ) -> Result<(), DocumentValidationError>
Helper method for update_section to actually mutate the content
Auto Trait Implementations§
impl Freeze for Adr
impl RefUnwindSafe for Adr
impl Send for Adr
impl Sync for Adr
impl Unpin for Adr
impl UnwindSafe for Adr
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> IntoSql for T
impl<T> IntoSql for T
Source§fn into_sql<T>(self) -> Self::Expression
fn into_sql<T>(self) -> Self::Expression
Convert
self
to an expression for Diesel’s query builder. Read moreSource§fn as_sql<'a, T>(&'a self) -> <&'a Self as AsExpression<T>>::Expression
fn as_sql<'a, T>(&'a self) -> <&'a Self as AsExpression<T>>::Expression
Convert
&self
to an expression for Diesel’s query builder. Read more