diff options
Diffstat (limited to 'chromium/mojo/apps/js/bindings/threading.cc')
-rw-r--r-- | chromium/mojo/apps/js/bindings/threading.cc | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/chromium/mojo/apps/js/bindings/threading.cc b/chromium/mojo/apps/js/bindings/threading.cc new file mode 100644 index 00000000000..64e32fc8f21 --- /dev/null +++ b/chromium/mojo/apps/js/bindings/threading.cc @@ -0,0 +1,47 @@ +// Copyright 2013 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "mojo/apps/js/bindings/threading.h" + +#include "base/message_loop/message_loop.h" +#include "gin/object_template_builder.h" +#include "gin/per_isolate_data.h" +#include "mojo/bindings/js/handle.h" + +namespace mojo { +namespace apps { + +namespace { + +void Quit() { + base::MessageLoop::current()->QuitNow(); +} + +gin::WrapperInfo g_wrapper_info = { gin::kEmbedderNativeGin }; + +} // namespace + +const char Threading::kModuleName[] = "mojo/apps/js/bindings/threading"; + +v8::Local<v8::Value> Threading::GetModule(v8::Isolate* isolate) { + gin::PerIsolateData* data = gin::PerIsolateData::From(isolate); + v8::Local<v8::ObjectTemplate> templ = data->GetObjectTemplate( + &g_wrapper_info); + + if (templ.IsEmpty()) { + templ = gin::ObjectTemplateBuilder(isolate) + .SetMethod("quit", Quit) + .Build(); + + data->SetObjectTemplate(&g_wrapper_info, templ); + } + + return templ->NewInstance(); +} + +Threading::Threading() { +} + +} // namespace apps +} // namespace mojo |