36 #include "gnc-sql-connection.hpp" 37 #include "gnc-sql-backend.hpp" 38 #include "gnc-sql-object-backend.hpp" 39 #include "gnc-sql-column-table-entry.hpp" 43 #if defined( S_SPLINT_S ) 44 #include "splint-defs.h" 47 [[maybe_unused]]
static QofLogModule log_module =
G_LOG_DOMAIN;
49 static gpointer get_quote_source_name (gpointer pObject);
50 static void set_quote_source_name (gpointer pObject, gpointer pValue);
52 #define COMMODITIES_TABLE "commodities" 53 #define TABLE_VERSION 1 55 #define COMMODITY_MAX_NAMESPACE_LEN 2048 56 #define COMMODITY_MAX_MNEMONIC_LEN 2048 57 #define COMMODITY_MAX_FULLNAME_LEN 2048 58 #define COMMODITY_MAX_CUSIP_LEN 2048 59 #define COMMODITY_MAX_QUOTESOURCE_LEN 2048 60 #define COMMODITY_MAX_QUOTE_TZ_LEN 2048 62 static const EntryVec col_table
64 gnc_sql_make_table_entry<CT_GUID>(
65 "guid", 0, COL_NNUL | COL_PKEY | COL_UNIQUE,
"guid"),
66 gnc_sql_make_table_entry<CT_STRING>(
"namespace",
67 COMMODITY_MAX_NAMESPACE_LEN, COL_NNUL,
70 gnc_sql_make_table_entry<CT_STRING>(
71 "mnemonic", COMMODITY_MAX_MNEMONIC_LEN, COL_NNUL,
"mnemonic"),
72 gnc_sql_make_table_entry<CT_STRING>(
73 "fullname", COMMODITY_MAX_FULLNAME_LEN, 0,
"fullname"),
74 gnc_sql_make_table_entry<CT_STRING>(
75 "cusip", COMMODITY_MAX_CUSIP_LEN, 0,
"cusip"),
76 gnc_sql_make_table_entry<CT_INT>(
"fraction", 0, COL_NNUL,
"fraction"),
77 gnc_sql_make_table_entry<CT_BOOLEAN>(
78 "quote_flag", 0, COL_NNUL,
"quote_flag"),
79 gnc_sql_make_table_entry<CT_STRING>(
"quote_source",
80 COMMODITY_MAX_QUOTESOURCE_LEN, 0,
82 set_quote_source_name),
83 gnc_sql_make_table_entry<CT_STRING>(
84 "quote_tz", COMMODITY_MAX_QUOTE_TZ_LEN, 0,
"quote-tz"),
87 GncSqlCommodityBackend::GncSqlCommodityBackend() :
89 COMMODITIES_TABLE, col_table) {}
93 get_quote_source_name (gpointer pObject)
95 const gnc_commodity* pCommodity;
97 g_return_val_if_fail (pObject != NULL, NULL);
98 g_return_val_if_fail (GNC_IS_COMMODITY (pObject), NULL);
100 pCommodity = GNC_COMMODITY (pObject);
106 set_quote_source_name (gpointer pObject, gpointer pValue)
108 gnc_commodity* pCommodity;
109 const gchar* quote_source_name = (
const gchar*)pValue;
110 gnc_quote_source* quote_source;
112 g_return_if_fail (pObject != NULL);
113 g_return_if_fail (GNC_IS_COMMODITY (pObject));
115 if (pValue == NULL)
return;
117 pCommodity = GNC_COMMODITY (pObject);
122 static gnc_commodity*
125 QofBook* pBook = sql_be->book();
126 gnc_commodity* pCommodity;
129 gnc_commodity_begin_edit (pCommodity);
130 gnc_sql_load_object (sql_be, row, GNC_ID_COMMODITY, pCommodity, col_table);
131 gnc_commodity_commit_edit (pCommodity);
139 gnc_commodity_table* pTable;
142 std::string sql(
"SELECT * FROM " COMMODITIES_TABLE);
143 auto stmt = sql_be->create_statement_from_sql(sql);
146 for (
auto row : *result)
148 auto pCommodity = load_single_commodity (sql_be, row);
150 if (pCommodity != NULL)
158 qof_instance_set_guid (QOF_INSTANCE (pCommodity), &guid);
162 std::string pkey(col_table[0]->name());
163 sql =
"SELECT DISTINCT ";
164 sql += pkey +
" FROM " COMMODITIES_TABLE;
166 (BookLookupFn)gnc_commodity_find_commodity_by_guid);
171 gboolean force_insert)
178 is_infant = qof_instance_get_infant (inst);
183 else if (sql_be->pristine() || is_infant || force_insert)
191 is_ok = sql_be->
do_db_operation(op, COMMODITIES_TABLE, GNC_ID_COMMODITY,
214 g_return_val_if_fail (sql_be != NULL, FALSE);
215 g_return_val_if_fail (inst != NULL, FALSE);
216 g_return_val_if_fail (GNC_IS_COMMODITY (inst), FALSE);
218 return do_commit_commodity (sql_be, inst, !in_be);
226 gpointer pObject)
const noexcept
228 load_from_guid_ref(row, obj_name, pObject,
230 return gnc_commodity_find_commodity_by_guid(g, sql_be->book());
237 add_objectref_guid_to_table(vec);
242 const gpointer pObject,
243 PairVec& vec)
const noexcept
245 add_objectref_guid_to_query(obj_name, pObject, vec);
bool do_db_operation(E_DB_OPERATION op, const char *table_name, QofIdTypeConst obj_name, gpointer pObject, const EntryVec &table) const noexcept
Performs an operation on the database.
gnc_commodity * gnc_commodity_table_insert(gnc_commodity_table *table, gnc_commodity *comm)
Add a new commodity to the commodity table.
gnc_commodity_table * gnc_commodity_table_get_table(QofBook *book)
Returns the commodity table associated with a book.
GncSqlResultPtr execute_select_statement(const GncSqlStatementPtr &stmt) const noexcept
Executes an SQL SELECT statement and returns the result rows.
const GncGUID * qof_instance_get_guid(gconstpointer inst)
Return the GncGUID of this instance.
#define qof_instance_is_dirty
Return value of is_dirty flag.
void gnc_sql_slots_load_for_sql_subquery(GncSqlBackend *sql_be, const std::string subquery, BookLookupFn lookup_fn)
gnc_sql_slots_load_for_sql_subquery - Loads slots for all objects whose guid is supplied by a subquer...
#define G_LOG_DOMAIN
Functions providing the SX List as a plugin page.
load and save data to SQL
const gchar * QofIdTypeConst
QofIdTypeConst declaration.
load and save accounts data to SQL
gboolean qof_instance_get_destroying(gconstpointer ptr)
Retrieve the flag that indicates whether or not this object is about to be destroyed.
gboolean gnc_sql_slots_save(GncSqlBackend *sql_be, const GncGUID *guid, gboolean is_infant, QofInstance *inst)
gnc_sql_slots_save - Saves slots for an object to the db.
void add_to_query(QofIdTypeConst obj_name, void *pObject, PairVec &vec) const noexcept override
Add a pair of the table column heading and object's value's string representation to a PairVec; used ...
void commodity_for_postload_processing(gnc_commodity *)
Register a commodity to be committed after loading is complete.
const char * gnc_commodity_get_namespace(const gnc_commodity *cm)
Retrieve the namespace for the specified commodity.
void(* QofSetterFunc)(gpointer, gpointer)
The QofSetterFunc defines an function pointer for parameter setters.
void load(const GncSqlBackend *sql_be, GncSqlRow &row, QofIdTypeConst obj_name, void *pObject) const noexcept override
Load a value into an object from the database row.
void gnc_commodity_set_quote_source(gnc_commodity *cm, gnc_quote_source *src)
Set the automatic price quote source for the specified commodity.
Row of SQL Query results.
gnc_commodity * gnc_commodity_new(QofBook *book, const char *fullname, const char *name_space, const char *mnemonic, const char *cusip, int fraction)
Create a new commodity.
gpointer(* QofAccessFunc)(gpointer object, const QofParam *param)
The QofAccessFunc defines an arbitrary function pointer for access functions.
Encapsulates per-class table schema with functions to load, create a table, commit a changed front-en...
void load_all(GncSqlBackend *) override
Load all objects of m_type in the database into memory.
gnc_quote_source * gnc_quote_source_lookup_by_internal(const char *name)
Given the internal (gnucash or F::Q) name of a quote source, find the data structure identified by th...
gnc_quote_source * gnc_commodity_get_quote_source(const gnc_commodity *cm)
Retrieve the automatic price quote source for the specified commodity.
bool commit(GncSqlBackend *, QofInstance *) override
UPDATE/INSERT a single instance of m_type_name into the database.
gboolean gnc_sql_slots_delete(GncSqlBackend *sql_be, const GncGUID *guid)
gnc_sql_slots_delete - Deletes slots for an object from the db.
void add_to_table(ColVec &vec) const noexcept override
Add a GncSqlColumnInfo structure for the column type to a ColVec.
void gnc_commodity_set_namespace(gnc_commodity *cm, const char *name_space)
Set the namespace for the specified commodity.
const char * gnc_quote_source_get_internal_name(const gnc_quote_source *source)
Given a gnc_quote_source data structure, return the internal name of this quote source.
The type used to store guids in C.
Commodity handling public routines.
Main SQL backend structure.
bool instance_in_db(const GncSqlBackend *sql_be, QofInstance *inst) const noexcept
Check the presence of an object in the backend's database.