| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
| 4 // met: | 4 // met: |
| 5 // | 5 // |
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
| (...skipping 502 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 513 } | 513 } |
| 514 } | 514 } |
| 515 } | 515 } |
| 516 | 516 |
| 517 // Notify debugger | 517 // Notify debugger |
| 518 isolate->debugger()->OnBeforeCompile(script); | 518 isolate->debugger()->OnBeforeCompile(script); |
| 519 #endif | 519 #endif |
| 520 | 520 |
| 521 // Only allow non-global compiles for eval. | 521 // Only allow non-global compiles for eval. |
| 522 ASSERT(info->is_eval() || info->is_global()); | 522 ASSERT(info->is_eval() || info->is_global()); |
| 523 ParsingFlags flags = kNoParsingFlags; | 523 { |
| 524 if ((info->pre_parse_data() != NULL || | 524 Parser parser(info); |
| 525 String::cast(script->source())->length() > FLAG_min_preparse_length) && | 525 if ((info->pre_parse_data() != NULL || |
| 526 !DebuggerWantsEagerCompilation(info)) { | 526 String::cast(script->source())->length() > FLAG_min_preparse_length) && |
| 527 flags = kAllowLazy; | 527 !DebuggerWantsEagerCompilation(info)) |
| 528 } | 528 parser.set_allow_lazy(true); |
| 529 if (!ParserApi::Parse(info, flags)) { | 529 if (!parser.Parse()) { |
| 530 return Handle<SharedFunctionInfo>::null(); | 530 return Handle<SharedFunctionInfo>::null(); |
| 531 } |
| 531 } | 532 } |
| 532 | 533 |
| 533 // Measure how long it takes to do the compilation; only take the | 534 // Measure how long it takes to do the compilation; only take the |
| 534 // rest of the function into account to avoid overlap with the | 535 // rest of the function into account to avoid overlap with the |
| 535 // parsing statistics. | 536 // parsing statistics. |
| 536 HistogramTimer* rate = info->is_eval() | 537 HistogramTimer* rate = info->is_eval() |
| 537 ? info->isolate()->counters()->compile_eval() | 538 ? info->isolate()->counters()->compile_eval() |
| 538 : info->isolate()->counters()->compile(); | 539 : info->isolate()->counters()->compile(); |
| 539 HistogramTimerScope timer(rate); | 540 HistogramTimerScope timer(rate); |
| 540 | 541 |
| (...skipping 316 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 857 | 858 |
| 858 PostponeInterruptsScope postpone(isolate); | 859 PostponeInterruptsScope postpone(isolate); |
| 859 | 860 |
| 860 Handle<SharedFunctionInfo> shared = info->shared_info(); | 861 Handle<SharedFunctionInfo> shared = info->shared_info(); |
| 861 int compiled_size = shared->end_position() - shared->start_position(); | 862 int compiled_size = shared->end_position() - shared->start_position(); |
| 862 isolate->counters()->total_compile_size()->Increment(compiled_size); | 863 isolate->counters()->total_compile_size()->Increment(compiled_size); |
| 863 | 864 |
| 864 if (InstallCodeFromOptimizedCodeMap(info)) return true; | 865 if (InstallCodeFromOptimizedCodeMap(info)) return true; |
| 865 | 866 |
| 866 // Generate the AST for the lazily compiled function. | 867 // Generate the AST for the lazily compiled function. |
| 867 if (ParserApi::Parse(info, kNoParsingFlags)) { | 868 if (Parser::Parse(info)) { |
| 868 // Measure how long it takes to do the lazy compilation; only take the | 869 // Measure how long it takes to do the lazy compilation; only take the |
| 869 // rest of the function into account to avoid overlap with the lazy | 870 // rest of the function into account to avoid overlap with the lazy |
| 870 // parsing statistics. | 871 // parsing statistics. |
| 871 HistogramTimerScope timer(isolate->counters()->compile_lazy()); | 872 HistogramTimerScope timer(isolate->counters()->compile_lazy()); |
| 872 | 873 |
| 873 // After parsing we know the function's language mode. Remember it. | 874 // After parsing we know the function's language mode. Remember it. |
| 874 LanguageMode language_mode = info->function()->language_mode(); | 875 LanguageMode language_mode = info->function()->language_mode(); |
| 875 info->SetLanguageMode(language_mode); | 876 info->SetLanguageMode(language_mode); |
| 876 shared->set_language_mode(language_mode); | 877 shared->set_language_mode(language_mode); |
| 877 | 878 |
| (...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 925 isolate->counters()->total_compile_size()->Increment(compiled_size); | 926 isolate->counters()->total_compile_size()->Increment(compiled_size); |
| 926 info->SetOptimizing(BailoutId::None()); | 927 info->SetOptimizing(BailoutId::None()); |
| 927 | 928 |
| 928 { | 929 { |
| 929 CompilationHandleScope handle_scope(*info); | 930 CompilationHandleScope handle_scope(*info); |
| 930 | 931 |
| 931 if (InstallCodeFromOptimizedCodeMap(*info)) { | 932 if (InstallCodeFromOptimizedCodeMap(*info)) { |
| 932 return; | 933 return; |
| 933 } | 934 } |
| 934 | 935 |
| 935 if (ParserApi::Parse(*info, kNoParsingFlags)) { | 936 if (Parser::Parse(*info)) { |
| 936 LanguageMode language_mode = info->function()->language_mode(); | 937 LanguageMode language_mode = info->function()->language_mode(); |
| 937 info->SetLanguageMode(language_mode); | 938 info->SetLanguageMode(language_mode); |
| 938 shared->set_language_mode(language_mode); | 939 shared->set_language_mode(language_mode); |
| 939 info->SaveHandles(); | 940 info->SaveHandles(); |
| 940 | 941 |
| 941 if (Rewriter::Rewrite(*info) && Scope::Analyze(*info)) { | 942 if (Rewriter::Rewrite(*info) && Scope::Analyze(*info)) { |
| 942 OptimizingCompiler* compiler = | 943 OptimizingCompiler* compiler = |
| 943 new(info->zone()) OptimizingCompiler(*info); | 944 new(info->zone()) OptimizingCompiler(*info); |
| 944 OptimizingCompiler::Status status = compiler->CreateGraph(); | 945 OptimizingCompiler::Status status = compiler->CreateGraph(); |
| 945 if (status == OptimizingCompiler::SUCCEEDED) { | 946 if (status == OptimizingCompiler::SUCCEEDED) { |
| (...skipping 212 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1158 } | 1159 } |
| 1159 } | 1160 } |
| 1160 | 1161 |
| 1161 GDBJIT(AddCode(Handle<String>(shared->DebugName()), | 1162 GDBJIT(AddCode(Handle<String>(shared->DebugName()), |
| 1162 Handle<Script>(info->script()), | 1163 Handle<Script>(info->script()), |
| 1163 Handle<Code>(info->code()), | 1164 Handle<Code>(info->code()), |
| 1164 info)); | 1165 info)); |
| 1165 } | 1166 } |
| 1166 | 1167 |
| 1167 } } // namespace v8::internal | 1168 } } // namespace v8::internal |
| OLD | NEW |