mirror of
https://github.com/Gnucash/gnucash.git
synced 2024-11-25 18:30:23 -06:00
Merge branch 'speed-up-book-close' into stable #1941
This commit is contained in:
commit
448e9ac255
@ -3070,6 +3070,12 @@ destroy_tx_on_book_close(QofInstance *ent, gpointer data)
|
||||
xaccTransDestroy(tx);
|
||||
}
|
||||
|
||||
static int
|
||||
trans_reverse_order (const Transaction* a, const Transaction* b)
|
||||
{
|
||||
return xaccTransOrder (b, a);
|
||||
}
|
||||
|
||||
/** Handles book end - frees all transactions from the book
|
||||
*
|
||||
* @param book Book being closed
|
||||
@ -3080,7 +3086,12 @@ gnc_transaction_book_end(QofBook* book)
|
||||
QofCollection *col;
|
||||
|
||||
col = qof_book_get_collection(book, GNC_ID_TRANS);
|
||||
qof_collection_foreach(col, destroy_tx_on_book_close, nullptr);
|
||||
|
||||
// destroy all transactions from latest to earliest, because
|
||||
// accounts' splits are stored chronologically and removing from
|
||||
// the end is faster than from the middle.
|
||||
qof_collection_foreach_sorted (col, destroy_tx_on_book_close, nullptr,
|
||||
(GCompareFunc)trans_reverse_order);
|
||||
}
|
||||
|
||||
#ifdef _MSC_VER
|
||||
|
@ -302,40 +302,30 @@ qof_collection_set_data (QofCollection *col, gpointer user_data)
|
||||
|
||||
/* =============================================================== */
|
||||
|
||||
struct _qofid_iterate
|
||||
void
|
||||
qof_collection_foreach_sorted (const QofCollection *col, QofInstanceForeachCB cb_func,
|
||||
gpointer user_data, GCompareFunc sort_fn)
|
||||
{
|
||||
QofInstanceForeachCB fcn;
|
||||
gpointer data;
|
||||
};
|
||||
GList *entries;
|
||||
|
||||
static void
|
||||
foreach_cb (gpointer item, gpointer arg)
|
||||
{
|
||||
struct _qofid_iterate *iter = static_cast<_qofid_iterate*>(arg);
|
||||
QofInstance *ent = static_cast<QofInstance*>(item);
|
||||
g_return_if_fail (col);
|
||||
g_return_if_fail (cb_func);
|
||||
|
||||
iter->fcn (ent, iter->data);
|
||||
PINFO("Hash Table size of %s before is %d", col->e_type, g_hash_table_size(col->hash_of_entities));
|
||||
|
||||
entries = g_hash_table_get_values (col->hash_of_entities);
|
||||
if (sort_fn)
|
||||
entries = g_list_sort (entries, sort_fn);
|
||||
g_list_foreach (entries, (GFunc)cb_func, user_data);
|
||||
g_list_free (entries);
|
||||
|
||||
PINFO("Hash Table size of %s after is %d", col->e_type, g_hash_table_size(col->hash_of_entities));
|
||||
}
|
||||
|
||||
void
|
||||
qof_collection_foreach (const QofCollection *col, QofInstanceForeachCB cb_func,
|
||||
gpointer user_data)
|
||||
{
|
||||
struct _qofid_iterate iter;
|
||||
GList *entries;
|
||||
|
||||
g_return_if_fail (col);
|
||||
g_return_if_fail (cb_func);
|
||||
|
||||
iter.fcn = cb_func;
|
||||
iter.data = user_data;
|
||||
|
||||
PINFO("Hash Table size of %s before is %d", col->e_type, g_hash_table_size(col->hash_of_entities));
|
||||
|
||||
entries = g_hash_table_get_values (col->hash_of_entities);
|
||||
g_list_foreach (entries, foreach_cb, &iter);
|
||||
g_list_free (entries);
|
||||
|
||||
PINFO("Hash Table size of %s after is %d", col->e_type, g_hash_table_size(col->hash_of_entities));
|
||||
qof_collection_foreach_sorted (col, cb_func, user_data, nullptr);
|
||||
}
|
||||
/* =============================================================== */
|
||||
|
@ -146,6 +146,9 @@ QofInstance * qof_collection_lookup_entity (const QofCollection *, const GncGUID
|
||||
typedef void (*QofInstanceForeachCB) (QofInstance *, gpointer user_data);
|
||||
|
||||
/** Call the callback for each entity in the collection. */
|
||||
void qof_collection_foreach_sorted (const QofCollection *col, QofInstanceForeachCB cb_func,
|
||||
gpointer user_data, GCompareFunc sort_fn);
|
||||
|
||||
void qof_collection_foreach (const QofCollection *, QofInstanceForeachCB,
|
||||
gpointer user_data);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user