dbd/mysql/connection.c

Wed, 26 Nov 2008 10:43:45 +0000

author
nrich@ii.net
date
Wed, 26 Nov 2008 10:43:45 +0000
changeset 4
c50b0e6f25d6
parent 3
b61020ca4753
child 13
10c8c6f0da14
permissions
-rw-r--r--

Clean up error messages for consistency.

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:
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
37 if (lua_isnil(L, 1) == 0)
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
38 db = luaL_checkstring(L, 1);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
39 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
40
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
41 conn = (connection_t *)lua_newuserdata(L, sizeof(connection_t));
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
42
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
43 conn->mysql = mysql_init(NULL);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
44
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
45 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
46 lua_pushnil(L);
4
c50b0e6f25d6 Clean up error messages for consistency.
nrich@ii.net
parents: 3
diff changeset
47 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
48 return 2;
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
49 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
50
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
51 luaL_getmetatable(L, DBD_MYSQL_CONNECTION);
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
52 lua_setmetatable(L, -2);
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
53
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
54 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
55 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
56
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
57 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
58 * success = connection:close()
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
59 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
60 static int connection_close(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
61 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_MYSQL_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
62 int disconnect = 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
63
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
64 if (conn->mysql) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
65 mysql_close(conn->mysql);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
66 disconnect = 1;
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
67 conn->mysql = NULL;
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
68 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
69
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
70 lua_pushboolean(L, disconnect);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
71 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
72 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
73
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
74 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
75 * ok = connection:ping()
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
76 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
77 static int connection_ping(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
78 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_MYSQL_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
79 int err = 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
80
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
81 if (conn->mysql) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
82 err = mysql_ping(conn->mysql);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
83 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
84
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
85 lua_pushboolean(L, !err);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
86 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
87 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
88
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
89 /*
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
90 * statement,err = connection:prepare(sql_string)
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
91 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
92 static int connection_prepare(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
93 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_MYSQL_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
94
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
95 if (conn->mysql) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
96 return dbd_mysql_statement_create(L, conn, luaL_checkstring(L, 2));
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 lua_pushnil(L);
4
c50b0e6f25d6 Clean up error messages for consistency.
nrich@ii.net
parents: 3
diff changeset
100 lua_pushstring(L, DBI_ERR_DB_UNAVAILABLE);
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
101
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
102 return 2;
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
103 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
104
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
105 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
106 * __gc
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
107 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
108 static int connection_gc(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
109 /* always close the connection */
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
110 connection_close(L);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
111
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
112 return 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
113 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
114
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
115 int dbd_mysql_connection(lua_State *L) {
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
116 static const luaL_Reg connection_methods[] = {
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
117 {"close", connection_close},
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
118 {"ping", connection_ping},
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
119 {"prepare", connection_prepare},
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
120 {NULL, NULL}
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
121 };
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
122
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
123 static const luaL_Reg connection_class_methods[] = {
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
124 {"New", connection_new},
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
125 {NULL, NULL}
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
126 };
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
127
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
128 luaL_newmetatable(L, DBD_MYSQL_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
129 luaL_register(L, 0, connection_methods);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
130 lua_pushvalue(L,-1);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
131 lua_setfield(L, -2, "__index");
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
132
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
133 lua_pushcfunction(L, connection_gc);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
134 lua_setfield(L, -2, "__gc");
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
135
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
136 luaL_register(L, DBD_MYSQL_CONNECTION, connection_class_methods);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
137
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
138 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
139 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
140

mercurial