source: tags/1.2.2/processor/processor.m4 @ 493

Last change on this file since 493 was 493, checked in by moo, 6 years ago

released 1.2.2

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