summaryrefslogtreecommitdiff
path: root/src/journal.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/journal.cc')
-rw-r--r--src/journal.cc15
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