[Gnucash-changes] new, account-name quickfill utility
Linas Vepstas
linas at cvs.gnucash.org
Mon May 31 12:31:42 EDT 2004
Log Message:
-----------
new, account-name quickfill utility
Added Files:
-----------
gnucash/src/gnome-utils:
account-quickfill.h
Revision Data
-------------
--- /dev/null
+++ src/gnome-utils/account-quickfill.h
@@ -0,0 +1,75 @@
+/********************************************************************\
+ * account-quickfill.h -- Create an account-name quick-fill *
+ * *
+ * This program is free software; you can redistribute it and/or *
+ * modify it under the terms of the GNU General Public License as *
+ * published by the Free Software Foundation; either version 2 of *
+ * the License, or (at your option) any later version. *
+ * *
+ * This program is distributed in the hope that it will be useful, *
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of *
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
+ * GNU General Public License for more details. *
+ * *
+ * You should have received a copy of the GNU General Public License*
+ * along with this program; if not, contact: *
+ * *
+ * Free Software Foundation Voice: +1-617-542-5942 *
+ * 59 Temple Place - Suite 330 Fax: +1-617-542-2652 *
+ * Boston, MA 02111-1307, USA gnu at gnu.org *
+ * *
+\********************************************************************/
+/** @addtogroup Account_Quickfill Quickfill Account Names
+ For systems with a large number of accounts (>500), the creation
+ of the account name quickfill can take a significant amount of
+ time (tens of seconds in bad cases). This routine will build
+ a cache of account names that can be shared by all registers,
+ thus dramatically improving the performance of opening a new
+ register.
+ @{
+
+ @file account-quickfill.h
+ @brief Create an account-name quick-fill
+ @author Copyright (C) 2004 Linas Vepstas <linas at linas.org>
+*/
+
+#ifndef QUICKFILL_ACCOUNT_H
+#define QUICKFILL_ACCOUNT_H
+
+#include <glib.h>
+
+#include "Account.h"
+#include "Group.h"
+#include "QuickFill.h"
+
+typedef gboolean (*AccountBoolCB) (Account *, gpointer);
+
+/** Create/fetch a quickfill of account names.
+ *
+ * The quickfill is created out of all of the subaccounts
+ * the the account group, filtered by the 'skip_cb' callback.
+ * If 'skip_cb' is not NULL, and if it returns TRUE when passed
+ * a particular account, then that account won't be included in
+ * the quickfill. The 'cb_data' is passed to the callback.
+ *
+ * The quickfill is created only once; it is then stored with
+ * the QofBook that is the parent of the AccountGroup. It is
+ * automatically destroyed when the QofBook is destroyed.
+ *
+ * Multiple, distinct quickfills, for different uses, are allowed.
+ * Each is identified with the 'key'. Be sure to use distinct,
+ * unique keys that don't conflict with other users of QofBook.
+ *
+ * This code listens to account creation events, and automatically
+ * adds new accounts to the quickfill list (assuming skip_cb allows
+ * it). This code does not currently listen to account-destroy
+ * events.
+ */
+QuickFill * gnc_get_shared_account_name_quickfill (AccountGroup *group,
+ const char * key,
+ AccountBoolCB skip_cb,
+ gpointer cb_data);
+
+#endif
+
+/** @} */
More information about the gnucash-changes
mailing list