source: branches/1.3/processor/processor.m4 @ 622

Last change on this file since 622 was 622, checked in by moo, 5 years ago

merged r504:513 from trunk

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