OLD | NEW |
---|---|
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/ast/scopes.h" | 5 #include "src/ast/scopes.h" |
6 | 6 |
7 #include <set> | 7 #include <set> |
8 | 8 |
9 #include "src/accessors.h" | 9 #include "src/accessors.h" |
10 #include "src/bootstrapper.h" | 10 #include "src/bootstrapper.h" |
(...skipping 358 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
369 return static_cast<const DeclarationScope*>(this); | 369 return static_cast<const DeclarationScope*>(this); |
370 } | 370 } |
371 | 371 |
372 int Scope::num_parameters() const { | 372 int Scope::num_parameters() const { |
373 return is_declaration_scope() ? AsDeclarationScope()->num_parameters() : 0; | 373 return is_declaration_scope() ? AsDeclarationScope()->num_parameters() : 0; |
374 } | 374 } |
375 | 375 |
376 void Scope::Analyze(ParseInfo* info) { | 376 void Scope::Analyze(ParseInfo* info) { |
377 DCHECK(info->literal() != NULL); | 377 DCHECK(info->literal() != NULL); |
378 DeclarationScope* scope = info->literal()->scope(); | 378 DeclarationScope* scope = info->literal()->scope(); |
379 DeclarationScope* top = scope; | |
380 | 379 |
381 // Traverse the scope tree up to the first unresolved scope or the global | 380 // We are compiling one of three cases: |
382 // scope and start scope resolution and variable allocation from that scope. | 381 // 1) top-level code, |
383 // Such a scope is always a closure-scope, so always skip to the next closure | 382 // 2) a function/eval/module on the top-level |
384 // scope. | 383 // 3) a function/eval in a scope that was already resolved. |
bradnelson
2016/08/07 03:05:24
You can also be compiling the text of an Asm.js mo
| |
385 while (!top->is_script_scope() && | 384 DCHECK(scope->scope_type() == SCRIPT_SCOPE || |
386 !top->outer_scope()->already_resolved()) { | 385 scope->outer_scope()->scope_type() == SCRIPT_SCOPE || |
387 top = top->outer_scope()->GetClosureScope(); | 386 scope->outer_scope()->already_resolved()); |
388 } | |
389 | 387 |
390 // Allocate the variables. | 388 // Allocate the variables. |
391 { | 389 { |
392 AstNodeFactory ast_node_factory(info->ast_value_factory()); | 390 AstNodeFactory ast_node_factory(info->ast_value_factory()); |
393 top->AllocateVariables(info, &ast_node_factory); | 391 scope->AllocateVariables(info, &ast_node_factory); |
394 } | 392 } |
395 | 393 |
396 #ifdef DEBUG | 394 #ifdef DEBUG |
397 if (info->script_is_native() ? FLAG_print_builtin_scopes | 395 if (info->script_is_native() ? FLAG_print_builtin_scopes |
398 : FLAG_print_scopes) { | 396 : FLAG_print_scopes) { |
399 scope->Print(); | 397 scope->Print(); |
400 } | 398 } |
401 scope->CheckScopePositions(); | 399 scope->CheckScopePositions(); |
402 scope->CheckZones(); | 400 scope->CheckZones(); |
403 #endif | 401 #endif |
(...skipping 1368 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1772 function != NULL && function->proxy()->var()->IsContextSlot(); | 1770 function != NULL && function->proxy()->var()->IsContextSlot(); |
1773 return num_heap_slots() - Context::MIN_CONTEXT_SLOTS - num_global_slots() - | 1771 return num_heap_slots() - Context::MIN_CONTEXT_SLOTS - num_global_slots() - |
1774 (is_function_var_in_context ? 1 : 0); | 1772 (is_function_var_in_context ? 1 : 0); |
1775 } | 1773 } |
1776 | 1774 |
1777 | 1775 |
1778 int Scope::ContextGlobalCount() const { return num_global_slots(); } | 1776 int Scope::ContextGlobalCount() const { return num_global_slots(); } |
1779 | 1777 |
1780 } // namespace internal | 1778 } // namespace internal |
1781 } // namespace v8 | 1779 } // namespace v8 |
OLD | NEW |