mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-04 23:02:02 +01:00
598be04bef
Lots of changes adding a games-list view to the app from which you create new games, open and delete existing ones, etc. There's still plenty that's unimplemented, but it's already more useful for testing and development. Which is the point.
94 lines
3 KiB
C
94 lines
3 KiB
C
/* -*- compile-command: "make MEMDEBUG=TRUE -j5"; -*- */
|
|
/*
|
|
* Copyright 2000 - 2016 by Eric House (xwords@eehouse.org). All rights
|
|
* reserved.
|
|
*
|
|
* 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, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
*/
|
|
|
|
#ifndef _GAMESDB_H_
|
|
#define _GAMESDB_H_
|
|
|
|
#include <sqlite3.h>
|
|
#include <glib.h>
|
|
|
|
#include "main.h"
|
|
#include "comtypes.h"
|
|
|
|
typedef struct _GameInfo {
|
|
sqlite3_int64 rowid;
|
|
XP_UCHAR name[128];
|
|
XP_UCHAR room[128];
|
|
XP_UCHAR conn[128];
|
|
XP_UCHAR scores[128];
|
|
XP_UCHAR relayID[32];
|
|
#ifdef PLATFORM_GTK
|
|
GdkPixbuf* snap;
|
|
#endif
|
|
XP_LangCode dictLang;
|
|
XP_U32 gameID;
|
|
XP_S16 nMoves;
|
|
XP_Bool gameOver;
|
|
XP_Bool turnLocal;
|
|
XP_S16 turn;
|
|
XP_U16 nTotal;
|
|
XP_S16 nMissing;
|
|
XP_U16 seed;
|
|
XP_U16 nPending;
|
|
XP_U32 lastMoveTime;
|
|
XP_U16 role;
|
|
} GameInfo;
|
|
|
|
sqlite3* openGamesDB( const char* dbName );
|
|
void closeGamesDB( sqlite3* pDb );
|
|
|
|
void writeToDB( XWStreamCtxt* stream, void* closure );
|
|
sqlite3_int64 writeNewGameToDB( XWStreamCtxt* stream, sqlite3* pDb );
|
|
|
|
void summarize( CommonGlobals* cGlobals );
|
|
|
|
/* Return GSList whose data is (ptrs to) rowids */
|
|
GSList* listGames( sqlite3* pDb );
|
|
/* free list and data allocated by above */
|
|
void freeGamesList( GSList* games );
|
|
|
|
/* Mapping of relayID -> rowid */
|
|
GHashTable* getRelayIDsToRowsMap( sqlite3* pDb );
|
|
|
|
XP_Bool getGameInfo( sqlite3* pDb, sqlite3_int64 rowid, GameInfo* gib );
|
|
void getRowsForGameID( sqlite3* pDb, XP_U32 gameID, sqlite3_int64* rowids,
|
|
int* nRowIDs );
|
|
XP_Bool loadGame( XWStreamCtxt* stream, sqlite3* pDb, sqlite3_int64 rowid );
|
|
void saveInviteAddrs( XWStreamCtxt* stream, sqlite3* pDb,
|
|
sqlite3_int64 rowid );
|
|
XP_Bool loadInviteAddrs( XWStreamCtxt* stream, sqlite3* pDb,
|
|
sqlite3_int64 rowid );
|
|
void deleteGame( sqlite3* pDb, sqlite3_int64 rowid );
|
|
|
|
#define KEY_RDEVID "RDEVID"
|
|
#define KEY_LDEVID "LDEVID"
|
|
#define KEY_SMSPHONE "SMSPHONE"
|
|
#define KEY_SMSPORT "SMSPORT"
|
|
#define KEY_WIN_LOC "WIN_LOC"
|
|
|
|
void db_store( sqlite3* pDb, const gchar* key, const gchar* value );
|
|
void db_remove( sqlite3* pDb, const gchar* key );
|
|
|
|
typedef enum { NOT_THERE, BUFFER_TOO_SMALL, SUCCESS } FetchResult;
|
|
FetchResult db_fetch( sqlite3* pDb, const gchar* key, gchar* buf, gint* buflen );
|
|
XP_Bool db_fetch_safe( sqlite3* pDb, const gchar* key, gchar* buf, gint buflen );
|
|
|
|
|
|
#endif
|