source: branches/1.2/processor/processor.m4 @ 394

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

merged [393] from trunk: svn:eol-style

  • Property svn:eol-style set to native
File size: 19.1 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)
[272]266    PROC_ZSTRING_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)
[272]358    PROC_ZSTRING_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
[267]596    IFRESTORE(`
597        COPY(script_encoding)
598    ', `
599        PROC_STRING(script_encoding)
600    ')
[1]601#endif
602#ifdef ZEND_ENGINE_2
603    DISPATCH(zend_uint, line_start)
604    DISPATCH(zend_uint, line_end)
605    DISPATCH(int, doc_comment_len)
[272]606    PROC_ZSTRING_L(, doc_comment, doc_comment_len)
[1]607#endif
608
609    /* reserved */
610    DONE(reserved)
611#if defined(HARDENING_PATCH) && HARDENING_PATCH
612    DISPATCH(zend_bool, created_by_eval)
613#endif
614    } while (0);
[189]615
[219]616#ifdef ZEND_ENGINE_2
617    dnl mark it as -1 on store, and lookup parent on restore
618    IFSTORE(`dst->prototype = (processor->active_class_entry_src && src->prototype) ? (zend_function *) -1 : NULL; DONE(prototype)', `
619            IFRESTORE(`do {
620                zend_function *parent;
621                if (src->prototype != NULL
622                 && zend_u_hash_find(&(processor->active_class_entry_dst->parent->function_table),
623                        UG(unicode) ? IS_UNICODE : IS_STRING,
624                        src->function_name, xc_zstrlen(UG(unicode), src->function_name) + 1,
625                        (void **) &parent) == SUCCESS) {
626                    /* see do_inherit_method_check() */
627                    if ((parent->common.fn_flags & ZEND_ACC_ABSTRACT)) {
628                      dst->prototype = parent;
629                    } else if (!(parent->common.fn_flags & ZEND_ACC_CTOR) || (parent->common.prototype && (parent->common.prototype->common.scope->ce_flags & ZEND_ACC_INTERFACE))) {
630                        /* ctors only have a prototype if it comes from an interface */
631                        dst->prototype = parent->common.prototype ? parent->common.prototype : parent;
632                    }
633                    else {
634                        dst->prototype = NULL;
635                    }
636                }
637                else {
638                    dst->prototype = NULL;
639                }
640                DONE(prototype)
641            } while (0);
642            ', `
643                COPYNULL(prototype)
644            ')
645    ')
646#endif
647
[189]648    IFRESTORE(`
649#ifdef ZEND_ENGINE_2
[219]650        if (src->scope) {
651            dst->scope = xc_get_class(processor, (zend_ulong) src->scope);
[189]652            xc_fix_method(processor, dst);
653        }
654        DONE(scope)
655#endif
656    ', `
657#ifdef ZEND_ENGINE_2
658        PROC_CLASS_ENTRY_P(scope)
659#endif
660    ')
661
662    IFRESTORE(`
663        if (xc_have_op_array_ctor) {
664            zend_llist_apply_with_argument(&zend_extensions, (llist_apply_with_arg_func_t) xc_zend_extension_op_array_ctor_handler, dst TSRMLS_CC);
665        }
666    ')
[1]667')
668dnl }}}
669
[95]670#ifdef HAVE_XCACHE_CONSTANT
671DEF_STRUCT_P_FUNC(`xc_constinfo_t', , `dnl {{{
672    DISPATCH(zend_uint, key_size)
673#ifdef IS_UNICODE
674    DISPATCH(zend_uchar, type)
675#endif
676    IFRESTORE(`COPY(key)', `
[103]677        PROC_ZSTRING_N(type, key, key_size)
[95]678    ')
679    STRUCT(zend_constant, constant)
680')
681dnl }}}
682#endif
[1]683DEF_STRUCT_P_FUNC(`xc_funcinfo_t', , `dnl {{{
684    DISPATCH(zend_uint, key_size)
685#ifdef IS_UNICODE
686    DISPATCH(zend_uchar, type)
687#endif
688    IFRESTORE(`COPY(key)', `
[103]689        PROC_ZSTRING_N(type, key, key_size)
[1]690    ')
691    STRUCT(zend_function, func)
692')
693dnl }}}
694DEF_STRUCT_P_FUNC(`xc_classinfo_t', , `dnl {{{
695    DISPATCH(zend_uint, key_size)
696#ifdef IS_UNICODE
697    DISPATCH(zend_uchar, type)
698#endif
699    IFRESTORE(`COPY(key)', `
[103]700        PROC_ZSTRING_N(type, key, key_size)
[1]701    ')
702#ifdef ZEND_ENGINE_2
703    STRUCT_P(zend_class_entry, cest)
704#else
705    STRUCT(zend_class_entry, cest)
706#endif
[212]707    DISPATCH(int, oplineno)
[1]708')
709dnl }}}
[268]710#ifdef ZEND_ENGINE_2_1
711DEF_STRUCT_P_FUNC(`xc_autoglobal_t', , `dnl {{{
712    DISPATCH(zend_uint, key_len)
713#ifdef IS_UNICODE
714    DISPATCH(zend_uchar, type)
715#endif
716    IFRESTORE(`COPY(key)', `
717        PROC_ZSTRING_L(type, key, key_len)
718    ')
719')
720dnl }}}
721#endif
[1]722DEF_STRUCT_P_FUNC(`xc_entry_data_php_t', , `dnl {{{
723    zend_uint i;
724
725#ifdef HAVE_INODE
726    DISPATCH(int, device)
727    DISPATCH(int, inode)
728#endif
729    DISPATCH(size_t, sourcesize)
730
731    DISPATCH(time_t, mtime)
732
733    STRUCT_P(zend_op_array, op_array)
734
[95]735#ifdef HAVE_XCACHE_CONSTANT
736    DISPATCH(zend_uint, constinfo_cnt)
737    STRUCT_ARRAY(constinfo_cnt, xc_constinfo_t, constinfos)
738#endif
739
[1]740    DISPATCH(zend_uint, funcinfo_cnt)
741    STRUCT_ARRAY(funcinfo_cnt, xc_funcinfo_t, funcinfos)
742
743    DISPATCH(zend_uint, classinfo_cnt)
744    pushdef(`BEFORE_LOOP', `
745        IFCOPY(`
746            processor->active_class_num = i + 1;
747        ')
748    ')
749    STRUCT_ARRAY(classinfo_cnt, xc_classinfo_t, classinfos)
[268]750#ifdef ZEND_ENGINE_2_1
751    DISPATCH(zend_uint, autoglobal_cnt)
752    STRUCT_ARRAY(autoglobal_cnt, xc_autoglobal_t, autoglobals)
753#endif
[212]754    DISPATCH(zend_bool, have_early_binding)
[1]755    popdef(`BEFORE_LOOP')
756')
757dnl }}}
758DEF_STRUCT_P_FUNC(`xc_entry_data_var_t', , `dnl {{{
[230]759    IFDPRINT(`INDENT()`'fprintf(stderr, "zval:value");')
[4]760    STRUCT_P_EX(zval_ptr, dst->value, src->value, `value', `', `&')
[1]761    DONE(value)
762')
763dnl }}}
764dnl {{{ xc_entry_t
765DEF_STRUCT_P_FUNC(`xc_entry_t', , `
766    IFCOPY(`
767        processor->xce_dst = dst;
768        processor->xce_src = src;
769    ')
770    DISPATCH(xc_entry_type_t, type)
771    DISPATCH(size_t, size)
772
773    DISPATCH(xc_hash_value_t, hvalue)
774    COPY(cache)
775    /* skip */
776    DONE(next)
777
778    IFSTORE(`dst->refcount = 0; DONE(refcount)', `DISPATCH(long, refcount)')
779
780    DISPATCH(time_t, ctime)
781    DISPATCH(time_t, atime)
782    DISPATCH(time_t, dtime)
[114]783    DISPATCH(long, ttl)
[1]784    DISPATCH(zend_ulong, hits)
785#ifdef IS_UNICODE
786    DISPATCH(zend_uchar, name_type)
787#endif
788    dnl {{{ name
789    DISABLECHECK(`
790#ifdef IS_UNICODE
791        if (src->name_type == IS_UNICODE) {
792            DISPATCH(int32_t, name.ustr.len)
793        }
794        else {
795            DISPATCH(int, name.str.len)
796        }
797#else
798        DISPATCH(int, name.str.len)
799#endif
[103]800        IFRESTORE(`COPY(name.str.val)', `
801#ifdef IS_UNICODE
802            PROC_ZSTRING_L(name_type, name.uni.val, name.uni.len)
803#else
804            PROC_STRING_L(name.str.val, name.str.len)
805#endif
806        ')
[1]807    ')
808    DONE(name)
809    dnl }}}
810
811    dnl {{{ data
812    DISABLECHECK(`
813        switch (src->type) {
814        case XC_TYPE_PHP:
815            STRUCT_P(xc_entry_data_php_t, data.php)
816            break;
817        case XC_TYPE_VAR:
818            STRUCT_P(xc_entry_data_var_t, data.var)
819            break;
820        default:
821            assert(0);
822        }
823    ')
824    DONE(data)
825    dnl }}}
[233]826    DISPATCH(zend_bool, have_references)
[1]827')
828dnl }}}
829dnl ====================================================
Note: See TracBrowser for help on using the repository browser.