Struct beancount_parser::Transaction
source · #[non_exhaustive]pub struct Transaction<D> {
pub flag: Option<char>,
pub payee: Option<String>,
pub narration: Option<String>,
pub tags: HashSet<Tag>,
pub links: HashSet<Link>,
pub postings: Vec<Posting<D>>,
}
Expand description
A transaction
It notably contains a list of Posting
§Example
let input = r#"
2022-05-22 * "Grocery store" "Grocery shopping" #food
Assets:Cash -10 CHF
Expenses:Groceries
"#;
let beancount: BeancountFile<f64> = input.parse().unwrap();
let DirectiveContent::Transaction(trx) = &beancount.directives[0].content else {
unreachable!("was not a transaction")
};
assert_eq!(trx.flag, Some('*'));
assert_eq!(trx.payee.as_deref(), Some("Grocery store"));
assert_eq!(trx.narration.as_deref(), Some("Grocery shopping"));
assert!(trx.tags.contains("food"));
assert_eq!(trx.postings.len(), 2);
Fields (Non-exhaustive)§
This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional
Struct { .. }
syntax; cannot be matched against without a wildcard ..
; and struct update syntax will not work.flag: Option<char>
Transaction flag (*
or !
or None
when using the txn
keyword)
payee: Option<String>
Payee (if present)
narration: Option<String>
Narration (if present)
Set of tags
links: HashSet<Link>
Set of links
postings: Vec<Posting<D>>
Postings
Trait Implementations§
source§impl<D: Clone> Clone for Transaction<D>
impl<D: Clone> Clone for Transaction<D>
source§fn clone(&self) -> Transaction<D>
fn clone(&self) -> Transaction<D>
Returns a copy 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<D: Debug> Debug for Transaction<D>
impl<D: Debug> Debug for Transaction<D>
source§impl<D: PartialEq> PartialEq for Transaction<D>
impl<D: PartialEq> PartialEq for Transaction<D>
source§fn eq(&self, other: &Transaction<D>) -> bool
fn eq(&self, other: &Transaction<D>) -> bool
This method tests for
self
and other
values to be equal, and is used
by ==
.impl<D> StructuralPartialEq for Transaction<D>
Auto Trait Implementations§
impl<D> Freeze for Transaction<D>
impl<D> RefUnwindSafe for Transaction<D>where
D: RefUnwindSafe,
impl<D> Send for Transaction<D>where
D: Send,
impl<D> Sync for Transaction<D>where
D: Sync,
impl<D> Unpin for Transaction<D>where
D: Unpin,
impl<D> UnwindSafe for Transaction<D>where
D: UnwindSafe,
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