summaryrefslogtreecommitdiff
path: root/ext/sqlite/sqlite.c
diff options
context:
space:
mode:
authorEdin Kadribasic <edink@php.net>2003-04-22 00:08:48 +0000
committerEdin Kadribasic <edink@php.net>2003-04-22 00:08:48 +0000
commit43349ea014a2f7b4c9cf1118dacd0f3c7e2a52cc (patch)
tree0bef9be20b31544ecc7f715e9aa413e5178a1f98 /ext/sqlite/sqlite.c
parent04c5e2fc067507c7d8142259eb74d784eb048189 (diff)
downloadphp-git-43349ea014a2f7b4c9cf1118dacd0f3c7e2a52cc.tar.gz
Added sqlite.assoc_case ini entry with 0 as the default value.
0 - Make no changes to the keys in the associative array 1 - Change the keys to uppercase 2 - Change the keys to lowercase
Diffstat (limited to 'ext/sqlite/sqlite.c')
-rw-r--r--ext/sqlite/sqlite.c44
1 files changed, 44 insertions, 0 deletions
diff --git a/ext/sqlite/sqlite.c b/ext/sqlite/sqlite.c
index 291130e423..89a51291a6 100644
--- a/ext/sqlite/sqlite.c
+++ b/ext/sqlite/sqlite.c
@@ -37,6 +37,8 @@
#include <sqlite.h>
+ZEND_DECLARE_MODULE_GLOBALS(sqlite)
+
extern int sqlite_encode_binary(const unsigned char *in, int n, unsigned char *out);
extern int sqlite_decode_binary(const unsigned char *in, unsigned char *out);
@@ -44,6 +46,30 @@ static unsigned char arg3_force_ref[] = {3, BYREF_NONE, BYREF_NONE, BYREF_FORCE
static int le_sqlite_db, le_sqlite_result, le_sqlite_pdb;
+static inline void php_sqlite_strtoupper(char *s)
+{
+ while (*s!='\0') {
+ *s = toupper(*s);
+ s++;
+ }
+}
+
+static inline void php_sqlite_strtolower(char *s)
+{
+ while (*s!='\0') {
+ *s = tolower(*s);
+ s++;
+ }
+}
+
+/* {{{ PHP_INI
+ */
+PHP_INI_BEGIN()
+STD_PHP_INI_ENTRY_EX("sqlite.assoc_case", "0", PHP_INI_ALL, OnUpdateInt, assoc_case, zend_sqlite_globals, sqlite_globals, display_link_numbers)
+PHP_INI_END()
+/* }}} */
+
+
#define DB_FROM_ZVAL(db, zv) ZEND_FETCH_RESOURCE2(db, struct php_sqlite_db *, zv, -1, "sqlite database", le_sqlite_db, le_sqlite_pdb)
struct php_sqlite_result {
@@ -535,6 +561,7 @@ static int php_sqlite_authorizer(void *autharg, int access_type, const char *arg
PHP_MINIT_FUNCTION(sqlite)
{
+ REGISTER_INI_ENTRIES();
le_sqlite_db = zend_register_list_destructors_ex(php_sqlite_db_dtor, NULL, "sqlite database", module_number);
le_sqlite_pdb = zend_register_list_destructors_ex(NULL, php_sqlite_db_dtor, "sqlite database (persistent)", module_number);
le_sqlite_result = zend_register_list_destructors_ex(php_sqlite_result_dtor, NULL, "sqlite result", module_number);
@@ -581,6 +608,8 @@ PHP_MINFO_FUNCTION(sqlite)
php_info_print_table_row(2, "SQLite Library", sqlite_libversion());
php_info_print_table_row(2, "SQLite Encoding", sqlite_libencoding());
php_info_print_table_end();
+
+ DISPLAY_INI_ENTRIES();
}
static struct php_sqlite_db *php_sqlite_open(char *filename, int mode, char *persistent_id, zval *return_value, zval *errmsg)
@@ -1007,6 +1036,12 @@ PHP_FUNCTION(sqlite_fetch_array)
}
}
if (mode & PHPSQLITE_ASSOC) {
+ /* Lets see if we need to change case of the assoc key */
+ if (SQLITE_G(assoc_case) == 1) {
+ php_sqlite_strtoupper((char*)colnames[j]);
+ } else if (SQLITE_G(assoc_case) == 2) {
+ php_sqlite_strtolower((char*)colnames[j]);
+ }
if (decoded == NULL) {
add_assoc_null(return_value, (char*)colnames[j]);
} else {
@@ -1386,3 +1421,12 @@ PHP_FUNCTION(sqlite_create_function)
}
}
/* }}} */
+
+/*
+ * Local variables:
+ * tab-width: 4
+ * c-basic-offset: 4
+ * End:
+ * vim600: sw=4 ts=4 fdm=marker
+ * vim<600: sw=4 ts=4
+ */