Cleanup of the parser.

The lazy parsing functions took a host of arguments that can all be
derived from the SharedFunctionInfo, and the SharedFunctionInfo is
always available when parsing lazily.  Change the interface to take a
single CompilationInfo or SharedFunctionInfo argument.

Also remove a flag in the parser that was always false when it was read.

Review URL: http://codereview.chromium.org/3538005

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@5561 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent f21b34ef
...@@ -377,20 +377,12 @@ bool Compiler::CompileLazy(CompilationInfo* info) { ...@@ -377,20 +377,12 @@ bool Compiler::CompileLazy(CompilationInfo* info) {
// Compute name, source code and script data. // Compute name, source code and script data.
Handle<SharedFunctionInfo> shared = info->shared_info(); Handle<SharedFunctionInfo> shared = info->shared_info();
Handle<String> name(String::cast(shared->name())); int compiled_size = shared->end_position() - shared->start_position();
Counters::total_compile_size.Increment(compiled_size);
int start_position = shared->start_position();
int end_position = shared->end_position();
bool is_expression = shared->is_expression();
Counters::total_compile_size.Increment(end_position - start_position);
// Generate the AST for the lazily compiled function. The AST may be // Generate the AST for the lazily compiled function. The AST may be
// NULL in case of parser stack overflow. // NULL in case of parser stack overflow.
FunctionLiteral* lit = MakeLazyAST(info->script(), FunctionLiteral* lit = MakeLazyAST(shared);
name,
start_position,
end_position,
is_expression);
// Check for parse errors. // Check for parse errors.
if (lit == NULL) { if (lit == NULL) {
...@@ -414,9 +406,9 @@ bool Compiler::CompileLazy(CompilationInfo* info) { ...@@ -414,9 +406,9 @@ bool Compiler::CompileLazy(CompilationInfo* info) {
} }
RecordFunctionCompilation(Logger::LAZY_COMPILE_TAG, RecordFunctionCompilation(Logger::LAZY_COMPILE_TAG,
name, Handle<String>(String::cast(shared->name())),
Handle<String>(shared->inferred_name()), Handle<String>(shared->inferred_name()),
start_position, shared->start_position(),
info->script(), info->script(),
code); code);
......
...@@ -115,11 +115,7 @@ class Parser { ...@@ -115,11 +115,7 @@ class Parser {
// Returns NULL if parsing failed. // Returns NULL if parsing failed.
FunctionLiteral* ParseProgram(Handle<String> source, FunctionLiteral* ParseProgram(Handle<String> source,
bool in_global_context); bool in_global_context);
FunctionLiteral* ParseLazy(Handle<String> source, FunctionLiteral* ParseLazy(Handle<SharedFunctionInfo> info);
Handle<String> name,
int start_position,
int end_position,
bool is_expression);
FunctionLiteral* ParseJson(Handle<String> source); FunctionLiteral* ParseJson(Handle<String> source);
// The minimum number of contiguous assignment that will // The minimum number of contiguous assignment that will
...@@ -1587,21 +1583,20 @@ FunctionLiteral* Parser::ParseProgram(Handle<String> source, ...@@ -1587,21 +1583,20 @@ FunctionLiteral* Parser::ParseProgram(Handle<String> source,
} }
FunctionLiteral* Parser::ParseLazy(Handle<String> source, FunctionLiteral* Parser::ParseLazy(Handle<SharedFunctionInfo> info) {
Handle<String> name,
int start_position,
int end_position,
bool is_expression) {
CompilationZoneScope zone_scope(DONT_DELETE_ON_EXIT); CompilationZoneScope zone_scope(DONT_DELETE_ON_EXIT);
HistogramTimerScope timer(&Counters::parse_lazy); HistogramTimerScope timer(&Counters::parse_lazy);
Handle<String> source(String::cast(script_->source()));
Counters::total_parse_size.Increment(source->length()); Counters::total_parse_size.Increment(source->length());
Handle<String> name(String::cast(info->name()));
fni_ = new FuncNameInferrer(); fni_ = new FuncNameInferrer();
fni_->PushEnclosingName(name); fni_->PushEnclosingName(name);
// Initialize parser state. // Initialize parser state.
source->TryFlatten(); source->TryFlatten();
scanner_.Initialize(source, start_position, end_position, JAVASCRIPT); scanner_.Initialize(source, info->start_position(), info->end_position(),
JAVASCRIPT);
ASSERT(target_stack_ == NULL); ASSERT(target_stack_ == NULL);
mode_ = PARSE_EAGERLY; mode_ = PARSE_EAGERLY;
...@@ -1616,7 +1611,8 @@ FunctionLiteral* Parser::ParseLazy(Handle<String> source, ...@@ -1616,7 +1611,8 @@ FunctionLiteral* Parser::ParseLazy(Handle<String> source,
LexicalScope lexical_scope(this, scope); LexicalScope lexical_scope(this, scope);
TemporaryScope temp_scope(this); TemporaryScope temp_scope(this);
FunctionLiteralType type = is_expression ? EXPRESSION : DECLARATION; FunctionLiteralType type =
info->is_expression() ? EXPRESSION : DECLARATION;
bool ok = true; bool ok = true;
result = ParseFunctionLiteral(name, RelocInfo::kNoPosition, type, &ok); result = ParseFunctionLiteral(name, RelocInfo::kNoPosition, type, &ok);
// Make sure the results agree. // Make sure the results agree.
...@@ -1637,6 +1633,7 @@ FunctionLiteral* Parser::ParseLazy(Handle<String> source, ...@@ -1637,6 +1633,7 @@ FunctionLiteral* Parser::ParseLazy(Handle<String> source,
return result; return result;
} }
FunctionLiteral* Parser::ParseJson(Handle<String> source) { FunctionLiteral* Parser::ParseJson(Handle<String> source) {
CompilationZoneScope zone_scope(DONT_DELETE_ON_EXIT); CompilationZoneScope zone_scope(DONT_DELETE_ON_EXIT);
...@@ -5475,12 +5472,6 @@ RegExpTree* RegExpParser::ParseCharacterClass() { ...@@ -5475,12 +5472,6 @@ RegExpTree* RegExpParser::ParseCharacterClass() {
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// The Parser interface. // The Parser interface.
// MakeAST() is just a wrapper for the corresponding Parser calls
// so we don't have to expose the entire Parser class in the .h file.
static bool always_allow_natives_syntax = false;
ParserMessage::~ParserMessage() { ParserMessage::~ParserMessage() {
for (int i = 0; i < args().length(); i++) for (int i = 0; i < args().length(); i++)
DeleteArray(args()[i]); DeleteArray(args()[i]);
...@@ -5515,9 +5506,7 @@ ScriptDataImpl* PartialPreParse(Handle<String> source, ...@@ -5515,9 +5506,7 @@ ScriptDataImpl* PartialPreParse(Handle<String> source,
v8::Extension* extension) { v8::Extension* extension) {
Handle<Script> no_script; Handle<Script> no_script;
bool allow_natives_syntax = bool allow_natives_syntax =
always_allow_natives_syntax || FLAG_allow_natives_syntax || Bootstrapper::IsActive();
FLAG_allow_natives_syntax ||
Bootstrapper::IsActive();
PartialPreParser parser(no_script, allow_natives_syntax, extension); PartialPreParser parser(no_script, allow_natives_syntax, extension);
if (!parser.PreParseProgram(source, stream)) return NULL; if (!parser.PreParseProgram(source, stream)) return NULL;
// Extract the accumulated data from the recorder as a single // Extract the accumulated data from the recorder as a single
...@@ -5575,9 +5564,7 @@ ScriptDataImpl* PreParse(Handle<String> source, ...@@ -5575,9 +5564,7 @@ ScriptDataImpl* PreParse(Handle<String> source,
v8::Extension* extension) { v8::Extension* extension) {
Handle<Script> no_script; Handle<Script> no_script;
bool allow_natives_syntax = bool allow_natives_syntax =
always_allow_natives_syntax || FLAG_allow_natives_syntax || Bootstrapper::IsActive();
FLAG_allow_natives_syntax ||
Bootstrapper::IsActive();
CompletePreParser parser(no_script, allow_natives_syntax, extension); CompletePreParser parser(no_script, allow_natives_syntax, extension);
if (!parser.PreParseProgram(source, stream)) return NULL; if (!parser.PreParseProgram(source, stream)) return NULL;
// Extract the accumulated data from the recorder as a single // Extract the accumulated data from the recorder as a single
...@@ -5609,15 +5596,15 @@ bool ParseRegExp(FlatStringReader* input, ...@@ -5609,15 +5596,15 @@ bool ParseRegExp(FlatStringReader* input,
} }
// MakeAST is just a wrapper for the corresponding Parser calls so we don't
// have to expose the entire Parser class in the .h file.
FunctionLiteral* MakeAST(bool compile_in_global_context, FunctionLiteral* MakeAST(bool compile_in_global_context,
Handle<Script> script, Handle<Script> script,
v8::Extension* extension, v8::Extension* extension,
ScriptDataImpl* pre_data, ScriptDataImpl* pre_data,
bool is_json) { bool is_json) {
bool allow_natives_syntax = bool allow_natives_syntax =
always_allow_natives_syntax || FLAG_allow_natives_syntax || Bootstrapper::IsActive();
FLAG_allow_natives_syntax ||
Bootstrapper::IsActive();
AstBuildingParser parser(script, allow_natives_syntax, extension, pre_data); AstBuildingParser parser(script, allow_natives_syntax, extension, pre_data);
if (pre_data != NULL && pre_data->has_error()) { if (pre_data != NULL && pre_data->has_error()) {
Scanner::Location loc = pre_data->MessageLocation(); Scanner::Location loc = pre_data->MessageLocation();
...@@ -5643,20 +5630,10 @@ FunctionLiteral* MakeAST(bool compile_in_global_context, ...@@ -5643,20 +5630,10 @@ FunctionLiteral* MakeAST(bool compile_in_global_context,
} }
FunctionLiteral* MakeLazyAST(Handle<Script> script, FunctionLiteral* MakeLazyAST(Handle<SharedFunctionInfo> info) {
Handle<String> name, Handle<Script> script(Script::cast(info->script()));
int start_position, AstBuildingParser parser(script, true, NULL, NULL);
int end_position, FunctionLiteral* result = parser.ParseLazy(info);
bool is_expression) {
bool allow_natives_syntax_before = always_allow_natives_syntax;
always_allow_natives_syntax = true;
AstBuildingParser parser(script, true, NULL, NULL); // always allow
always_allow_natives_syntax = allow_natives_syntax_before;
// Parse the function by pointing to the function source in the script source.
Handle<String> script_source(String::cast(script->source()));
FunctionLiteral* result =
parser.ParseLazy(script_source, name,
start_position, end_position, is_expression);
return result; return result;
} }
......
...@@ -192,20 +192,8 @@ bool ParseRegExp(FlatStringReader* input, ...@@ -192,20 +192,8 @@ bool ParseRegExp(FlatStringReader* input,
RegExpCompileData* result); RegExpCompileData* result);
// Support for doing lazy compilation. The script is the script containing full // Support for doing lazy compilation.
// source of the script where the function is declared. The start_position and FunctionLiteral* MakeLazyAST(Handle<SharedFunctionInfo> info);
// end_position specifies the part of the script source which has the source
// for the function declaration in the form:
//
// (<formal parameters>) { <function body> }
//
// without any function keyword or name.
//
FunctionLiteral* MakeLazyAST(Handle<Script> script,
Handle<String> name,
int start_position,
int end_position,
bool is_expression);
// Support for handling complex values (array and object literals) that // Support for handling complex values (array and object literals) that
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment