From dbb42efd61ad769e52d3656882befe3f6b23f26d Mon Sep 17 00:00:00 2001 From: Attila Szegedi Date: Thu, 14 Aug 2014 14:35:44 +0200 Subject: [PATCH] 8055042: Compile-time expression evaluator was missing variables Reviewed-by: jlaskey, lagergren --- .../internal/codegen/AssignSymbols.java | 20 +++++++++++++++---- .../internal/codegen/TypeEvaluator.java | 8 ++++++++ 2 files changed, 24 insertions(+), 4 deletions(-) diff --git a/nashorn/src/jdk/nashorn/internal/codegen/AssignSymbols.java b/nashorn/src/jdk/nashorn/internal/codegen/AssignSymbols.java index 0659e3f5c3e..91a022d9acc 100644 --- a/nashorn/src/jdk/nashorn/internal/codegen/AssignSymbols.java +++ b/nashorn/src/jdk/nashorn/internal/codegen/AssignSymbols.java @@ -382,10 +382,6 @@ final class AssignSymbols extends NodeOperatorVisitor implements symbol.setFlags(flags); } - if((isVar || isParam) && compiler.useOptimisticTypes() && compiler.isOnDemandCompilation()) { - compiler.declareLocalSymbol(name); - } - return symbol; } @@ -687,6 +683,22 @@ final class AssignSymbols extends NodeOperatorVisitor implements return binaryNode; } + @Override + public Node leaveBlock(final Block block) { + // It's not necessary to guard the marking of symbols as locals with this "if"condition for correctness, it's + // just an optimization -- runtime type calculation is not used when the compilation is not an on-demand + // optimistic compilation, so we can skip locals marking then. + if (compiler.useOptimisticTypes() && compiler.isOnDemandCompilation()) { + for (final Symbol symbol: block.getSymbols()) { + if (!symbol.isScope()) { + assert symbol.isVar() || symbol.isParam(); + compiler.declareLocalSymbol(symbol.getName()); + } + } + } + return block; + } + @Override public Node leaveDELETE(final UnaryNode unaryNode) { final FunctionNode currentFunctionNode = lc.getCurrentFunction(); diff --git a/nashorn/src/jdk/nashorn/internal/codegen/TypeEvaluator.java b/nashorn/src/jdk/nashorn/internal/codegen/TypeEvaluator.java index 2c90a3eb846..c8dd5b34193 100644 --- a/nashorn/src/jdk/nashorn/internal/codegen/TypeEvaluator.java +++ b/nashorn/src/jdk/nashorn/internal/codegen/TypeEvaluator.java @@ -115,6 +115,14 @@ final class TypeEvaluator { return Type.typeFor(JSType.unboxedFieldType(value)); } + /** + * Declares a symbol name as belonging to a non-scoped local variable during an on-demand compilation of a single + * function. This method will add an explicit Undefined binding for the local into the runtime scope if it's + * otherwise implicitly undefined so that when an expression is evaluated for the name, it won't accidentally find + * an unrelated value higher up the scope chain. It is only required to call this method when doing an optimistic + * on-demand compilation. + * @param symbolName the name of the symbol that is to be declared as being a non-scoped local variable. + */ void declareLocalSymbol(final String symbolName) { assert compiler.useOptimisticTypes() &&