2 +--------------------------------------------------------------------+
4 +--------------------------------------------------------------------+
5 | Redistribution and use in source and binary forms, with or without |
6 | modification, are permitted provided that the conditions mentioned |
7 | in the accompanying LICENSE file are met. |
8 +--------------------------------------------------------------------+
9 | Copyright (c) 2013, Michael Wallner <mike@php.net> |
10 +--------------------------------------------------------------------+
19 #include <ext/spl/spl_iterators.h>
20 #if PHP_PQ_HAVE_PHP_JSON_H
21 #include <php_json.h> /* we've added the include directory to INCLUDES */
24 #include <libpq-events.h>
27 #include "php_pq_misc.h"
28 #include "php_pq_object.h"
29 #include "php_pqexc.h"
30 #include "php_pqres.h"
32 #include "php_pq_type.h"
34 zend_class_entry
*php_pqres_class_entry
;
35 static zend_object_handlers php_pqres_object_handlers
;
36 static HashTable php_pqres_object_prophandlers
;
37 static zend_object_iterator_funcs php_pqres_iterator_funcs
;
39 static inline zend_object_iterator
*php_pqres_iterator_init_ex(zend_class_entry
*ce
, zval
*object
, int by_ref
)
41 php_pqres_iterator_t
*iter
;
42 zval tmp
, *zfetch_type
;
44 iter
= ecalloc(1, sizeof(*iter
));
45 iter
->zi
.funcs
= &php_pqres_iterator_funcs
;
46 ZVAL_COPY_VALUE(&iter
->zi
.data
, object
);
48 zfetch_type
= php_pq_read_property(object
, "fetchType", &tmp
);
49 iter
->fetch_type
= zval_get_long(zfetch_type
);
51 fprintf(stderr
, "INIT iter(#%d) %p res(#%d) %p\n", iter
->zi
.std
.handle
, iter
, Z_OBJ_HANDLE_P(object
), PHP_PQ_OBJ(object
, NULL
));
53 return (zend_object_iterator
*) iter
;
56 static zend_object_iterator
*php_pqres_iterator_init(zend_class_entry
*ce
, zval
*object
, int by_ref
)
58 zend_object_iterator
*iter
= php_pqres_iterator_init_ex(ce
, object
, by_ref
);
60 zend_iterator_init(iter
);
65 static void php_pqres_internal_iterator_init(zval
*zobj
)
67 php_pqres_object_t
*obj
= PHP_PQ_OBJ(zobj
, NULL
);
69 obj
->intern
->iter
= (php_pqres_iterator_t
*) php_pqres_iterator_init_ex(Z_OBJCE_P(zobj
), zobj
, 0);
70 obj
->intern
->iter
->zi
.funcs
->rewind((zend_object_iterator
*) obj
->intern
->iter
);
74 static inline void php_pqres_iterator_dtor_ex(zend_object_iterator
*i
)
76 php_pqres_iterator_t
*iter
= (php_pqres_iterator_t
*) i
;
79 fprintf(stderr
, "FREE iter(#%d) rc=%d %p\n", iter
->zi
.std
.handle
, GC_REFCOUNT(&iter
->zi
.std
), iter
);
81 if (!Z_ISUNDEF(iter
->current_val
)) {
82 zval_ptr_dtor(&iter
->current_val
);
83 ZVAL_UNDEF(&iter
->current_val
);
87 static void php_pqres_iterator_dtor(zend_object_iterator
*i
)
89 php_pqres_iterator_dtor_ex(i
);
90 zval_ptr_dtor(&i
->data
);
93 static void php_pqres_internal_iterator_dtor(php_pqres_object_t
*obj
)
95 if (obj
->intern
&& obj
->intern
->iter
) {
96 php_pqres_iterator_dtor_ex((zend_object_iterator
*) obj
->intern
->iter
);
97 efree(obj
->intern
->iter
);
98 obj
->intern
->iter
= NULL
;
102 static ZEND_RESULT_CODE
php_pqres_iterator_valid(zend_object_iterator
*i
)
104 php_pqres_iterator_t
*iter
= (php_pqres_iterator_t
*) i
;
105 php_pqres_object_t
*obj
= PHP_PQ_OBJ(&i
->data
, NULL
);
107 switch (PQresultStatus(obj
->intern
->res
)) {
108 case PGRES_TUPLES_OK
:
109 #ifdef HAVE_PGRES_SINGLE_TUPLE
110 case PGRES_SINGLE_TUPLE
:
112 if (PQntuples(obj
->intern
->res
) <= iter
->index
) {
123 #define PHP_PQRES_JSON_OPTIONS(res) \
124 (php_pqres_fetch_type(res) != PHP_PQRES_FETCH_OBJECT ? PHP_JSON_OBJECT_AS_ARRAY:0)
126 zval
*php_pqres_typed_zval(php_pqres_t
*res
, Oid typ
, zval
*zv
)
132 if ((zconv
= zend_hash_index_find(&res
->converters
, typ
))) {
136 ZVAL_LONG(&ztype
, typ
);
137 php_pq_call_method(zconv
, "convertfromstring", 2, &rv
, zv
, &ztype
);
140 ZVAL_ZVAL(zv
, &rv
, 0, 0);
145 str
= zval_get_string(zv
);
149 case PHP_PQ_OID_BOOL
:
150 if (!(res
->auto_convert
& PHP_PQRES_CONV_BOOL
)) {
153 ZVAL_BOOL(zv
, *str
->val
== 't');
156 case PHP_PQ_OID_INT8
:
158 case PHP_PQ_OID_INT4
:
159 case PHP_PQ_OID_INT2
:
162 if (!(res
->auto_convert
& PHP_PQRES_CONV_INT
)) {
169 switch (is_numeric_str_function(str
, &lval
, &dval
)) {
174 ZVAL_DOUBLE(zv
, dval
);
182 case PHP_PQ_OID_FLOAT4
:
183 case PHP_PQ_OID_FLOAT8
:
184 if (!(res
->auto_convert
& PHP_PQRES_CONV_FLOAT
)) {
187 ZVAL_DOUBLE(zv
, zend_strtod(str
->val
, NULL
));
190 case PHP_PQ_OID_DATE
:
191 if (!(res
->auto_convert
& PHP_PQRES_CONV_DATETIME
)) {
194 php_pqdt_from_string(zv
, NULL
, str
->val
, str
->len
, "Y-m-d", NULL
);
196 #ifdef PHP_PQ_OID_ABSTIME
197 case PHP_PQ_OID_ABSTIME
:
198 if (!(res
->auto_convert
& PHP_PQRES_CONV_DATETIME
)) {
201 php_pqdt_from_string(zv
, NULL
, str
->val
, str
->len
, "Y-m-d H:i:s", NULL
);
204 case PHP_PQ_OID_TIMESTAMP
:
205 if (!(res
->auto_convert
& PHP_PQRES_CONV_DATETIME
)) {
208 php_pqdt_from_string(zv
, NULL
, str
->val
, str
->len
, "Y-m-d H:i:s.u", NULL
);
211 case PHP_PQ_OID_TIMESTAMPTZ
:
212 if (!(res
->auto_convert
& PHP_PQRES_CONV_DATETIME
)) {
215 php_pqdt_from_string(zv
, NULL
, str
->val
, str
->len
, "Y-m-d H:i:s.uO", NULL
);
218 #if PHP_PQ_HAVE_PHP_JSON_H && defined(PHP_PQ_OID_JSON)
219 # ifdef PHP_PQ_OID_JSONB
220 case PHP_PQ_OID_JSONB
:
222 case PHP_PQ_OID_JSON
:
223 if (!(res
->auto_convert
& PHP_PQRES_CONV_JSON
)) {
226 php_json_decode_ex(zv
, str
->val
, str
->len
, PHP_PQRES_JSON_OPTIONS(res
), 512 /* PHP_JSON_DEFAULT_DEPTH */);
231 if (!(res
->auto_convert
& PHP_PQRES_CONV_ARRAY
)) {
234 if (PHP_PQ_TYPE_IS_ARRAY(typ
) && (ht
= php_pq_parse_array(res
, str
->val
, str
->len
, PHP_PQ_TYPE_OF_ARRAY(typ
)))) {
242 zend_string_release(str
);
250 static inline zval
*php_pqres_get_col(php_pqres_t
*r
, unsigned row
, unsigned col
, zval
*zv
)
252 if (PQgetisnull(r
->res
, row
, col
)) {
255 ZVAL_STRINGL(zv
, PQgetvalue(r
->res
, row
, col
), PQgetlength(r
->res
, row
, col
));
256 zv
= php_pqres_typed_zval(r
, PQftype(r
->res
, col
), zv
);
262 static inline void php_pqres_add_col_to_zval(php_pqres_t
*r
, unsigned row
, unsigned col
, php_pqres_fetch_t fetch_type
, zval
*data
)
264 if (PQgetisnull(r
->res
, row
, col
)) {
265 switch (fetch_type
) {
266 case PHP_PQRES_FETCH_OBJECT
:
267 add_property_null(data
, PQfname(r
->res
, col
));
270 case PHP_PQRES_FETCH_ASSOC
:
271 add_assoc_null(data
, PQfname(r
->res
, col
));
274 case PHP_PQRES_FETCH_ARRAY
:
275 add_index_null(data
, col
);
281 ZVAL_STRINGL(&zv
, PQgetvalue(r
->res
, row
, col
), PQgetlength(r
->res
, row
, col
));
282 php_pqres_typed_zval(r
, PQftype(r
->res
, col
), &zv
);
284 switch (fetch_type
) {
285 case PHP_PQRES_FETCH_OBJECT
:
286 add_property_zval(data
, PQfname(r
->res
, col
), &zv
);
290 case PHP_PQRES_FETCH_ASSOC
:
291 add_assoc_zval(data
, PQfname(r
->res
, col
), &zv
);
294 case PHP_PQRES_FETCH_ARRAY
:
295 add_index_zval(data
, col
, &zv
);
301 zval
*php_pqres_row_to_zval(PGresult
*res
, unsigned row
, php_pqres_fetch_t fetch_type
, zval
*data
)
303 int c
, cols
= PQnfields(res
);
304 php_pqres_object_t
*res_obj
= PQresultInstanceData(res
, php_pqconn_event
);
306 if (Z_TYPE_P(data
) != IS_OBJECT
&& Z_TYPE_P(data
) != IS_ARRAY
) {
307 if (PHP_PQRES_FETCH_OBJECT
== fetch_type
) {
310 array_init_size(data
, cols
);
314 if (PQntuples(res
) > row
) {
315 for (c
= 0; c
< cols
; ++c
) {
316 php_pqres_add_col_to_zval(res_obj
->intern
, row
, c
, fetch_type
, data
);
323 static zval
*php_pqres_iterator_current(zend_object_iterator
*i
)
325 php_pqres_iterator_t
*iter
= (php_pqres_iterator_t
*) i
;
326 php_pqres_object_t
*obj
= PHP_PQ_OBJ(&i
->data
, NULL
);
328 if (Z_ISUNDEF(iter
->current_val
)) {
329 php_pqres_row_to_zval(obj
->intern
->res
, iter
->index
, iter
->fetch_type
, &iter
->current_val
);
331 return &iter
->current_val
;
334 static void php_pqres_iterator_key(zend_object_iterator
*i
, zval
*key
)
336 php_pqres_iterator_t
*iter
= (php_pqres_iterator_t
*) i
;
338 ZVAL_LONG(key
, iter
->index
);
341 static void php_pqres_iterator_invalidate(zend_object_iterator
*i
)
343 php_pqres_iterator_t
*iter
= (php_pqres_iterator_t
*) i
;
345 if (!Z_ISUNDEF(iter
->current_val
)) {
346 zval_ptr_dtor(&iter
->current_val
);
347 ZVAL_UNDEF(&iter
->current_val
);
351 static void php_pqres_iterator_next(zend_object_iterator
*i
)
353 php_pqres_iterator_t
*iter
= (php_pqres_iterator_t
*) i
;
355 php_pqres_iterator_invalidate(i
);
359 static void php_pqres_iterator_rewind(zend_object_iterator
*i
)
361 php_pqres_iterator_t
*iter
= (php_pqres_iterator_t
*) i
;
363 php_pqres_iterator_invalidate(i
);
367 static zend_object_iterator_funcs php_pqres_iterator_funcs
= {
368 php_pqres_iterator_dtor
,
369 /* check for end of iteration (FAILURE or SUCCESS if data is valid) */
370 php_pqres_iterator_valid
,
371 /* fetch the item data for the current element */
372 php_pqres_iterator_current
,
373 /* fetch the key for the current element (return HASH_KEY_IS_STRING or HASH_KEY_IS_LONG) (optional, may be NULL) */
374 php_pqres_iterator_key
,
375 /* step forwards to next element */
376 php_pqres_iterator_next
,
377 /* rewind to start of data (optional, may be NULL) */
378 php_pqres_iterator_rewind
,
379 /* invalidate current value/key (optional, may be NULL) */
380 php_pqres_iterator_invalidate
381 #if PHP_VERSION_ID >= 80000
386 static inline ZEND_RESULT_CODE
php_pqres_count_elements_ex(zend_object
*object
, long *count
)
388 php_pqres_object_t
*obj
= PHP_PQ_OBJ(NULL
, object
);
393 *count
= (long) PQntuples(obj
->intern
->res
);
397 #if PHP_VERSION_ID >= 80000
398 static ZEND_RESULT_CODE
php_pqres_count_elements(zend_object
*object
, long *count
)
400 return php_pqres_count_elements_ex(object
, count
);
403 static ZEND_RESULT_CODE
php_pqres_count_elements(zval
*object
, long *count
)
405 return php_pqres_count_elements_ex(Z_OBJ_P(object
), count
);
409 ZEND_RESULT_CODE
php_pqres_success(PGresult
*res
)
411 zval zexc
, zsqlstate
;
413 switch (PQresultStatus(res
)) {
414 case PGRES_BAD_RESPONSE
:
415 case PGRES_NONFATAL_ERROR
:
416 case PGRES_FATAL_ERROR
:
417 ZVAL_OBJ(&zexc
, throw_exce(EX_SQL
, "%s", PHP_PQresultErrorMessage(res
)));
418 ZVAL_STRING(&zsqlstate
, PQresultErrorField(res
, PG_DIAG_SQLSTATE
));
419 php_pq_update_property(&zexc
, "sqlstate", &zsqlstate
);
420 zval_ptr_dtor(&zsqlstate
);
427 php_pqres_object_t
*php_pqres_init_instance_data(PGresult
*res
, php_pqconn_object_t
*conn_obj
)
429 php_pqres_object_t
*obj
;
430 php_pqres_t
*r
= ecalloc(1, sizeof(*r
));
433 zend_hash_init(&r
->bound
, 0, 0, ZVAL_PTR_DTOR
, 0);
434 zend_hash_init(&r
->converters
, zend_hash_num_elements(&conn_obj
->intern
->converters
), 0, ZVAL_PTR_DTOR
, 0);
435 zend_hash_copy(&r
->converters
, &conn_obj
->intern
->converters
, (copy_ctor_func_t
) zval_add_ref
);
437 r
->auto_convert
= conn_obj
->intern
->default_auto_convert
;
438 r
->default_fetch_type
= conn_obj
->intern
->default_fetch_type
;
440 obj
= php_pqres_create_object_ex(php_pqres_class_entry
, r
);
441 PQresultSetInstanceData(res
, php_pqconn_event
, obj
);
446 php_pqres_fetch_t
php_pqres_fetch_type(php_pqres_t
*res
)
448 return res
->iter
? res
->iter
->fetch_type
: res
->default_fetch_type
;
451 static void php_pqres_object_free(zend_object
*o
)
453 php_pqres_object_t
*obj
= PHP_PQ_OBJ(NULL
, o
);
456 if (obj
->intern
->res
) {
457 PQresultSetInstanceData(obj
->intern
->res
, php_pqconn_event
, NULL
);
458 PQclear(obj
->intern
->res
);
459 obj
->intern
->res
= NULL
;
462 php_pqres_internal_iterator_dtor(obj
);
464 zend_hash_destroy(&obj
->intern
->bound
);
465 zend_hash_destroy(&obj
->intern
->converters
);
470 php_pq_object_dtor(o
);
473 php_pqres_object_t
*php_pqres_create_object_ex(zend_class_entry
*ce
, php_pqres_t
*intern
)
475 return php_pq_object_create(ce
, intern
, sizeof(php_pqres_object_t
),
476 &php_pqres_object_handlers
, &php_pqres_object_prophandlers
);
479 static zend_object
*php_pqres_create_object(zend_class_entry
*class_type
)
481 return &php_pqres_create_object_ex(class_type
, NULL
)->zo
;
484 static void php_pqres_object_read_status(void *o
, zval
*return_value
)
486 php_pqres_object_t
*obj
= o
;
488 RETVAL_LONG(PQresultStatus(obj
->intern
->res
));
491 static void php_pqres_object_read_status_message(void *o
, zval
*return_value
)
493 php_pqres_object_t
*obj
= o
;
495 RETVAL_STRING(PQresStatus(PQresultStatus(obj
->intern
->res
))+sizeof("PGRES"));
498 static void php_pqres_object_read_error_message(void *o
, zval
*return_value
)
500 php_pqres_object_t
*obj
= o
;
501 char *error
= PHP_PQresultErrorMessage(obj
->intern
->res
);
504 RETVAL_STRING(error
);
510 #ifndef PG_DIAG_SEVERITY
511 # define PG_DIAG_SEVERITY 'S'
513 #ifndef PG_DIAG_SQLSTATE
514 # define PG_DIAG_SQLSTATE 'C'
516 #ifndef PG_DIAG_MESSAGE_PRIMARY
517 # define PG_DIAG_MESSAGE_PRIMARY 'M'
519 #ifndef PG_DIAG_MESSAGE_DETAIL
520 # define PG_DIAG_MESSAGE_DETAIL 'D'
522 #ifndef PG_DIAG_MESSAGE_HINT
523 # define PG_DIAG_MESSAGE_HINT 'H'
525 #ifndef PG_DIAG_STATEMENT_POSITION
526 # define PG_DIAG_STATEMENT_POSITION 'P'
528 #ifndef PG_DIAG_INTERNAL_POSITION
529 # define PG_DIAG_INTERNAL_POSITION 'p'
531 #ifndef PG_DIAG_INTERNAL_QUERY
532 # define PG_DIAG_INTERNAL_QUERY 'q'
534 #ifndef PG_DIAG_CONTEXT
535 # define PG_DIAG_CONTEXT 'W'
537 #ifndef PG_DIAG_SCHEMA_NAME
538 # define PG_DIAG_SCHEMA_NAME 's'
540 #ifndef PG_DIAG_TABLE_NAME
541 # define PG_DIAG_TABLE_NAME 't'
543 #ifndef PG_DIAG_COLUMN_NAME
544 # define PG_DIAG_COLUMN_NAME 'c'
546 #ifndef PG_DIAG_DATATYPE_NAME
547 # define PG_DIAG_DATATYPE_NAME 'd'
549 #ifndef PG_DIAG_CONSTRAINT_NAME
550 # define PG_DIAG_CONSTRAINT_NAME 'n'
552 #ifndef PG_DIAG_SOURCE_FILE
553 # define PG_DIAG_SOURCE_FILE 'F'
555 #ifndef PG_DIAG_SOURCE_LINE
556 # define PG_DIAG_SOURCE_LINE 'L'
558 #ifndef PG_DIAG_SOURCE_FUNCTION
559 # define PG_DIAG_SOURCE_FUNCTION 'R'
562 static void php_pqres_object_read_diag(void *o
, zval
*return_value
)
564 php_pqres_object_t
*obj
= o
;
568 const char *const name
;
570 {PG_DIAG_SEVERITY
, "severity"},
571 {PG_DIAG_SQLSTATE
, "sqlstate"},
572 {PG_DIAG_MESSAGE_PRIMARY
, "message_primary"},
573 {PG_DIAG_MESSAGE_DETAIL
, "message_detail"},
574 {PG_DIAG_MESSAGE_HINT
, "message_hint"},
575 {PG_DIAG_STATEMENT_POSITION
,"statement_position"},
576 {PG_DIAG_INTERNAL_POSITION
, "internal_position"},
577 {PG_DIAG_INTERNAL_QUERY
, "internal_query"},
578 {PG_DIAG_CONTEXT
, "context"},
579 {PG_DIAG_SCHEMA_NAME
, "schema_name"},
580 {PG_DIAG_TABLE_NAME
, "table_name"},
581 {PG_DIAG_COLUMN_NAME
, "column_name"},
582 {PG_DIAG_DATATYPE_NAME
, "datatype_name"},
583 {PG_DIAG_CONSTRAINT_NAME
, "constraint_name"},
584 {PG_DIAG_SOURCE_FILE
, "source_file"},
585 {PG_DIAG_SOURCE_LINE
, "source_line"},
586 {PG_DIAG_SOURCE_FUNCTION
, "source_function"},
589 array_init_size(return_value
, 32);
590 for (i
= 0; i
< sizeof(diag
)/sizeof(diag
[0]); ++i
) {
591 char *value
= PQresultErrorField(obj
->intern
->res
, diag
[i
].code
);
594 add_assoc_string(return_value
, diag
[i
].name
, value
);
596 add_assoc_null(return_value
, diag
[i
].name
);
601 static void php_pqres_object_read_num_rows(void *o
, zval
*return_value
)
603 php_pqres_object_t
*obj
= o
;
605 RETVAL_LONG(PQntuples(obj
->intern
->res
));
608 static void php_pqres_object_read_num_cols(void *o
, zval
*return_value
)
610 php_pqres_object_t
*obj
= o
;
612 RETVAL_LONG(PQnfields(obj
->intern
->res
));
615 static void php_pqres_object_read_affected_rows(void *o
, zval
*return_value
)
617 php_pqres_object_t
*obj
= o
;
619 RETVAL_LONG(atoi(PQcmdTuples(obj
->intern
->res
)));
622 static void php_pqres_object_read_fetch_type(void *o
, zval
*return_value
)
624 php_pqres_object_t
*obj
= o
;
626 RETVAL_LONG(php_pqres_fetch_type(obj
->intern
));
629 static void php_pqres_object_write_fetch_type(void *o
, zval
*value
)
631 php_pqres_object_t
*obj
= o
;
633 if (!obj
->intern
->iter
) {
636 ZVAL_OBJ(&object
, &obj
->zo
);
637 php_pqres_internal_iterator_init(&object
);
639 obj
->intern
->iter
->fetch_type
= zval_get_long(value
);
642 static void php_pqres_object_read_auto_conv(void *o
, zval
*return_value
)
644 php_pqres_object_t
*obj
= o
;
646 RETVAL_LONG(obj
->intern
->auto_convert
);
649 static void php_pqres_object_write_auto_conv(void *o
, zval
*value
)
651 php_pqres_object_t
*obj
= o
;
653 obj
->intern
->auto_convert
= zval_get_long(value
);
656 static ZEND_RESULT_CODE
php_pqres_iteration(zval
*zobj
, php_pqres_object_t
*obj
, php_pqres_fetch_t fetch_type
, zval
*row
)
659 php_pqres_fetch_t orig_fetch
;
662 obj
= PHP_PQ_OBJ(zobj
, NULL
);
665 if (obj
->intern
->iter
) {
666 obj
->intern
->iter
->zi
.funcs
->move_forward((zend_object_iterator
*) obj
->intern
->iter
);
668 php_pqres_internal_iterator_init(zobj
);
670 orig_fetch
= obj
->intern
->iter
->fetch_type
;
671 obj
->intern
->iter
->fetch_type
= fetch_type
;
672 if (SUCCESS
== (rv
= obj
->intern
->iter
->zi
.funcs
->valid((zend_object_iterator
*) obj
->intern
->iter
))) {
673 zval
*tmp
= obj
->intern
->iter
->zi
.funcs
->get_current_data((zend_object_iterator
*) obj
->intern
->iter
);
674 ZVAL_COPY_VALUE(row
, tmp
);
676 obj
->intern
->iter
->fetch_type
= orig_fetch
;
681 typedef struct php_pqres_col
{
686 static ZEND_RESULT_CODE
column_nn(php_pqres_object_t
*obj
, zval
*zcol
, php_pqres_col_t
*col
)
688 zend_long index
= -1;
694 switch (Z_TYPE_P(zcol
)) {
700 index
= Z_LVAL_P(zcol
);
704 convert_to_string(zcol
);
708 if (!is_numeric_string(Z_STRVAL_P(zcol
), Z_STRLEN_P(zcol
), &index
, NULL
, 0)) {
709 name
= Z_STRVAL_P(zcol
);
717 col
->num
= PQfnumber(obj
->intern
->res
, name
);
719 col
->name
= PQfname(obj
->intern
->res
, index
);
724 php_error_docref(NULL
, E_WARNING
, "Failed to find column at index %ld", index
);
727 if (col
->num
== -1) {
728 php_error_docref(NULL
, E_WARNING
, "Failed to find column with name '%s'", name
);
734 ZEND_BEGIN_ARG_INFO_EX(ai_pqres_bind
, 0, 0, 2)
735 ZEND_ARG_INFO(0, col
)
736 ZEND_ARG_INFO(1, ref
)
738 static PHP_METHOD(pqres
, bind
) {
740 zend_error_handling zeh
;
743 zend_replace_error_handling(EH_THROW
, exce(EX_INVALID_ARGUMENT
), &zeh
);
744 rv
= zend_parse_parameters(ZEND_NUM_ARGS(), "z/z", &zcol
, &zref
);
745 zend_restore_error_handling(&zeh
);
748 php_pqres_object_t
*obj
= PHP_PQ_OBJ(getThis(), NULL
);
751 throw_exce(EX_UNINITIALIZED
, "pq\\Result not initialized");
755 if (SUCCESS
!= column_nn(obj
, zcol
, &col
)) {
758 Z_TRY_ADDREF_P(zref
);
760 if (!zend_hash_index_update(&obj
->intern
->bound
, col
.num
, zref
)) {
761 php_error_docref(NULL
, E_WARNING
, "Failed to bind column %s@%d", col
.name
, col
.num
);
764 zend_hash_sort(&obj
->intern
->bound
, php_pq_compare_index
, 0);
772 static int apply_bound(zval
*zbound
, int argc
, va_list argv
, zend_hash_key
*key
)
775 zval
*zrow
= va_arg(argv
, zval
*);
776 ZEND_RESULT_CODE
*rv
= va_arg(argv
, ZEND_RESULT_CODE
*);
778 if (!(zvalue
= zend_hash_index_find(Z_ARRVAL_P(zrow
), key
->h
))) {
779 php_error_docref(NULL
, E_WARNING
, "Failed to find column ad index %lu", key
->h
);
781 return ZEND_HASH_APPLY_STOP
;
785 ZVAL_COPY(zbound
, zvalue
);
787 return ZEND_HASH_APPLY_KEEP
;
791 ZEND_BEGIN_ARG_INFO_EX(ai_pqres_fetch_bound
, 0, 0, 0)
793 static PHP_METHOD(pqres
, fetchBound
) {
794 zend_error_handling zeh
;
797 zend_replace_error_handling(EH_THROW
, exce(EX_INVALID_ARGUMENT
), &zeh
);
798 rv
= zend_parse_parameters_none();
799 zend_restore_error_handling(&zeh
);
802 php_pqres_object_t
*obj
= PHP_PQ_OBJ(getThis(), NULL
);
805 throw_exce(EX_UNINITIALIZED
, "pq\\Result not initialized");
809 zend_replace_error_handling(EH_THROW
, exce(EX_RUNTIME
), &zeh
);
810 if (SUCCESS
== php_pqres_iteration(getThis(), obj
, PHP_PQRES_FETCH_ARRAY
, &row
)) {
811 zend_hash_apply_with_arguments(&obj
->intern
->bound
, apply_bound
, 2, &row
, &rv
);
814 RETVAL_ZVAL(&row
, 1, 0);
817 zend_restore_error_handling(&zeh
);
822 ZEND_BEGIN_ARG_INFO_EX(ai_pqres_fetch_row
, 0, 0, 0)
823 ZEND_ARG_INFO(0, fetch_type
)
825 static PHP_METHOD(pqres
, fetchRow
) {
826 zend_error_handling zeh
;
827 php_pqres_object_t
*obj
= PHP_PQ_OBJ(getThis(), NULL
);
828 zend_long fetch_type
= -1;
831 zend_replace_error_handling(EH_THROW
, exce(EX_INVALID_ARGUMENT
), &zeh
);
832 rv
= zend_parse_parameters(ZEND_NUM_ARGS(), "|l", &fetch_type
);
833 zend_restore_error_handling(&zeh
);
837 throw_exce(EX_UNINITIALIZED
, "pq\\Result not initialized");
841 if (fetch_type
== -1) {
842 fetch_type
= php_pqres_fetch_type(obj
->intern
);
845 zend_replace_error_handling(EH_THROW
, exce(EX_RUNTIME
), &zeh
);
846 if (SUCCESS
== php_pqres_iteration(getThis(), obj
, fetch_type
, &row
)) {
847 RETVAL_ZVAL(&row
, 1, 0);
849 zend_restore_error_handling(&zeh
);
854 static zval
*column_at(zval
*row
, int col
)
857 HashTable
*ht
= HASH_OF(row
);
858 int count
= zend_hash_num_elements(ht
);
861 php_error_docref(NULL
, E_WARNING
, "Column index %d exceeds column count %d", col
, count
);
863 zend_hash_internal_pointer_reset(ht
);
865 zend_hash_move_forward(ht
);
867 data
= zend_hash_get_current_data(ht
);
872 ZEND_BEGIN_ARG_INFO_EX(ai_pqres_fetch_col
, 0, 0, 1)
873 ZEND_ARG_INFO(1, ref
)
874 ZEND_ARG_INFO(0, col
)
876 static PHP_METHOD(pqres
, fetchCol
) {
877 zend_error_handling zeh
;
878 zval
*zcol
= NULL
, *zref
;
881 zend_replace_error_handling(EH_THROW
, exce(EX_INVALID_ARGUMENT
), &zeh
);
882 rv
= zend_parse_parameters(ZEND_NUM_ARGS(), "z|z/!", &zref
, &zcol
);
883 zend_restore_error_handling(&zeh
);
886 php_pqres_object_t
*obj
= PHP_PQ_OBJ(getThis(), NULL
);
889 throw_exce(EX_UNINITIALIZED
, "pq\\Result not initialized");
893 zend_replace_error_handling(EH_THROW
, exce(EX_RUNTIME
), &zeh
);
894 if (SUCCESS
== php_pqres_iteration(getThis(), obj
, php_pqres_fetch_type(obj
->intern
), &row
)) {
897 if (SUCCESS
!= column_nn(obj
, zcol
, &col
)) {
900 zval
*zres
= column_at(&row
, col
.num
);
907 ZVAL_ZVAL(zref
, zres
, 1, 0);
912 zend_restore_error_handling(&zeh
);
917 ZEND_BEGIN_ARG_INFO_EX(ai_pqres_fetch_all_cols
, 0, 0, 0)
918 ZEND_ARG_INFO(0, col
)
920 static PHP_METHOD(pqres
, fetchAllCols
) {
921 zend_error_handling zeh
;
925 zend_replace_error_handling(EH_THROW
, exce(EX_INVALID_ARGUMENT
), &zeh
);
926 rv
= zend_parse_parameters(ZEND_NUM_ARGS(), "|z!", &zcol
);
927 zend_restore_error_handling(&zeh
);
930 php_pqres_object_t
*obj
= PHP_PQ_OBJ(getThis(), NULL
);
933 throw_exce(EX_UNINITIALIZED
, "pq\\Result not initialized");
937 zend_replace_error_handling(EH_THROW
, exce(EX_RUNTIME
), &zeh
);
938 if (SUCCESS
== column_nn(obj
, zcol
, &col
)) {
939 int r
, rows
= PQntuples(obj
->intern
->res
);
942 array_init(return_value
);
943 for (r
= 0; r
< rows
; ++r
) {
944 add_next_index_zval(return_value
, php_pqres_get_col(obj
->intern
, r
, col
.num
, &tmp
));
947 zend_restore_error_handling(&zeh
);
952 struct apply_to_col_arg
{
953 php_pqres_object_t
*obj
;
954 php_pqres_col_t
*cols
;
955 ZEND_RESULT_CODE status
;
958 static int apply_to_col(zval
*c
, void *a
)
960 struct apply_to_col_arg
*arg
= a
;
962 if (SUCCESS
!= column_nn(arg
->obj
, c
, arg
->cols
)) {
963 arg
->status
= FAILURE
;
964 return ZEND_HASH_APPLY_STOP
;
966 arg
->status
= SUCCESS
;
968 return ZEND_HASH_APPLY_KEEP
;
972 static php_pqres_col_t
*php_pqres_convert_to_cols(php_pqres_object_t
*obj
, HashTable
*ht
)
974 struct apply_to_col_arg arg
= {NULL
};
975 php_pqres_col_t
*tmp
;
978 arg
.cols
= ecalloc(zend_hash_num_elements(ht
), sizeof(*tmp
));
980 zend_hash_apply_with_argument(ht
, apply_to_col
, &arg
);
982 if (SUCCESS
== arg
.status
) {
990 ZEND_BEGIN_ARG_INFO_EX(ai_pqres_map
, 0, 0, 0)
991 ZEND_ARG_INFO(0, keys
)
992 ZEND_ARG_INFO(0, vals
)
993 ZEND_ARG_INFO(0, fetch_type
)
995 static PHP_METHOD(pqres
, map
) {
996 zend_error_handling zeh
;
997 zval
*zkeys
= 0, *zvals
= 0;
998 zend_long fetch_type
= -1;
1001 zend_replace_error_handling(EH_THROW
, exce(EX_INVALID_ARGUMENT
), &zeh
);
1002 rv
= zend_parse_parameters(ZEND_NUM_ARGS(), "|z/!z/!l", &zkeys
, &zvals
, &fetch_type
);
1003 zend_restore_error_handling(&zeh
);
1005 if (SUCCESS
== rv
) {
1006 php_pqres_object_t
*obj
= PHP_PQ_OBJ(getThis(), NULL
);
1009 throw_exce(EX_UNINITIALIZED
, "pq\\Result not initialized");
1012 php_pqres_col_t def
= {PQfname(obj
->intern
->res
, 0), 0}, *keys
= NULL
, *vals
= NULL
;
1015 convert_to_array(zkeys
);
1017 if ((ks
= zend_hash_num_elements(Z_ARRVAL_P(zkeys
)))) {
1018 keys
= php_pqres_convert_to_cols(obj
, Z_ARRVAL_P(zkeys
));
1028 convert_to_array(zvals
);
1030 if ((vs
= zend_hash_num_elements(Z_ARRVAL_P(zvals
)))) {
1031 vals
= php_pqres_convert_to_cols(obj
, Z_ARRVAL_P(zvals
));
1035 if (fetch_type
== -1) {
1036 fetch_type
= php_pqres_fetch_type(obj
->intern
);
1043 switch (fetch_type
) {
1044 case PHP_PQRES_FETCH_ARRAY
:
1045 case PHP_PQRES_FETCH_ASSOC
:
1046 array_init(return_value
);
1048 case PHP_PQRES_FETCH_OBJECT
:
1049 object_init(return_value
);
1052 for (r
= 0, rows
= PQntuples(obj
->intern
->res
); r
< rows
; ++r
) {
1057 for (k
= 0; k
< ks
; ++k
) {
1058 char *key
= PQgetvalue(obj
->intern
->res
, r
, keys
[k
].num
);
1059 int len
= PQgetlength(obj
->intern
->res
, r
, keys
[k
].num
);
1061 if (!(ptr
= zend_symtable_str_find(HASH_OF(cur
), key
, len
))) {
1064 switch (fetch_type
) {
1065 case PHP_PQRES_FETCH_ARRAY
:
1066 case PHP_PQRES_FETCH_ASSOC
:
1069 case PHP_PQRES_FETCH_OBJECT
:
1073 if (!(ptr
= zend_symtable_str_update(HASH_OF(cur
), key
, len
, &tmp
))) {
1074 throw_exce(EX_RUNTIME
, "Failed to create map");
1082 for (v
= 0; v
< vs
; ++v
) {
1083 char *val
= PQgetvalue(obj
->intern
->res
, r
, vals
[v
].num
);
1084 int len
= PQgetlength(obj
->intern
->res
, r
, vals
[v
].num
);
1086 switch (fetch_type
) {
1087 case PHP_PQRES_FETCH_ARRAY
:
1088 add_index_stringl(cur
, vals
[v
].num
, val
, len
);
1090 case PHP_PQRES_FETCH_ASSOC
:
1091 add_assoc_stringl(cur
, vals
[v
].name
, val
, len
);
1093 case PHP_PQRES_FETCH_OBJECT
:
1094 add_property_stringl(cur
, vals
[v
].name
, val
, len
);
1099 php_pqres_row_to_zval(obj
->intern
->res
, r
, fetch_type
, cur
);
1105 if (keys
&& keys
!= &def
) {
1115 ZEND_BEGIN_ARG_INFO_EX(ai_pqres_fetch_all
, 0, 0, 0)
1116 ZEND_ARG_INFO(0, fetch_type
)
1117 ZEND_END_ARG_INFO();
1118 static PHP_METHOD(pqres
, fetchAll
) {
1119 zend_error_handling zeh
;
1120 zend_long fetch_type
= -1;
1121 ZEND_RESULT_CODE rv
;
1123 zend_replace_error_handling(EH_THROW
, exce(EX_INVALID_ARGUMENT
), &zeh
);
1124 rv
= zend_parse_parameters(ZEND_NUM_ARGS(), "|l", &fetch_type
);
1125 zend_restore_error_handling(&zeh
);
1127 if (SUCCESS
== rv
) {
1128 php_pqres_object_t
*obj
= PHP_PQ_OBJ(getThis(), NULL
);
1131 throw_exce(EX_UNINITIALIZED
, "pq\\Result not initialized");
1133 int r
, rows
= PQntuples(obj
->intern
->res
);
1136 if (fetch_type
== -1) {
1137 fetch_type
= php_pqres_fetch_type(obj
->intern
);
1140 array_init(return_value
);
1141 for (r
= 0; r
< rows
; ++r
) {
1143 add_next_index_zval(return_value
, php_pqres_row_to_zval(obj
->intern
->res
, r
, fetch_type
, &tmp
));
1149 ZEND_BEGIN_ARG_INFO_EX(ai_pqres_count
, 0, 0, 0)
1150 ZEND_END_ARG_INFO();
1151 static PHP_METHOD(pqres
, count
) {
1152 zend_error_handling zeh
;
1153 ZEND_RESULT_CODE rv
;
1155 zend_replace_error_handling(EH_THROW
, exce(EX_INVALID_ARGUMENT
), &zeh
);
1156 rv
= zend_parse_parameters_none();
1157 zend_restore_error_handling(&zeh
);
1159 if (SUCCESS
== rv
) {
1162 if (SUCCESS
!= php_pqres_count_elements_ex(Z_OBJ_P(getThis()), &count
)) {
1163 throw_exce(EX_UNINITIALIZED
, "pq\\Result not initialized");
1170 ZEND_BEGIN_ARG_INFO_EX(ai_pqres_desc
, 0, 0, 0)
1171 ZEND_END_ARG_INFO();
1172 static PHP_METHOD(pqres
, desc
) {
1173 zend_error_handling zeh
;
1174 ZEND_RESULT_CODE rv
;
1176 zend_replace_error_handling(EH_THROW
, exce(EX_INVALID_ARGUMENT
), &zeh
);
1177 rv
= zend_parse_parameters_none();
1178 zend_restore_error_handling(&zeh
);
1180 if (SUCCESS
== rv
) {
1181 php_pqres_object_t
*obj
= PHP_PQ_OBJ(getThis(), NULL
);
1184 throw_exce(EX_UNINITIALIZED
, "pq\\Result not initialized");
1188 array_init(return_value
);
1189 for (p
= 0, params
= PQnparams(obj
->intern
->res
); p
< params
; ++p
) {
1190 add_next_index_long(return_value
, PQparamtype(obj
->intern
->res
, p
));
1196 #if PHP_VERSION_ID >= 80000
1197 ZEND_BEGIN_ARG_INFO_EX(ai_pqres_getIterator
, 0, 0, 0)
1198 ZEND_END_ARG_INFO();
1199 static PHP_METHOD(pqres
, getIterator
)
1201 zend_error_handling zeh
;
1202 ZEND_RESULT_CODE rv
;
1204 zend_replace_error_handling(EH_THROW
, exce(EX_INVALID_ARGUMENT
), &zeh
);
1205 rv
= zend_parse_parameters_none();
1206 zend_restore_error_handling(&zeh
);
1208 if (SUCCESS
== rv
) {
1209 php_pqres_object_t
*obj
= PHP_PQ_OBJ(getThis(), NULL
);
1212 throw_exce(EX_UNINITIALIZED
, "pq\\Result not initialized");
1214 zend_create_internal_iterator_zval(return_value
, getThis());
1220 static zend_function_entry php_pqres_methods
[] = {
1221 PHP_ME(pqres
, bind
, ai_pqres_bind
, ZEND_ACC_PUBLIC
)
1222 PHP_ME(pqres
, fetchBound
, ai_pqres_fetch_bound
, ZEND_ACC_PUBLIC
)
1223 PHP_ME(pqres
, fetchRow
, ai_pqres_fetch_row
, ZEND_ACC_PUBLIC
)
1224 PHP_ME(pqres
, fetchCol
, ai_pqres_fetch_col
, ZEND_ACC_PUBLIC
)
1225 PHP_ME(pqres
, fetchAll
, ai_pqres_fetch_all
, ZEND_ACC_PUBLIC
)
1226 PHP_ME(pqres
, fetchAllCols
, ai_pqres_fetch_all_cols
, ZEND_ACC_PUBLIC
)
1227 PHP_ME(pqres
, count
, ai_pqres_count
, ZEND_ACC_PUBLIC
)
1228 PHP_ME(pqres
, map
, ai_pqres_map
, ZEND_ACC_PUBLIC
)
1229 PHP_ME(pqres
, desc
, ai_pqres_desc
, ZEND_ACC_PUBLIC
)
1230 #if PHP_VERSION_ID >= 80000
1231 PHP_ME(pqres
, getIterator
, ai_pqres_getIterator
, ZEND_ACC_PUBLIC
)
1236 PHP_MSHUTDOWN_FUNCTION(pqres
)
1238 zend_hash_destroy(&php_pqres_object_prophandlers
);
1242 PHP_MINIT_FUNCTION(pqres
)
1244 zend_class_entry ce
= {0};
1245 php_pq_object_prophandler_t ph
= {0};
1247 INIT_NS_CLASS_ENTRY(ce
, "pq", "Result", php_pqres_methods
);
1248 php_pqres_class_entry
= zend_register_internal_class_ex(&ce
, NULL
);
1249 php_pqres_class_entry
->create_object
= php_pqres_create_object
;
1250 php_pqres_class_entry
->get_iterator
= php_pqres_iterator_init
;
1251 #if PHP_VERSION_ID >= 80000
1252 zend_class_implements(php_pqres_class_entry
, 2, zend_ce_aggregate
, zend_ce_countable
);
1254 zend_class_implements(php_pqres_class_entry
, 2, zend_ce_traversable
, zend_ce_countable
);
1257 memcpy(&php_pqres_object_handlers
, zend_get_std_object_handlers(), sizeof(zend_object_handlers
));
1258 php_pqres_object_handlers
.offset
= XtOffsetOf(php_pqres_object_t
, zo
);
1259 php_pqres_object_handlers
.free_obj
= php_pqres_object_free
;
1260 php_pqres_object_handlers
.read_property
= php_pq_object_read_prop
;
1261 php_pqres_object_handlers
.write_property
= php_pq_object_write_prop
;
1262 php_pqres_object_handlers
.clone_obj
= NULL
;
1263 php_pqres_object_handlers
.get_property_ptr_ptr
= php_pq_object_get_prop_ptr_null
;
1264 php_pqres_object_handlers
.get_gc
= php_pq_object_get_gc
;
1265 php_pqres_object_handlers
.get_debug_info
= php_pq_object_debug_info
;
1266 php_pqres_object_handlers
.get_properties
= php_pq_object_properties
;
1267 php_pqres_object_handlers
.count_elements
= php_pqres_count_elements
;
1269 zend_hash_init(&php_pqres_object_prophandlers
, 9, NULL
, php_pq_object_prophandler_dtor
, 1);
1271 zend_declare_property_null(php_pqres_class_entry
, ZEND_STRL("status"), ZEND_ACC_PUBLIC
);
1272 ph
.read
= php_pqres_object_read_status
;
1273 zend_hash_str_add_mem(&php_pqres_object_prophandlers
, "status", sizeof("status")-1, (void *) &ph
, sizeof(ph
));
1275 zend_declare_property_null(php_pqres_class_entry
, ZEND_STRL("statusMessage"), ZEND_ACC_PUBLIC
);
1276 ph
.read
= php_pqres_object_read_status_message
;
1277 zend_hash_str_add_mem(&php_pqres_object_prophandlers
, "statusMessage", sizeof("statusMessage")-1, (void *) &ph
, sizeof(ph
));
1279 zend_declare_property_null(php_pqres_class_entry
, ZEND_STRL("errorMessage"), ZEND_ACC_PUBLIC
);
1280 ph
.read
= php_pqres_object_read_error_message
;
1281 zend_hash_str_add_mem(&php_pqres_object_prophandlers
, "errorMessage", sizeof("errorMessage")-1, (void *) &ph
, sizeof(ph
));
1283 zend_declare_property_null(php_pqres_class_entry
, ZEND_STRL("diag"), ZEND_ACC_PUBLIC
);
1284 ph
.read
= php_pqres_object_read_diag
;
1285 zend_hash_str_add_mem(&php_pqres_object_prophandlers
, "diag", sizeof("diag")-1, (void *) &ph
, sizeof(ph
));
1287 zend_declare_property_long(php_pqres_class_entry
, ZEND_STRL("numRows"), 0, ZEND_ACC_PUBLIC
);
1288 ph
.read
= php_pqres_object_read_num_rows
;
1289 zend_hash_str_add_mem(&php_pqres_object_prophandlers
, "numRows", sizeof("numRows")-1, (void *) &ph
, sizeof(ph
));
1291 zend_declare_property_long(php_pqres_class_entry
, ZEND_STRL("numCols"), 0, ZEND_ACC_PUBLIC
);
1292 ph
.read
= php_pqres_object_read_num_cols
;
1293 zend_hash_str_add_mem(&php_pqres_object_prophandlers
, "numCols", sizeof("numCols")-1, (void *) &ph
, sizeof(ph
));
1295 zend_declare_property_long(php_pqres_class_entry
, ZEND_STRL("affectedRows"), 0, ZEND_ACC_PUBLIC
);
1296 ph
.read
= php_pqres_object_read_affected_rows
;
1297 zend_hash_str_add_mem(&php_pqres_object_prophandlers
, "affectedRows", sizeof("affectedRows")-1, (void *) &ph
, sizeof(ph
));
1299 zend_declare_property_long(php_pqres_class_entry
, ZEND_STRL("fetchType"), PHP_PQRES_FETCH_ARRAY
, ZEND_ACC_PUBLIC
);
1300 ph
.read
= php_pqres_object_read_fetch_type
;
1301 ph
.write
= php_pqres_object_write_fetch_type
;
1302 zend_hash_str_add_mem(&php_pqres_object_prophandlers
, "fetchType", sizeof("fetchType")-1, (void *) &ph
, sizeof(ph
));
1305 zend_declare_property_long(php_pqres_class_entry
, ZEND_STRL("autoConvert"), PHP_PQRES_CONV_ALL
, ZEND_ACC_PUBLIC
);
1306 ph
.read
= php_pqres_object_read_auto_conv
;
1307 ph
.write
= php_pqres_object_write_auto_conv
;
1308 zend_hash_str_add_mem(&php_pqres_object_prophandlers
, "autoConvert", sizeof("autoConvert")-1, (void *) &ph
, sizeof(ph
));
1311 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("EMPTY_QUERY"), PGRES_EMPTY_QUERY
);
1312 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("COMMAND_OK"), PGRES_COMMAND_OK
);
1313 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("TUPLES_OK"), PGRES_TUPLES_OK
);
1314 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("COPY_OUT"), PGRES_COPY_OUT
);
1315 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("COPY_IN"), PGRES_COPY_IN
);
1316 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("BAD_RESPONSE"), PGRES_BAD_RESPONSE
);
1317 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("NONFATAL_ERROR"), PGRES_NONFATAL_ERROR
);
1318 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("FATAL_ERROR"), PGRES_FATAL_ERROR
);
1319 #ifdef HAVE_PGRES_COPY_BOTH
1320 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("COPY_BOTH"), PGRES_COPY_BOTH
);
1322 #ifdef HAVE_PGRES_SINGLE_TUPLE
1323 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("SINGLE_TUPLE"), PGRES_SINGLE_TUPLE
);
1326 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("FETCH_ARRAY"), PHP_PQRES_FETCH_ARRAY
);
1327 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("FETCH_ASSOC"), PHP_PQRES_FETCH_ASSOC
);
1328 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("FETCH_OBJECT"), PHP_PQRES_FETCH_OBJECT
);
1330 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("CONV_BOOL"), PHP_PQRES_CONV_BOOL
);
1331 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("CONV_INT"), PHP_PQRES_CONV_INT
);
1332 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("CONV_FLOAT"), PHP_PQRES_CONV_FLOAT
);
1333 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("CONV_SCALAR"), PHP_PQRES_CONV_SCALAR
);
1334 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("CONV_ARRAY"), PHP_PQRES_CONV_ARRAY
);
1335 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("CONV_DATETIME"), PHP_PQRES_CONV_DATETIME
);
1336 #if PHP_PQ_HAVE_PHP_JSON_H
1337 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("CONV_JSON"), PHP_PQRES_CONV_JSON
);
1339 zend_declare_class_constant_long(php_pqres_class_entry
, ZEND_STRL("CONV_ALL"), PHP_PQRES_CONV_ALL
);
1349 * vim600: noet sw=4 ts=4 fdm=marker
1350 * vim<600: noet sw=4 ts=4