summaryrefslogtreecommitdiff
path: root/ext
diff options
context:
space:
mode:
authorZak Greant <zak@php.net>2003-07-15 18:19:51 +0000
committerZak Greant <zak@php.net>2003-07-15 18:19:51 +0000
commitc0bd985ad90014e6ccb4a1e10fda8ddc25d5480e (patch)
tree9ec29e021925a6d75806c9ea13c8c150077c0b59 /ext
parente3a55ba2975d742fda74a14be4fd73c975f14cb0 (diff)
downloadphp-git-c0bd985ad90014e6ccb4a1e10fda8ddc25d5480e.tar.gz
Added function dbase_get_header_info
* Passed a handle for an open dbase database, it returns an array of associative arrays. Each associative array contains information on a single column, including name, column type, length, precision, ...
Diffstat (limited to 'ext')
-rw-r--r--ext/dbase/dbase.c63
-rw-r--r--ext/dbase/php_dbase.h1
2 files changed, 64 insertions, 0 deletions
diff --git a/ext/dbase/dbase.c b/ext/dbase/dbase.c
index 9df8ad0174..4874eff26f 100644
--- a/ext/dbase/dbase.c
+++ b/ext/dbase/dbase.c
@@ -737,10 +737,73 @@ function_entry dbase_functions[] = {
PHP_FE(dbase_get_record_with_names, NULL)
PHP_FE(dbase_delete_record, NULL)
PHP_FE(dbase_pack, NULL)
+ PHP_FE(dbase_get_header_info, NULL)
{NULL, NULL, NULL}
};
/* }}} */
+/* Added by Zak Greant <zak@php.net> */
+/* {{{ proto array dbase_get_header_info(int database_handle)
+ */
+PHP_FUNCTION(dbase_get_header_info)
+{
+ zval **dbh_id, *row;
+ dbfield_t *dbf, *cur_f;
+ dbhead_t *dbh;
+ int dbh_type;
+ DBase_TLS_VARS;
+
+ if (ZEND_NUM_ARGS() != 1 || (zend_get_parameters_ex(1, &dbh_id) == FAILURE)) {
+ WRONG_PARAM_COUNT;
+ }
+ convert_to_long_ex(dbh_id);
+
+ dbh = zend_list_find(Z_LVAL_PP(dbh_id), &dbh_type);
+ if (!dbh || dbh_type != DBase_GLOBAL(le_dbhead)) {
+ php_error_docref(NULL TSRMLS_CC, E_WARNING, "Unable to find database for identifier %d", Z_LVAL_PP(dbh_id));
+ RETURN_FALSE;
+ }
+
+ if (array_init(return_value)==FAILURE) {
+ RETURN_FALSE;
+ }
+
+ dbf = dbh->db_fields;
+ for (cur_f = dbf; cur_f < &dbh->db_fields[dbh->db_nfields]; ++cur_f) {
+ MAKE_STD_ZVAL(row);
+ array_init(row);
+
+ add_next_index_zval(return_value, row);
+
+ /* field name */
+ add_assoc_string(row, "name", cur_f->db_fname, 1);
+
+ /* field type */
+ switch (cur_f->db_type) {
+ case 'C': add_assoc_string(row, "type", "character", 1); break;
+ case 'D': add_assoc_string(row, "type", "date", 1); break;
+ case 'I': add_assoc_string(row, "type", "integer", 1); break;
+ case 'N': add_assoc_string(row, "type", "number", 1); break;
+ case 'L': add_assoc_string(row, "type", "boolean", 1); break;
+ case 'M': add_assoc_string(row, "type", "memo", 1); break;
+ default: add_assoc_string(row, "type", "unknown", 1); break;
+ }
+
+ /* length of field */
+ add_assoc_long(row, "length", cur_f->db_flen);
+
+ /* number of decimals in field */
+ add_assoc_long(row, "decimal places", cur_f->db_fdc);
+
+ /* format for printing %s etc */
+ add_assoc_string(row, "printf format", cur_f->db_format, 1);
+
+ /* offset within record */
+ add_assoc_long(row, "record offset", cur_f->db_foffset);
+ }
+}
+/* }}} */
+
zend_module_entry dbase_module_entry = {
STANDARD_MODULE_HEADER,
"dbase", dbase_functions, PHP_MINIT(dbase), PHP_MSHUTDOWN(dbase), NULL, NULL, NULL, NO_VERSION_YET, STANDARD_MODULE_PROPERTIES
diff --git a/ext/dbase/php_dbase.h b/ext/dbase/php_dbase.h
index c51b34b0c3..f445808933 100644
--- a/ext/dbase/php_dbase.h
+++ b/ext/dbase/php_dbase.h
@@ -35,6 +35,7 @@ PHP_FUNCTION(dbase_get_record);
PHP_FUNCTION(dbase_delete_record);
PHP_FUNCTION(dbase_pack);
PHP_FUNCTION(dbase_get_record_with_names);
+PHP_FUNCTION(dbase_get_header_info);
#else
#define dbase_module_ptr NULL
#endif