Skip to content

Commit

Permalink
[account.cpp] (maybe) use HashTable for splits
Browse files Browse the repository at this point in the history
reduces xml loading time from 3.5s to 3.1s, i.e. 11% improvement
  • Loading branch information
christopherlam committed May 12, 2024
1 parent b28ca9b commit 19a9004
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 5 deletions.
12 changes: 7 additions & 5 deletions libgnucash/engine/Account.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -333,6 +333,7 @@ gnc_account_init(Account* acc)
priv->include_sub_account_balances = {};

new (&priv->splits) SplitsVec ();
priv->splits_hash = g_hash_table_new (g_direct_hash, g_direct_equal);
priv->sort_dirty = FALSE;
}

Expand Down Expand Up @@ -1470,6 +1471,7 @@ xaccFreeAccount (Account *acc)
priv->balance_dirty = FALSE;
priv->sort_dirty = FALSE;
priv->splits.~SplitsVec();
g_hash_table_destroy (priv->splits_hash);

/* qof_instance_release (&acc->inst); */
g_object_unref(acc);
Expand Down Expand Up @@ -1556,6 +1558,7 @@ xaccAccountCommitEdit (Account *acc)
else
{
priv->splits.clear();
g_hash_table_remove_all (priv->splits_hash);
}

/* It turns out there's a case where this assertion does not hold:
Expand Down Expand Up @@ -1966,8 +1969,8 @@ gnc_account_insert_split (Account *acc, Split *s)
g_return_val_if_fail(GNC_IS_SPLIT(s), FALSE);

priv = GET_PRIVATE(acc);
if (std::find (priv->splits.begin(), priv->splits.end(), s) != priv->splits.end())
return FALSE;
if (!g_hash_table_add (priv->splits_hash, s))
return false;

priv->splits.push_back (s);

Expand Down Expand Up @@ -1997,10 +2000,9 @@ gnc_account_remove_split (Account *acc, Split *s)

priv = GET_PRIVATE(acc);

if (!g_hash_table_remove (priv->splits_hash, s))
return false;
auto it = std::remove (priv->splits.begin(), priv->splits.end(), s);
if (it == priv->splits.end())
return FALSE;

priv->splits.erase (it, priv->splits.end());
//FIXME: find better event type
qof_event_gen(&acc->inst, QOF_EVENT_MODIFY, nullptr);
Expand Down
1 change: 1 addition & 0 deletions libgnucash/engine/AccountP.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -120,6 +120,7 @@ typedef struct AccountPrivate
gboolean balance_dirty; /* balances in splits incorrect */

std::vector<Split*> splits; /* list of split pointers */
GHashTable* splits_hash;
gboolean sort_dirty; /* sort order of splits is bad */

LotList *lots; /* list of lot pointers */
Expand Down

0 comments on commit 19a9004

Please sign in to comment.