[Bugfix]free error in typearray set value routine (#2147)

Issue: #2143

JerryScript-DCO-1.0-Signed-off-by: Zidong Jiang zidong.jiang@intel.com
This commit is contained in:
Zidong Jiang
2017-12-20 19:52:29 +08:00
committed by Dániel Bátyai
parent be9e88784a
commit c3c0bb8ddc
2 changed files with 22 additions and 3 deletions
@@ -26,6 +26,7 @@
#include "ecma-gc.h"
#include "ecma-globals.h"
#include "ecma-helpers.h"
#include "jcontext.h"
#ifndef CONFIG_DISABLE_ES2015_TYPEDARRAY_BUILTIN
@@ -892,12 +893,14 @@ ecma_op_typedarray_set_index_prop (ecma_object_t *obj_p, /**< a TypedArray objec
ECMA_OP_TO_NUMBER_FINALIZE (value_num);
if (ecma_is_value_empty (error))
if (ECMA_IS_VALUE_ERROR (error))
{
return true;
ecma_free_value (JERRY_CONTEXT (error_value));
return false;
}
return false;
JERRY_ASSERT (ecma_is_value_empty (error));
return true;
} /* ecma_op_typedarray_set_index_prop */
/**
@@ -0,0 +1,16 @@
// Copyright JS Foundation and other contributors, http://js.foundation
//
// 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.
var a = new Uint8Array(2);
a[0] = { valueOf : function() { throw "intoint"; } };