Skip to content

Commit

Permalink
[import-match-picker.cpp] use GncTreeContainer and std::find_if
Browse files Browse the repository at this point in the history
  • Loading branch information
christopherlam committed Aug 20, 2023
1 parent 2f58894 commit 5a38017
Showing 1 changed file with 23 additions and 32 deletions.
55 changes: 23 additions & 32 deletions gnucash/import-export/import-match-picker.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -31,12 +31,15 @@
#include <gtk/gtk.h>
#include <glib/gi18n.h>

#include "gnc-tree-container.hpp"
#include "import-match-picker.h"
#include "qof.h"
#include "gnc-ui-util.h"
#include "dialog-utils.h"
#include "gnc-prefs.h"

#include <algorithm>

/********************************************************************\
* Constants *
\********************************************************************/
Expand Down Expand Up @@ -98,32 +101,22 @@ downloaded_transaction_append(GNCImportMatchPicker * matcher,
g_return_if_fail (matcher);
g_return_if_fail (transaction_info);

auto found = false;
auto store = GTK_LIST_STORE(gtk_tree_view_get_model(matcher->downloaded_view));
auto split = gnc_import_TransInfo_get_fsplit(transaction_info);
auto trans = gnc_import_TransInfo_get_trans(transaction_info);
GncTreeContainer container{GTK_TREE_MODEL(store)};

/* Has the transaction already been added? */
GtkTreeIter iter;
if (gtk_tree_model_get_iter_first(GTK_TREE_MODEL(store), &iter))
{
do
{
GNCImportTransInfo *local_info;
gtk_tree_model_get(GTK_TREE_MODEL(store), &iter,
DOWNLOADED_COL_INFO_PTR, &local_info,
-1);
if (local_info == transaction_info)
{
found = TRUE;
break;
}
}
while (gtk_tree_model_iter_next(GTK_TREE_MODEL(store), &iter));
}
if (!found)
gtk_list_store_append(store, &iter);
auto it_matches = [&transaction_info](auto it)
{ return it.template get<GNCImportTransInfo*>(DOWNLOADED_COL_INFO_PTR) == transaction_info; };

// find the GncTreeIter whose DOWNLOADED_COL_INFO_PTR matches transaction_info
auto iter = std::find_if (container.begin(), container.end(), it_matches);

// not found. append a new GtkTreeIter in container.
if (iter == container.end())
iter = container.append();

// now iter is a GncTreeIter; iter->get_iter() is the GtkTreeIter
auto account = xaccAccountGetName(xaccSplitGetAccount(split));
auto date = qof_print_date(xaccTransGetDate(trans));
auto amount = g_strdup (xaccPrintAmount(xaccSplitGetAmount(split), gnc_split_amount_print_info(split, TRUE)));
Expand All @@ -137,17 +130,15 @@ downloaded_transaction_append(GNCImportMatchPicker * matcher,
auto imbalance = g_strdup (xaccPrintAmount (xaccTransGetImbalanceValue(trans),
gnc_commodity_print_info (xaccTransGetCurrency (trans), TRUE)));

gtk_list_store_set (store, &iter,
DOWNLOADED_COL_ACCOUNT, account,
DOWNLOADED_COL_DATE, date,
DOWNLOADED_COL_AMOUNT, amount,
DOWNLOADED_COL_DESCRIPTION, desc,
DOWNLOADED_COL_MEMO, memo,
DOWNLOADED_COL_BALANCED, imbalance,
DOWNLOADED_COL_INFO_PTR, transaction_info,
-1);

gtk_tree_selection_select_iter (gtk_tree_view_get_selection(matcher->downloaded_view), &iter);
iter->set_column (DOWNLOADED_COL_ACCOUNT, account);
iter->set_column (DOWNLOADED_COL_DATE, date);
iter->set_column (DOWNLOADED_COL_AMOUNT, amount);
iter->set_column (DOWNLOADED_COL_DESCRIPTION, desc);
iter->set_column (DOWNLOADED_COL_MEMO, memo);
iter->set_column (DOWNLOADED_COL_BALANCED, imbalance);
iter->set_column (DOWNLOADED_COL_INFO_PTR, transaction_info);

gtk_tree_selection_select_iter (gtk_tree_view_get_selection(matcher->downloaded_view), &iter->get_iter());

g_free (date);
g_free (amount);
Expand Down

0 comments on commit 5a38017

Please sign in to comment.