dbd/sqlite3/connection.c

Mon, 20 Dec 2010 09:01:12 +0000

author
nrich@ii.net
date
Mon, 20 Dec 2010 09:01:12 +0000
changeset 41
e490414a391d
parent 32
03ed0ca09837
child 42
93335fa1f1d0
permissions
-rw-r--r--

Fix DBD.SQLite3 transaction handling

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
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
3 int dbd_sqlite3_statement_create(lua_State *L, connection_t *conn, const char *sql_query);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
4
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
5 static int run(connection_t *conn, const char *command) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
6 int res = sqlite3_exec(conn->sqlite, command, NULL, NULL, NULL);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
7
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
8 return res != SQLITE_OK;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
9 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
10
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
11 static int commit(connection_t *conn) {
41
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
12 conn->txn_in_progress = 0;
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
13 return run(conn, "COMMIT TRANSACTION");
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
14 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
15
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
16
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
17 static int begin(connection_t *conn) {
41
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
18 int err = 0;
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
19
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
20 if (conn->txn_in_progress) {
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
21 err = 0;
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
22 } else {
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
23 conn->txn_in_progress = 1;
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
24 err = run(conn, "BEGIN TRANSACTION");
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
25 }
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
26
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
27 return err;
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
28 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
29
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
30 static int rollback(connection_t *conn) {
41
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
31 conn->txn_in_progress = 0;
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
32 return run(conn, "ROLLBACK TRANSACTION");
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
33 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
34
41
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
35 int try_begin_transaction(connection_t *conn) {
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
36 if (conn->autocommit) {
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
37 return 1;
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
38 }
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
39
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
40 return begin(conn) == 0;
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
41 }
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
42
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
43 /*
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
44 * connection,err = DBD.SQLite3.New(dbfile)
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
45 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
46 static int connection_new(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
47 int n = lua_gettop(L);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
48
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
49 const char *db = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
50 connection_t *conn = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
51
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
52 /* db */
9
06eb2850703f Bugfix: fix connection in DBD.SQLite3.New
nrich@ii.net
parents: 4
diff changeset
53 switch(n) {
06eb2850703f Bugfix: fix connection in DBD.SQLite3.New
nrich@ii.net
parents: 4
diff changeset
54 default:
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents: 13
diff changeset
55 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents: 13
diff changeset
56 * db is the only mandatory parameter
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents: 13
diff changeset
57 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents: 13
diff changeset
58 db = luaL_checkstring(L, 1);
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
59 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
60
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
61 conn = (connection_t *)lua_newuserdata(L, sizeof(connection_t));
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
62
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
63 if (sqlite3_open(db, &conn->sqlite) != SQLITE_OK) {
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
64 lua_pushnil(L);
4
c50b0e6f25d6 Clean up error messages for consistency.
nrich@ii.net
parents: 3
diff changeset
65 lua_pushfstring(L, DBI_ERR_CONNECTION_FAILED, sqlite3_errmsg(conn->sqlite));
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
66 return 2;
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
67 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
68
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
69 conn->autocommit = 0;
41
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
70 conn->txn_in_progress = 0;
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
71
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
72 luaL_getmetatable(L, DBD_SQLITE_CONNECTION);
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
73 lua_setmetatable(L, -2);
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
74
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
75 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
76 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
77
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
78 /*
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
79 * success = connection:autocommit(on)
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
80 */
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
81 static int connection_autocommit(lua_State *L) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
82 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_SQLITE_CONNECTION);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
83 int on = lua_toboolean(L, 2);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
84 int err = 1;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
85
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
86 if (conn->sqlite) {
41
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
87 if (on) {
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
88 err = rollback(conn);
41
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
89 }
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
90 /*
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
91 else
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
92 err = begin(conn);
41
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
93 */
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
94
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
95 conn->autocommit = on;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
96 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
97
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
98 lua_pushboolean(L, !err);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
99 return 1;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
100 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
101
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
102
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
103 /*
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
104 * success = connection:close()
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
105 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
106 static int connection_close(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
107 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_SQLITE_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
108 int disconnect = 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
109
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
110 if (conn->sqlite) {
41
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
111 rollback(conn);
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
112 sqlite3_close(conn->sqlite);
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
113 disconnect = 1;
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
114 conn->sqlite = NULL;
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
115 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
116
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
117 lua_pushboolean(L, disconnect);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
118 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
119 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
120
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
121 /*
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
122 * success = connection:commit()
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
123 */
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
124 static int connection_commit(lua_State *L) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
125 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_SQLITE_CONNECTION);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
126 int err = 1;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
127
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
128 if (conn->sqlite) {
41
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
129 err = commit(conn);
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
130 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
131
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
132 lua_pushboolean(L, !err);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
133 return 1;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
134 }
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
135
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
136 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
137 * ok = connection:ping()
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
138 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
139 static int connection_ping(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
140 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_SQLITE_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
141 int ok = 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
142
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
143 if (conn->sqlite) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
144 ok = 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
145 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
146
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
147 lua_pushboolean(L, ok);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
148 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
149 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
150
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
151 /*
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
152 * statement,err = connection:prepare(sql_str)
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
153 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
154 static int connection_prepare(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
155 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_SQLITE_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
156
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
157 if (conn->sqlite) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
158 return dbd_sqlite3_statement_create(L, conn, luaL_checkstring(L, 2));
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
159 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
160
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
161 lua_pushnil(L);
4
c50b0e6f25d6 Clean up error messages for consistency.
nrich@ii.net
parents: 3
diff changeset
162 lua_pushstring(L, DBI_ERR_DB_UNAVAILABLE);
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
163 return 2;
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
164 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
165
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
166 /*
22
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
167 * quoted = connection:quote(str)
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
168 */
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
169 static int connection_quote(lua_State *L) {
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
170 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_SQLITE_CONNECTION);
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
171 size_t len;
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
172 const char *from = luaL_checklstring(L, 2, &len);
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
173 char *to;
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
174
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
175 if (!conn->sqlite) {
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
176 luaL_error(L, DBI_ERR_DB_UNAVAILABLE);
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
177 }
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
178
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
179 to = sqlite3_mprintf("%q", from);
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
180
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
181 lua_pushstring(L, to);
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
182 sqlite3_free(to);
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
183
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
184 return 1;
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
185 }
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
186
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
187 /*
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
188 * success = connection:rollback()
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
189 */
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
190 static int connection_rollback(lua_State *L) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
191 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_SQLITE_CONNECTION);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
192 int err = 1;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
193
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
194 if (conn->sqlite) {
41
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
195 err =rollback(conn);
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
196
41
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
197 /*
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
198 if (!conn->autocommit)
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
199 err = begin(conn);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
200 else
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
201 err = 1;
41
e490414a391d Fix DBD.SQLite3 transaction handling
nrich@ii.net
parents: 32
diff changeset
202 */
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
203 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
204
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
205 lua_pushboolean(L, !err);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
206 return 1;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
207 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
208
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
209 /*
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
210 * __gc
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
211 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
212 static int connection_gc(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
213 /* always close the connection */
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
214 connection_close(L);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
215
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
216 return 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
217 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
218
32
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
219 /*
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
220 * __tostring
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
221 */
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
222 static int connection_tostring(lua_State *L) {
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
223 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_SQLITE_CONNECTION);
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
224
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
225 lua_pushfstring(L, "%s: %p", DBD_SQLITE_CONNECTION, conn);
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
226
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
227 return 1;
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
228 }
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
229
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
230 int dbd_sqlite3_connection(lua_State *L) {
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
231 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
232 * instance methods
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
233 */
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
234 static const luaL_Reg connection_methods[] = {
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
235 {"autocommit", connection_autocommit},
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
236 {"close", connection_close},
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
237 {"commit", connection_commit},
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
238 {"ping", connection_ping},
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
239 {"prepare", connection_prepare},
22
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
240 {"quote", connection_quote},
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 9
diff changeset
241 {"rollback", connection_rollback},
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
242 {NULL, NULL}
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
243 };
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
244
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
245 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
246 * class methods
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
247 */
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
248 static const luaL_Reg connection_class_methods[] = {
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
249 {"New", connection_new},
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
250 {NULL, NULL}
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
251 };
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
252
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
253 luaL_newmetatable(L, DBD_SQLITE_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
254 luaL_register(L, 0, connection_methods);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
255 lua_pushvalue(L,-1);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
256 lua_setfield(L, -2, "__index");
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
257
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
258 lua_pushcfunction(L, connection_gc);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
259 lua_setfield(L, -2, "__gc");
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
260
32
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
261 lua_pushcfunction(L, connection_tostring);
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
262 lua_setfield(L, -2, "__tostring");
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
263
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
264 luaL_register(L, DBD_SQLITE_CONNECTION, connection_class_methods);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
265
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
266 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
267 }

mercurial