Skip to content

Commit ca40664

Browse files
committed
Conversion related optimizations
1 parent 85b2bc3 commit ca40664

File tree

2 files changed

+29
-27
lines changed

2 files changed

+29
-27
lines changed

Zend/zend_operators.c

Lines changed: 22 additions & 26 deletions
Original file line numberDiff line numberDiff line change
@@ -374,9 +374,8 @@ ZEND_API void ZEND_FASTCALL convert_to_long_base(zval *op, int base) /* {{{ */
374374
zval_dtor(op);
375375

376376
if (Z_TYPE(dst) == IS_LONG) {
377-
ZVAL_COPY_VALUE(op, &dst);
377+
ZVAL_LONG(op, Z_LVAL(dst));
378378
} else {
379-
380379
ZVAL_LONG(op, 1);
381380
}
382381
return;
@@ -434,7 +433,7 @@ ZEND_API void ZEND_FASTCALL convert_to_double(zval *op) /* {{{ */
434433
zval_dtor(op);
435434

436435
if (Z_TYPE(dst) == IS_DOUBLE) {
437-
ZVAL_COPY_VALUE(op, &dst);
436+
ZVAL_DOUBLE(op, Z_DVAL(dst));
438437
} else {
439438
ZVAL_DOUBLE(op, 1.0);
440439
}
@@ -505,8 +504,8 @@ ZEND_API void ZEND_FASTCALL convert_to_boolean(zval *op) /* {{{ */
505504
convert_object_to_type(op, &dst, _IS_BOOL, convert_to_boolean);
506505
zval_dtor(op);
507506

508-
if (Z_TYPE(dst) == IS_FALSE || Z_TYPE(dst) == IS_TRUE) {
509-
ZVAL_COPY_VALUE(op, &dst);
507+
if (Z_TYPE_INFO(dst) == IS_FALSE || Z_TYPE_INFO(dst) == IS_TRUE) {
508+
Z_TYPE_INFO_P(op) = Z_TYPE_INFO(dst);
510509
} else {
511510
ZVAL_TRUE(op);
512511
}
@@ -596,12 +595,9 @@ ZEND_API void ZEND_FASTCALL _convert_to_string(zval *op ZEND_FILE_LINE_DC) /* {{
596595

597596
static void convert_scalar_to_array(zval *op) /* {{{ */
598597
{
599-
zval entry;
600-
601-
ZVAL_COPY_VALUE(&entry, op);
602-
603-
array_init_size(op, 1);
604-
zend_hash_index_add_new(Z_ARRVAL_P(op), 0, &entry);
598+
HashTable *ht = zend_new_array(1);
599+
zend_hash_index_add_new(ht, 0, op);
600+
ZVAL_ARR(op, ht);
605601
}
606602
/* }}} */
607603

@@ -619,19 +615,13 @@ ZEND_API void ZEND_FASTCALL convert_to_array(zval *op) /* {{{ */
619615
if (Z_OBJ_HT_P(op)->get_properties) {
620616
HashTable *obj_ht = Z_OBJ_HT_P(op)->get_properties(op);
621617
if (obj_ht) {
622-
zend_array *arr;
623-
624618
/* fast copy */
625-
if (!Z_OBJCE_P(op)->default_properties_count &&
626-
obj_ht == Z_OBJ_P(op)->properties &&
627-
!GC_IS_RECURSIVE(obj_ht) &&
628-
EXPECTED(Z_OBJ_P(op)->handlers == &std_object_handlers)) {
629-
arr = zend_proptable_to_symtable(obj_ht, 0);
630-
} else {
631-
arr = zend_proptable_to_symtable(obj_ht, 1);
632-
}
619+
obj_ht = zend_proptable_to_symtable(obj_ht,
620+
(Z_OBJCE_P(op)->default_properties_count ||
621+
Z_OBJ_P(op)->handlers != &std_object_handlers ||
622+
GC_IS_RECURSIVE(obj_ht)));
633623
zval_dtor(op);
634-
ZVAL_ARR(op, arr);
624+
ZVAL_ARR(op, obj_ht);
635625
return;
636626
}
637627
} else {
@@ -670,14 +660,20 @@ ZEND_API void ZEND_FASTCALL convert_to_object(zval *op) /* {{{ */
670660
switch (Z_TYPE_P(op)) {
671661
case IS_ARRAY:
672662
{
673-
HashTable *ht = Z_ARR_P(op);
674-
ht = zend_symtable_to_proptable(ht);
663+
HashTable *ht = zend_symtable_to_proptable(Z_ARR_P(op));
664+
zend_object *obj;
665+
675666
if (GC_FLAGS(ht) & IS_ARRAY_IMMUTABLE) {
676667
/* TODO: try not to duplicate immutable arrays as well ??? */
677668
ht = zend_array_dup(ht);
669+
} else if (ht != Z_ARR_P(op)) {
670+
zval_dtor(op);
671+
} else {
672+
GC_DELREF(ht);
678673
}
679-
zval_dtor(op);
680-
object_and_properties_init(op, zend_standard_class_def, ht);
674+
obj = zend_objects_new(zend_standard_class_def);
675+
obj->properties = ht;
676+
ZVAL_OBJ(op, obj);
681677
break;
682678
}
683679
case IS_OBJECT:

Zend/zend_operators.h

Lines changed: 7 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -437,7 +437,13 @@ ZEND_API void ZEND_FASTCALL zend_locale_sprintf_double(zval *op ZEND_FILE_LINE_D
437437
convert_to_explicit_type(pzv, str_type); \
438438
}
439439

440-
#define convert_to_boolean_ex(pzv) convert_to_ex_master(pzv, boolean, _IS_BOOL)
440+
#define convert_to_boolean_ex(pzv) do { \
441+
if (Z_TYPE_INFO_P(pzv) > IS_TRUE) { \
442+
convert_to_boolean(pzv); \
443+
} else if (Z_TYPE_INFO_P(pzv) < IS_FALSE) { \
444+
ZVAL_FALSE(pzv); \
445+
} \
446+
} while (0)
441447
#define convert_to_long_ex(pzv) convert_to_ex_master(pzv, long, IS_LONG)
442448
#define convert_to_double_ex(pzv) convert_to_ex_master(pzv, double, IS_DOUBLE)
443449
#define convert_to_string_ex(pzv) convert_to_ex_master(pzv, string, IS_STRING)

0 commit comments

Comments
 (0)