1
0
mirror of https://github.com/lxsang/antd-lua-plugin synced 2025-01-15 17:28:26 +01:00
antd-lua-plugin/db-wrapper.c
2018-10-08 22:50:40 +02:00

113 lines
2.2 KiB
C

#include "lua-api.h"
//sqldb db = NULL;
static int l_getdb (lua_State *L) {
const char* s = luaL_checkstring(L,1);
// if(db)
// dbclose(db);
//printf("OPEN: %s\n",s);
sqldb db = __getdb((char*)s);
if(db)
lua_pushlightuserdata(L, db);
else
lua_pushnil(L);
return 1; /* number of results */
}
static int l_db_close(lua_State *L)
{
sqldb db = (sqldb) lua_touserdata(L, 1);
if(db)
{
//printf("close database\n");
dbclose(db);
}
db = NULL;
return 0;
}
static int l_db_query(lua_State *L)
{
sqldb db = (sqldb) lua_touserdata(L, 1);
const char* s = luaL_checkstring(L,2);
int r = 0;
if(db)
r = dbquery(db,s,NULL);
lua_pushnumber(L,r);
return 1;
}
static int l_db_lastid(lua_State *L)
{
sqldb db = (sqldb) lua_touserdata(L, 1);
int idx = -1;
if(db)
idx = sqlite3_last_insert_rowid(db);
lua_pushnumber(L,idx);
return 1;
}
static int l_db_select(lua_State *L)
{
sqldb db = (sqldb) lua_touserdata(L, 1);
const char* tbl = luaL_checkstring(L,2);
const char* fname = luaL_checkstring(L,3);
const char* cond = luaL_checkstring(L,4);
if(!db)
{
lua_pushnil(L);
return 1;
}
dbrecord records = dbselect(db,tbl, fname,cond);
int cnt = 1;
//new table for data
lua_newtable(L);
for(dbrecord r = records;r != NULL; r=r->next)
{
dbfield row = r-> fields;
if(row)
{
lua_pushnumber(L,cnt);
lua_newtable(L);
for(dbfield c = row; c != NULL; c= c->next)
{
if(c->name)
{
//LOG("%s->%s",c->name,c->value);
lua_pushstring(L,c->name);
lua_pushstring(L,c->value);
lua_settable(L, -3);
}
}
//free(row);
lua_settable(L, -3);
cnt++;
}
}
if(records)
freerecord(&records);
return 1;
}
static int l_hastable(lua_State *L)
{
sqldb db = (sqldb) lua_touserdata(L, 1);
const char* tbl = luaL_checkstring(L,2);
if(db)
lua_pushnumber(L,hastable(db,tbl));
else
lua_pushnumber(L,0);
return 1;
}
static const struct luaL_Reg sqlite [] = {
{"getdb", l_getdb},
{"dbclose", l_db_close},
{"query", l_db_query},
{"lastInsertID", l_db_lastid},
{"select", l_db_select},
{"hasTable", l_hastable},
{NULL,NULL}
};
int luaopen_sqlite(lua_State *L)
{
luaL_newlib(L, sqlite);
return 1;
}