pub struct DirectiveWrapper {
pub directive_type: String,
pub date: String,
pub filename: Option<String>,
pub lineno: Option<u32>,
pub data: DirectiveData,
}Expand description
A wrapper around directives for serialization.
This wrapper exists because Directive contains types that need
special serialization handling (like Decimal and NaiveDate).
Fields§
§directive_type: StringThe type of directive (derived from data, not serialized to avoid duplicate keys).
date: StringThe directive date (YYYY-MM-DD).
filename: Option<String>Source filename (for tracking through plugin processing). If None, the directive was created by a plugin.
lineno: Option<u32>Source line number (1-based). If None, the directive was created by a plugin.
data: DirectiveDataDirective-specific data as a nested structure.
Implementations§
Source§impl DirectiveWrapper
impl DirectiveWrapper
Sourcepub const fn type_sort_order(&self) -> i8
pub const fn type_sort_order(&self) -> i8
Returns the sort order for directive types, matching Python beancount’s SORT_ORDER.
Order ensures logical processing:
- Open (-2): Accounts must be opened first
- Balance (-1): Balance assertions checked before transactions
- Default (0): Transactions, Commodity, Pad, Event, Note, Price, Query, Custom
- Document (1): Documents recorded after transactions
- Close (2): Accounts closed last
Trait Implementations§
Source§impl Clone for DirectiveWrapper
impl Clone for DirectiveWrapper
Source§fn clone(&self) -> DirectiveWrapper
fn clone(&self) -> DirectiveWrapper
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for DirectiveWrapper
impl Debug for DirectiveWrapper
Source§impl<'de> Deserialize<'de> for DirectiveWrapper
impl<'de> Deserialize<'de> for DirectiveWrapper
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Auto Trait Implementations§
impl Freeze for DirectiveWrapper
impl RefUnwindSafe for DirectiveWrapper
impl Send for DirectiveWrapper
impl Sync for DirectiveWrapper
impl Unpin for DirectiveWrapper
impl UnwindSafe for DirectiveWrapper
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out indicating that a T is niched.