8066407: Function with same body not reparsed after SyntaxError
Reviewed-by: attila, lagergren
This commit is contained in:
parent
18bafb792c
commit
9becc306ef
@ -26,7 +26,7 @@
|
||||
package jdk.nashorn.internal.runtime.regexp;
|
||||
|
||||
import java.util.Collections;
|
||||
import java.util.Set;
|
||||
import java.util.Map;
|
||||
import java.util.WeakHashMap;
|
||||
import jdk.nashorn.internal.runtime.ParserException;
|
||||
import jdk.nashorn.internal.runtime.options.Options;
|
||||
@ -45,11 +45,10 @@ public class RegExpFactory {
|
||||
/** Weak cache of already validated regexps - when reparsing, we don't, for example
|
||||
* need to recompile (reverify) all regexps that have previously been parsed by this
|
||||
* RegExpFactory in a previous compilation. This saves significant time in e.g. avatar
|
||||
* startup */
|
||||
private static final Set<String> VALID_CACHE_SET =
|
||||
Collections.newSetFromMap(
|
||||
Collections.synchronizedMap(
|
||||
new WeakHashMap<String, Boolean>()));
|
||||
* startup
|
||||
*/
|
||||
private static final Map<String, RegExp> REGEXP_CACHE =
|
||||
Collections.synchronizedMap(new WeakHashMap<String, RegExp>());
|
||||
|
||||
static {
|
||||
final String impl = Options.getStringProperty("nashorn.regexp.impl", JONI);
|
||||
@ -87,7 +86,13 @@ public class RegExpFactory {
|
||||
* @throws ParserException if invalid source or flags
|
||||
*/
|
||||
public static RegExp create(final String pattern, final String flags) {
|
||||
return instance.compile(pattern, flags);
|
||||
final String key = pattern + "/" + flags;
|
||||
RegExp regexp = REGEXP_CACHE.get(key);
|
||||
if (regexp == null) {
|
||||
regexp = instance.compile(pattern, flags);
|
||||
REGEXP_CACHE.put(key, regexp);
|
||||
}
|
||||
return regexp;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -98,11 +103,8 @@ public class RegExpFactory {
|
||||
*
|
||||
* @throws ParserException if invalid source or flags
|
||||
*/
|
||||
// @SuppressWarnings({"unused"})
|
||||
public static void validate(final String pattern, final String flags) throws ParserException {
|
||||
if (VALID_CACHE_SET.add(pattern + flags)) {
|
||||
instance.compile(pattern, flags);
|
||||
}
|
||||
create(pattern, flags);
|
||||
}
|
||||
|
||||
/**
|
||||
|
48
nashorn/test/script/basic/JDK-8066407.js
Normal file
48
nashorn/test/script/basic/JDK-8066407.js
Normal file
@ -0,0 +1,48 @@
|
||||
/*
|
||||
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*/
|
||||
|
||||
/**
|
||||
* JDK-8066407: Function with same body not reparsed after SyntaxError
|
||||
*
|
||||
* @test
|
||||
* @run
|
||||
*/
|
||||
|
||||
function testFunction(body) {
|
||||
try {
|
||||
Function(body);
|
||||
Assert.fail("Should have thrown");
|
||||
} catch (e) {
|
||||
Assert.assertEquals(e.name, "SyntaxError");
|
||||
count++;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
var count = 0;
|
||||
|
||||
testFunction("/a/r");
|
||||
testFunction("/a/r");
|
||||
testFunction("/a/r");
|
||||
|
||||
Assert.assertTrue(count === 3);
|
Loading…
x
Reference in New Issue
Block a user