dbd/sqlite3/statement.c

Sun, 23 Nov 2008 04:12:04 +0000

author
nrich@ii.net
date
Sun, 23 Nov 2008 04:12:04 +0000
changeset 2
c4f02fc67e5a
parent 1
408291a6eb3e
child 3
b61020ca4753
permissions
-rw-r--r--

Cleanup and commenting

1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
1 #include "dbd_sqlite3.h"
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
2
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
3 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
4 * Converts SQLite types to Lua types
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
5 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
6 static lua_push_type_t sqlite_to_lua_push(unsigned int sqlite_type) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
7 lua_push_type_t lua_type;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
8
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
9 switch(sqlite_type) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
10 case SQLITE_NULL:
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
11 lua_type = LUA_PUSH_NIL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
12 break;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
13
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
14 case SQLITE_INTEGER:
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
15 lua_type = LUA_PUSH_INTEGER;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
16 break;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
17
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
18 case SQLITE_FLOAT:
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
19 lua_type = LUA_PUSH_NUMBER;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
20 break;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
21
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
22 default:
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
23 lua_type = LUA_PUSH_STRING;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
24 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
25
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
26 return lua_type;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
27 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
28
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
29 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
30 * runs sqlite3_step on a statement handle
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
31 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
32 static int step(statement_t *statement) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
33 int res = sqlite3_step(statement->stmt);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
34
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
35 if (res == SQLITE_DONE) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
36 statement->more_data = 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
37 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
38 } else if (res == SQLITE_ROW) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
39 statement->more_data = 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
40 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
41 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
42
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
43 return 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
44 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
45
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
46 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
47 * success = statement:close()
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
48 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
49 static int statement_close(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
50 statement_t *statement = (statement_t *)luaL_checkudata(L, 1, DBD_SQLITE_STATEMENT);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
51 int ok = 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
52
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
53 if (statement->stmt) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
54 if (sqlite3_finalize(statement->stmt) == SQLITE_OK) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
55 ok = 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
56 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
57 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
58
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
59 lua_pushboolean(L, ok);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
60
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
61 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
62 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
63
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
64 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
65 * success = statement:execute(...)
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
66 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
67 static int statement_execute(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
68 int n = lua_gettop(L);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
69 statement_t *statement = (statement_t *)luaL_checkudata(L, 1, DBD_SQLITE_STATEMENT);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
70 int p;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
71
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
72 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
73 * reset the handle before binding params
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
74 * this wil be a NOP if the handle has not
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
75 * been executed
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
76 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
77 if (sqlite3_reset(statement->stmt) != SQLITE_OK) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
78 lua_pushboolean(L, 0);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
79 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
80 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
81
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
82 for (p = 2; p <= n; p++) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
83 int i = p - 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
84
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
85 if (lua_isnil(L, p)) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
86 if (sqlite3_bind_null(statement->stmt, i) != SQLITE_OK) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
87 luaL_error(L, "Failed to execute statement: %s", sqlite3_errmsg(statement->sqlite));
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
88 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
89 } else if (lua_isnumber(L, p)) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
90 if (sqlite3_bind_double(statement->stmt, i, luaL_checknumber(L, p)) != SQLITE_OK) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
91 luaL_error(L, "Failed to execute statement: %s", sqlite3_errmsg(statement->sqlite));
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
92 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
93 } else if (lua_isstring(L, p)) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
94 if (sqlite3_bind_text(statement->stmt, i, luaL_checkstring(L, p), -1, SQLITE_STATIC) != SQLITE_OK) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
95 luaL_error(L, "Failed to execute statement: %s", sqlite3_errmsg(statement->sqlite));
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
96 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
97 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
98 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
99
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
100 lua_pushboolean(L, step(statement));
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
101 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
102 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
103
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
104 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
105 * must be called after an execute
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
106 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
107 static int statement_fetch_impl(lua_State *L, int named_columns) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
108 statement_t *statement = (statement_t *)luaL_checkudata(L, 1, DBD_SQLITE_STATEMENT);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
109 int num_columns;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
110
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
111 if (!statement->more_data) {
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
112 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
113 * Result set is empty, or not result set returned
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
114 */
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
115
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
116 lua_pushnil(L);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
117 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
118 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
119
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
120 num_columns = sqlite3_column_count(statement->stmt);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
121
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
122 if (num_columns) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
123 int i;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
124 int d = 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
125
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
126 lua_newtable(L);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
127
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
128 for (i = 0; i < num_columns; i++) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
129 lua_push_type_t lua_push = sqlite_to_lua_push(sqlite3_column_type(statement->stmt, i));
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
130 const char *name = sqlite3_column_name(statement->stmt, i);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
131
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
132 if (lua_push == LUA_PUSH_NIL) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
133 if (named_columns) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
134 LUA_PUSH_ATTRIB_NIL(name);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
135 } else {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
136 LUA_PUSH_ARRAY_NIL(d);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
137 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
138 } else if (lua_push == LUA_PUSH_INTEGER) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
139 int val = sqlite3_column_int(statement->stmt, i);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
140
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
141 if (named_columns) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
142 LUA_PUSH_ATTRIB_INT(name, val);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
143 } else {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
144 LUA_PUSH_ARRAY_INT(d, val);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
145 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
146 } else if (lua_push == LUA_PUSH_NUMBER) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
147 double val = sqlite3_column_double(statement->stmt, i);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
148
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
149 if (named_columns) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
150 LUA_PUSH_ATTRIB_FLOAT(name, val);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
151 } else {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
152 LUA_PUSH_ARRAY_FLOAT(d, val);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
153 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
154 } else if (lua_push == LUA_PUSH_STRING) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
155 const char *val = (const char *)sqlite3_column_text(statement->stmt, i);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
156
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
157 if (named_columns) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
158 LUA_PUSH_ATTRIB_STRING(name, val);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
159 } else {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
160 LUA_PUSH_ARRAY_STRING(d, val);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
161 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
162 } else if (lua_push == LUA_PUSH_BOOLEAN) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
163 int val = sqlite3_column_int(statement->stmt, i);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
164
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
165 if (named_columns) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
166 LUA_PUSH_ATTRIB_BOOL(name, val);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
167 } else {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
168 LUA_PUSH_ARRAY_BOOL(d, val);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
169 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
170 } else {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
171 luaL_error(L, "Unknown push type in result set");
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
172 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
173 }
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
174 } else {
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
175 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
176 * no columns returned by statement?
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
177 */
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
178 lua_pushnil(L);
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
179 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
180
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
181 if (step(statement) == 0) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
182 if (sqlite3_reset(statement->stmt) != SQLITE_OK) {
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
183 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
184 * reset needs to be called to retrieve the 'real' error message
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
185 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
186 luaL_error(L, "Failed to fetch statement: %s", sqlite3_errmsg(statement->sqlite));
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
187 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
188 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
189
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
190 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
191 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
192
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
193 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
194 * array = statement:fetch()
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
195 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
196 static int statement_fetch(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
197 return statement_fetch_impl(L, 0);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
198 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
199
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
200 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
201 * hashmap = statement:fetchtable()
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
202 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
203 static int statement_fetchtable(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
204 return statement_fetch_impl(L, 1);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
205 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
206
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
207 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
208 * __gc
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
209 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
210 static int statement_gc(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
211 /* always free the handle */
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
212 statement_close(L);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
213
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
214 return 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
215 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
216
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
217 int dbd_sqlite3_statement_create(lua_State *L, connection_t *conn, const char *sql_query) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
218 statement_t *statement = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
219
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
220 statement = (statement_t *)lua_newuserdata(L, sizeof(statement_t));
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
221 statement->sqlite = conn->sqlite;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
222 statement->stmt = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
223 statement->more_data = 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
224
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
225 if (sqlite3_prepare_v2(statement->sqlite, sql_query, strlen(sql_query), &statement->stmt, NULL) != SQLITE_OK) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
226 luaL_error(L, "Failed to prepare statement: %s", sqlite3_errmsg(statement->sqlite));
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
227 lua_pushnil(L);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
228 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
229 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
230
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
231 luaL_getmetatable(L, DBD_SQLITE_STATEMENT);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
232 lua_setmetatable(L, -2);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
233
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
234 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
235 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
236
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
237 int dbd_sqlite3_statement(lua_State *L) {
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
238 static const luaL_Reg statement_methods[] = {
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
239 {"close", statement_close},
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
240 {"execute", statement_execute},
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
241 {"fetch", statement_fetch},
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
242 {"fetchtable", statement_fetchtable},
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
243 {NULL, NULL}
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
244 };
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
245
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
246 static const luaL_Reg statement_class_methods[] = {
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
247 {NULL, NULL}
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
248 };
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
249
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
250 luaL_newmetatable(L, DBD_SQLITE_STATEMENT);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
251 luaL_register(L, 0, statement_methods);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
252 lua_pushvalue(L,-1);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
253 lua_setfield(L, -2, "__index");
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
254
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
255 lua_pushcfunction(L, statement_gc);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
256 lua_setfield(L, -2, "__gc");
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
257
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
258 luaL_register(L, DBD_SQLITE_STATEMENT, statement_class_methods);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
259
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
260 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
261 }

mercurial