TypedValue* fg_call_user_method_array(HPHP::VM::ActRec *ar) { TypedValue rv; long long count = ar->numArgs(); TypedValue* args UNUSED = ((TypedValue*)ar) - 1; if (count == 3LL) { if ((args-2)->m_type == KindOfArray && IS_STRING_TYPE((args-0)->m_type)) { fh_call_user_method_array((&(rv)), (Value*)(args-0), (args-1), (Value*)(args-2)); if (rv.m_type == KindOfUninit) rv.m_type = KindOfNull; frame_free_locals_no_this_inl(ar, 3); memcpy(&ar->m_r, &rv, sizeof(TypedValue)); return &ar->m_r; } else { fg1_call_user_method_array(&rv, ar, count); frame_free_locals_no_this_inl(ar, 3); memcpy(&ar->m_r, &rv, sizeof(TypedValue)); return &ar->m_r; } } else { throw_wrong_arguments_nr("call_user_method_array", count, 3, 3, 1); } rv.m_data.num = 0LL; rv._count = 0; rv.m_type = KindOfNull; frame_free_locals_no_this_inl(ar, 3); memcpy(&ar->m_r, &rv, sizeof(TypedValue)); return &ar->m_r; return &ar->m_r; }
void fg1_call_user_method_array(TypedValue* rv, ActRec* ar, int32_t count) { TypedValue* args UNUSED = ((TypedValue*)ar) - 1; if ((args-2)->m_type != KindOfArray) { tvCastToArrayInPlace(args-2); } if (!IS_STRING_TYPE((args-0)->m_type)) { tvCastToStringInPlace(args-0); } fh_call_user_method_array(rv, &args[-0].m_data, (args-1), &args[-2].m_data); if (rv->m_type == KindOfUninit) rv->m_type = KindOfNull; }
TypedValue * fg1_call_user_method_array(TypedValue* rv, HPHP::VM::ActRec* ar, long long count) { TypedValue* args UNUSED = ((TypedValue*)ar) - 1; if ((args-2)->m_type != KindOfArray) { tvCastToArrayInPlace(args-2); } if (!IS_STRING_TYPE((args-0)->m_type)) { tvCastToStringInPlace(args-0); } fh_call_user_method_array((rv), (Value*)(args-0), (args-1), (Value*)(args-2)); if (rv->m_type == KindOfUninit) rv->m_type = KindOfNull; return rv; }
TypedValue* fg_call_user_method_array(ActRec* ar) { TypedValue rvSpace; TypedValue* rv = &rvSpace; int32_t count = ar->numArgs(); TypedValue* args UNUSED = ((TypedValue*)ar) - 1; if (count == 3) { if ((args - 2)->m_type == KindOfArray && IS_STRING_TYPE((args - 0)->m_type)) { fh_call_user_method_array(rv, &args[-0].m_data, (args-1), &args[-2].m_data); if (rv->m_type == KindOfUninit) rv->m_type = KindOfNull; } else { fg1_call_user_method_array(rv, ar, count); } } else { throw_wrong_arguments_nr("call_user_method_array", count, 3, 3, 1); rv->m_data.num = 0LL; rv->m_type = KindOfNull; } frame_free_locals_no_this_inl(ar, 3); memcpy(&ar->m_r, rv, sizeof(TypedValue)); return &ar->m_r; }