⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 php_sybase_db.c

📁 php-4.4.7学习linux时下载的源代码
💻 C
📖 第 1 页 / 共 3 页
字号:
/*   +----------------------------------------------------------------------+   | PHP Version 4                                                        |   +----------------------------------------------------------------------+   | Copyright (c) 1997-2007 The PHP Group                                |   +----------------------------------------------------------------------+   | This source file is subject to version 3.01 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_01.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>                                |   +----------------------------------------------------------------------+   | php_sybase_get_column_content_with_type() based on code by:          |   |                     Muhammad A Muquit <MA_Muquit@fccc.edu>           |   |                     Rasmus Lerdorf <rasmus@lerdorf.on.ca>            |   +----------------------------------------------------------------------+ */ /* $Id: php_sybase_db.c,v 1.38.2.17.2.2 2007/01/01 09:46:49 sebastian Exp $ */#ifdef HAVE_CONFIG_H#include "config.h"#endif#include "php.h"#include "php_sybase_db.h"#include "ext/standard/php_standard.h"#include "ext/standard/info.h"#include "php_globals.h"#if HAVE_SYBASE#include <sybfront.h>#include <sybdb.h>#include <syberror.h>#if BROKEN_SYBASE_PCONNECTS#include "http_log.h"#endif/* Moved these structures/defines into the .c file (or into a *private* header),   because leaving them in php_sybase_db.h caused namespace pollution in   main/internal_functions.c. */#define coltype(j) dbcoltype(sybase_ptr->link,j)#define intcol(i) ((int) *(DBINT *) dbdata(sybase_ptr->link,i))#define smallintcol(i) ((int) *(DBSMALLINT *) dbdata(sybase_ptr->link,i))#define tinyintcol(i) ((int) *(DBTINYINT *) dbdata(sybase_ptr->link,i))#define anyintcol(j) (coltype(j)==SYBINT4?intcol(j):(coltype(j)==SYBINT2?smallintcol(j):tinyintcol(j)))#define charcol(i) ((DBCHAR *) dbdata(sybase_ptr->link,i))#define floatcol(i) ((float) *(DBFLT8 *) dbdata(sybase_ptr->link,i))typedef struct sybase_link_struct sybase_link;struct sybase_link_struct {        LOGINREC *login;        DBPROCESS *link;        int valid;};#define SYBASE_ROWS_BLOCK 128typedef struct {        char *name,*column_source;        int max_length, numeric;        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;} sybase_result;function_entry sybase_functions[] = {	PHP_FE(sybase_connect,			NULL)	PHP_FE(sybase_pconnect,			NULL)	PHP_FE(sybase_close,			NULL)	PHP_FE(sybase_select_db,		NULL)	PHP_FE(sybase_query,			NULL)	PHP_FE(sybase_free_result,		NULL)	PHP_FE(sybase_get_last_message,	NULL)	PHP_FE(sybase_num_rows,			NULL)	PHP_FE(sybase_num_fields,		NULL)	PHP_FE(sybase_fetch_row,		NULL)	PHP_FE(sybase_fetch_array,		NULL)	PHP_FE(sybase_fetch_object,		NULL)	PHP_FE(sybase_data_seek,		NULL)	PHP_FE(sybase_fetch_field,		NULL)	PHP_FE(sybase_field_seek,		NULL)	PHP_FE(sybase_result,			NULL)	PHP_FE(sybase_affected_rows,		NULL)	PHP_FE(sybase_min_error_severity,	NULL)	PHP_FE(sybase_min_message_severity,	NULL)	PHP_FALIAS(mssql_connect,		sybase_connect,			NULL)	PHP_FALIAS(mssql_pconnect,		sybase_pconnect,		NULL)	PHP_FALIAS(mssql_close,			sybase_close,			NULL)	PHP_FALIAS(mssql_select_db,		sybase_select_db,		NULL)	PHP_FALIAS(mssql_query,			sybase_query,			NULL)	PHP_FALIAS(mssql_free_result,	sybase_free_result,		NULL)	PHP_FALIAS(mssql_get_last_message,	sybase_get_last_message,	NULL)	PHP_FALIAS(mssql_num_rows,		sybase_num_rows,		NULL)	PHP_FALIAS(mssql_num_fields,	sybase_num_fields,		NULL)	PHP_FALIAS(mssql_fetch_row,		sybase_fetch_row,		NULL)	PHP_FALIAS(mssql_fetch_array,	sybase_fetch_array,		NULL)	PHP_FALIAS(mssql_fetch_object,	sybase_fetch_object,	NULL)	PHP_FALIAS(mssql_data_seek,		sybase_data_seek,		NULL)	PHP_FALIAS(mssql_fetch_field,	sybase_fetch_field,		NULL)	PHP_FALIAS(mssql_field_seek,	sybase_field_seek,		NULL)	PHP_FALIAS(mssql_result,		sybase_result,			NULL)	PHP_FALIAS(mssql_affected_rows,		sybase_affected_rows,			NULL)	PHP_FALIAS(mssql_min_error_severity,	sybase_min_error_severity,		NULL)	PHP_FALIAS(mssql_min_message_severity,	sybase_min_message_severity,	NULL)	{NULL, NULL, NULL}};zend_module_entry sybase_module_entry = {	STANDARD_MODULE_HEADER,	"sybase", sybase_functions, PHP_MINIT(sybase), PHP_MSHUTDOWN(sybase), PHP_RINIT(sybase), PHP_RSHUTDOWN(sybase), PHP_MINFO(sybase), NO_VERSION_YET, STANDARD_MODULE_PROPERTIES};#ifdef COMPILE_DL_SYBASEZEND_GET_MODULE(sybase)#endifTHREAD_LS sybase_module php_sybase_module;#define CHECK_LINK(link) { if (link==-1) { php_error_docref(NULL TSRMLS_CC, E_WARNING, "Sybase:  A link to the server could not be established"); RETURN_FALSE; } }static void php_sybase_get_column_content(sybase_link *sybase_ptr,int offset,pval **result_ptr, int column_type);/* error handler */static int php_sybase_error_handler(DBPROCESS *dbproc,int severity,int dberr,										int oserr,char *dberrstr,char *oserrstr){	if (severity >= php_sybase_module.min_error_severity) {		TSRMLS_FETCH();		php_error_docref(NULL TSRMLS_CC, E_WARNING, "Sybase error:  %s (severity %d)",dberrstr,severity);	}	return INT_CANCEL;  }/* message handler */static int php_sybase_message_handler(DBPROCESS *dbproc,DBINT msgno,int msgstate,										int severity,char *msgtext,char *srvname,										char *procname,DBUSMALLINT line){	if (severity >= php_sybase_module.min_message_severity) {		TSRMLS_FETCH();		php_error_docref(NULL TSRMLS_CC, E_WARNING, "Sybase message:  %s (severity %d)",msgtext,severity);	}	STR_FREE(php_sybase_module.server_message);	php_sybase_module.server_message = estrdup(msgtext);	return 0;}static int _clean_invalid_results(list_entry *le TSRMLS_DC){	if (Z_TYPE_P(le) == php_sybase_module.le_result) {		sybase_link *sybase_ptr = ((sybase_result *) le->ptr)->sybase_ptr;				if (!sybase_ptr->valid) {			return 1;		}	}	return 0;}static void _free_sybase_result(zend_rsrc_list_entry *rsrc TSRMLS_DC){	sybase_result *result = (sybase_result *)rsrc->ptr;	int i,j;		if (result->data) {		for (i=0; i<result->num_rows; i++) {			for (j=0; j<result->num_fields; j++) {				zval_ptr_dtor(&result->data[i][j]);			}			efree(result->data[i]);		}		efree(result->data);	}		if (result->fields) {		for (i=0; i<result->num_fields; i++) {			STR_FREE(result->fields[i].name);			STR_FREE(result->fields[i].column_source);		}		efree(result->fields);	}	efree(result);}static void _close_sybase_link(zend_rsrc_list_entry *rsrc TSRMLS_DC){	sybase_link *sybase_ptr = (sybase_link *)rsrc->ptr;	sybase_ptr->valid = 0;    /* 	  this can cause crashes in the current model.      if the resource gets destroyed via destroy_resource_list() resource_list      will *not* be in a consistent state. thies@thieso.net    */	zend_hash_apply(&EG(regular_list), (apply_func_t) _clean_invalid_results TSRMLS_CC);	dbclose(sybase_ptr->link);	dbloginfree(sybase_ptr->login);	efree(sybase_ptr);	php_sybase_module.num_links--;}static void _close_sybase_plink(zend_rsrc_list_entry *rsrc TSRMLS_DC){	sybase_link *sybase_ptr = (sybase_link *)rsrc->ptr;	dbclose(sybase_ptr->link);	dbloginfree(sybase_ptr->login);	free(sybase_ptr);	php_sybase_module.num_persistent--;	php_sybase_module.num_links--;}PHP_MINIT_FUNCTION(sybase){	char *interface_file;	if (dbinit()==FAIL) {		return FAILURE;	}	dberrhandle((EHANDLEFUNC) php_sybase_error_handler);	dbmsghandle((MHANDLEFUNC) php_sybase_message_handler);	if (cfg_get_string("sybase.interface_file",&interface_file)==SUCCESS) {		dbsetifile(interface_file);	}	if (cfg_get_long("sybase.allow_persistent",&php_sybase_module.allow_persistent)==FAILURE) {		php_sybase_module.allow_persistent=1;	}	if (cfg_get_long("sybase.max_persistent",&php_sybase_module.max_persistent)==FAILURE) {		php_sybase_module.max_persistent=-1;	}	if (cfg_get_long("sybase.max_links",&php_sybase_module.max_links)==FAILURE) {		php_sybase_module.max_links=-1;	}	if (cfg_get_long("sybase.min_error_severity",&php_sybase_module.cfg_min_error_severity)==FAILURE) {		php_sybase_module.cfg_min_error_severity=10;	}	if (cfg_get_long("sybase.min_message_severity",&php_sybase_module.cfg_min_message_severity)==FAILURE) {		php_sybase_module.cfg_min_message_severity=10;	}	if (cfg_get_long("sybase.compatability_mode",&php_sybase_module.compatability_mode)==FAILURE) {		php_sybase_module.compatability_mode = 0;	}		php_sybase_module.num_persistent=0;	php_sybase_module.le_link = zend_register_list_destructors_ex(_close_sybase_link, NULL, "sybase-db link", module_number);	php_sybase_module.le_plink = zend_register_list_destructors_ex(NULL, _close_sybase_plink, "sybase-db link persistent", module_number);	php_sybase_module.le_result = zend_register_list_destructors_ex(_free_sybase_result, NULL, "sybase-db result", module_number);		return SUCCESS;}PHP_RINIT_FUNCTION(sybase){	php_sybase_module.default_link=-1;	php_sybase_module.num_links = php_sybase_module.num_persistent;	php_sybase_module.appname = estrndup("PHP " PHP_VERSION, sizeof("PHP " PHP_VERSION));	php_sybase_module.server_message = empty_string;	php_sybase_module.min_error_severity = php_sybase_module.cfg_min_error_severity;	php_sybase_module.min_message_severity = php_sybase_module.cfg_min_message_severity;	return SUCCESS;}PHP_MSHUTDOWN_FUNCTION(sybase){	dbexit();	return SUCCESS;}PHP_RSHUTDOWN_FUNCTION(sybase){	efree(php_sybase_module.appname);	php_sybase_module.appname = NULL;	STR_FREE(php_sybase_module.server_message);	php_sybase_module.server_message = NULL;	return SUCCESS;}static void php_sybase_do_connect(INTERNAL_FUNCTION_PARAMETERS,int persistent){	char *user=NULL,*passwd=NULL,*host=NULL,*charset=NULL,*appname=NULL;	char *hashed_details;	int hashed_details_length;	sybase_link sybase,*sybase_ptr;	switch(ZEND_NUM_ARGS()) {		case 0: /* defaults */			hashed_details_length=6+3;			hashed_details = (char *) emalloc(hashed_details_length+1);			strcpy(hashed_details,"sybase___");			break;		case 1: {				zval **yyhost;								if (zend_get_parameters_ex(1, &yyhost) == FAILURE) {					RETURN_FALSE;				}				convert_to_string_ex(yyhost);				host = Z_STRVAL_PP(yyhost);				hashed_details_length = Z_STRLEN_PP(yyhost)+6+5;				hashed_details = (char *) emalloc(hashed_details_length+1);				sprintf(hashed_details,"sybase_%s____", Z_STRVAL_PP(yyhost));			}			break;		case 2: {				zval **yyhost, **yyuser;								if (zend_get_parameters_ex(2, &yyhost, &yyuser) == FAILURE) {					RETURN_FALSE;				}				convert_to_string_ex(yyhost);				convert_to_string_ex(yyuser);				host = Z_STRVAL_PP(yyhost);				user = Z_STRVAL_PP(yyuser);				hashed_details_length = Z_STRLEN_PP(yyhost)+Z_STRLEN_PP(yyuser)+6+5;				hashed_details = (char *) emalloc(hashed_details_length+1);				sprintf(hashed_details,"sybase_%s_%s___",Z_STRVAL_PP(yyhost),Z_STRVAL_PP(yyuser));			}			break;		case 3: {				zval **yyhost, **yyuser,**yypasswd;							if (zend_get_parameters_ex(3, &yyhost, &yyuser, &yypasswd) == FAILURE) {					RETURN_FALSE;				}				convert_to_string_ex(yyhost);				convert_to_string_ex(yyuser);				convert_to_string_ex(yypasswd);				host = Z_STRVAL_PP(yyhost);				user = Z_STRVAL_PP(yyuser);				passwd = Z_STRVAL_PP(yypasswd);				hashed_details_length = Z_STRLEN_PP(yyhost)+Z_STRLEN_PP(yyuser)+Z_STRLEN_PP(yypasswd)+6+5;				hashed_details = (char *) emalloc(hashed_details_length+1);				sprintf(hashed_details,"sybase_%s_%s_%s__",Z_STRVAL_PP(yyhost),Z_STRVAL_PP(yyuser),Z_STRVAL_PP(yypasswd)); /* SAFE */			}			break;		case 4: {				zval **yyhost, **yyuser, **yypasswd, **yycharset;				if (zend_get_parameters_ex(4, &yyhost, &yyuser, &yypasswd, &yycharset) == FAILURE) {					RETURN_FALSE;				}				convert_to_string_ex(yyhost);				convert_to_string_ex(yyuser);				convert_to_string_ex(yypasswd);				convert_to_string_ex(yycharset);				host = Z_STRVAL_PP(yyhost);				user = Z_STRVAL_PP(yyuser);				passwd = Z_STRVAL_PP(yypasswd);				charset = Z_STRVAL_PP(yycharset);				hashed_details_length = Z_STRLEN_PP(yyhost)+Z_STRLEN_PP(yyuser)+Z_STRLEN_PP(yypasswd)+Z_STRLEN_PP(yycharset)+6+5;				hashed_details = (char *) emalloc(hashed_details_length+1);				sprintf(hashed_details,"sybase_%s_%s_%s_%s_",Z_STRVAL_PP(yyhost),Z_STRVAL_PP(yyuser),Z_STRVAL_PP(yypasswd),Z_STRVAL_PP(yycharset)); /* SAFE */			}			break;		case 5: {				zval **yyhost, **yyuser, **yypasswd, **yycharset, **yyappname;				if (zend_get_parameters_ex(5, &yyhost, &yyuser, &yypasswd, &yycharset, &yyappname) == FAILURE) {					RETURN_FALSE;				}				convert_to_string_ex(yyhost);				convert_to_string_ex(yyuser);				convert_to_string_ex(yypasswd);				convert_to_string_ex(yycharset);				convert_to_string_ex(yyappname);				host = Z_STRVAL_PP(yyhost);				user = Z_STRVAL_PP(yyuser);				passwd = Z_STRVAL_PP(yypasswd);				charset = Z_STRVAL_PP(yycharset);				appname = Z_STRVAL_PP(yyappname);				hashed_details_length = Z_STRLEN_PP(yyhost)+Z_STRLEN_PP(yyuser)+Z_STRLEN_PP(yypasswd)+Z_STRLEN_PP(yycharset)+Z_STRLEN_PP(yyappname)+6+5;				hashed_details = (char *) emalloc(hashed_details_length+1);				sprintf(hashed_details,"sybase_%s_%s_%s_%s_%s",Z_STRVAL_PP(yyhost),Z_STRVAL_PP(yyuser),Z_STRVAL_PP(yypasswd),Z_STRVAL_PP(yycharset),Z_STRVAL_PP(yyappname)); /* SAFE */			}			break;		default:			WRONG_PARAM_COUNT;			break;	}	/* set a DBLOGIN record */		if ((sybase.login=dblogin())==NULL) {		php_error_docref(NULL TSRMLS_CC, E_WARNING,"Sybase:  Unable to allocate login record");		goto err;	}		if (user) {		DBSETLUSER(sybase.login,user);	}	if (passwd) {		DBSETLPWD(sybase.login,passwd);	}	if (charset) {		DBSETLCHARSET(sybase.login,charset);	}	if (appname) {		DBSETLAPP(sybase.login,appname);	} else {		DBSETLAPP(sybase.login,php_sybase_module.appname);	}	sybase.valid = 1;	if (!php_sybase_module.allow_persistent) {		persistent=0;	}	if (persistent) {		list_entry *le;		/* try to find if we already have this link in our persistent list */		if (zend_hash_find(&EG(persistent_list), hashed_details, hashed_details_length+1, (void **) &le)==FAILURE) {  /* we don't */			list_entry new_le;			if (php_sybase_module.max_links!=-1 && php_sybase_module.num_links>=php_sybase_module.max_links) {				php_error_docref(NULL TSRMLS_CC, E_WARNING,"Sybase:  Too many open links (%d)",php_sybase_module.num_links);				goto err_login;			}			if (php_sybase_module.max_persistent!=-1 && php_sybase_module.num_persistent>=php_sybase_module.max_persistent) {				php_error_docref(NULL TSRMLS_CC, E_WARNING,"Sybase:  Too many open persistent links (%d)",php_sybase_module.num_persistent);				goto err_login;			}			/* create the link */			if ((sybase.link=PHP_SYBASE_DBOPEN(sybase.login,host))==FAIL) {				/*php_error_docref(NULL TSRMLS_CC, E_WARNING,"Sybase:  Unable to connect to server:  %s",sybase_error(sybase));*/				goto err_login;			}			if (dbsetopt(sybase.link,DBBUFFER,"2",-1)==FAIL) {				goto err_link;			}			/* hash it up */			sybase_ptr = (sybase_link *) malloc(sizeof(sybase_link));			memcpy(sybase_ptr,&sybase,sizeof(sybase_link));			Z_TYPE(new_le) = php_sybase_module.le_plink;			new_le.ptr = sybase_ptr;			if (zend_hash_update(&EG(persistent_list), hashed_details, hashed_details_length+1, (void *) &new_le, sizeof(list_entry),NULL)==FAILURE) {				free(sybase_ptr);				goto err_link;			}			php_sybase_module.num_persistent++;			php_sybase_module.num_links++;		} else {  /* we do */			if (Z_TYPE_P(le) != php_sybase_module.le_plink) {				php_error_docref(NULL TSRMLS_CC, E_WARNING,"Sybase:  Hashed persistent link is not a Sybase link!");				goto err_login;			}						sybase_ptr = (sybase_link *) le->ptr;			/* test that the link hasn't died */			if (DBDEAD(sybase_ptr->link)==TRUE) {				if ((sybase_ptr->link=PHP_SYBASE_DBOPEN(sybase_ptr->login,host))==FAIL) {					/*php_error_docref(NULL TSRMLS_CC, E_WARNING,"Sybase:  Link to server lost, unable to reconnect");*/					zend_hash_del(&EG(persistent_list), hashed_details, hashed_details_length+1);					goto err_login;				}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -