source: trunk/processor/processor.m4 @ 484

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

fix: zval_data type size mismatch

  • Property svn:eol-style set to native
File size: 19.6 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#ifdef ZEND_ENGINE_2
153        DISPATCH(zend_uint, refcount)
154#else
155        DISPATCH(zend_ushort, refcount)
156#endif
157#ifdef ZEND_ENGINE_2_3
158        DISPATCH(zend_uchar, idx_type)
159#endif
160    ')dnl IFDASM
161')
162dnl }}}
163DEF_STRUCT_P_FUNC(`zval_ptr', , `dnl {{{
164    IFDASM(`
165        pushdefFUNC_NAME(`zval')
166        FUNC_NAME (dst, src[0] TSRMLS_CC);
167        popdef(`FUNC_NAME')
168    ', `
169        do {
170            IFCALCCOPY(`
171                if (processor->reference) {
172                    zval_ptr *ppzv;
173                    if (zend_hash_find(&processor->zvalptrs, (char *) &src[0], sizeof(src[0]), (void **) &ppzv) == SUCCESS) {
174                        IFCOPY(`
175                            dst[0] = *ppzv;
176                            /* *dst is updated */
177                            dnl fprintf(stderr, "*dst is set to %p, KIND is_shm %d\n", dst[0], xc_is_shm(dst[0]));
178                        ')
179                        IFCALCSTORE(`processor->have_references = 1;')
180                        IFSTORE(`assert(xc_is_shm(dst[0]));')
181                        IFRESTORE(`assert(!xc_is_shm(dst[0]));')
182                        break;
183                    }
184                }
185            ')
186           
187            ALLOC(dst[0], zval)
188            IFCALCCOPY(`
189                if (processor->reference) {
190                    IFCALC(`
191                        /* make dummy */
192                        zval_ptr pzv = (zval_ptr)-1;
193                    ', `
194                        zval_ptr pzv = dst[0];
195                        FIXPOINTER_EX(zval, pzv)
196                    ')
197                    if (zend_hash_add(&processor->zvalptrs, (char *) &src[0], sizeof(src[0]), (void *) &pzv, sizeof(pzv), NULL) == SUCCESS) {
198                        /* first add, go on */
199                        dnl fprintf(stderr, "mark[%p] = %p\n", src[0], pzv);
200                    }
201                    else {
202                        assert(0);
203                    }
204                }
205            ')
206            IFCOPY(`
207                dnl fprintf(stderr, "copy from %p to %p\n", src[0], dst[0]);
208            ')
209            IFDPRINT(`INDENT()`'fprintf(stderr, "[%p]", src[0]);')
210            STRUCT_P_EX(zval, dst[0], src[0], `[0]', `', ` ')
211            FIXPOINTER_EX(zval, dst[0])
212        } while (0);
213    ')
214    DONE_SIZE(sizeof(zval_ptr))
215')
216dnl }}}
217dnl {{{ zend_arg_info
218#ifdef ZEND_ENGINE_2
219DEF_STRUCT_P_FUNC(`zend_arg_info', , `
220    DISPATCH(zend_uint, name_len)
221    PROC_ZSTRING_L(, name, name_len)
222    DISPATCH(zend_uint, class_name_len)
223    PROC_ZSTRING_L(, class_name, class_name_len)
224    DISPATCH(zend_bool, array_type_hint)
225    DISPATCH(zend_bool, allow_null)
226    DISPATCH(zend_bool, pass_by_reference)
227    DISPATCH(zend_bool, return_reference)
228    DISPATCH(int, required_num_args)
229')
230#endif
231dnl }}}
232#ifdef HAVE_XCACHE_CONSTANT
233DEF_STRUCT_P_FUNC(`zend_constant', , `dnl {{{
234    STRUCT(zval, value)
235    DISPATCH(int, flags)
236    DISPATCH(uint, name_len)
237    pushdef(`emalloc', `malloc($1)')
238    pushdef(`ecalloc', `calloc($1, $2)')
239    PROC_ZSTRING_L(, name, name_len)
240    popdef(`ecalloc')
241    popdef(`emalloc')
242    DISPATCH(int, module_number)
243')
244dnl }}}
245#endif
246DEF_STRUCT_P_FUNC(`zend_function', , `dnl {{{
247    DISABLECHECK(`
248    switch (src->type) {
249    case ZEND_INTERNAL_FUNCTION:
250    case ZEND_OVERLOADED_FUNCTION:
251        IFNOTMEMCPY(`IFCOPY(`memcpy(dst, src, sizeof(src[0]));')')
252        break;
253
254    case ZEND_USER_FUNCTION:
255    case ZEND_EVAL_CODE:
256        DONE(type)
257        STRUCT(zend_op_array, op_array)
258        break;
259
260    default:
261        assert(0);
262    }
263    ')
264    DONE_SIZE(sizeof(src[0]))
265')
266dnl }}}
267dnl {{{ zend_property_info
268#ifdef ZEND_ENGINE_2
269DEF_STRUCT_P_FUNC(`zend_property_info', , `
270    DISPATCH(zend_uint, flags)
271    DISPATCH(int, name_length)
272    PROC_ZSTRING_L(, name, name_length)
273    DISPATCH(ulong, h)
274#ifdef ZEND_ENGINE_2_1
275    DISPATCH(int, doc_comment_len)
276    PROC_ZSTRING_L(, doc_comment, doc_comment_len)
277#endif
278    dnl isnt in php6 yet
279#if defined(ZEND_ENGINE_2_2) && !defined(IS_UNICODE)
280    PROC_CLASS_ENTRY_P(ce)
281#endif
282')
283#endif
284dnl }}}
285DEF_STRUCT_P_FUNC(`zend_class_entry', , `dnl {{{
286    IFCALCCOPY(`
287        processor->active_class_entry_src = src;
288        IFCOPY(`processor->active_class_entry_dst = dst;')
289    ')
290    DISPATCH(char, type)
291    DISPATCH(zend_uint, name_length)
292    PROC_ZSTRING_L(, name, name_length)
293    IFRESTORE(`
294#ifndef ZEND_ENGINE_2
295        /* just copy parent and resolve on install_class */
296        COPY(parent)
297#else
298        PROC_CLASS_ENTRY_P(parent)
299#endif
300    ', `
301        PROC_CLASS_ENTRY_P(parent)
302    ')
303#ifdef ZEND_ENGINE_2
304    DISPATCH(int, refcount)
305#else
306    STRUCT_P(int, refcount)
307#endif
308    DISPATCH(zend_bool, constants_updated)
309#ifdef ZEND_ENGINE_2
310    DISPATCH(zend_uint, ce_flags)
311#endif
312
313    STRUCT(HashTable, default_properties, HashTable_zval_ptr)
314    IFCOPY(`dst->builtin_functions = src->builtin_functions;')
315    DONE(builtin_functions)
316#ifdef ZEND_ENGINE_2
317    STRUCT(HashTable, properties_info, HashTable_zend_property_info)
318#   ifdef ZEND_ENGINE_2_1
319    STRUCT(HashTable, default_static_members, HashTable_zval_ptr)
320    IFCOPY(`dst->static_members = &dst->default_static_members;')
321    DONE(static_members)
322#   else
323    STRUCT_P(HashTable, static_members, HashTable_zval_ptr)
324#   endif
325    STRUCT(HashTable, constants_table, HashTable_zval_ptr)
326
327    dnl runtime binding: ADD_INTERFACE will deal with it
328    IFRESTORE(`
329        if (src->num_interfaces) {
330            CALLOC(dst->interfaces, zend_class_entry*, src->num_interfaces)
331            DONE(`interfaces')
332        }
333        else {
334            COPYNULL(interfaces)
335        }
336    ')
337    IFDASM(`
338        if (src->num_interfaces) {
339            /*
340            zval *arr;
341            ALLOC_INIT_ZVAL(arr);
342            array_init(arr);
343            for (i = 0; i < src->num_interfaces; i ++) {
344                zval *zv;
345                ALLOC_INIT_ZVAL(zv);
346                ZVAL_STRING(src->num_interfaces);
347            }
348            add_assoc_zval_ex(dst, ZEND_STRS("interfaces"), arr);
349            */
350            DONE(`interfaces')
351        }
352        else {
353            COPYNULL(interfaces)
354        }
355    ')
356    IFRESTORE(`', `
357        IFDASM(`', `
358            DONE(`interfaces')
359        ')
360    ')
361    DISPATCH(zend_uint, num_interfaces)
362
363    IFRESTORE(`COPY(filename)', `PROC_STRING(filename)')
364    DISPATCH(zend_uint, line_start)
365    DISPATCH(zend_uint, line_end)
366#ifdef ZEND_ENGINE_2_1
367    DISPATCH(zend_uint, doc_comment_len)
368    PROC_ZSTRING_L(, doc_comment, doc_comment_len)
369#endif
370    /* # NOT DONE */
371    COPY(serialize_func)
372    COPY(unserialize_func)
373    COPY(iterator_funcs)
374    COPY(create_object)
375    COPY(get_iterator)
376    COPY(interface_gets_implemented)
377#ifdef ZEND_ENGINE_2_3
378    COPY(get_static_method)
379#endif
380    COPY(serialize)
381    COPY(unserialize)
382    /* deal with it inside xc_fix_method */
383    SETNULL(constructor)
384    COPY(destructor)
385    COPY(clone)
386    COPY(__get)
387    COPY(__set)
388/* should be >5.1 */
389#ifdef ZEND_ENGINE_2_1
390    COPY(__unset)
391    COPY(__isset)
392# if defined(ZEND_ENGINE_2_2) || PHP_MAJOR_VERSION >= 6
393    COPY(__tostring)
394# endif
395#endif
396    COPY(__call)
397#ifdef ZEND_CALLSTATIC_FUNC_NAME
398    COPY(__callstatic)
399#endif
400    /* # NOT DONE */
401    COPY(module)
402#else
403    COPY(handle_function_call)
404    COPY(handle_property_get)
405    COPY(handle_property_set)
406#endif
407    dnl must do after SETNULL(constructor) and dst->parent
408    STRUCT(HashTable, function_table, HashTable_zend_function)
409    IFRESTORE(`dst->function_table.pDestructor = ZEND_FUNCTION_DTOR;')
410    IFCALCCOPY(`
411        processor->active_class_entry_src = NULL;
412        IFCOPY(`processor->active_class_entry_dst = NULL;')
413    ')
414')
415dnl }}}
416DEF_STRUCT_P_FUNC(`znode', , `dnl {{{
417    DISPATCH(int, op_type)
418
419#ifdef IS_CV
420#   define XCACHE_IS_CV IS_CV
421#else
422/* compatible with zend optimizer */
423#   define XCACHE_IS_CV 16
424#endif
425    assert(src->op_type == IS_CONST ||
426        src->op_type == IS_VAR ||
427        src->op_type == XCACHE_IS_CV ||
428        src->op_type == IS_TMP_VAR ||
429        src->op_type == IS_UNUSED);
430    dnl dirty dispatch
431    DISABLECHECK(`
432    switch (src->op_type) {
433        case IS_CONST:
434            STRUCT(zval, u.constant)
435            break;
436        IFCOPY(`
437            IFNOTMEMCPY(`
438                default:
439                    memcpy(&dst->u, &src->u, sizeof(src->u));
440            ')
441        ', `
442        case IS_VAR:
443        case IS_TMP_VAR:
444        case XCACHE_IS_CV:
445            DISPATCH(zend_uint, u.var)
446            DISPATCH(zend_uint, u.EA.type)
447            break;
448        case IS_UNUSED:
449            IFDASM(`DISPATCH(zend_uint, u.var)')
450            DISPATCH(zend_uint, u.opline_num)
451#ifndef ZEND_ENGINE_2
452            DISPATCH(zend_uint, u.fetch_type)
453#endif
454            DISPATCH(zend_uint, u.EA.type)
455            break;
456        ')
457    }
458    ')
459    DONE(u)
460#undef XCACHE_IS_CV
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->php_src->op_array && processor->php_src->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    IFCOPY(`
738        processor->php_dst = dst;
739        processor->php_src = src;
740    ')
741
742    DISPATCH(xc_hash_value_t, hvalue)
743    /* skip */
744    DONE(next)
745    COPY(cache)
746    DISPATCH(xc_md5sum_t, md5)
747    DISPATCH(zend_ulong, refcount)
748
749    DISPATCH(size_t, sourcesize)
750    DISPATCH(zend_ulong, hits)
751    DISPATCH(size_t, size)
752
753    STRUCT_P(zend_op_array, op_array)
754
755#ifdef HAVE_XCACHE_CONSTANT
756    DISPATCH(zend_uint, constinfo_cnt)
757    STRUCT_ARRAY(constinfo_cnt, xc_constinfo_t, constinfos)
758#endif
759
760    DISPATCH(zend_uint, funcinfo_cnt)
761    STRUCT_ARRAY(funcinfo_cnt, xc_funcinfo_t, funcinfos)
762
763    DISPATCH(zend_uint, classinfo_cnt)
764    pushdef(`BEFORE_LOOP', `
765        IFCOPY(`
766            processor->active_class_num = i + 1;
767        ')
768    ')
769    STRUCT_ARRAY(classinfo_cnt, xc_classinfo_t, classinfos)
770#ifdef ZEND_ENGINE_2_1
771    DISPATCH(zend_uint, autoglobal_cnt)
772    STRUCT_ARRAY(autoglobal_cnt, xc_autoglobal_t, autoglobals)
773#endif
774    DISPATCH(zend_bool, have_early_binding)
775    popdef(`BEFORE_LOOP')
776    DISPATCH(zend_bool, have_references)
777')
778dnl }}}
779DEF_STRUCT_P_FUNC(`xc_entry_data_var_t', , `dnl {{{
780    IFDPRINT(`INDENT()`'fprintf(stderr, "zval:value");')
781    STRUCT_P_EX(zval_ptr, dst->value, src->value, `value', `', `&')
782    DISPATCH(zend_bool, have_references)
783    DONE(value)
784')
785dnl }}}
786dnl {{{ xc_entry_t
787DEF_STRUCT_P_FUNC(`xc_entry_t', , `
788    DISPATCH(xc_entry_type_t, type)
789    DISPATCH(size_t, size)
790
791    DISPATCH(xc_hash_value_t, hvalue)
792    COPY(cache)
793    /* skip */
794    DONE(next)
795
796    IFSTORE(`dst->refcount = 0; DONE(refcount)', `DISPATCH(long, refcount)')
797
798    DISPATCH(time_t, ctime)
799    DISPATCH(time_t, atime)
800    DISPATCH(time_t, dtime)
801    DISPATCH(long, ttl)
802    DISPATCH(zend_ulong, hits)
803#ifdef IS_UNICODE
804    DISPATCH(zend_uchar, name_type)
805#endif
806    dnl {{{ name
807    DISABLECHECK(`
808#ifdef IS_UNICODE
809        if (src->name_type == IS_UNICODE) {
810            DISPATCH(int32_t, name.ustr.len)
811        }
812        else {
813            DISPATCH(int, name.str.len)
814        }
815#else
816        DISPATCH(int, name.str.len)
817#endif
818        IFRESTORE(`COPY(name.str.val)', `
819#ifdef IS_UNICODE
820            PROC_ZSTRING_L(name_type, name.uni.val, name.uni.len)
821#else
822            PROC_STRING_L(name.str.val, name.str.len)
823#endif
824        ')
825    ')
826    DONE(name)
827    dnl }}}
828
829    dnl {{{ data
830    DISABLECHECK(`
831        switch (src->type) {
832        case XC_TYPE_PHP:
833            IFCALCCOPY(`DONE(data.php)', `STRUCT_P(xc_entry_data_php_t, data.php)')
834            break;
835
836        case XC_TYPE_VAR:
837            STRUCT_P(xc_entry_data_var_t, data.var)
838            break;
839
840        default:
841            assert(0);
842        }
843    ')
844    DONE(data)
845    dnl }}}
846    DISPATCH(time_t, mtime)
847#ifdef HAVE_INODE
848    DISPATCH(int, device)
849    DISPATCH(int, inode)
850#endif
851')
852dnl }}}
853dnl ====================================================
Note: See TracBrowser for help on using the repository browser.