X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=src%2Fmarshal.c;h=63a7dc914bbcfc278c98c627d809fafac260325f;hb=4d2c075c160bbc1ff49c3499f8fdd07d9c447a12;hp=c771e79f246f4c401cf5d8c3e5de2e07e8cbf89f;hpb=ddeb4918bce67ed63c5f4c8c4e250e92ebdef89d;p=m6w6%2Fext-psi diff --git a/src/marshal.c b/src/marshal.c index c771e79..63a7dc9 100644 --- a/src/marshal.c +++ b/src/marshal.c @@ -99,7 +99,12 @@ zend_internal_arg_info *psi_internal_arginfo(struct psi_impl *impl) aip = calloc(argc + 1 + !!impl->func->vararg, sizeof(*aip)); fi = (zend_internal_function_info *) &aip[0]; +#ifdef ZEND_TYPE_ENCODE fi->type = ZEND_TYPE_ENCODE(psi_internal_type(impl->func->return_type), 1); +#else + fi->allow_null = 1; + fi->type_hint = psi_internal_type(impl->func->return_type); +#endif fi->required_num_args = psi_impl_num_min_args(impl); fi->return_reference = impl->func->return_reference; @@ -108,7 +113,12 @@ zend_internal_arg_info *psi_internal_arginfo(struct psi_impl *impl) zend_internal_arg_info *ai = &aip[argc]; ai->name = vararg->var->name; +#ifdef ZEND_TYPE_ENCODE ai->type = ZEND_TYPE_ENCODE(psi_internal_type(vararg->type), 1); +#else + ai->allow_null = 1; + ai->type_hint = psi_internal_type(vararg->type); +#endif if (vararg->var->reference) { ai->pass_by_reference = 1; } @@ -119,7 +129,12 @@ zend_internal_arg_info *psi_internal_arginfo(struct psi_impl *impl) zend_internal_arg_info *ai = &aip[i]; ai->name = iarg->var->name; +#ifdef ZEND_TYPE_ENCODE ai->type = ZEND_TYPE_ENCODE(psi_internal_type(iarg->type), 1); +#else + ai->allow_null = 1; + ai->type_hint = psi_internal_type(iarg->type); +#endif if (iarg->var->reference) { ai->pass_by_reference = 1; }