dbd/mysql/connection.c

Fri, 29 Jun 2012 17:45:37 +0100

author
Matthew Wild <mwild1@gmail.com>
date
Fri, 29 Jun 2012 17:45:37 +0100
changeset 45
7c968f66bccd
parent 32
03ed0ca09837
permissions
-rw-r--r--

MySQL: Avoid allocating the full column size to receive results, for variable-length types check result size before allocation (thanks Florob)

1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
1 #include "dbd_mysql.h"
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
2
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
3 int dbd_mysql_statement_create(lua_State *L, connection_t *conn, const char *sql_query);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
4
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
5 /*
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
6 * connection,err = DBD.MySQl.New(dbname, user, password, host, port)
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
7 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
8 static int connection_new(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
9 int n = lua_gettop(L);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
10
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
11 connection_t *conn = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
12
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
13 const char *host = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
14 const char *user = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
15 const char *password = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
16 const char *db = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
17 int port = 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
18
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
19 const char *unix_socket = NULL; /* TODO always NULL */
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
20 int client_flag = 0; /* TODO always 0, set flags from options table */
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
21
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
22 /* db, user, password, host, port */
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
23 switch (n) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
24 case 5:
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
25 if (lua_isnil(L, 5) == 0)
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
26 port = luaL_checkint(L, 5);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
27 case 4:
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
28 if (lua_isnil(L, 4) == 0)
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
29 host = luaL_checkstring(L, 4);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
30 case 3:
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
31 if (lua_isnil(L, 3) == 0)
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
32 password = luaL_checkstring(L, 3);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
33 case 2:
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
34 if (lua_isnil(L, 2) == 0)
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
35 user = luaL_checkstring(L, 2);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
36 case 1:
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents: 13
diff changeset
37 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents: 13
diff changeset
38 * db is the only mandatory parameter
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents: 13
diff changeset
39 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents: 13
diff changeset
40 db = luaL_checkstring(L, 1);
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 conn = (connection_t *)lua_newuserdata(L, sizeof(connection_t));
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
44
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
45 conn->mysql = mysql_init(NULL);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
46
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
47 if (!mysql_real_connect(conn->mysql, host, user, password, db, port, unix_socket, client_flag)) {
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
48 lua_pushnil(L);
4
c50b0e6f25d6 Clean up error messages for consistency.
nrich@ii.net
parents: 3
diff changeset
49 lua_pushfstring(L, DBI_ERR_CONNECTION_FAILED, mysql_error(conn->mysql));
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
50 return 2;
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
51 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
52
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
53 /*
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
54 * by default turn off autocommit
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
55 */
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
56 mysql_autocommit(conn->mysql, 0);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
57
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
58 luaL_getmetatable(L, DBD_MYSQL_CONNECTION);
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
59 lua_setmetatable(L, -2);
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
60
1
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 /*
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
65 * success = connection:autocommit(on)
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
66 */
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
67 static int connection_autocommit(lua_State *L) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
68 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_MYSQL_CONNECTION);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
69 int on = lua_toboolean(L, 2);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
70 int err = 0;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
71
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
72 if (conn->mysql) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
73 err = mysql_autocommit(conn->mysql, on);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
74 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
75
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
76 lua_pushboolean(L, !err);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
77 return 1;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
78 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
79
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
80 /*
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
81 * success = connection:close()
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
82 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
83 static int connection_close(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
84 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_MYSQL_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
85 int disconnect = 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
86
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
87 if (conn->mysql) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
88 mysql_close(conn->mysql);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
89 disconnect = 1;
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
90 conn->mysql = NULL;
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
91 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
92
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
93 lua_pushboolean(L, disconnect);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
94 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
95 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
96
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
97 /*
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
98 * success = connection:commit()
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
99 */
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
100 static int connection_commit(lua_State *L) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
101 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_MYSQL_CONNECTION);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
102 int err = 0;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
103
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
104 if (conn->mysql) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
105 err = mysql_commit(conn->mysql);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
106 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
107
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
108 lua_pushboolean(L, !err);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
109 return 1;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
110 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
111
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 * ok = connection:ping()
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
114 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
115 static int connection_ping(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
116 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_MYSQL_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
117 int err = 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
118
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
119 if (conn->mysql) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
120 err = mysql_ping(conn->mysql);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
121 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
122
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
123 lua_pushboolean(L, !err);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
124 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
125 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
126
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
127 /*
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
128 * statement,err = connection:prepare(sql_string)
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
129 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
130 static int connection_prepare(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
131 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_MYSQL_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
132
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
133 if (conn->mysql) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
134 return dbd_mysql_statement_create(L, conn, luaL_checkstring(L, 2));
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
135 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
136
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
137 lua_pushnil(L);
4
c50b0e6f25d6 Clean up error messages for consistency.
nrich@ii.net
parents: 3
diff changeset
138 lua_pushstring(L, DBI_ERR_DB_UNAVAILABLE);
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
139
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
140 return 2;
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
141 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
142
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
143 /*
22
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
144 * quoted = connection:quote(str)
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
145 */
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
146 static int connection_quote(lua_State *L) {
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
147 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_MYSQL_CONNECTION);
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
148 size_t len;
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
149 const char *from = luaL_checklstring(L, 2, &len);
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
150 char *to = (char *)calloc(len*2+1, sizeof(char));
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
151 int quoted_len;
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
152
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
153 if (!conn->mysql) {
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
154 luaL_error(L, DBI_ERR_DB_UNAVAILABLE);
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
155 }
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
156
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
157 quoted_len = mysql_real_escape_string(conn->mysql, to, from, len);
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
158
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
159 lua_pushlstring(L, to, quoted_len);
23
a4825c3e65e9 Bugfix: memory corruption possible after reallocs. Using a static buffer instead. Will need to check for overflows on static buffer.
nrich@ii.net
parents: 22
diff changeset
160 free(to);
22
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
161
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
162 return 1;
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
163 }
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
164
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
165 /*
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
166 * success = connection:rollback()
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
167 */
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
168 static int connection_rollback(lua_State *L) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
169 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_MYSQL_CONNECTION);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
170 int err = 0;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
171
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
172 if (conn->mysql) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
173 err = mysql_rollback(conn->mysql);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
174 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
175
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
176 lua_pushboolean(L, !err);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
177 return 1;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
178 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
179
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
180 /*
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
181 * __gc
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
182 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
183 static int connection_gc(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
184 /* always close the connection */
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
185 connection_close(L);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
186
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
187 return 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
188 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
189
32
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 23
diff changeset
190 /*
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 23
diff changeset
191 * __tostring
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 23
diff changeset
192 */
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 23
diff changeset
193 static int connection_tostring(lua_State *L) {
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 23
diff changeset
194 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_MYSQL_CONNECTION);
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 23
diff changeset
195
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 23
diff changeset
196 lua_pushfstring(L, "%s: %p", DBD_MYSQL_CONNECTION, conn);
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 23
diff changeset
197
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 23
diff changeset
198 return 1;
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 23
diff changeset
199 }
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 23
diff changeset
200
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
201 int dbd_mysql_connection(lua_State *L) {
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
202 static const luaL_Reg connection_methods[] = {
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
203 {"autocommit", connection_autocommit},
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
204 {"close", connection_close},
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
205 {"commit", connection_commit},
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
206 {"ping", connection_ping},
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
207 {"prepare", connection_prepare},
22
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
208 {"quote", connection_quote},
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
209 {"rollback", connection_rollback},
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
210 {NULL, NULL}
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
211 };
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
212
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
213 static const luaL_Reg connection_class_methods[] = {
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
214 {"New", connection_new},
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
215 {NULL, NULL}
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
216 };
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
217
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
218 luaL_newmetatable(L, DBD_MYSQL_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
219 luaL_register(L, 0, connection_methods);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
220 lua_pushvalue(L,-1);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
221 lua_setfield(L, -2, "__index");
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
222
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
223 lua_pushcfunction(L, connection_gc);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
224 lua_setfield(L, -2, "__gc");
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
225
32
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 23
diff changeset
226 lua_pushcfunction(L, connection_tostring);
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 23
diff changeset
227 lua_setfield(L, -2, "__tostring");
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 23
diff changeset
228
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
229 luaL_register(L, DBD_MYSQL_CONNECTION, connection_class_methods);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
230
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
231 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
232 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
233

mercurial