annotate src/lib-sql/driver-sqlite.c @ 4294:1a98cb709395 HEAD

Added sql_escape_string()
author Timo Sirainen <tss@iki.fi>
date Wed, 31 May 2006 14:02:50 +0300
parents 5b21fb41d14d
children d0d04db8e7a6
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
3923
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
1 /* Copyright (C) 2006 Jakob Hirsch */
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
2
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
3 #include "lib.h"
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
4 #include "str.h"
4294
1a98cb709395 Added sql_escape_string()
Timo Sirainen <tss@iki.fi>
parents: 3947
diff changeset
5 #include "strescape.h"
3923
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
6 #include "sql-api-private.h"
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
7
3943
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
8 #ifdef BUILD_SQLITE
3923
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
9 #include <sqlite3.h>
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
10
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
11 /* retry time if db is busy (in ms) */
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
12 const int sqlite_busy_timeout = 1000;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
13
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
14 struct sqlite_db {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
15 struct sql_db api;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
16
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
17 pool_t pool;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
18 const char *dbfile;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
19 sqlite3 *sqlite;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
20 unsigned int connected:1;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
21 int rc;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
22 };
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
23
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
24 struct sqlite_result {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
25 struct sql_result api;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
26 sqlite3_stmt *stmt;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
27 unsigned int cols;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
28 const char **row;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
29 };
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
30
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
31 struct sqlite_transaction_context {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
32 struct sql_transaction_context ctx;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
33 unsigned int failed:1;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
34 };
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
35
3943
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
36 extern struct sql_db driver_sqlite_db;
3923
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
37 extern struct sql_result driver_sqlite_result;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
38 extern struct sql_result driver_sqlite_error_result;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
39
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
40 static int driver_sqlite_connect(struct sql_db *_db)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
41 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
42 struct sqlite_db *db = (struct sqlite_db *)_db;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
43
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
44 if (db->connected)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
45 return 1;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
46
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
47 db->rc = sqlite3_open(db->dbfile, &db->sqlite);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
48
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
49 if (db->rc == SQLITE_OK) {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
50 db->connected = TRUE;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
51 sqlite3_busy_timeout(db->sqlite, sqlite_busy_timeout);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
52 return 1;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
53 } else {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
54 i_error("sqlite: open(%s) failed: %s", db->dbfile,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
55 sqlite3_errmsg(db->sqlite));
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
56 sqlite3_close(db->sqlite);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
57 return -1;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
58 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
59 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
60
3943
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
61 static struct sql_db *_driver_sqlite_init(const char *connect_string)
3923
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
62 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
63 struct sqlite_db *db;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
64 pool_t pool;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
65
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
66 i_assert(connect_string != NULL);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
67
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
68 pool = pool_alloconly_create("sqlite driver", 512);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
69 db = p_new(pool, struct sqlite_db, 1);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
70 db->pool = pool;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
71 db->api = driver_sqlite_db;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
72 db->dbfile = p_strdup(db->pool, connect_string);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
73 db->connected = FALSE;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
74
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
75 return &db->api;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
76 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
77
3943
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
78 static void _driver_sqlite_deinit(struct sql_db *_db)
3923
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
79 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
80 struct sqlite_db *db = (struct sqlite_db *)_db;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
81
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
82 sqlite3_close(db->sqlite);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
83 pool_unref(db->pool);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
84 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
85
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
86 static enum sql_db_flags
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
87 driver_sqlite_get_flags(struct sql_db *db __attr_unused__)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
88 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
89 return SQL_DB_FLAG_BLOCKING;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
90 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
91
4294
1a98cb709395 Added sql_escape_string()
Timo Sirainen <tss@iki.fi>
parents: 3947
diff changeset
92 static char *driver_sqlite_escape_string(struct sql_db *_db __attr_unused__,
1a98cb709395 Added sql_escape_string()
Timo Sirainen <tss@iki.fi>
parents: 3947
diff changeset
93 const char *string)
1a98cb709395 Added sql_escape_string()
Timo Sirainen <tss@iki.fi>
parents: 3947
diff changeset
94 {
1a98cb709395 Added sql_escape_string()
Timo Sirainen <tss@iki.fi>
parents: 3947
diff changeset
95 return t_strdup_noconst(str_escape(string));
1a98cb709395 Added sql_escape_string()
Timo Sirainen <tss@iki.fi>
parents: 3947
diff changeset
96 }
1a98cb709395 Added sql_escape_string()
Timo Sirainen <tss@iki.fi>
parents: 3947
diff changeset
97
3923
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
98 static void driver_sqlite_exec(struct sql_db *_db, const char *query)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
99 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
100 struct sqlite_db *db = (struct sqlite_db *)_db;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
101
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
102 db->rc = sqlite3_exec(db->sqlite, query, NULL, 0, NULL);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
103 if (db->rc != SQLITE_OK) {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
104 i_error("sqlite: exec(%s) failed: %s (%d)",
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
105 query, sqlite3_errmsg(db->sqlite), db->rc);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
106 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
107 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
108
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
109 static void driver_sqlite_query(struct sql_db *db, const char *query,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
110 sql_query_callback_t *callback, void *context)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
111 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
112 struct sql_result *result;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
113
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
114 result = sql_query_s(db, query);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
115 result->callback = TRUE;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
116 callback(result, context);
3946
d7051c7a0200 Fixed memory leaks
Timo Sirainen <tss@iki.fi>
parents: 3943
diff changeset
117 result->callback = FALSE;
3923
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
118 sql_result_free(result);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
119 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
120
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
121 static struct sql_result *
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
122 driver_sqlite_query_s(struct sql_db *_db, const char *query)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
123 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
124 struct sqlite_db *db = (struct sqlite_db *)_db;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
125 struct sqlite_result *result;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
126 int rc;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
127
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
128 result = i_new(struct sqlite_result, 1);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
129
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
130 rc = sqlite3_prepare(db->sqlite, query, -1, &result->stmt, NULL);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
131 if (rc == SQLITE_OK) {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
132 result->api = driver_sqlite_result;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
133 result->cols = sqlite3_column_count(result->stmt);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
134 result->row = i_new(const char *, result->cols);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
135 } else {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
136 result->api = driver_sqlite_error_result;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
137 result->stmt = NULL;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
138 result->cols = 0;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
139 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
140 result->api.db = _db;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
141
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
142 return &result->api;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
143 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
144
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
145 static void driver_sqlite_result_free(struct sql_result *_result)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
146 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
147 struct sqlite_result *result = (struct sqlite_result *)_result;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
148 struct sqlite_db *db = (struct sqlite_db *) result->api.db;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
149 int rc;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
150
3947
5b21fb41d14d Cleanups.
Timo Sirainen <tss@iki.fi>
parents: 3946
diff changeset
151 if (_result->callback)
5b21fb41d14d Cleanups.
Timo Sirainen <tss@iki.fi>
parents: 3946
diff changeset
152 return;
5b21fb41d14d Cleanups.
Timo Sirainen <tss@iki.fi>
parents: 3946
diff changeset
153
3923
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
154 if (result->stmt != NULL) {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
155 if ((rc = sqlite3_finalize(result->stmt)) != SQLITE_OK) {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
156 i_warning("sqlite: finalize failed: %s (%d)",
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
157 sqlite3_errmsg(db->sqlite), rc);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
158 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
159 i_free(result->row);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
160 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
161 i_free(result);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
162 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
163
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
164 static int driver_sqlite_result_next_row(struct sql_result *_result)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
165 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
166 struct sqlite_result *result = (struct sqlite_result *)_result;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
167
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
168 switch (sqlite3_step(result->stmt)) {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
169 case SQLITE_ROW:
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
170 return 1;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
171 case SQLITE_DONE:
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
172 return 0;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
173 default:
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
174 return -1;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
175 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
176 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
177
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
178 static unsigned int
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
179 driver_sqlite_result_get_fields_count(struct sql_result *_result)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
180 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
181 struct sqlite_result *result = (struct sqlite_result *)_result;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
182
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
183 return result->cols;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
184 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
185
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
186 static const char *
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
187 driver_sqlite_result_get_field_name(struct sql_result *_result,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
188 unsigned int idx)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
189 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
190 struct sqlite_result *result = (struct sqlite_result *)_result;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
191
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
192 return sqlite3_column_name(result->stmt, idx);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
193 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
194
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
195 static int driver_sqlite_result_find_field(struct sql_result *_result,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
196 const char *field_name)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
197 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
198 struct sqlite_result *result = (struct sqlite_result *)_result;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
199 unsigned int i;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
200
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
201 for (i = 0; i < result->cols; ++i) {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
202 const char *col = sqlite3_column_name(result->stmt, i);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
203
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
204 if (strcmp(col, field_name) == 0)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
205 return i;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
206 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
207
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
208 return -1;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
209 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
210
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
211 static const char *
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
212 driver_sqlite_result_get_field_value(struct sql_result *_result,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
213 unsigned int idx)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
214 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
215 struct sqlite_result *result = (struct sqlite_result *)_result;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
216
3936
8e827b05047b Compiler warning fix. Patch by Marcus Rueckert
Timo Sirainen <tss@iki.fi>
parents: 3923
diff changeset
217 return (const char*)sqlite3_column_text(result->stmt, idx);
3923
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
218 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
219
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
220 static const char *
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
221 driver_sqlite_result_find_field_value(struct sql_result *result,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
222 const char *field_name)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
223 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
224 int idx;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
225
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
226 idx = driver_sqlite_result_find_field(result, field_name);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
227 if (idx < 0)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
228 return NULL;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
229 return driver_sqlite_result_get_field_value(result, idx);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
230 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
231
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
232 static const char *const *
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
233 driver_sqlite_result_get_values(struct sql_result *_result)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
234 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
235 struct sqlite_result *result = (struct sqlite_result *)_result;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
236 unsigned int i;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
237
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
238 for (i = 0; i < result->cols; ++i) {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
239 result->row[i] =
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
240 driver_sqlite_result_get_field_value(_result, i);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
241 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
242
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
243 return (const char *const *)result->row;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
244 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
245
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
246 static const char *driver_sqlite_result_get_error(struct sql_result *_result)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
247 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
248 struct sqlite_result *result = (struct sqlite_result *)_result;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
249 struct sqlite_db *db = (struct sqlite_db *)result->api.db;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
250
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
251 return sqlite3_errmsg(db->sqlite);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
252 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
253
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
254 static struct sql_transaction_context *
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
255 driver_sqlite_transaction_begin(struct sql_db *_db)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
256 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
257 struct sqlite_transaction_context *ctx;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
258 struct sqlite_db *db = (struct sqlite_db *)_db;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
259
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
260 ctx = i_new(struct sqlite_transaction_context, 1);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
261 ctx->ctx.db = _db;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
262
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
263 sql_exec(_db, "BEGIN TRANSACTION");
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
264 if (db->rc != SQLITE_OK)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
265 ctx->failed = TRUE;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
266
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
267 return &ctx->ctx;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
268 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
269
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
270 static void
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
271 driver_sqlite_transaction_rollback(struct sql_transaction_context *_ctx)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
272 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
273 struct sqlite_transaction_context *ctx =
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
274 (struct sqlite_transaction_context *)_ctx;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
275
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
276 sql_exec(_ctx->db, "ROLLBACK");
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
277 i_free(ctx);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
278 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
279
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
280 static void
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
281 driver_sqlite_transaction_commit(struct sql_transaction_context *_ctx,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
282 sql_commit_callback_t *callback, void *context)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
283 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
284 struct sqlite_transaction_context *ctx =
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
285 (struct sqlite_transaction_context *)_ctx;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
286 struct sqlite_db *db = (struct sqlite_db *)ctx->ctx.db;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
287 const char *errmsg;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
288
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
289 if (!ctx->failed) {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
290 sql_exec(_ctx->db, "COMMIT");
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
291 if (db->rc != SQLITE_OK)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
292 ctx->failed = TRUE;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
293 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
294
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
295 if (ctx->failed) {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
296 errmsg = sqlite3_errmsg(db->sqlite);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
297 callback(errmsg, context);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
298 /* also does i_free(ctx) */
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
299 driver_sqlite_transaction_rollback(_ctx);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
300 } else {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
301 callback(NULL, context);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
302 i_free(ctx);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
303 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
304 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
305
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
306 static int
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
307 driver_sqlite_transaction_commit_s(struct sql_transaction_context *_ctx,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
308 const char **error_r)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
309 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
310 struct sqlite_transaction_context *ctx =
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
311 (struct sqlite_transaction_context *)_ctx;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
312 struct sqlite_db *db = (struct sqlite_db *) ctx->ctx.db;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
313
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
314 if (ctx->failed) {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
315 /* also does i_free(ctx) */
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
316 driver_sqlite_transaction_rollback(_ctx);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
317 return -1;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
318 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
319
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
320 sql_exec(_ctx->db, "COMMIT");
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
321 *error_r = sqlite3_errmsg(db->sqlite);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
322 i_free(ctx);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
323 return 0;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
324 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
325
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
326 static void
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
327 driver_sqlite_update(struct sql_transaction_context *_ctx, const char *query)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
328 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
329 struct sqlite_transaction_context *ctx =
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
330 (struct sqlite_transaction_context *)_ctx;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
331 struct sqlite_db *db = (struct sqlite_db *)ctx->ctx.db;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
332
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
333 if (ctx->failed)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
334 return;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
335
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
336 sql_exec(_ctx->db, query);
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
337 if (db->rc != SQLITE_OK)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
338 ctx->failed = TRUE;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
339 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
340
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
341 struct sql_db driver_sqlite_db = {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
342 "sqlite",
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
343
3943
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
344 _driver_sqlite_init,
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
345 _driver_sqlite_deinit,
3923
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
346 driver_sqlite_get_flags,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
347 driver_sqlite_connect,
4294
1a98cb709395 Added sql_escape_string()
Timo Sirainen <tss@iki.fi>
parents: 3947
diff changeset
348 driver_sqlite_escape_string,
3923
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
349 driver_sqlite_exec,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
350 driver_sqlite_query,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
351 driver_sqlite_query_s,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
352
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
353 driver_sqlite_transaction_begin,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
354 driver_sqlite_transaction_commit,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
355 driver_sqlite_transaction_commit_s,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
356 driver_sqlite_transaction_rollback,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
357 driver_sqlite_update
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
358 };
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
359
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
360 struct sql_result driver_sqlite_result = {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
361 NULL,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
362
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
363 driver_sqlite_result_free,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
364 driver_sqlite_result_next_row,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
365 driver_sqlite_result_get_fields_count,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
366 driver_sqlite_result_get_field_name,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
367 driver_sqlite_result_find_field,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
368 driver_sqlite_result_get_field_value,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
369 driver_sqlite_result_find_field_value,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
370 driver_sqlite_result_get_values,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
371 driver_sqlite_result_get_error,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
372
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
373 FALSE
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
374 };
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
375
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
376 static int
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
377 driver_sqlite_result_error_next_row(struct sql_result *result __attr_unused__)
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
378 {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
379 return -1;
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
380 }
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
381
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
382 struct sql_result driver_sqlite_error_result = {
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
383 NULL,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
384
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
385 driver_sqlite_result_free,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
386 driver_sqlite_result_error_next_row,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
387 NULL, NULL, NULL, NULL, NULL, NULL,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
388 driver_sqlite_result_get_error,
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
389
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
390 FALSE
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
391 };
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
392
3943
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
393 void driver_sqlite_init(void);
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
394 void driver_sqlite_deinit(void);
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
395
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
396 void driver_sqlite_init(void)
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
397 {
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
398 sql_driver_register(&driver_sqlite_db);
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
399 }
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
400
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
401 void driver_sqlite_deinit(void)
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
402 {
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
403 sql_driver_unregister(&driver_sqlite_db);
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
404 }
cbe5c6772e0d Added support for dynamically building SQL drivers.
Timo Sirainen <tss@iki.fi>
parents: 3936
diff changeset
405
3923
e9d45ec624cb Forgot to add in sqlite patch.
Timo Sirainen <tss@iki.fi>
parents:
diff changeset
406 #endif