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

Last change on this file since 481 was 481, checked in by moo, 7 years ago

merged [480] from trunk: compile against PHP_5_3

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