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 + */ | 
