summaryrefslogtreecommitdiff
path: root/ext/pdo/php_pdo_driver.h
diff options
context:
space:
mode:
Diffstat (limited to 'ext/pdo/php_pdo_driver.h')
-rw-r--r--ext/pdo/php_pdo_driver.h78
1 files changed, 48 insertions, 30 deletions
diff --git a/ext/pdo/php_pdo_driver.h b/ext/pdo/php_pdo_driver.h
index 56a69cac30..50729a7b00 100644
--- a/ext/pdo/php_pdo_driver.h
+++ b/ext/pdo/php_pdo_driver.h
@@ -26,6 +26,7 @@
/* forward declarations */
typedef struct _pdo_dbh_t pdo_dbh_t;
typedef struct _pdo_stmt_t pdo_stmt_t;
+typedef struct _pdo_row_t pdo_row_t;
struct pdo_bound_param_data;
#ifdef PHP_WIN32
@@ -194,21 +195,21 @@ enum pdo_null_handling {
/* {{{ utils for reading attributes set as driver_options */
static inline long pdo_attr_lval(zval *options, enum pdo_attribute_type option_name, long defval TSRMLS_DC)
{
- zval **v;
+ zval *v;
- if (options && SUCCESS == zend_hash_index_find(Z_ARRVAL_P(options), option_name, (void**)&v)) {
+ if (options && (v = zend_hash_index_find(Z_ARRVAL_P(options), option_name))) {
convert_to_long_ex(v);
- return Z_LVAL_PP(v);
+ return Z_LVAL_P(v);
}
return defval;
}
static inline char *pdo_attr_strval(zval *options, enum pdo_attribute_type option_name, char *defval TSRMLS_DC)
{
- zval **v;
+ zval *v;
- if (options && SUCCESS == zend_hash_index_find(Z_ARRVAL_P(options), option_name, (void**)&v)) {
+ if (options && (v = zend_hash_index_find(Z_ARRVAL_P(options), option_name))) {
convert_to_string_ex(v);
- return estrndup(Z_STRVAL_PP(v), Z_STRLEN_PP(v));
+ return estrndup(Z_STRVAL_P(v), Z_STRLEN_P(v));
}
return defval ? estrdup(defval) : NULL;
}
@@ -426,13 +427,6 @@ enum pdo_placeholder_support {
/* represents a connection to a database */
struct _pdo_dbh_t {
- /* these items must appear in this order at the beginning of the
- struct so that this can be cast as a zend_object. we need this
- to allow the extending class to escape all the custom handlers
- that PDO declares.
- */
- zend_object std;
-
/* driver specific methods */
struct pdo_dbh_methods *methods;
/* driver specific data */
@@ -496,7 +490,7 @@ struct _pdo_dbh_t {
zend_class_entry *def_stmt_ce;
- zval *def_stmt_ctor_args;
+ zval def_stmt_ctor_args;
/* when calling PDO::query(), we need to keep the error
* context from the statement around until we next clear it.
@@ -507,8 +501,21 @@ struct _pdo_dbh_t {
/* defaults for fetches */
enum pdo_fetch_type default_fetch_type;
+
+ /* these items must appear in this order at the beginning of the
+ struct so that this can be cast as a zend_object. we need this
+ to allow the extending class to escape all the custom handlers
+ that PDO declares.
+ */
+ zend_object std;
};
+static inline pdo_dbh_t *php_pdo_dbh_fetch_object(zend_object *obj) {
+ return (pdo_dbh_t *)((char*)(obj) - XtOffsetOf(pdo_dbh_t, std));
+}
+
+#define Z_PDO_DBH_P(zv) php_pdo_dbh_fetch_object(Z_OBJ_P((zv)))
+
/* describes a column */
struct pdo_column_data {
char *name;
@@ -529,10 +536,10 @@ struct pdo_bound_param_data {
long max_value_len; /* as a hint for pre-allocation */
- zval *parameter; /* the variable itself */
+ zval parameter; /* the variable itself */
enum pdo_param_type param_type; /* desired or suggested type */
- zval *driver_params; /* optional parameter(s) for the driver */
+ zval driver_params; /* optional parameter(s) for the driver */
void *driver_data;
pdo_stmt_t *stmt; /* for convenience in dtor */
@@ -541,13 +548,6 @@ struct pdo_bound_param_data {
/* represents a prepared statement */
struct _pdo_stmt_t {
- /* these items must appear in this order at the beginning of the
- struct so that this can be cast as a zend_object. we need this
- to allow the extending class to escape all the custom handlers
- that PDO declares.
- */
- zend_object std;
-
/* driver specifics */
struct pdo_stmt_methods *methods;
void *driver_data;
@@ -607,25 +607,43 @@ struct _pdo_stmt_t {
int column;
struct {
zend_class_entry *ce;
- zval *ctor_args; /* freed */
- zval *retval_ptr;
+ zval ctor_args; /* freed */
+ zval retval;
zend_fcall_info fci;
zend_fcall_info_cache fcc;
} cls;
struct {
- zval *function;
- zval *fetch_args; /* freed */
- zval *object;
+ zval function;
+ zval fetch_args; /* freed */
+ zval object;
zend_fcall_info fci;
zend_fcall_info_cache fcc;
- zval **values; /* freed */
+ zval *values; /* freed */
} func;
- zval *into;
+ zval into;
} fetch;
/* used by the query parser for driver specific
* parameter naming (see pgsql driver for example) */
const char *named_rewrite_template;
+
+ /* these items must appear in this order at the beginning of the
+ struct so that this can be cast as a zend_object. we need this
+ to allow the extending class to escape all the custom handlers
+ that PDO declares.
+ */
+ zend_object std;
+};
+
+static inline pdo_stmt_t *php_pdo_stmt_fetch_object(zend_object *obj) {
+ return (pdo_stmt_t *)((char*)(obj) - XtOffsetOf(pdo_stmt_t, std));
+}
+
+#define Z_PDO_STMT_P(zv) php_pdo_stmt_fetch_object(Z_OBJ_P((zv)))
+
+struct _pdo_row_t {
+ zend_object std;
+ pdo_stmt_t *stmt;
};
/* call this in MINIT to register your PDO driver */