| 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 571 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 582 for (int i = 0; i < globals_->length(); ++i) | 582 for (int i = 0; i < globals_->length(); ++i) |
| 583 array->set(i, *globals_->at(i)); | 583 array->set(i, *globals_->at(i)); |
| 584 DeclareGlobals(array); | 584 DeclareGlobals(array); |
| 585 } | 585 } |
| 586 | 586 |
| 587 globals_ = saved_globals; | 587 globals_ = saved_globals; |
| 588 } | 588 } |
| 589 | 589 |
| 590 | 590 |
| 591 void FullCodeGenerator::VisitModuleLiteral(ModuleLiteral* module) { | 591 void FullCodeGenerator::VisitModuleLiteral(ModuleLiteral* module) { |
| 592 Handle<JSModule> instance = module->interface()->Instance(); | |
| 593 ASSERT(!instance.is_null()); | |
| 594 | |
| 595 // Allocate a module context statically. | 592 // Allocate a module context statically. |
| 596 Block* block = module->body(); | 593 Block* block = module->body(); |
| 597 Scope* saved_scope = scope(); | 594 Scope* saved_scope = scope(); |
| 598 scope_ = block->scope(); | 595 scope_ = block->scope(); |
| 599 Handle<ScopeInfo> scope_info = scope_->GetScopeInfo(); | 596 Handle<ScopeInfo> scope_info = scope_->GetScopeInfo(); |
| 597 Interface* interface = module->interface(); |
| 598 Handle<JSModule> instance = interface->Instance(); |
| 600 | 599 |
| 601 // Generate code for module creation and linking. | |
| 602 Comment cmnt(masm_, "[ ModuleLiteral"); | 600 Comment cmnt(masm_, "[ ModuleLiteral"); |
| 603 SetStatementPosition(block); | 601 SetStatementPosition(block); |
| 604 | 602 |
| 605 if (scope_info->HasContext()) { | 603 // Set up module context. |
| 606 // Set up module context. | 604 __ Push(instance); |
| 607 __ Push(scope_info); | 605 __ CallRuntime(Runtime::kPushModuleContext, 1); |
| 608 __ Push(instance); | 606 StoreToFrameField(StandardFrameConstants::kContextOffset, context_register()); |
| 609 __ CallRuntime(Runtime::kPushModuleContext, 2); | |
| 610 StoreToFrameField( | |
| 611 StandardFrameConstants::kContextOffset, context_register()); | |
| 612 } | |
| 613 | 607 |
| 614 { | 608 { |
| 615 Comment cmnt(masm_, "[ Declarations"); | 609 Comment cmnt(masm_, "[ Declarations"); |
| 616 VisitDeclarations(scope_->declarations()); | 610 VisitDeclarations(scope_->declarations()); |
| 617 } | 611 } |
| 618 | 612 |
| 619 scope_ = saved_scope; | 613 scope_ = saved_scope; |
| 620 if (scope_info->HasContext()) { | 614 // Pop module context. |
| 621 // Pop module context. | 615 LoadContextField(context_register(), Context::PREVIOUS_INDEX); |
| 622 LoadContextField(context_register(), Context::PREVIOUS_INDEX); | 616 // Update local stack frame context field. |
| 623 // Update local stack frame context field. | 617 StoreToFrameField(StandardFrameConstants::kContextOffset, context_register()); |
| 624 StoreToFrameField( | |
| 625 StandardFrameConstants::kContextOffset, context_register()); | |
| 626 } | |
| 627 | |
| 628 // Populate module instance object. | |
| 629 const PropertyAttributes attr = | |
| 630 static_cast<PropertyAttributes>(READ_ONLY | DONT_DELETE | DONT_ENUM); | |
| 631 for (Interface::Iterator it = module->interface()->iterator(); | |
| 632 !it.done(); it.Advance()) { | |
| 633 if (it.interface()->IsModule()) { | |
| 634 Handle<Object> value = it.interface()->Instance(); | |
| 635 ASSERT(!value.is_null()); | |
| 636 JSReceiver::SetProperty(instance, it.name(), value, attr, kStrictMode); | |
| 637 } else { | |
| 638 // TODO(rossberg): set proper getters instead of undefined... | |
| 639 // instance->DefineAccessor(*it.name(), ACCESSOR_GETTER, *getter, attr); | |
| 640 Handle<Object> value(isolate()->heap()->undefined_value()); | |
| 641 JSReceiver::SetProperty(instance, it.name(), value, attr, kStrictMode); | |
| 642 } | |
| 643 } | |
| 644 USE(instance->PreventExtensions()); | |
| 645 } | 618 } |
| 646 | 619 |
| 647 | 620 |
| 648 void FullCodeGenerator::VisitModuleVariable(ModuleVariable* module) { | 621 void FullCodeGenerator::VisitModuleVariable(ModuleVariable* module) { |
| 649 // Noting to do. | 622 // Nothing to do. |
| 650 // The instance object is resolved statically through the module's interface. | 623 // The instance object is resolved statically through the module's interface. |
| 651 } | 624 } |
| 652 | 625 |
| 653 | 626 |
| 654 void FullCodeGenerator::VisitModulePath(ModulePath* module) { | 627 void FullCodeGenerator::VisitModulePath(ModulePath* module) { |
| 655 // Noting to do. | 628 // Nothing to do. |
| 656 // The instance object is resolved statically through the module's interface. | 629 // The instance object is resolved statically through the module's interface. |
| 657 } | 630 } |
| 658 | 631 |
| 659 | 632 |
| 660 void FullCodeGenerator::VisitModuleUrl(ModuleUrl* decl) { | 633 void FullCodeGenerator::VisitModuleUrl(ModuleUrl* decl) { |
| 661 // TODO(rossberg) | 634 // TODO(rossberg) |
| 662 } | 635 } |
| 663 | 636 |
| 664 | 637 |
| 665 int FullCodeGenerator::DeclareGlobalsFlags() { | 638 int FullCodeGenerator::DeclareGlobalsFlags() { |
| (...skipping 243 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 909 | 882 |
| 910 | 883 |
| 911 void FullCodeGenerator::VisitBlock(Block* stmt) { | 884 void FullCodeGenerator::VisitBlock(Block* stmt) { |
| 912 Comment cmnt(masm_, "[ Block"); | 885 Comment cmnt(masm_, "[ Block"); |
| 913 NestedBlock nested_block(this, stmt); | 886 NestedBlock nested_block(this, stmt); |
| 914 SetStatementPosition(stmt); | 887 SetStatementPosition(stmt); |
| 915 | 888 |
| 916 Scope* saved_scope = scope(); | 889 Scope* saved_scope = scope(); |
| 917 // Push a block context when entering a block with block scoped variables. | 890 // Push a block context when entering a block with block scoped variables. |
| 918 if (stmt->scope() != NULL) { | 891 if (stmt->scope() != NULL) { |
| 919 { Comment cmnt(masm_, "[ Extend block context"); | 892 scope_ = stmt->scope(); |
| 920 scope_ = stmt->scope(); | 893 if (scope_->is_module_scope()) { |
| 921 Handle<ScopeInfo> scope_info = scope_->GetScopeInfo(); | 894 // If this block is a module body, then we have already allocated and |
| 922 int heap_slots = scope_info->ContextLength() - Context::MIN_CONTEXT_SLOTS; | 895 // initialized the declarations earlier. Just push the context. |
| 923 __ Push(scope_info); | 896 ASSERT(!scope_->interface()->Instance().is_null()); |
| 924 PushFunctionArgumentForContextAllocation(); | 897 __ Push(scope_->interface()->Instance()); |
| 925 if (heap_slots <= FastNewBlockContextStub::kMaximumSlots) { | 898 __ CallRuntime(Runtime::kPushModuleContext, 1); |
| 926 FastNewBlockContextStub stub(heap_slots); | 899 StoreToFrameField( |
| 927 __ CallStub(&stub); | 900 StandardFrameConstants::kContextOffset, context_register()); |
| 928 } else { | 901 } else { |
| 929 __ CallRuntime(Runtime::kPushBlockContext, 2); | 902 { Comment cmnt(masm_, "[ Extend block context"); |
| 903 Handle<ScopeInfo> scope_info = scope_->GetScopeInfo(); |
| 904 int heap_slots = |
| 905 scope_info->ContextLength() - Context::MIN_CONTEXT_SLOTS; |
| 906 __ Push(scope_info); |
| 907 PushFunctionArgumentForContextAllocation(); |
| 908 if (heap_slots <= FastNewBlockContextStub::kMaximumSlots) { |
| 909 FastNewBlockContextStub stub(heap_slots); |
| 910 __ CallStub(&stub); |
| 911 } else { |
| 912 __ CallRuntime(Runtime::kPushBlockContext, 2); |
| 913 } |
| 914 |
| 915 // Replace the context stored in the frame. |
| 916 StoreToFrameField(StandardFrameConstants::kContextOffset, |
| 917 context_register()); |
| 930 } | 918 } |
| 931 | 919 { Comment cmnt(masm_, "[ Declarations"); |
| 932 // Replace the context stored in the frame. | 920 VisitDeclarations(scope_->declarations()); |
| 933 StoreToFrameField(StandardFrameConstants::kContextOffset, | 921 } |
| 934 context_register()); | |
| 935 } | |
| 936 { Comment cmnt(masm_, "[ Declarations"); | |
| 937 VisitDeclarations(scope_->declarations()); | |
| 938 } | 922 } |
| 939 } | 923 } |
| 940 PrepareForBailoutForId(stmt->EntryId(), NO_REGISTERS); | 924 PrepareForBailoutForId(stmt->EntryId(), NO_REGISTERS); |
| 941 VisitStatements(stmt->statements()); | 925 VisitStatements(stmt->statements()); |
| 942 scope_ = saved_scope; | 926 scope_ = saved_scope; |
| 943 __ bind(nested_block.break_label()); | 927 __ bind(nested_block.break_label()); |
| 944 PrepareForBailoutForId(stmt->ExitId(), NO_REGISTERS); | 928 PrepareForBailoutForId(stmt->ExitId(), NO_REGISTERS); |
| 945 | 929 |
| 946 // Pop block context if necessary. | 930 // Pop block context if necessary. |
| 947 if (stmt->scope() != NULL) { | 931 if (stmt->scope() != NULL) { |
| (...skipping 475 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1423 } | 1407 } |
| 1424 | 1408 |
| 1425 return false; | 1409 return false; |
| 1426 } | 1410 } |
| 1427 | 1411 |
| 1428 | 1412 |
| 1429 #undef __ | 1413 #undef __ |
| 1430 | 1414 |
| 1431 | 1415 |
| 1432 } } // namespace v8::internal | 1416 } } // namespace v8::internal |
| OLD | NEW |