jerryscript/tests/jerry/regression-test-issue-737.js
Andrey Shitov 50d124bfc3 Parser optimizations.
- parser is now non-recursive (i.e. parse function is not called recursively in any case);
 - byte-code is now more compact:
    - constants are now not immediately dumped upon occurence, but later - where necessary;
    - assignments are combined with unary / binary operations;
    - binary operations are encoded more compactly in many cases;
 - byte-code arrays are now allocated separately for each scope (so, GC of the scopes now becomes possible);
 - byte-code is dumped directly into corresponding byte-code arrays:
   - linked lists of op_meta are not now used for main code of a scope.

JerryScript-DCO-1.0-Signed-off-by: Ruben Ayrapetyan r.ayrapetyan@samsung.com
JerryScript-DCO-1.0-Signed-off-by: Andrey Shitov a.shitov@samsung.com
2015-12-23 14:21:10 +03:00

69 lines
2.7 KiB
JavaScript

// Copyright 2015 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.
function check_syntax_error (s) {
try {
eval (s);
assert (false);
} catch (e) {
assert (e instanceof SyntaxError);
}
}
/* Test case #1 */
check_syntax_error (
" new function f(f) { \
return {className: 'xxx'}; \
}; \
x = 1; \
function g(active) { \
for (i = 1; i <= 1000; i++) { if (i == active) { \
x = i; if (f(\"\" + i) != null) { } \
} else { \
if (f(\"\" + i) != null) } \
} \
} \
g(0) \
");
/* Test case #2 */
check_syntax_error (
" new function a(a) {;for (f in [1,2,3]) print(f); \
}; 1; \
function g(active) { \
for (i = 1; i <= 1000; i++) { if (i == active) { \
xI \
if (f != null) { } \
} else { \
if (f(\"\" + i) != null) } \
} \
} \
g(0) \
");
/* Test case #3 */
check_syntax_error (
" new function f(f) {;for (f in [1,2,3]) pRint(f); \
}; 1; \
function g(active) { \
for (i = 1; i <= 1000; i++) { if (i == active) { \
x \
if (f != null) { } \
} else { \
if (f(\"\" + i) != null) } \
} \
} \
g(0) \
");