diff options
author | Edin Kadribasic <edink@php.net> | 2003-04-22 00:08:48 +0000 |
---|---|---|
committer | Edin Kadribasic <edink@php.net> | 2003-04-22 00:08:48 +0000 |
commit | 43349ea014a2f7b4c9cf1118dacd0f3c7e2a52cc (patch) | |
tree | 0bef9be20b31544ecc7f715e9aa413e5178a1f98 /ext/sqlite/sqlite.c | |
parent | 04c5e2fc067507c7d8142259eb74d784eb048189 (diff) | |
download | php-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.c | 44 |
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 + */ |