Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium 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 "gin/modules/module_runner_delegate.h" | 5 #include "gin/modules/module_runner_delegate.h" |
| 6 | 6 |
| 7 #include "gin/modules/module_registry.h" | 7 #include "gin/modules/module_registry.h" |
| 8 #include "gin/object_template_builder.h" | 8 #include "gin/object_template_builder.h" |
| 9 #include "gin/public/context_holder.h" | |
| 9 | 10 |
| 10 namespace gin { | 11 namespace gin { |
| 11 | 12 |
| 13 namespace { | |
| 14 | |
| 15 // DefaultModuleLoader is a ModuleLoader that forwards to the ModuleRegistry. | |
| 16 class DefaultModuleLoader : public ModuleLoader { | |
|
abarth-chromium
2014/02/26 06:08:44
Is there a better term to use here than "default"?
| |
| 17 public: | |
| 18 explicit DefaultModuleLoader(v8::Handle<v8::Context> context); | |
| 19 virtual ~DefaultModuleLoader(); | |
| 20 | |
| 21 static void RegisterGlobals(v8::Isolate* isolate, | |
| 22 v8::Handle<v8::ObjectTemplate> templ); | |
| 23 | |
| 24 private: | |
| 25 // ModuleLoader overrides: | |
| 26 virtual void Load(v8::Handle<v8::Context> context, | |
| 27 scoped_ptr<PendingModule> pending) OVERRIDE; | |
| 28 | |
| 29 DISALLOW_COPY_AND_ASSIGN(DefaultModuleLoader); | |
| 30 }; | |
| 31 | |
| 32 DefaultModuleLoader::~DefaultModuleLoader() { | |
| 33 } | |
| 34 | |
| 35 // static | |
| 36 void DefaultModuleLoader::RegisterGlobals( | |
| 37 v8::Isolate* isolate, | |
| 38 v8::Handle<v8::ObjectTemplate> templ) { | |
| 39 ModuleLoader::RegisterGlobals(isolate, templ); | |
| 40 } | |
| 41 | |
| 42 DefaultModuleLoader::DefaultModuleLoader(v8::Handle<v8::Context> context) | |
| 43 : ModuleLoader(context) { | |
| 44 } | |
| 45 | |
| 46 void DefaultModuleLoader::Load(v8::Handle<v8::Context> context, | |
| 47 scoped_ptr<PendingModule> pending) { | |
| 48 ModuleRegistry::From(context)->AddPendingModule(context->GetIsolate(), | |
| 49 pending.Pass()); | |
| 50 } | |
| 51 | |
| 52 } // namespace | |
| 53 | |
| 12 ModuleRunnerDelegate::ModuleRunnerDelegate( | 54 ModuleRunnerDelegate::ModuleRunnerDelegate( |
| 13 const std::vector<base::FilePath>& search_paths) | 55 const std::vector<base::FilePath>& search_paths) |
| 14 : module_provider_(search_paths) { | 56 : module_provider_(search_paths) { |
| 15 } | 57 } |
| 16 | 58 |
| 17 ModuleRunnerDelegate::~ModuleRunnerDelegate() { | 59 ModuleRunnerDelegate::~ModuleRunnerDelegate() { |
| 18 } | 60 } |
| 19 | 61 |
| 20 void ModuleRunnerDelegate::AddBuiltinModule(const std::string& id, | 62 void ModuleRunnerDelegate::AddBuiltinModule(const std::string& id, |
| 21 ModuleGetter getter) { | 63 ModuleGetter getter) { |
| 22 builtin_modules_[id] = getter; | 64 builtin_modules_[id] = getter; |
| 23 } | 65 } |
| 24 | 66 |
| 25 void ModuleRunnerDelegate::AttemptToLoadMoreModules(Runner* runner) { | 67 void ModuleRunnerDelegate::AttemptToLoadMoreModules(Runner* runner) { |
| 26 ModuleRegistry* registry = ModuleRegistry::From(runner->context()); | 68 ModuleRegistry* registry = ModuleRegistry::From( |
| 27 registry->AttemptToLoadMoreModules(runner->isolate()); | 69 runner->GetContextHolder()->context()); |
| 70 registry->AttemptToLoadMoreModules(runner->GetContextHolder()->isolate()); | |
| 28 module_provider_.AttempToLoadModules( | 71 module_provider_.AttempToLoadModules( |
| 29 runner, registry->unsatisfied_dependencies()); | 72 runner, registry->unsatisfied_dependencies()); |
| 30 } | 73 } |
| 31 | 74 |
| 32 v8::Handle<v8::ObjectTemplate> ModuleRunnerDelegate::GetGlobalTemplate( | 75 v8::Handle<v8::ObjectTemplate> ModuleRunnerDelegate::GetGlobalTemplate( |
| 33 Runner* runner) { | 76 DefaultRunner* runner, |
| 34 v8::Handle<v8::ObjectTemplate> templ = | 77 v8::Isolate* isolate) { |
| 35 ObjectTemplateBuilder(runner->isolate()).Build(); | 78 v8::Handle<v8::ObjectTemplate> templ = ObjectTemplateBuilder(isolate).Build(); |
| 36 ModuleRegistry::RegisterGlobals(runner->isolate(), templ); | 79 DefaultModuleLoader::RegisterGlobals(isolate, templ); |
| 37 return templ; | 80 return templ; |
| 38 } | 81 } |
| 39 | 82 |
| 40 void ModuleRunnerDelegate::DidCreateContext(Runner* runner) { | 83 void ModuleRunnerDelegate::DidCreateContext(DefaultRunner* runner) { |
| 41 RunnerDelegate::DidCreateContext(runner); | 84 DefaultRunnerDelegate::DidCreateContext(runner); |
| 42 | 85 |
| 43 v8::Handle<v8::Context> context = runner->context(); | 86 v8::Handle<v8::Context> context = runner->GetContextHolder()->context(); |
| 87 // DefaultModuleLoader is owned with the context. | |
| 88 new DefaultModuleLoader(runner->GetContextHolder()->context()); | |
| 44 ModuleRegistry* registry = ModuleRegistry::From(context); | 89 ModuleRegistry* registry = ModuleRegistry::From(context); |
| 45 | 90 |
| 91 v8::Isolate* isolate = runner->GetContextHolder()->isolate(); | |
| 46 for (BuiltinModuleMap::const_iterator it = builtin_modules_.begin(); | 92 for (BuiltinModuleMap::const_iterator it = builtin_modules_.begin(); |
| 47 it != builtin_modules_.end(); ++it) { | 93 it != builtin_modules_.end(); ++it) { |
| 48 registry->AddBuiltinModule(runner->isolate(), it->first, | 94 registry->AddBuiltinModule(isolate, it->first, it->second(isolate)); |
| 49 it->second(runner->isolate())); | |
| 50 } | 95 } |
| 51 } | 96 } |
| 52 | 97 |
| 53 void ModuleRunnerDelegate::DidRunScript(Runner* runner) { | 98 void ModuleRunnerDelegate::DidRunScript(DefaultRunner* runner) { |
| 54 AttemptToLoadMoreModules(runner); | 99 AttemptToLoadMoreModules(runner); |
| 55 } | 100 } |
| 56 | 101 |
| 57 } // namespace gin | 102 } // namespace gin |
| OLD | NEW |