source: trunk/processor/processor.m4 @ 248

Last change on this file since 248 was 248, checked in by moo, 8 years ago

fix var reference handling, fix #47, Assertion failed on shm

File size: 18.7 KB
RevLine 
[1]1dnl ================
2/* {{{ Pre-declare */
3DECL_STRUCT_P_FUNC(`zval')
4DECL_STRUCT_P_FUNC(`zval_ptr')
5DECL_STRUCT_P_FUNC(`zend_op_array')
6DECL_STRUCT_P_FUNC(`zend_class_entry')
[95]7#ifdef HAVE_XCACHE_CONSTANT
8DECL_STRUCT_P_FUNC(`zend_constant')
9#endif
[1]10DECL_STRUCT_P_FUNC(`zend_function')
11DECL_STRUCT_P_FUNC(`xc_entry_t')
12#ifdef ZEND_ENGINE_2
13DECL_STRUCT_P_FUNC(`zend_property_info')
14#endif
15/* }}} */
16dnl ====================================================
17dnl {{{ zend_compiled_variable
18#ifdef IS_CV
19DEF_STRUCT_P_FUNC(`zend_compiled_variable', , `
20    DISPATCH(int, name_len)
[103]21    PROC_ZSTRING_L(, name, name_len)
[1]22    DISPATCH(ulong, hash_value)
23')
24#endif
25dnl }}}
26dnl {{{ zend_uint
27DEF_STRUCT_P_FUNC(`zend_uint', , `
28    IFCOPY(`dst[0] = src[0];')
29    IFDPRINT(`
30        INDENT()
31        fprintf(stderr, "%u\n", src[0]);
32    ')
33    DONE_SIZE(sizeof(src[0]))
34')
35dnl }}}
36dnl {{{ int
37#ifndef ZEND_ENGINE_2
38DEF_STRUCT_P_FUNC(`int', , `
39    IFCOPY(`*dst = *src;')
40    IFDPRINT(`
41        INDENT()
42        fprintf(stderr, "%d\n", src[0]);
43    ')
44    DONE_SIZE(sizeof(src[0]))
45')
46#endif
47dnl }}}
48dnl {{{ zend_try_catch_element
49#ifdef ZEND_ENGINE_2
50DEF_STRUCT_P_FUNC(`zend_try_catch_element', , `
51    DISPATCH(zend_uint, try_op)
52    DISPATCH(zend_uint, catch_op)
53')
54#endif /* ifdef ZEND_ENGINE_2 */
55dnl }}}
56dnl {{{ zend_brk_cont_element
57DEF_STRUCT_P_FUNC(`zend_brk_cont_element', , `
[194]58#ifdef ZEND_ENGINE_2_2
[200]59#ifndef IS_UNICODE
[194]60    DISPATCH(int, start)
61#endif
[200]62#endif
[1]63    DISPATCH(int, cont)
64    DISPATCH(int, brk)
65    DISPATCH(int, parent)
66')
67dnl }}}
68DEF_HASH_TABLE_FUNC(`HashTable_zval_ptr',           `zval_ptr')
[95]69#ifdef HAVE_XCACHE_CONSTANT
70DEF_HASH_TABLE_FUNC(`HashTable_zend_constant',      `zend_constant')
71#endif
[1]72DEF_HASH_TABLE_FUNC(`HashTable_zend_function',      `zend_function')
73#ifdef ZEND_ENGINE_2
74DEF_HASH_TABLE_FUNC(`HashTable_zend_property_info', `zend_property_info')
75#endif
76DEF_STRUCT_P_FUNC(`zval', , `dnl {{{
77    IFDASM(`do {
78        zval_dtor(dst);
79        *dst = *src;
80        zval_copy_ctor(dst);
81        ZVAL_REFCOUNT(dst) = 1;
82        DONE(value)
83        DONE(refcount)
84        DONE(type)
85        DONE(is_ref)
86    } while(0);
87    return;
88    ', `
89        dnl IFDASM else
90        /* Variable information */
91dnl {{{ zvalue_value
92        DISABLECHECK(`
93        switch (src->type & ~IS_CONSTANT_INDEX) {
94            case IS_LONG:
95            case IS_RESOURCE:
96            case IS_BOOL:
97                DISPATCH(long, value.lval)
98                break;
99            case IS_DOUBLE:
100                DISPATCH(double, value.dval)
101                break;
102            case IS_NULL:
103                IFDPRINT(`INDENT()`'fprintf(stderr, "\tNULL\n");')
104                break;
105
106            case IS_CONSTANT:
107#ifdef IS_UNICODE
108                if (UG(unicode)) {
109                    goto proc_unicode;
110                }
111#endif
112            case IS_STRING:
113#ifdef FLAG_IS_BC
114            case FLAG_IS_BC:
115#endif
116                DISPATCH(int, value.str.len)
117                PROC_STRING_L(value.str.val, value.str.len)
118                break;
119#ifdef IS_UNICODE
120            case IS_UNICODE:
121proc_unicode:
[103]122                DISPATCH(int32_t, value.uni.len)
123                PROC_ZSTRING_L(1, value.uni.val, value.uni.len)
[1]124                break;
125#endif
126
127            case IS_ARRAY:
128            case IS_CONSTANT_ARRAY:
129                STRUCT_P(HashTable, value.ht, HashTable_zval_ptr)
130                break;
131
132            case IS_OBJECT:
133                IFNOTMEMCPY(`IFCOPY(`memcpy(dst, src, sizeof(src[0]));')')
134                dnl STRUCT(value.obj)
135#ifndef ZEND_ENGINE_2
136                STRUCT_P(zend_class_entry, value.obj.ce)
137                STRUCT_P(HashTable, value.obj.properties, HashTable_zval_ptr)
138#endif
139                break;
140
141            default:
142                assert(0);
143        }
144        ')
145dnl }}}
146        DONE(value)
147        DISPATCH(zval_data_type, type)
148        DISPATCH(zend_uchar, is_ref)
149        DISPATCH(zend_ushort, refcount)
150    ')dnl IFDASM
151')
152dnl }}}
153DEF_STRUCT_P_FUNC(`zval_ptr', , `dnl {{{
154    IFDASM(`
155        pushdefFUNC_NAME(`zval')
156        FUNC_NAME (dst, src[0] TSRMLS_CC);
157        popdef(`FUNC_NAME')
158    ', `
159        do {
160            IFCALCCOPY(`
161                if (processor->reference) {
162                    zval_ptr *ppzv;
[231]163                    if (zend_hash_find(&processor->zvalptrs, (char *) &src[0], sizeof(src[0]), (void **) &ppzv) == SUCCESS) {
[1]164                        IFCOPY(`
165                            dst[0] = *ppzv;
166                            /* *dst is updated */
[248]167                            dnl fprintf(stderr, "*dst is set to %p, KIND is_shm %d\n", dst[0], xc_is_shm(dst[0]));
[1]168                        ')
[233]169                        IFCALCSTORE(`processor->have_references = 1;')
[1]170                        IFSTORE(`assert(xc_is_shm(dst[0]));')
171                        IFRESTORE(`assert(!xc_is_shm(dst[0]));')
172                        break;
173                    }
174                }
175            ')
176           
177            ALLOC(dst[0], zval)
178            IFCALCCOPY(`
179                if (processor->reference) {
180                    IFCALC(`
181                        /* make dummy */
182                        zval_ptr pzv = (zval_ptr)-1;
183                    ', `
184                        zval_ptr pzv = dst[0];
[248]185                        FIXPOINTER_EX(zval, pzv)
[1]186                    ')
[231]187                    if (zend_hash_add(&processor->zvalptrs, (char *) &src[0], sizeof(src[0]), (void *) &pzv, sizeof(pzv), NULL) == SUCCESS) {
[1]188                        /* first add, go on */
189                        dnl fprintf(stderr, "mark[%p] = %p\n", src[0], pzv);
190                    }
191                    else {
192                        assert(0);
193                    }
194                }
195            ')
196            IFCOPY(`
197                dnl fprintf(stderr, "copy from %p to %p\n", src[0], dst[0]);
198            ')
[230]199            IFDPRINT(`INDENT()`'fprintf(stderr, "[%p]", src[0]);')
[4]200            STRUCT_P_EX(zval, dst[0], src[0], `[0]', `', ` ')
[248]201            FIXPOINTER_EX(zval, dst[0])
[1]202        } while (0);
203    ')
204    DONE_SIZE(sizeof(zval_ptr))
205')
206dnl }}}
207dnl {{{ zend_arg_info
208#ifdef ZEND_ENGINE_2
209DEF_STRUCT_P_FUNC(`zend_arg_info', , `
210    DISPATCH(zend_uint, name_len)
[103]211    PROC_ZSTRING_L(, name, name_len)
[1]212    DISPATCH(zend_uint, class_name_len)
[103]213    PROC_ZSTRING_L(, class_name, class_name_len)
[1]214    DISPATCH(zend_bool, array_type_hint)
215    DISPATCH(zend_bool, allow_null)
216    DISPATCH(zend_bool, pass_by_reference)
217    DISPATCH(zend_bool, return_reference)
218    DISPATCH(int, required_num_args)
219')
220#endif
221dnl }}}
[95]222#ifdef HAVE_XCACHE_CONSTANT
223DEF_STRUCT_P_FUNC(`zend_constant', , `dnl {{{
224    STRUCT(zval, value)
225    DISPATCH(int, flags)
226    DISPATCH(uint, name_len)
[218]227    pushdef(`emalloc', `malloc($1)')
228    pushdef(`ecalloc', `calloc($1, $2)')
[103]229    PROC_ZSTRING_L(, name, name_len)
[218]230    popdef(`ecalloc')
231    popdef(`emalloc')
[95]232    DISPATCH(int, module_number)
233')
234dnl }}}
235#endif
[1]236DEF_STRUCT_P_FUNC(`zend_function', , `dnl {{{
237    DISABLECHECK(`
238    switch (src->type) {
239    case ZEND_INTERNAL_FUNCTION:
240    case ZEND_OVERLOADED_FUNCTION:
241        IFNOTMEMCPY(`IFCOPY(`memcpy(dst, src, sizeof(src[0]));')')
242        break;
243
244    case ZEND_USER_FUNCTION:
245    case ZEND_EVAL_CODE:
246        DONE(type)
247        STRUCT(zend_op_array, op_array)
248        break;
249
250    default:
251        assert(0);
252    }
253    ')
254    DONE_SIZE(sizeof(src[0]))
255')
256dnl }}}
257dnl {{{ zend_property_info
258#ifdef ZEND_ENGINE_2
259DEF_STRUCT_P_FUNC(`zend_property_info', , `
260    DISPATCH(zend_uint, flags)
261    DISPATCH(int, name_length)
[103]262    PROC_ZSTRING_L(, name, name_length)
[1]263    DISPATCH(ulong, h)
[56]264#ifdef ZEND_ENGINE_2_1
[1]265    DISPATCH(int, doc_comment_len)
[103]266    PROC_STRING_L(doc_comment, doc_comment_len)
[56]267#endif
[78]268    dnl isnt in php6 yet
269#if defined(ZEND_ENGINE_2_2) && !defined(IS_UNICODE)
270    PROC_CLASS_ENTRY_P(ce)
271#endif
[1]272')
273#endif
274dnl }}}
275DEF_STRUCT_P_FUNC(`zend_class_entry', , `dnl {{{
[199]276    IFCALCCOPY(`
[1]277        processor->active_class_entry_src = src;
[199]278        IFCOPY(`processor->active_class_entry_dst = dst;')
[1]279    ')
280    DISPATCH(char, type)
281    DISPATCH(zend_uint, name_length)
[103]282    PROC_ZSTRING_L(, name, name_length)
[1]283    IFRESTORE(`
284#ifndef ZEND_ENGINE_2
285        /* just copy parent and resolve on install_class */
286        COPY(parent)
287#else
288        PROC_CLASS_ENTRY_P(parent)
289#endif
290    ', `
291        PROC_CLASS_ENTRY_P(parent)
292    ')
293#ifdef ZEND_ENGINE_2
294    DISPATCH(int, refcount)
295#else
296    STRUCT_P(int, refcount)
297#endif
298    DISPATCH(zend_bool, constants_updated)
299#ifdef ZEND_ENGINE_2
300    DISPATCH(zend_uint, ce_flags)
301#endif
302
303    STRUCT(HashTable, default_properties, HashTable_zval_ptr)
304    IFCOPY(`dst->builtin_functions = src->builtin_functions;')
305    DONE(builtin_functions)
306#ifdef ZEND_ENGINE_2
307    STRUCT(HashTable, properties_info, HashTable_zend_property_info)
308#   ifdef ZEND_ENGINE_2_1
[233]309    STRUCT(HashTable, default_static_members, HashTable_zval_ptr)
[1]310    IFCOPY(`dst->static_members = &dst->default_static_members;')
311    DONE(static_members)
312#   else
[233]313    STRUCT_P(HashTable, static_members, HashTable_zval_ptr)
[1]314#   endif
315    STRUCT(HashTable, constants_table, HashTable_zval_ptr)
316
317    dnl runtime binding: ADD_INTERFACE will deal with it
318    IFRESTORE(`
319        if (src->num_interfaces) {
320            CALLOC(dst->interfaces, zend_class_entry*, src->num_interfaces)
[4]321            DONE(`interfaces')
[1]322        }
323        else {
[4]324            COPYNULL(interfaces)
[1]325        }
326    ')
327    IFDASM(`
328        if (src->num_interfaces) {
329            /*
330            zval *arr;
331            ALLOC_INIT_ZVAL(arr);
332            array_init(arr);
333            for (i = 0; i < src->num_interfaces; i ++) {
334                zval *zv;
335                ALLOC_INIT_ZVAL(zv);
336                ZVAL_STRING(src->num_interfaces);
337            }
338            add_assoc_zval_ex(dst, ZEND_STRS("interfaces"), arr);
339            */
[4]340            DONE(`interfaces')
[1]341        }
342        else {
[4]343            COPYNULL(interfaces)
[1]344        }
345    ')
[4]346    IFRESTORE(`', `
347        IFDASM(`', `
348            DONE(`interfaces')
349        ')
350    ')
[1]351    DISPATCH(zend_uint, num_interfaces)
352
353    IFRESTORE(`COPY(filename)', `PROC_STRING(filename)')
354    DISPATCH(zend_uint, line_start)
355    DISPATCH(zend_uint, line_end)
356#ifdef ZEND_ENGINE_2_1
357    DISPATCH(zend_uint, doc_comment_len)
[103]358    PROC_STRING_L(doc_comment, doc_comment_len)
[1]359#endif
360    /* # NOT DONE */
361    COPY(serialize_func)
362    COPY(unserialize_func)
363    COPY(iterator_funcs)
364    COPY(create_object)
365    COPY(get_iterator)
366    COPY(interface_gets_implemented)
367    COPY(serialize)
368    COPY(unserialize)
369    /* deal with it inside xc_fix_method */
370    SETNULL(constructor)
371    COPY(destructor)
372    COPY(clone)
373    COPY(__get)
374    COPY(__set)
375/* should be >5.1 */
376#ifdef ZEND_ENGINE_2_1
377    COPY(__unset)
378    COPY(__isset)
[94]379# if defined(ZEND_ENGINE_2_2) || PHP_MAJOR_VERSION >= 6
[1]380    COPY(__tostring)
381# endif
382#endif
383    COPY(__call)
384    /* # NOT DONE */
385    COPY(module)
386#else
387    COPY(handle_function_call)
388    COPY(handle_property_get)
389    COPY(handle_property_set)
390#endif
[89]391    dnl must do after SETNULL(constructor) and dst->parent
[1]392    STRUCT(HashTable, function_table, HashTable_zend_function)
[99]393    IFRESTORE(`dst->function_table.pDestructor = ZEND_FUNCTION_DTOR;')
[199]394    IFCALCCOPY(`
[89]395        processor->active_class_entry_src = NULL;
[199]396        IFCOPY(`processor->active_class_entry_dst = NULL;')
[89]397    ')
[1]398')
399dnl }}}
400DEF_STRUCT_P_FUNC(`znode', , `dnl {{{
401    DISPATCH(int, op_type)
402
403#ifdef IS_CV
[11]404#   define XCACHE_IS_CV IS_CV
[1]405#else
[11]406/* compatible with zend optimizer */
407#   define XCACHE_IS_CV 16
[1]408#endif
[11]409    assert(src->op_type == IS_CONST ||
410        src->op_type == IS_VAR ||
411        src->op_type == XCACHE_IS_CV ||
[1]412        src->op_type == IS_TMP_VAR ||
413        src->op_type == IS_UNUSED);
[11]414#undef XCACHE_IS_CV
[1]415    dnl dirty dispatch
416    DISABLECHECK(`
417    switch (src->op_type) {
418        case IS_CONST:
419            STRUCT(zval, u.constant)
420            break;
421        IFCOPY(`
422            IFNOTMEMCPY(`
423                default:
424                    memcpy(&dst->u, &src->u, sizeof(src->u));
425            ')
426        ', `
427        case IS_VAR:
428        case IS_TMP_VAR:
429#ifdef IS_CV
430        case IS_CV:
431#else
432        case 16:
433#endif
434            DISPATCH(zend_uint, u.var)
435            DISPATCH(zend_uint, u.EA.type)
436            break;
437        case IS_UNUSED:
438            IFDASM(`DISPATCH(zend_uint, u.var)')
439            DISPATCH(zend_uint, u.opline_num)
440#ifndef ZEND_ENGINE_2
441            DISPATCH(zend_uint, u.fetch_type)
442#endif
443            DISPATCH(zend_uint, u.EA.type)
444            break;
445        ')
446    }
447    ')
448    DONE(u)
449')
450dnl }}}
451DEF_STRUCT_P_FUNC(`zend_op', , `dnl {{{
452    DISPATCH(zend_uchar, opcode)
453    STRUCT(znode, result)
454    STRUCT(znode, op1)
455    STRUCT(znode, op2)
456    DISPATCH(ulong, extended_value)
457    DISPATCH(uint, lineno)
458#ifdef ZEND_ENGINE_2_1
459    IFCOPY(`
460        switch (src->opcode) {
461            case ZEND_JMP:
462                dst->op1.u.jmp_addr = processor->active_opcodes_dst + (src->op1.u.jmp_addr - processor->active_opcodes_src);
463                break;
464
465            case ZEND_JMPZ:
466            case ZEND_JMPNZ:
467            case ZEND_JMPZ_EX:
468            case ZEND_JMPNZ_EX:
469                dst->op2.u.jmp_addr = processor->active_opcodes_dst + (src->op2.u.jmp_addr - processor->active_opcodes_src);
470                break;
471
472            default:
473                break;
474        }
475    ')
476    DISPATCH(opcode_handler_t, handler)
477#endif
478')
479dnl }}}
480DEF_STRUCT_P_FUNC(`zend_op_array', , `dnl {{{
481    IFRESTORE(`
[212]482    dnl shadow copy must NOT meet:
483    dnl readonly_protection=on
484    dnl main op_array && have early binding
485    if (!processor->readonly_protection && !(src == processor->xce_src->data.php->op_array && processor->xce_src->data.php->have_early_binding)) {
[1]486        /* really fast shallow copy */
487        memcpy(dst, src, sizeof(src[0]));
488        dst->refcount[0] = 1000;
489        /* deep */
490        STRUCT_P(HashTable, static_variables, HashTable_zval_ptr)
491        define(`SKIPASSERT_ONCE')
492    }
493    else
494    ')
495    do {
496    dnl RESTORE is done above!
[11]497    zend_uint ii;
[1]498    int i;
499
500    /* Common elements */
501    DISPATCH(zend_uchar, type)
[103]502    PROC_ZSTRING(, function_name)
[1]503#ifdef ZEND_ENGINE_2
504    DISPATCH(zend_uint, fn_flags)
[11]505    STRUCT_ARRAY_I(num_args, zend_arg_info, arg_info)
[1]506    DISPATCH(zend_uint, num_args)
507    DISPATCH(zend_uint, required_num_args)
508    DISPATCH(zend_bool, pass_rest_by_reference)
509#else
510    if (src->arg_types) {
511        ALLOC(dst->arg_types, zend_uchar, src->arg_types[0] + 1)
512        IFCOPY(`memcpy(dst->arg_types, src->arg_types, sizeof(src->arg_types[0]) * (src->arg_types[0]+1));')
513        IFDASM(`do {
[11]514            zend_uint ii;
[1]515            int i;
516            zval *zv;
517            ALLOC_INIT_ZVAL(zv);
518            array_init(zv);
519            for (i = 0; i < src->arg_types[0]; i ++) {
520                add_next_index_long(zv, src->arg_types[i + 1]);
521            }
522            add_assoc_zval_ex(dst, ZEND_STRS("arg_types"), zv);
523        } while (0);')
524        DONE(arg_types)
525    }
526    else {
527        IFDASM(`do {
528            /* empty array */
529            zval *zv;
530            ALLOC_INIT_ZVAL(zv);
531            array_init(zv);
532            add_assoc_zval_ex(dst, ZEND_STRS("arg_types"), zv);
533        } while (0);
534        DONE(arg_types)
535        ', `
536        COPYNULL(arg_types)
537        ')
538    }
539#endif
540    DISPATCH(unsigned char, return_reference)
541    /* END of common elements */
542#ifdef IS_UNICODE
[103]543    dnl SETNULL(u_twin)
[1]544#endif
545
546    STRUCT_P(zend_uint, refcount)
547    UNFIXPOINTER(zend_uint, refcount)
[221]548    IFSTORE(`dst->refcount[0] = 1;')
[1]549
550    pushdef(`AFTER_ALLOC', `IFCOPY(`
551        processor->active_opcodes_dst = dst->opcodes;
552        processor->active_opcodes_src = src->opcodes;
553    ')')
[11]554    STRUCT_ARRAY_I(last, zend_op, opcodes)
[1]555    popdef(`AFTER_ALLOC')
556    DISPATCH(zend_uint, last)
557    IFCOPY(`dst->size = src->last;DONE(size)', `DISPATCH(zend_uint, size)')
558
559#ifdef IS_CV
560    STRUCT_ARRAY(last_var, zend_compiled_variable, vars)
561    DISPATCH(int, last_var)
562    IFCOPY(`dst->size_var = src->last_var;DONE(size_var)', `DISPATCH(zend_uint, size_var)')
563#else
564    dnl zend_cv.m4 is illegal to be made public, don not ask me for it
565    IFDASM(`
[4]566        sinclude(srcdir`/processor/zend_cv.m4')
[1]567        ')
568#endif
569
570    DISPATCH(zend_uint, T)
571
[11]572    STRUCT_ARRAY_I(last_brk_cont, zend_brk_cont_element, brk_cont_array)
[1]573    DISPATCH(zend_uint, last_brk_cont)
574    DISPATCH(zend_uint, current_brk_cont)
575#ifndef ZEND_ENGINE_2
576    DISPATCH(zend_bool, uses_globals)
577#endif
578
579#ifdef ZEND_ENGINE_2
580    STRUCT_ARRAY(last_try_catch, zend_try_catch_element, try_catch_array)
581    DISPATCH(int, last_try_catch)
582#endif
583
584    STRUCT_P(HashTable, static_variables, HashTable_zval_ptr)
585
[95]586    COPY(start_op)
[1]587    DISPATCH(int, backpatch_count)
588
589    DISPATCH(zend_bool, done_pass_two)
590#ifdef ZEND_ENGINE_2
591    DISPATCH(zend_bool, uses_this)
592#endif
593
594    IFRESTORE(`COPY(filename)', `PROC_STRING(filename)')
595#ifdef IS_UNICODE
596    PROC_STRING(script_encoding)
597#endif
598#ifdef ZEND_ENGINE_2
599    DISPATCH(zend_uint, line_start)
600    DISPATCH(zend_uint, line_end)
601    DISPATCH(int, doc_comment_len)
[103]602    PROC_STRING_L(doc_comment, doc_comment_len)
[1]603#endif
604
605    /* reserved */
606    DONE(reserved)
607#if defined(HARDENING_PATCH) && HARDENING_PATCH
608    DISPATCH(zend_bool, created_by_eval)
609#endif
610    } while (0);
[189]611
[219]612#ifdef ZEND_ENGINE_2
613    dnl mark it as -1 on store, and lookup parent on restore
614    IFSTORE(`dst->prototype = (processor->active_class_entry_src && src->prototype) ? (zend_function *) -1 : NULL; DONE(prototype)', `
615            IFRESTORE(`do {
616                zend_function *parent;
617                if (src->prototype != NULL
618                 && zend_u_hash_find(&(processor->active_class_entry_dst->parent->function_table),
619                        UG(unicode) ? IS_UNICODE : IS_STRING,
620                        src->function_name, xc_zstrlen(UG(unicode), src->function_name) + 1,
621                        (void **) &parent) == SUCCESS) {
622                    /* see do_inherit_method_check() */
623                    if ((parent->common.fn_flags & ZEND_ACC_ABSTRACT)) {
624                      dst->prototype = parent;
625                    } else if (!(parent->common.fn_flags & ZEND_ACC_CTOR) || (parent->common.prototype && (parent->common.prototype->common.scope->ce_flags & ZEND_ACC_INTERFACE))) {
626                        /* ctors only have a prototype if it comes from an interface */
627                        dst->prototype = parent->common.prototype ? parent->common.prototype : parent;
628                    }
629                    else {
630                        dst->prototype = NULL;
631                    }
632                }
633                else {
634                    dst->prototype = NULL;
635                }
636                DONE(prototype)
637            } while (0);
638            ', `
639                COPYNULL(prototype)
640            ')
641    ')
642#endif
643
[189]644    IFRESTORE(`
645#ifdef ZEND_ENGINE_2
[219]646        if (src->scope) {
647            dst->scope = xc_get_class(processor, (zend_ulong) src->scope);
[189]648            xc_fix_method(processor, dst);
649        }
650        DONE(scope)
651#endif
652    ', `
653#ifdef ZEND_ENGINE_2
654        PROC_CLASS_ENTRY_P(scope)
655#endif
656    ')
657
658    IFRESTORE(`
659        if (xc_have_op_array_ctor) {
660            zend_llist_apply_with_argument(&zend_extensions, (llist_apply_with_arg_func_t) xc_zend_extension_op_array_ctor_handler, dst TSRMLS_CC);
661        }
662    ')
[1]663')
664dnl }}}
665
[95]666#ifdef HAVE_XCACHE_CONSTANT
667DEF_STRUCT_P_FUNC(`xc_constinfo_t', , `dnl {{{
668    DISPATCH(zend_uint, key_size)
669#ifdef IS_UNICODE
670    DISPATCH(zend_uchar, type)
671#endif
672    IFRESTORE(`COPY(key)', `
[103]673        PROC_ZSTRING_N(type, key, key_size)
[95]674    ')
675    STRUCT(zend_constant, constant)
676')
677dnl }}}
678#endif
[1]679DEF_STRUCT_P_FUNC(`xc_funcinfo_t', , `dnl {{{
680    DISPATCH(zend_uint, key_size)
681#ifdef IS_UNICODE
682    DISPATCH(zend_uchar, type)
683#endif
684    IFRESTORE(`COPY(key)', `
[103]685        PROC_ZSTRING_N(type, key, key_size)
[1]686    ')
687    STRUCT(zend_function, func)
688')
689dnl }}}
690DEF_STRUCT_P_FUNC(`xc_classinfo_t', , `dnl {{{
691    DISPATCH(zend_uint, key_size)
692#ifdef IS_UNICODE
693    DISPATCH(zend_uchar, type)
694#endif
695    IFRESTORE(`COPY(key)', `
[103]696        PROC_ZSTRING_N(type, key, key_size)
[1]697    ')
698#ifdef ZEND_ENGINE_2
699    STRUCT_P(zend_class_entry, cest)
700#else
701    STRUCT(zend_class_entry, cest)
702#endif
[212]703    DISPATCH(int, oplineno)
[1]704')
705dnl }}}
706DEF_STRUCT_P_FUNC(`xc_entry_data_php_t', , `dnl {{{
707    zend_uint i;
708
709#ifdef HAVE_INODE
710    DISPATCH(int, device)
711    DISPATCH(int, inode)
712#endif
713    DISPATCH(size_t, sourcesize)
714
715    DISPATCH(time_t, mtime)
716
717    STRUCT_P(zend_op_array, op_array)
718
[95]719#ifdef HAVE_XCACHE_CONSTANT
720    DISPATCH(zend_uint, constinfo_cnt)
721    STRUCT_ARRAY(constinfo_cnt, xc_constinfo_t, constinfos)
722#endif
723
[1]724    DISPATCH(zend_uint, funcinfo_cnt)
725    STRUCT_ARRAY(funcinfo_cnt, xc_funcinfo_t, funcinfos)
726
727    DISPATCH(zend_uint, classinfo_cnt)
728    pushdef(`BEFORE_LOOP', `
729        IFCOPY(`
730            processor->active_class_num = i + 1;
731        ')
732    ')
733    STRUCT_ARRAY(classinfo_cnt, xc_classinfo_t, classinfos)
[212]734    DISPATCH(zend_bool, have_early_binding)
[1]735    popdef(`BEFORE_LOOP')
736')
737dnl }}}
738DEF_STRUCT_P_FUNC(`xc_entry_data_var_t', , `dnl {{{
[230]739    IFDPRINT(`INDENT()`'fprintf(stderr, "zval:value");')
[4]740    STRUCT_P_EX(zval_ptr, dst->value, src->value, `value', `', `&')
[1]741    DONE(value)
742')
743dnl }}}
744dnl {{{ xc_entry_t
745DEF_STRUCT_P_FUNC(`xc_entry_t', , `
746    IFCOPY(`
747        processor->xce_dst = dst;
748        processor->xce_src = src;
749    ')
750    DISPATCH(xc_entry_type_t, type)
751    DISPATCH(size_t, size)
752
753    DISPATCH(xc_hash_value_t, hvalue)
754    COPY(cache)
755    /* skip */
756    DONE(next)
757
758    IFSTORE(`dst->refcount = 0; DONE(refcount)', `DISPATCH(long, refcount)')
759
760    DISPATCH(time_t, ctime)
761    DISPATCH(time_t, atime)
762    DISPATCH(time_t, dtime)
[114]763    DISPATCH(long, ttl)
[1]764    DISPATCH(zend_ulong, hits)
765#ifdef IS_UNICODE
766    DISPATCH(zend_uchar, name_type)
767#endif
768    dnl {{{ name
769    DISABLECHECK(`
770#ifdef IS_UNICODE
771        if (src->name_type == IS_UNICODE) {
772            DISPATCH(int32_t, name.ustr.len)
773        }
774        else {
775            DISPATCH(int, name.str.len)
776        }
777#else
778        DISPATCH(int, name.str.len)
779#endif
[103]780        IFRESTORE(`COPY(name.str.val)', `
781#ifdef IS_UNICODE
782            PROC_ZSTRING_L(name_type, name.uni.val, name.uni.len)
783#else
784            PROC_STRING_L(name.str.val, name.str.len)
785#endif
786        ')
[1]787    ')
788    DONE(name)
789    dnl }}}
790
791    dnl {{{ data
792    DISABLECHECK(`
793        switch (src->type) {
794        case XC_TYPE_PHP:
795            STRUCT_P(xc_entry_data_php_t, data.php)
796            break;
797        case XC_TYPE_VAR:
798            STRUCT_P(xc_entry_data_var_t, data.var)
799            break;
800        default:
801            assert(0);
802        }
803    ')
804    DONE(data)
805    dnl }}}
[233]806    DISPATCH(zend_bool, have_references)
[1]807')
808dnl }}}
809dnl ====================================================
Note: See TracBrowser for help on using the repository browser.