diff options
Diffstat (limited to 'src/journal.cc')
-rw-r--r-- | src/journal.cc | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/src/journal.cc b/src/journal.cc index 55c89dd9..37eacdaf 100644 --- a/src/journal.cc +++ b/src/journal.cc @@ -122,14 +122,21 @@ account_t * journal_t::register_account(const string& name, post_t * post, { account_t * result = NULL; + // If there any account aliases, substitute before creating an account + // object. if (account_aliases.size() > 0) { accounts_map::const_iterator i = account_aliases.find(name); if (i != account_aliases.end()) result = (*i).second; } + + // Create the account object and associate it with the journal; this + // is registering the account. if (! result) result = master_account->find_account(name); + // If the account name being registered is "Unknown", check whether + // the payee indicates an account that should be used. if (result->name == _("Unknown")) { foreach (account_mapping_t& value, payees_for_unknown_accounts) { if (value.first.match(post->xact->payee)) { @@ -139,6 +146,8 @@ account_t * journal_t::register_account(const string& name, post_t * post, } } + // Now that we have an account, make certain that the account is + // "known", if the user has requested validation of that fact. if (checking_style == CHECK_WARNING || checking_style == CHECK_ERROR) { if (! result->has_flags(ACCOUNT_KNOWN)) { if (! post) { @@ -313,10 +322,12 @@ bool journal_t::add_xact(xact_t * xact) } extend_xact(xact); - check_all_metadata(*this, xact); - foreach (post_t * post, xact->posts) + + foreach (post_t * post, xact->posts) { + extend_post(*post, *this); check_all_metadata(*this, post); + } // If a transaction with this UUID has already been seen, simply do // not add this one to the journal. However, all automated checks |