mirror of
https://github.com/jerryscript-project/jerryscript.git
synced 2025-12-15 16:29:21 +00:00
Fixing object declaration and function expression opcode handlers; adding unit test that declares object and operates on the object's properties.
This commit is contained in:
parent
5630352f36
commit
b9fd80ce36
@ -595,6 +595,8 @@ ecma_completion_value_t
|
|||||||
opfunc_func_expr_n (opcode_t opdata, /**< operation data */
|
opfunc_func_expr_n (opcode_t opdata, /**< operation data */
|
||||||
int_data_t *int_data) /**< interpreter context */
|
int_data_t *int_data) /**< interpreter context */
|
||||||
{
|
{
|
||||||
|
int_data->pos++;
|
||||||
|
|
||||||
const idx_t dst_var_idx = opdata.data.func_expr_n.lhs;
|
const idx_t dst_var_idx = opdata.data.func_expr_n.lhs;
|
||||||
const idx_t function_name_lit_idx = opdata.data.func_expr_n.name_lit_idx;
|
const idx_t function_name_lit_idx = opdata.data.func_expr_n.name_lit_idx;
|
||||||
const ecma_length_t params_number = opdata.data.func_expr_n.arg_list;
|
const ecma_length_t params_number = opdata.data.func_expr_n.arg_list;
|
||||||
@ -985,9 +987,12 @@ opfunc_obj_decl (opcode_t opdata, /**< operation data */
|
|||||||
ecma_string_t *prop_name_string_p = ecma_new_ecma_string_from_lit_index (prop_name_lit_idx);
|
ecma_string_t *prop_name_string_p = ecma_new_ecma_string_from_lit_index (prop_name_lit_idx);
|
||||||
ecma_property_t *previous_p = ecma_op_object_get_own_property (obj_p, prop_name_string_p);
|
ecma_property_t *previous_p = ecma_op_object_get_own_property (obj_p, prop_name_string_p);
|
||||||
|
|
||||||
const bool is_previous_data_desc = (previous_p->type == ECMA_PROPERTY_NAMEDDATA);
|
const bool is_previous_undefined = (previous_p == NULL);
|
||||||
const bool is_previous_accessor_desc = (previous_p->type == ECMA_PROPERTY_NAMEDACCESSOR);
|
const bool is_previous_data_desc = (!is_previous_undefined
|
||||||
JERRY_ASSERT (is_previous_data_desc || is_previous_accessor_desc);
|
&& previous_p->type == ECMA_PROPERTY_NAMEDDATA);
|
||||||
|
const bool is_previous_accessor_desc = (!is_previous_undefined
|
||||||
|
&& previous_p->type == ECMA_PROPERTY_NAMEDACCESSOR);
|
||||||
|
JERRY_ASSERT (is_previous_undefined || is_previous_data_desc || is_previous_accessor_desc);
|
||||||
|
|
||||||
ecma_property_descriptor_t prop_desc = ecma_make_empty_property_descriptor ();
|
ecma_property_descriptor_t prop_desc = ecma_make_empty_property_descriptor ();
|
||||||
{
|
{
|
||||||
@ -1006,9 +1011,10 @@ opfunc_obj_decl (opcode_t opdata, /**< operation data */
|
|||||||
prop_desc.is_writable_defined = true;
|
prop_desc.is_writable_defined = true;
|
||||||
prop_desc.writable = ECMA_PROPERTY_WRITABLE;
|
prop_desc.writable = ECMA_PROPERTY_WRITABLE;
|
||||||
|
|
||||||
if ((is_previous_data_desc
|
if (!is_previous_undefined
|
||||||
|
&& ((is_previous_data_desc
|
||||||
&& int_data->is_strict)
|
&& int_data->is_strict)
|
||||||
|| is_previous_accessor_desc)
|
|| is_previous_accessor_desc))
|
||||||
{
|
{
|
||||||
is_throw_syntax_error = true;
|
is_throw_syntax_error = true;
|
||||||
}
|
}
|
||||||
@ -1020,7 +1026,8 @@ opfunc_obj_decl (opcode_t opdata, /**< operation data */
|
|||||||
prop_desc.is_get_defined = true;
|
prop_desc.is_get_defined = true;
|
||||||
prop_desc.get_p = ECMA_GET_POINTER (value_for_prop_desc.u.value.value);
|
prop_desc.get_p = ECMA_GET_POINTER (value_for_prop_desc.u.value.value);
|
||||||
|
|
||||||
if (is_previous_data_desc)
|
if (!is_previous_undefined
|
||||||
|
&& is_previous_data_desc)
|
||||||
{
|
{
|
||||||
is_throw_syntax_error = true;
|
is_throw_syntax_error = true;
|
||||||
}
|
}
|
||||||
@ -1032,7 +1039,8 @@ opfunc_obj_decl (opcode_t opdata, /**< operation data */
|
|||||||
prop_desc.is_set_defined = true;
|
prop_desc.is_set_defined = true;
|
||||||
prop_desc.set_p = ECMA_GET_POINTER (value_for_prop_desc.u.value.value);
|
prop_desc.set_p = ECMA_GET_POINTER (value_for_prop_desc.u.value.value);
|
||||||
|
|
||||||
if (is_previous_data_desc)
|
if (!is_previous_undefined
|
||||||
|
&& is_previous_data_desc)
|
||||||
{
|
{
|
||||||
is_throw_syntax_error = true;
|
is_throw_syntax_error = true;
|
||||||
}
|
}
|
||||||
@ -1765,6 +1773,9 @@ opfunc_meta (opcode_t opdata, /**< operation data */
|
|||||||
switch (type)
|
switch (type)
|
||||||
{
|
{
|
||||||
case OPCODE_META_TYPE_VARG:
|
case OPCODE_META_TYPE_VARG:
|
||||||
|
case OPCODE_META_TYPE_VARG_PROP_DATA:
|
||||||
|
case OPCODE_META_TYPE_VARG_PROP_GETTER:
|
||||||
|
case OPCODE_META_TYPE_VARG_PROP_SETTER:
|
||||||
case OPCODE_META_TYPE_END_WITH:
|
case OPCODE_META_TYPE_END_WITH:
|
||||||
case OPCODE_META_TYPE_CATCH:
|
case OPCODE_META_TYPE_CATCH:
|
||||||
case OPCODE_META_TYPE_FINALLY:
|
case OPCODE_META_TYPE_FINALLY:
|
||||||
@ -1774,9 +1785,7 @@ opfunc_meta (opcode_t opdata, /**< operation data */
|
|||||||
}
|
}
|
||||||
case OPCODE_META_TYPE_UNDEFINED:
|
case OPCODE_META_TYPE_UNDEFINED:
|
||||||
case OPCODE_META_TYPE_THIS_ARG:
|
case OPCODE_META_TYPE_THIS_ARG:
|
||||||
case OPCODE_META_TYPE_VARG_PROP_DATA:
|
|
||||||
case OPCODE_META_TYPE_VARG_PROP_GETTER:
|
|
||||||
case OPCODE_META_TYPE_VARG_PROP_SETTER:
|
|
||||||
case OPCODE_META_TYPE_FUNCTION_END:
|
case OPCODE_META_TYPE_FUNCTION_END:
|
||||||
case OPCODE_META_TYPE_CATCH_EXCEPTION_IDENTIFIER:
|
case OPCODE_META_TYPE_CATCH_EXCEPTION_IDENTIFIER:
|
||||||
case OPCODE_META_TYPE_STRICT_CODE:
|
case OPCODE_META_TYPE_STRICT_CODE:
|
||||||
|
|||||||
@ -61,7 +61,7 @@ ecma_op_create_object_object_noarg (void)
|
|||||||
FIXME (/* Set to built-in Object prototype (15.2.4) */);
|
FIXME (/* Set to built-in Object prototype (15.2.4) */);
|
||||||
|
|
||||||
// 3., 4., 6., 7.
|
// 3., 4., 6., 7.
|
||||||
ecma_object_t *obj_p = ecma_create_object (NULL, false, ECMA_OBJECT_TYPE_GENERAL);
|
ecma_object_t *obj_p = ecma_create_object (NULL, true, ECMA_OBJECT_TYPE_GENERAL);
|
||||||
|
|
||||||
ecma_property_t *class_prop_p = ecma_create_internal_property (obj_p, ECMA_INTERNAL_PROPERTY_CLASS);
|
ecma_property_t *class_prop_p = ecma_create_internal_property (obj_p, ECMA_INTERNAL_PROPERTY_CLASS);
|
||||||
class_prop_p->u.internal_property.value = ECMA_OBJECT_CLASS_OBJECT;
|
class_prop_p->u.internal_property.value = ECMA_OBJECT_CLASS_OBJECT;
|
||||||
|
|||||||
158
tests/unit/test_obj_initializer.c
Normal file
158
tests/unit/test_obj_initializer.c
Normal file
@ -0,0 +1,158 @@
|
|||||||
|
/* Copyright 2014 Samsung Electronics Co., Ltd.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "globals.h"
|
||||||
|
#include "interpreter.h"
|
||||||
|
#include "mem-allocator.h"
|
||||||
|
#include "opcodes.h"
|
||||||
|
#include "serializer.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Unit test's main function.
|
||||||
|
*/
|
||||||
|
int
|
||||||
|
main( int __unused argc,
|
||||||
|
char __unused **argv)
|
||||||
|
{
|
||||||
|
const opcode_t test_program[] = {
|
||||||
|
[ 0] = getop_reg_var_decl (240, 255),
|
||||||
|
[ 1] = getop_jmp_down (2),
|
||||||
|
[ 2] = getop_exitval (1),
|
||||||
|
|
||||||
|
/* var a, b; */
|
||||||
|
[ 3] = getop_var_decl (0),
|
||||||
|
[ 4] = getop_var_decl (1),
|
||||||
|
|
||||||
|
/* b = 'property1'; */
|
||||||
|
[ 5] = getop_assignment (1, OPCODE_ARG_TYPE_STRING, 2),
|
||||||
|
|
||||||
|
/* a = { */
|
||||||
|
[ 6] = getop_obj_decl (0, 4),
|
||||||
|
|
||||||
|
/* 'property1' : 'value1', */
|
||||||
|
[ 7] = getop_assignment (240, OPCODE_ARG_TYPE_STRING, 5),
|
||||||
|
[ 8] = getop_meta (OPCODE_META_TYPE_VARG_PROP_DATA, 2, 240),
|
||||||
|
|
||||||
|
/* get property2 () { return 1; }, */
|
||||||
|
[ 9] = getop_func_expr_n (240, 243 /* any tmp reg */, 0),
|
||||||
|
[10] = getop_meta (OPCODE_META_TYPE_FUNCTION_END, 0, 14),
|
||||||
|
[11] = getop_reg_var_decl (250, 255),
|
||||||
|
[12] = getop_assignment (250, OPCODE_ARG_TYPE_SMALLINT, 1),
|
||||||
|
[13] = getop_retval (250),
|
||||||
|
[14] = getop_meta (OPCODE_META_TYPE_VARG_PROP_GETTER, 3, 240),
|
||||||
|
|
||||||
|
/* set property2 (a) { this.property3 = a * 10; }, */
|
||||||
|
[15] = getop_func_expr_n (250, 243 /* any tmp reg */, 1),
|
||||||
|
[16] = getop_meta (OPCODE_META_TYPE_VARG, 0, 255),
|
||||||
|
[17] = getop_meta (OPCODE_META_TYPE_FUNCTION_END, 0, 25),
|
||||||
|
[18] = getop_reg_var_decl (250, 255),
|
||||||
|
[19] = getop_this (250),
|
||||||
|
[20] = getop_assignment (251, OPCODE_ARG_TYPE_STRING, 4),
|
||||||
|
[21] = getop_assignment (252, OPCODE_ARG_TYPE_SMALLINT, 10),
|
||||||
|
[22] = getop_multiplication (252, 0, 252),
|
||||||
|
[23] = getop_prop_setter (250, 251, 252),
|
||||||
|
[24] = getop_ret (),
|
||||||
|
[25] = getop_meta (OPCODE_META_TYPE_VARG_PROP_SETTER, 3, 250),
|
||||||
|
|
||||||
|
/* set property3 (b) { this.property1 = b; } }; */
|
||||||
|
[26] = getop_func_expr_n (250, 243 /* any tmp reg */, 1),
|
||||||
|
[27] = getop_meta (OPCODE_META_TYPE_VARG, 1, 255),
|
||||||
|
[28] = getop_meta (OPCODE_META_TYPE_FUNCTION_END, 0, 34),
|
||||||
|
[29] = getop_reg_var_decl (250, 255),
|
||||||
|
[30] = getop_this (250),
|
||||||
|
[31] = getop_assignment (251, OPCODE_ARG_TYPE_STRING, 2),
|
||||||
|
[32] = getop_prop_setter (250, 251, 1),
|
||||||
|
[33] = getop_ret (),
|
||||||
|
[34] = getop_meta (OPCODE_META_TYPE_VARG_PROP_SETTER, 4, 250),
|
||||||
|
|
||||||
|
/* assert (a.property1 === 'value1'); */
|
||||||
|
[35] = getop_assignment (240, OPCODE_ARG_TYPE_STRING, 2),
|
||||||
|
[36] = getop_prop_getter (240, 0, 240),
|
||||||
|
[37] = getop_assignment (241, OPCODE_ARG_TYPE_STRING, 5),
|
||||||
|
[38] = getop_equal_value_type (240, 240, 241),
|
||||||
|
[39] = getop_is_false_jmp (240, 2),
|
||||||
|
|
||||||
|
/* assert (a.property2 === 1); */
|
||||||
|
[40] = getop_assignment (240, OPCODE_ARG_TYPE_STRING, 3),
|
||||||
|
[41] = getop_prop_getter (240, 0, 240),
|
||||||
|
[42] = getop_assignment (241, OPCODE_ARG_TYPE_SMALLINT, 1),
|
||||||
|
[43] = getop_equal_value_type (240, 240, 241),
|
||||||
|
[44] = getop_is_false_jmp (240, 2),
|
||||||
|
|
||||||
|
/* a.property3 = 'value2'; */
|
||||||
|
[45] = getop_assignment (240, OPCODE_ARG_TYPE_STRING, 4),
|
||||||
|
[46] = getop_assignment (241, OPCODE_ARG_TYPE_STRING, 6),
|
||||||
|
[47] = getop_prop_setter (0, 240, 241),
|
||||||
|
|
||||||
|
/* assert (a.property1 === 'value2'); */
|
||||||
|
[48] = getop_assignment (240, OPCODE_ARG_TYPE_STRING, 2),
|
||||||
|
[49] = getop_prop_getter (240, 0, 240),
|
||||||
|
[50] = getop_assignment (241, OPCODE_ARG_TYPE_STRING, 6),
|
||||||
|
[51] = getop_equal_value_type (240, 240, 241),
|
||||||
|
[52] = getop_is_false_jmp (240, 2),
|
||||||
|
|
||||||
|
/* a.property2 = 2.5; */
|
||||||
|
[53] = getop_assignment (240, OPCODE_ARG_TYPE_STRING, 3),
|
||||||
|
[54] = getop_assignment (241, OPCODE_ARG_TYPE_NUMBER, 7),
|
||||||
|
[55] = getop_prop_setter (0, 240, 241),
|
||||||
|
|
||||||
|
/* assert (a.property1 === 25); */
|
||||||
|
[56] = getop_assignment (240, OPCODE_ARG_TYPE_STRING, 2),
|
||||||
|
[57] = getop_prop_getter (240, 0, 240),
|
||||||
|
[58] = getop_assignment (241, OPCODE_ARG_TYPE_SMALLINT, 25),
|
||||||
|
[59] = getop_equal_value_type (240, 240, 241),
|
||||||
|
[60] = getop_is_false_jmp (240, 2),
|
||||||
|
|
||||||
|
/* b = delete a[b]; */
|
||||||
|
[61] = getop_delete_prop (1, 0, 1),
|
||||||
|
|
||||||
|
/* assert (b === true); */
|
||||||
|
[62] = getop_assignment (240, OPCODE_ARG_TYPE_SIMPLE, ECMA_SIMPLE_VALUE_TRUE),
|
||||||
|
[63] = getop_equal_value_type (240, 240, 1),
|
||||||
|
[64] = getop_is_false_jmp (240, 2),
|
||||||
|
|
||||||
|
/* assert (a.property1 === undefined); */
|
||||||
|
[65] = getop_assignment (240, OPCODE_ARG_TYPE_STRING, 2),
|
||||||
|
[66] = getop_prop_getter (240, 0, 240),
|
||||||
|
[67] = getop_assignment (241, OPCODE_ARG_TYPE_SIMPLE, ECMA_SIMPLE_VALUE_UNDEFINED),
|
||||||
|
[68] = getop_equal_value_type (240, 240, 241),
|
||||||
|
[69] = getop_is_false_jmp (240, 2),
|
||||||
|
|
||||||
|
[70] = getop_exitval (0)
|
||||||
|
};
|
||||||
|
|
||||||
|
mem_init();
|
||||||
|
serializer_init (false);
|
||||||
|
|
||||||
|
const char *strings[] = { "a",
|
||||||
|
"b",
|
||||||
|
"property1",
|
||||||
|
"property2",
|
||||||
|
"property3",
|
||||||
|
"value1",
|
||||||
|
"value2" };
|
||||||
|
ecma_number_t nums [] = { 2.5 };
|
||||||
|
uint16_t offset = serializer_dump_strings( strings, 7);
|
||||||
|
serializer_dump_nums( nums, 1, offset, 7);
|
||||||
|
|
||||||
|
init_int( test_program);
|
||||||
|
|
||||||
|
bool status = run_int();
|
||||||
|
|
||||||
|
serializer_free ();
|
||||||
|
mem_finalize (false);
|
||||||
|
|
||||||
|
return (status ? 0 : 1);
|
||||||
|
} /* main */
|
||||||
Loading…
x
Reference in New Issue
Block a user