diff options
author | Mark A. Hershberger <mah@debian.(none)> | 2009-03-25 00:34:21 -0400 |
---|---|---|
committer | Mark A. Hershberger <mah@debian.(none)> | 2009-03-25 00:34:21 -0400 |
commit | 0e920280a2e04b110827bb766b9f29e3d581c4ee (patch) | |
tree | 8f2125f3d00fe3089e3b94adb06f04479ee15f2a /ext/sybase_ct/php_sybase_ct.h | |
download | php-0e920280a2e04b110827bb766b9f29e3d581c4ee.tar.gz |
Imported Upstream version 5.0.4upstream/5.0.4
Diffstat (limited to 'ext/sybase_ct/php_sybase_ct.h')
-rw-r--r-- | ext/sybase_ct/php_sybase_ct.h | 131 |
1 files changed, 131 insertions, 0 deletions
diff --git a/ext/sybase_ct/php_sybase_ct.h b/ext/sybase_ct/php_sybase_ct.h new file mode 100644 index 000000000..2386be12c --- /dev/null +++ b/ext/sybase_ct/php_sybase_ct.h @@ -0,0 +1,131 @@ +/* + +----------------------------------------------------------------------+ + | PHP Version 5 | + +----------------------------------------------------------------------+ + | Copyright (c) 1997-2004 The PHP Group | + +----------------------------------------------------------------------+ + | This source file is subject to version 3.0 of the PHP license, | + | that is bundled with this package in the file LICENSE, and is | + | available through the world-wide-web at the following url: | + | http://www.php.net/license/3_0.txt. | + | If you did not receive a copy of the PHP license and are unable to | + | obtain it through the world-wide-web, please send a note to | + | license@php.net so we can mail you a copy immediately. | + +----------------------------------------------------------------------+ + | Authors: Zeev Suraski <zeev@zend.com> | + | Timm Friebe <php_sybase_ct@thekid.de> | + +----------------------------------------------------------------------+ +*/ + +/* $Id: php_sybase_ct.h,v 1.18 2004/01/25 20:03:10 thekid Exp $ */ + +#ifndef PHP_SYBASE_CT_H +#define PHP_SYBASE_CT_H + +#if HAVE_SYBASE_CT + +#define CTLIB_VERSION CS_VERSION_100 + +extern zend_module_entry sybase_module_entry; +#define sybase_module_ptr &sybase_module_entry + +PHP_MINIT_FUNCTION(sybase); +PHP_MSHUTDOWN_FUNCTION(sybase); +PHP_RINIT_FUNCTION(sybase); +PHP_RSHUTDOWN_FUNCTION(sybase); +PHP_MINFO_FUNCTION(sybase); + +PHP_FUNCTION(sybase_connect); +PHP_FUNCTION(sybase_pconnect); +PHP_FUNCTION(sybase_close); +PHP_FUNCTION(sybase_select_db); +PHP_FUNCTION(sybase_query); +PHP_FUNCTION(sybase_unbuffered_query); +PHP_FUNCTION(sybase_free_result); +PHP_FUNCTION(sybase_get_last_message); +PHP_FUNCTION(sybase_num_rows); +PHP_FUNCTION(sybase_num_fields); +PHP_FUNCTION(sybase_fetch_row); +PHP_FUNCTION(sybase_fetch_array); +PHP_FUNCTION(sybase_fetch_assoc); +PHP_FUNCTION(sybase_fetch_object); +PHP_FUNCTION(sybase_data_seek); +PHP_FUNCTION(sybase_result); +PHP_FUNCTION(sybase_affected_rows); +PHP_FUNCTION(sybase_field_seek); +PHP_FUNCTION(sybase_min_client_severity); +PHP_FUNCTION(sybase_min_server_severity); +PHP_FUNCTION(sybase_fetch_field); +PHP_FUNCTION(sybase_set_message_handler); +PHP_FUNCTION(sybase_deadlock_retry_count); + +#include <ctpublic.h> + +ZEND_BEGIN_MODULE_GLOBALS(sybase) + long default_link; + long num_links,num_persistent; + long max_links,max_persistent; + long login_timeout; + long allow_persistent; + char *appname; + char *hostname; + char *server_message; + long min_server_severity, min_client_severity; + long deadlock_retry_count; + zval *callback_name; + CS_CONTEXT *context; +ZEND_END_MODULE_GLOBALS(sybase) + +typedef struct { + CS_CONNECTION *connection; + CS_COMMAND *cmd; + int valid; + int deadlock; + int dead; + int active_result_index; + long affected_rows; + zval *callback_name; +} sybase_link; + +#define SYBASE_ROWS_BLOCK 128 + +typedef struct { + char *name,*column_source; + int max_length, numeric; + CS_INT type; +} sybase_field; + +typedef struct { + pval **data; + sybase_field *fields; + sybase_link *sybase_ptr; + int cur_row,cur_field; + int num_rows,num_fields; + + /* For unbuffered reads */ + CS_INT *lengths; + CS_SMALLINT *indicators; + char **tmp_buffer; + unsigned char *numerics; + CS_INT *types; + CS_DATAFMT *datafmt; + int blocks_initialized; + CS_RETCODE last_retcode; + int store; +} sybase_result; + +#ifdef ZTS +# define SybCtG(v) TSRMG(sybase_globals_id, zend_sybase_globals *, v) +#else +# define SybCtG(v) (sybase_globals.v) +#endif + +#else + +#define sybase_module_ptr NULL + +#endif + +#define phpext_sybase_ct_ptr sybase_module_ptr + +#endif /* PHP_SYBASE_CT_H */ |