Extract gamedb open/close to separate functions.

This commit is contained in:
Enno Rehling 2018-09-25 18:52:29 +02:00
parent 274d44ee18
commit 4e5240628e
4 changed files with 56 additions and 22 deletions

View file

@ -4,17 +4,27 @@
#include "gamedb.h" #include "gamedb.h"
#include "kernel/db/driver.h"
#include "kernel/database.h" #include "kernel/database.h"
#include "kernel/faction.h" #include "kernel/faction.h"
void gamedb_update(void) int gamedb_update(void)
{ {
faction *f; faction *f;
int err;
const char *dbname;
for (f = factions; f; f = f->next) { dbname = config_get("game.dbname");
int uid = dblib_save_faction(f, turn);
if (uid > 0) { err = db_driver_open(DB_GAME, dbname);
f->uid = uid; if (err == 0) {
for (f = factions; f; f = f->next) {
int uid = dblib_save_faction(f, turn);
if (uid > 0) {
f->uid = uid;
}
} }
db_driver_close(DB_GAME);
} }
return err;
} }

View file

@ -34,10 +34,13 @@ int dblib_save_faction(const faction *f, int turn) {
void dblib_open(void) void dblib_open(void)
{ {
db_driver_open(); const char *dbname;
dbname = config_get("game.dbswap");
db_driver_open(DB_SWAP, dbname);
} }
void dblib_close(void) void dblib_close(void)
{ {
db_driver_close(); db_driver_close(DB_SWAP);
} }

View file

@ -2,8 +2,13 @@
struct order_data; struct order_data;
void db_driver_open(void); typedef enum database_t {
void db_driver_close(void); DB_SWAP,
DB_GAME,
} database_t;
int db_driver_open(database_t db, const char *dbname);
void db_driver_close(database_t db);
int db_driver_order_save(struct order_data *od); int db_driver_order_save(struct order_data *od);
struct order_data *db_driver_order_load(int id); struct order_data *db_driver_order_load(int id);
int db_driver_faction_save(int id, int no, int turn, const char *email, const char *password); int db_driver_faction_save(int id, int no, int turn, const char *email, const char *password);

View file

@ -144,15 +144,9 @@ int db_driver_faction_save(int id, int no, int turn, const char *email, const ch
return (int)row_id; return (int)row_id;
} }
void db_driver_open(void) static int db_open_game(const char *dbname) {
{
int err; int err;
const char *dbname, *dbtemp;
ERRNO_CHECK();
dbname = config_get("game.dbname");
if (!dbname) dbname = "";
err = sqlite3_open(dbname, &g_game_db); err = sqlite3_open(dbname, &g_game_db);
assert(err == SQLITE_OK); assert(err == SQLITE_OK);
err = sqlite3_exec(g_game_db, "CREATE TABLE IF NOT EXISTS factions (id INTEGER PRIMARY KEY, no INTEGER NOT NULL, email VARCHAR(128), password VARCHAR(128), turn INTEGER NOT NULL)", NULL, NULL, NULL); err = sqlite3_exec(g_game_db, "CREATE TABLE IF NOT EXISTS factions (id INTEGER PRIMARY KEY, no INTEGER NOT NULL, email VARCHAR(128), password VARCHAR(128), turn INTEGER NOT NULL)", NULL, NULL, NULL);
@ -162,9 +156,16 @@ void db_driver_open(void)
err = sqlite3_prepare_v2(g_game_db, "INSERT INTO factions (no, turn, email, password) VALUES (?,?,?,?)", -1, &g_stmt_insert_faction, NULL); err = sqlite3_prepare_v2(g_game_db, "INSERT INTO factions (no, turn, email, password) VALUES (?,?,?,?)", -1, &g_stmt_insert_faction, NULL);
assert(err == SQLITE_OK); assert(err == SQLITE_OK);
ERRNO_CHECK();
return 0;
}
static int db_open_swap(const char *dbname) {
int err;
g_order_batchsize = config_get_int("game.dbbatch", 100); g_order_batchsize = config_get_int("game.dbbatch", 100);
dbtemp = config_get("game.db.temp");
err = sqlite3_open(dbtemp ? dbtemp : dbname, &g_temp_db); err = sqlite3_open(dbname, &g_temp_db);
assert(err == SQLITE_OK); assert(err == SQLITE_OK);
err = sqlite3_exec(g_temp_db, "PRAGMA journal_mode=OFF", NULL, NULL, NULL); err = sqlite3_exec(g_temp_db, "PRAGMA journal_mode=OFF", NULL, NULL, NULL);
assert(err == SQLITE_OK); assert(err == SQLITE_OK);
@ -176,16 +177,30 @@ void db_driver_open(void)
assert(err == SQLITE_OK); assert(err == SQLITE_OK);
err = sqlite3_prepare_v2(g_temp_db, "SELECT data FROM orders WHERE id=?", -1, &g_stmt_select_order, NULL); err = sqlite3_prepare_v2(g_temp_db, "SELECT data FROM orders WHERE id=?", -1, &g_stmt_select_order, NULL);
assert(err == SQLITE_OK); assert(err == SQLITE_OK);
ERRNO_CHECK(); ERRNO_CHECK();
return 0;
} }
void db_driver_close(void) int db_driver_open(database_t db, const char *dbname)
{
ERRNO_CHECK();
if (db == DB_SWAP) {
return db_open_swap(dbname);
}
else if (db == DB_GAME) {
return db_open_game(dbname);
}
return -1;
}
void db_driver_close(database_t db)
{ {
int err; int err;
ERRNO_CHECK(); ERRNO_CHECK();
if (g_temp_db) { if (db == DB_SWAP) {
assert(g_temp_db);
err = sqlite3_finalize(g_stmt_select_order); err = sqlite3_finalize(g_stmt_select_order);
assert(err == SQLITE_OK); assert(err == SQLITE_OK);
err = sqlite3_finalize(g_stmt_insert_order); err = sqlite3_finalize(g_stmt_insert_order);
@ -193,7 +208,8 @@ void db_driver_close(void)
err = sqlite3_close(g_temp_db); err = sqlite3_close(g_temp_db);
assert(err == SQLITE_OK); assert(err == SQLITE_OK);
} }
if (g_game_db) { else if (db == DB_GAME) {
assert(g_game_db);
err = sqlite3_finalize(g_stmt_update_faction); err = sqlite3_finalize(g_stmt_update_faction);
assert(err == SQLITE_OK); assert(err == SQLITE_OK);
err = sqlite3_finalize(g_stmt_insert_faction); err = sqlite3_finalize(g_stmt_insert_faction);