GnuCash  5.6-150-g038405b370+
gnc-sx-instance-model.h
Go to the documentation of this file.
1 /*
2  * gnc-sx-instance-model.h
3  *
4  * Copyright (C) 2006 Josh Sled <jsled@asynchronous.org>
5  *
6  * This program is free software; you can redistribute it and/or
7  * modify it under the terms of version 2 and/or version 3 of the GNU General Public
8  * License as published by the Free Software Foundation.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program; if not, contact:
17  *
18  * Free Software Foundation Voice: +1-617-542-5942
19  * 51 Franklin Street, Fifth Floor Fax: +1-617-542-2652
20  * Boston, MA 02110-1301, USA gnu@gnu.org
21  */
22 
26 #ifndef _GNC_SX_INSTANCE_MODEL_H
27 #define _GNC_SX_INSTANCE_MODEL_H
28 
29 #include <config.h>
30 #include <glib.h>
31 #include <glib-object.h>
32 #include "gnc-numeric.h"
33 #include "SchedXaction.h"
34 
35 G_BEGIN_DECLS
36 
37 #define GNC_TYPE_SX_INSTANCE_MODEL (gnc_sx_instance_model_get_type ())
38 G_DECLARE_FINAL_TYPE (GncSxInstanceModel, gnc_sx_instance_model, GNC, SX_INSTANCE_MODEL, GObject)
39 
40 typedef struct _GncSxInstances
41 {
42  SchedXaction *sx;
43  GHashTable *variable_names;
44  gboolean variable_names_parsed;
45 
46  GDate next_instance_date;
47 
49  GList *instance_list;
51 
52 typedef enum
53 {
54  SX_INSTANCE_STATE_IGNORED,
55  SX_INSTANCE_STATE_POSTPONED,
56  SX_INSTANCE_STATE_TO_CREATE,
57  SX_INSTANCE_STATE_REMINDER,
58  SX_INSTANCE_STATE_CREATED,
59  SX_INSTANCE_STATE_MAX_STATE
60 } GncSxInstanceState;
61 
62 typedef struct _GncSxVariable
63 {
64  gchar *name;
65  gnc_numeric value;
66  gboolean editable;
68 
69 typedef struct _GncSxInstance
70 {
73  GncSxInstanceState orig_state;
74  GncSxInstanceState state;
75  GDate date;
76  GHashTable *variable_bindings;
78 
79 typedef struct _GncSxVariableNeeded
80 {
81  GncSxInstance *instance;
82  GncSxVariable *variable;
84 
86 GncSxInstanceModel* gnc_sx_get_current_instances(void);
87 
94 GncSxInstanceModel* gnc_sx_get_instances(const GDate *range_end, gboolean include_disabled);
95 
102 void gnc_sx_instance_model_update_sx_instances(GncSxInstanceModel *model, SchedXaction *sx);
103 void gnc_sx_instance_model_remove_sx_instances(GncSxInstanceModel *model, SchedXaction *sx);
104 
110 void gnc_sx_scrub_split_numerics (gpointer psplit, gpointer user);
111 
114 
115 Account* gnc_sx_get_template_transaction_account(const SchedXaction *sx);
116 
120 GHashTable* gnc_sx_instance_get_variables_for_parser(GHashTable *instance_var_hash);
121 
122 GncSxVariable* gnc_sx_variable_new_full(gchar *name, gnc_numeric value, gboolean editable);
123 void gnc_sx_variable_free(GncSxVariable *var);
124 
151 void gnc_sx_instance_model_change_instance_state(GncSxInstanceModel *model,
152  GncSxInstance *instance,
153  GncSxInstanceState new_state);
154 
155 void gnc_sx_instance_model_set_variable(GncSxInstanceModel *model,
156  GncSxInstance *instance,
157  GncSxVariable *variable,
158  gnc_numeric *new_value);
159 
164 GList* gnc_sx_instance_model_check_variables(GncSxInstanceModel *model);
165 
168 void gnc_sx_instance_model_effect_change(GncSxInstanceModel *model,
169  gboolean auto_create_only,
170  GList **created_transaction_guids,
171  GList **creation_errors);
172 
173 typedef struct _GncSxSummary
174 {
175  gboolean need_dialog;
181 } GncSxSummary;
182 
188 void gnc_sx_instance_model_summarize(GncSxInstanceModel *model, GncSxSummary *summary);
189 
191 void gnc_sx_summary_print(const GncSxSummary *summary);
192 
193 void gnc_sx_get_variables(SchedXaction *sx, GHashTable *var_hash);
194 int gnc_sx_parse_vars_from_formula(const char *formula, GHashTable *var_hash, gnc_numeric *result);
195 void gnc_sx_randomize_variables(GHashTable *vars);
196 
202 GHashTable* gnc_g_hash_new_guid_numeric(void);
203 
212 void gnc_sx_all_instantiate_cashflow(GList *all_sxes,
213  const GDate *range_start, const GDate *range_end,
214  GHashTable* map, GList **creation_errors);
215 
223 GHashTable* gnc_sx_all_instantiate_cashflow_all(GDate range_start, GDate range_end);
224 
230 GList *gnc_sx_instance_model_get_sx_instances_list (GncSxInstanceModel *model);
231 
232 G_END_DECLS
233 
234 
235 #endif // _GNC_SX_INSTANCE_MODEL_H
GHashTable * variable_bindings
variable bindings.
GHashTable * gnc_g_hash_new_guid_numeric(void)
Returns a GHashTable<GUID*, gnc_numeric*> with no destructor for the key, but a destructor for the va...
SXTmpStateData * temporal_state
the sx creation temporal state.
GHashTable * variable_names
<name:char*,GncSxVariable*>
void gnc_sx_scrub_split_numerics(gpointer psplit, gpointer user)
Fix up numerics where they&#39;ve gotten out-of-sync with the formulas.
void gnc_sx_instance_model_change_instance_state(GncSxInstanceModel *model, GncSxInstance *instance, GncSxInstanceState new_state)
There is a constraint around a sequence of upcoming instance states.
GHashTable * gnc_sx_all_instantiate_cashflow_all(GDate range_start, GDate range_end)
Simplified wrapper around gnc_sx_all_instantiate_cashflow(): Run that function on all SX of the curre...
gint num_auto_create_no_notify_instances
The number of automatically-created instances that do no request notification.
An exact-rational-number library for gnucash.
STRUCTS.
GncSxInstanceState orig_state
the original state at generation time.
GHashTable * gnc_sx_instance_get_variables_for_parser(GHashTable *instance_var_hash)
void gnc_sx_instance_model_summarize(GncSxInstanceModel *model, GncSxSummary *summary)
void gnc_sx_instance_model_update_sx_instances(GncSxInstanceModel *model, SchedXaction *sx)
Regenerates and updates the GncSxInstances* for the given SX.
void gnc_sx_instance_model_effect_change(GncSxInstanceModel *model, gboolean auto_create_only, GList **created_transaction_guids, GList **creation_errors)
Really ("effectively") create the transactions from the SX instances in the given model...
Just the variable temporal bits from the SX structure.
Definition: SchedXaction.h:131
gint num_to_create_instances
The number of (not-auto-create) to-create instances.
gint num_instances
The number of total instances (in any state).
void gnc_sx_summary_print(const GncSxSummary *summary)
Debug output to trace file.
GncSxInstances * parent
the parent instances collection.
gint num_auto_create_instances
The total number of auto-create instances.
GDate date
the instance date.
void gnc_sx_all_instantiate_cashflow(GList *all_sxes, const GDate *range_start, const GDate *range_end, GHashTable *map, GList **creation_errors)
Instantiates the cash flow of all given SXs (in the given GList<SchedXAction*>) into the GHashTable<G...
GList * gnc_sx_instance_get_variables(GncSxInstance *inst)
GList * gnc_sx_instance_model_get_sx_instances_list(GncSxInstanceModel *model)
Returns the list of GncSxInstances in the model (Each element in the list has type GncSxInstances) ...
GncSxInstanceModel * gnc_sx_get_instances(const GDate *range_end, gboolean include_disabled)
Allocates a new SxInstanceModel and fills it with generated instances for all scheduled transactions ...
gnc_numeric value
only numeric values are supported.
GncSxInstanceState state
the current state of the instance (during editing)
GncSxInstanceModel * gnc_sx_get_current_instances(void)
Shorthand for get_instances(now, FALSE);.
GList * instance_list
GList<GncSxInstance*>
Scheduled Transactions public handling routines.
gboolean need_dialog
If the dialog needs to be displayed.
GList * gnc_sx_instance_model_check_variables(GncSxInstanceModel *model)