Share same native bindings code on both renderer and browser.
This commit is contained in:
parent
993cf1cc61
commit
5948bff23f
16 changed files with 206 additions and 122 deletions
14
atom.gyp
14
atom.gyp
|
@ -17,16 +17,14 @@
|
||||||
'browser/api/atom_api_event.h',
|
'browser/api/atom_api_event.h',
|
||||||
'browser/api/atom_api_event_emitter.cc',
|
'browser/api/atom_api_event_emitter.cc',
|
||||||
'browser/api/atom_api_event_emitter.h',
|
'browser/api/atom_api_event_emitter.h',
|
||||||
'browser/api/atom_api_extensions.cc',
|
|
||||||
'browser/api/atom_api_extensions.h',
|
|
||||||
'browser/api/atom_api_objects_registry.cc',
|
'browser/api/atom_api_objects_registry.cc',
|
||||||
'browser/api/atom_api_objects_registry.h',
|
'browser/api/atom_api_objects_registry.h',
|
||||||
'browser/api/atom_api_recorded_object.cc',
|
'browser/api/atom_api_recorded_object.cc',
|
||||||
'browser/api/atom_api_recorded_object.h',
|
'browser/api/atom_api_recorded_object.h',
|
||||||
'browser/api/atom_api_window.cc',
|
'browser/api/atom_api_window.cc',
|
||||||
'browser/api/atom_api_window.h',
|
'browser/api/atom_api_window.h',
|
||||||
'browser/api/atom_bindings.cc',
|
'browser/api/atom_browser_bindings.cc',
|
||||||
'browser/api/atom_bindings.h',
|
'browser/api/atom_browser_bindings.h',
|
||||||
'browser/atom_browser_client.cc',
|
'browser/atom_browser_client.cc',
|
||||||
'browser/atom_browser_client.h',
|
'browser/atom_browser_client.h',
|
||||||
'browser/atom_browser_context.cc',
|
'browser/atom_browser_context.cc',
|
||||||
|
@ -40,8 +38,12 @@
|
||||||
'browser/native_window_mac.h',
|
'browser/native_window_mac.h',
|
||||||
'browser/native_window_mac.mm',
|
'browser/native_window_mac.mm',
|
||||||
'browser/native_window_observer.h',
|
'browser/native_window_observer.h',
|
||||||
'common/api_messages.cc',
|
'common/api/api_messages.cc',
|
||||||
'common/api_messages.h',
|
'common/api/api_messages.h',
|
||||||
|
'common/api/atom_bindings.cc',
|
||||||
|
'common/api/atom_bindings.h',
|
||||||
|
'common/api/atom_extensions.cc',
|
||||||
|
'common/api/atom_extensions.h',
|
||||||
'common/node_bindings.cc',
|
'common/node_bindings.cc',
|
||||||
'common/node_bindings.h',
|
'common/node_bindings.h',
|
||||||
'common/node_bindings_mac.h',
|
'common/node_bindings_mac.h',
|
||||||
|
|
|
@ -596,4 +596,4 @@ void Window::Initialize(v8::Handle<v8::Object> target) {
|
||||||
|
|
||||||
} // namespace atom
|
} // namespace atom
|
||||||
|
|
||||||
NODE_MODULE(atom_api_window, atom::api::Window::Initialize)
|
NODE_MODULE(atom_browser_window, atom::api::Window::Initialize)
|
||||||
|
|
|
@ -1,81 +0,0 @@
|
||||||
// Copyright (c) 2013 GitHub, Inc. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style license that can be
|
|
||||||
// found in the LICENSE file.
|
|
||||||
|
|
||||||
#include "browser/api/atom_bindings.h"
|
|
||||||
|
|
||||||
#include "base/logging.h"
|
|
||||||
#include "vendor/node/src/node.h"
|
|
||||||
#include "vendor/node/src/node_internals.h"
|
|
||||||
|
|
||||||
using node::node_isolate;
|
|
||||||
|
|
||||||
namespace atom {
|
|
||||||
|
|
||||||
// Defined in atom_api_extensions.cc.
|
|
||||||
namespace api {
|
|
||||||
node::node_module_struct* get_builtin_module(const char *name);
|
|
||||||
}
|
|
||||||
|
|
||||||
v8::Persistent<v8::Object> AtomBindings::binding_cache_;
|
|
||||||
|
|
||||||
AtomBindings::AtomBindings() {
|
|
||||||
}
|
|
||||||
|
|
||||||
AtomBindings::~AtomBindings() {
|
|
||||||
}
|
|
||||||
|
|
||||||
void AtomBindings::BindTo(v8::Handle<v8::Object> process) {
|
|
||||||
v8::HandleScope scope;
|
|
||||||
|
|
||||||
node::SetMethod(process, "atom_binding", Binding);
|
|
||||||
}
|
|
||||||
|
|
||||||
void AtomBindings::AfterLoad() {
|
|
||||||
v8::HandleScope scope;
|
|
||||||
|
|
||||||
v8::Handle<v8::Object> global = node::g_context->Global();
|
|
||||||
v8::Handle<v8::Object> atom =
|
|
||||||
global->Get(v8::String::New("__atom"))->ToObject();
|
|
||||||
DCHECK(!atom.IsEmpty());
|
|
||||||
|
|
||||||
browser_main_parts_ = v8::Persistent<v8::Object>::New(
|
|
||||||
node_isolate,
|
|
||||||
atom->Get(v8::String::New("browserMainParts"))->ToObject());
|
|
||||||
DCHECK(!browser_main_parts_.IsEmpty());
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
v8::Handle<v8::Value> AtomBindings::Binding(const v8::Arguments& args) {
|
|
||||||
v8::HandleScope scope;
|
|
||||||
|
|
||||||
v8::Local<v8::String> module = args[0]->ToString();
|
|
||||||
v8::String::Utf8Value module_v(module);
|
|
||||||
node::node_module_struct* modp;
|
|
||||||
|
|
||||||
if (binding_cache_.IsEmpty()) {
|
|
||||||
binding_cache_ = v8::Persistent<v8::Object>::New(
|
|
||||||
node_isolate, v8::Object::New());
|
|
||||||
}
|
|
||||||
|
|
||||||
v8::Local<v8::Object> exports;
|
|
||||||
|
|
||||||
if (binding_cache_->Has(module)) {
|
|
||||||
exports = binding_cache_->Get(module)->ToObject();
|
|
||||||
return scope.Close(exports);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((modp = api::get_builtin_module(*module_v)) != NULL) {
|
|
||||||
exports = v8::Object::New();
|
|
||||||
// Internal bindings don't have a "module" object,
|
|
||||||
// only exports.
|
|
||||||
modp->register_func(exports, v8::Undefined());
|
|
||||||
binding_cache_->Set(module, exports);
|
|
||||||
return scope.Close(exports);
|
|
||||||
}
|
|
||||||
|
|
||||||
return v8::ThrowException(v8::Exception::Error(
|
|
||||||
v8::String::New("No such module")));
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace atom
|
|
38
browser/api/atom_browser_bindings.cc
Normal file
38
browser/api/atom_browser_bindings.cc
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
// Copyright (c) 2013 GitHub, Inc. All rights reserved.
|
||||||
|
// Use of this source code is governed by a BSD-style license that can be
|
||||||
|
// found in the LICENSE file.
|
||||||
|
|
||||||
|
#include "browser/api/atom_browser_bindings.h"
|
||||||
|
|
||||||
|
#include "base/logging.h"
|
||||||
|
#include "content/public/browser/browser_thread.h"
|
||||||
|
#include "vendor/node/src/node.h"
|
||||||
|
#include "vendor/node/src/node_internals.h"
|
||||||
|
|
||||||
|
using node::node_isolate;
|
||||||
|
|
||||||
|
namespace atom {
|
||||||
|
|
||||||
|
AtomBrowserBindings::AtomBrowserBindings() {
|
||||||
|
}
|
||||||
|
|
||||||
|
AtomBrowserBindings::~AtomBrowserBindings() {
|
||||||
|
}
|
||||||
|
|
||||||
|
void AtomBrowserBindings::AfterLoad() {
|
||||||
|
DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI));
|
||||||
|
|
||||||
|
v8::HandleScope scope;
|
||||||
|
|
||||||
|
v8::Handle<v8::Object> global = node::g_context->Global();
|
||||||
|
v8::Handle<v8::Object> atom =
|
||||||
|
global->Get(v8::String::New("__atom"))->ToObject();
|
||||||
|
DCHECK(!atom.IsEmpty());
|
||||||
|
|
||||||
|
browser_main_parts_ = v8::Persistent<v8::Object>::New(
|
||||||
|
node_isolate,
|
||||||
|
atom->Get(v8::String::New("browserMainParts"))->ToObject());
|
||||||
|
DCHECK(!browser_main_parts_.IsEmpty());
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace atom
|
33
browser/api/atom_browser_bindings.h
Normal file
33
browser/api/atom_browser_bindings.h
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
// Copyright (c) 2013 GitHub, Inc. All rights reserved.
|
||||||
|
// Use of this source code is governed by a BSD-style license that can be
|
||||||
|
// found in the LICENSE file.
|
||||||
|
|
||||||
|
#ifndef ATOM_BROWSER_API_ATOM_BROWSER_BINDINGS_
|
||||||
|
#define ATOM_BROWSER_API_ATOM_BROWSER_BINDINGS_
|
||||||
|
|
||||||
|
#include "common/api/atom_bindings.h"
|
||||||
|
|
||||||
|
namespace atom {
|
||||||
|
|
||||||
|
class AtomBrowserBindings : public AtomBindings {
|
||||||
|
public:
|
||||||
|
AtomBrowserBindings();
|
||||||
|
virtual ~AtomBrowserBindings();
|
||||||
|
|
||||||
|
// Called when the node.js main script has been loaded.
|
||||||
|
virtual void AfterLoad();
|
||||||
|
|
||||||
|
// The require('atom').browserMainParts object.
|
||||||
|
v8::Handle<v8::Object> browser_main_parts() {
|
||||||
|
return browser_main_parts_;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
v8::Persistent<v8::Object> browser_main_parts_;
|
||||||
|
|
||||||
|
DISALLOW_COPY_AND_ASSIGN(AtomBrowserBindings);
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace atom
|
||||||
|
|
||||||
|
#endif // ATOM_BROWSER_API_ATOM_BINDINGS_
|
|
@ -4,7 +4,7 @@
|
||||||
|
|
||||||
#include "browser/atom_browser_main_parts.h"
|
#include "browser/atom_browser_main_parts.h"
|
||||||
|
|
||||||
#include "browser/api/atom_bindings.h"
|
#include "browser/api/atom_browser_bindings.h"
|
||||||
#include "browser/atom_browser_context.h"
|
#include "browser/atom_browser_context.h"
|
||||||
#include "browser/native_window.h"
|
#include "browser/native_window.h"
|
||||||
#include "common/node_bindings.h"
|
#include "common/node_bindings.h"
|
||||||
|
@ -14,7 +14,7 @@
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
|
||||||
AtomBrowserMainParts::AtomBrowserMainParts()
|
AtomBrowserMainParts::AtomBrowserMainParts()
|
||||||
: atom_bindings_(new AtomBindings),
|
: atom_bindings_(new AtomBrowserBindings),
|
||||||
node_bindings_(NodeBindings::Create(true)) {
|
node_bindings_(NodeBindings::Create(true)) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
|
||||||
class AtomBindings;
|
class AtomBrowserBindings;
|
||||||
class NodeBindings;
|
class NodeBindings;
|
||||||
|
|
||||||
class AtomBrowserMainParts : public brightray::BrowserMainParts {
|
class AtomBrowserMainParts : public brightray::BrowserMainParts {
|
||||||
|
@ -27,7 +27,7 @@ class AtomBrowserMainParts : public brightray::BrowserMainParts {
|
||||||
virtual void PreMainMessageLoopRun() OVERRIDE;
|
virtual void PreMainMessageLoopRun() OVERRIDE;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
scoped_ptr<AtomBindings> atom_bindings_;
|
scoped_ptr<AtomBrowserBindings> atom_bindings_;
|
||||||
scoped_ptr<NodeBindings> node_bindings_;
|
scoped_ptr<NodeBindings> node_bindings_;
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(AtomBrowserMainParts);
|
DISALLOW_COPY_AND_ASSIGN(AtomBrowserMainParts);
|
||||||
|
|
|
@ -4,30 +4,30 @@
|
||||||
|
|
||||||
// Get basic type definitions.
|
// Get basic type definitions.
|
||||||
#define IPC_MESSAGE_IMPL
|
#define IPC_MESSAGE_IMPL
|
||||||
#include "common/api_messages.h"
|
#include "common/api/api_messages.h"
|
||||||
|
|
||||||
// Generate constructors.
|
// Generate constructors.
|
||||||
#include "ipc/struct_constructor_macros.h"
|
#include "ipc/struct_constructor_macros.h"
|
||||||
#include "common/api_messages.h"
|
#include "common/api/api_messages.h"
|
||||||
|
|
||||||
// Generate destructors.
|
// Generate destructors.
|
||||||
#include "ipc/struct_destructor_macros.h"
|
#include "ipc/struct_destructor_macros.h"
|
||||||
#include "common/api_messages.h"
|
#include "common/api/api_messages.h"
|
||||||
|
|
||||||
// Generate param traits write methods.
|
// Generate param traits write methods.
|
||||||
#include "ipc/param_traits_write_macros.h"
|
#include "ipc/param_traits_write_macros.h"
|
||||||
namespace IPC {
|
namespace IPC {
|
||||||
#include "common/api_messages.h"
|
#include "common/api/api_messages.h"
|
||||||
} // namespace IPC
|
} // namespace IPC
|
||||||
|
|
||||||
// Generate param traits read methods.
|
// Generate param traits read methods.
|
||||||
#include "ipc/param_traits_read_macros.h"
|
#include "ipc/param_traits_read_macros.h"
|
||||||
namespace IPC {
|
namespace IPC {
|
||||||
#include "common/api_messages.h"
|
#include "common/api/api_messages.h"
|
||||||
} // namespace IPC
|
} // namespace IPC
|
||||||
|
|
||||||
// Generate param traits log methods.
|
// Generate param traits log methods.
|
||||||
#include "ipc/param_traits_log_macros.h"
|
#include "ipc/param_traits_log_macros.h"
|
||||||
namespace IPC {
|
namespace IPC {
|
||||||
#include "common/api_messages.h"
|
#include "common/api/api_messages.h"
|
||||||
} // namespace IPC
|
} // namespace IPC
|
91
common/api/atom_bindings.cc
Normal file
91
common/api/atom_bindings.cc
Normal file
|
@ -0,0 +1,91 @@
|
||||||
|
// Copyright (c) 2013 GitHub, Inc. All rights reserved.
|
||||||
|
// Use of this source code is governed by a BSD-style license that can be
|
||||||
|
// found in the LICENSE file.
|
||||||
|
|
||||||
|
#include "common/api/atom_bindings.h"
|
||||||
|
|
||||||
|
#include "base/logging.h"
|
||||||
|
#include "third_party/WebKit/Source/WebKit/chromium/public/WebFrame.h"
|
||||||
|
#include "vendor/node/src/node.h"
|
||||||
|
|
||||||
|
namespace atom {
|
||||||
|
|
||||||
|
// Defined in atom_extensions.cc.
|
||||||
|
node::node_module_struct* GetBuiltinModule(const char *name, bool is_browser);
|
||||||
|
|
||||||
|
AtomBindings::AtomBindings() {
|
||||||
|
}
|
||||||
|
|
||||||
|
AtomBindings::~AtomBindings() {
|
||||||
|
}
|
||||||
|
|
||||||
|
void AtomBindings::BindTo(v8::Handle<v8::Object> process) {
|
||||||
|
v8::HandleScope scope;
|
||||||
|
|
||||||
|
node::SetMethod(process, "atom_binding", Binding);
|
||||||
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
v8::Handle<v8::Value> AtomBindings::Binding(const v8::Arguments& args) {
|
||||||
|
v8::HandleScope scope;
|
||||||
|
|
||||||
|
v8::Local<v8::String> module = args[0]->ToString();
|
||||||
|
v8::String::Utf8Value module_v(module);
|
||||||
|
node::node_module_struct* modp;
|
||||||
|
|
||||||
|
v8::Local<v8::Object> process = v8::Context::GetCurrent()->Global()->
|
||||||
|
Get(v8::String::New("process"))->ToObject();
|
||||||
|
DCHECK(!process.IsEmpty());
|
||||||
|
|
||||||
|
// is_browser = process.__atom_type == 'browser'.
|
||||||
|
bool is_browser = std::string("browser") == *v8::String::Utf8Value(
|
||||||
|
process->Get(v8::String::New("__atom_type")));
|
||||||
|
|
||||||
|
// Cached in process.__atom_binding_cache.
|
||||||
|
v8::Local<v8::Object> binding_cache;
|
||||||
|
v8::Local<v8::String> bc_name = v8::String::New("__atom_binding_cache");
|
||||||
|
if (process->Has(bc_name)) {
|
||||||
|
binding_cache = process->Get(bc_name)->ToObject();
|
||||||
|
DCHECK(!binding_cache.IsEmpty());
|
||||||
|
} else {
|
||||||
|
binding_cache = v8::Object::New();
|
||||||
|
process->Set(bc_name, binding_cache);
|
||||||
|
}
|
||||||
|
|
||||||
|
v8::Local<v8::Object> exports;
|
||||||
|
|
||||||
|
if (binding_cache->Has(module)) {
|
||||||
|
exports = binding_cache->Get(module)->ToObject();
|
||||||
|
return scope.Close(exports);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((modp = GetBuiltinModule(*module_v, is_browser)) != NULL) {
|
||||||
|
exports = v8::Object::New();
|
||||||
|
// Internal bindings don't have a "module" object,
|
||||||
|
// only exports.
|
||||||
|
modp->register_func(exports, v8::Undefined());
|
||||||
|
binding_cache->Set(module, exports);
|
||||||
|
return scope.Close(exports);
|
||||||
|
}
|
||||||
|
|
||||||
|
return v8::ThrowException(v8::Exception::Error(
|
||||||
|
v8::String::New("No such module")));
|
||||||
|
}
|
||||||
|
|
||||||
|
void AtomBindings::BindToFrame(WebKit::WebFrame* frame) {
|
||||||
|
v8::HandleScope handle_scope;
|
||||||
|
|
||||||
|
v8::Handle<v8::Context> context = frame->mainWorldScriptContext();
|
||||||
|
if (context.IsEmpty())
|
||||||
|
return;
|
||||||
|
|
||||||
|
v8::Context::Scope scope(context);
|
||||||
|
|
||||||
|
v8::Handle<v8::Object> process =
|
||||||
|
context->Global()->Get(v8::String::New("process"))->ToObject();
|
||||||
|
DCHECK(!process.IsEmpty());
|
||||||
|
|
||||||
|
AtomBindings::BindTo(process);
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace atom
|
|
@ -2,12 +2,16 @@
|
||||||
// Use of this source code is governed by a BSD-style license that can be
|
// Use of this source code is governed by a BSD-style license that can be
|
||||||
// found in the LICENSE file.
|
// found in the LICENSE file.
|
||||||
|
|
||||||
#ifndef ATOM_BROWSER_API_ATOM_BINDINGS_
|
#ifndef ATOM_COMMON_API_ATOM_BINDINGS_
|
||||||
#define ATOM_BROWSER_API_ATOM_BINDINGS_
|
#define ATOM_COMMON_API_ATOM_BINDINGS_
|
||||||
|
|
||||||
#include "base/basictypes.h"
|
#include "base/basictypes.h"
|
||||||
#include "v8/include/v8.h"
|
#include "v8/include/v8.h"
|
||||||
|
|
||||||
|
namespace WebKit {
|
||||||
|
class WebFrame;
|
||||||
|
}
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
|
||||||
class AtomBindings {
|
class AtomBindings {
|
||||||
|
@ -19,24 +23,15 @@ class AtomBindings {
|
||||||
// load native code from atom-shell instead.
|
// load native code from atom-shell instead.
|
||||||
virtual void BindTo(v8::Handle<v8::Object> process);
|
virtual void BindTo(v8::Handle<v8::Object> process);
|
||||||
|
|
||||||
// Called when the node.js main script has been loaded.
|
// Call BindTo for process object of the frame.
|
||||||
virtual void AfterLoad();
|
void BindToFrame(WebKit::WebFrame* frame);
|
||||||
|
|
||||||
// The require('atom').browserMainParts object.
|
|
||||||
v8::Handle<v8::Object> browser_main_parts() {
|
|
||||||
return browser_main_parts_;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
static v8::Handle<v8::Value> Binding(const v8::Arguments& args);
|
static v8::Handle<v8::Value> Binding(const v8::Arguments& args);
|
||||||
|
|
||||||
static v8::Persistent<v8::Object> binding_cache_;
|
|
||||||
|
|
||||||
v8::Persistent<v8::Object> browser_main_parts_;
|
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(AtomBindings);
|
DISALLOW_COPY_AND_ASSIGN(AtomBindings);
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace atom
|
} // namespace atom
|
||||||
|
|
||||||
#endif // ATOM_BROWSER_API_ATOM_BINDINGS_
|
#endif // ATOM_COMMON_API_ATOM_BINDINGS_
|
|
@ -10,8 +10,6 @@
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
|
||||||
namespace api {
|
|
||||||
|
|
||||||
#undef NODE_EXT_LIST_START
|
#undef NODE_EXT_LIST_START
|
||||||
#undef NODE_EXT_LIST_ITEM
|
#undef NODE_EXT_LIST_ITEM
|
||||||
#undef NODE_EXT_LIST_END
|
#undef NODE_EXT_LIST_END
|
||||||
|
@ -20,7 +18,7 @@ namespace api {
|
||||||
#define NODE_EXT_LIST_ITEM NODE_MODULE_DECL
|
#define NODE_EXT_LIST_ITEM NODE_MODULE_DECL
|
||||||
#define NODE_EXT_LIST_END
|
#define NODE_EXT_LIST_END
|
||||||
|
|
||||||
#include "browser/api/atom_api_extensions.h"
|
#include "common/api/atom_extensions.h"
|
||||||
|
|
||||||
#undef NODE_EXT_LIST_START
|
#undef NODE_EXT_LIST_START
|
||||||
#undef NODE_EXT_LIST_ITEM
|
#undef NODE_EXT_LIST_ITEM
|
||||||
|
@ -31,12 +29,15 @@ namespace api {
|
||||||
#define NODE_EXT_LIST_ITEM NODE_EXT_STRING
|
#define NODE_EXT_LIST_ITEM NODE_EXT_STRING
|
||||||
#define NODE_EXT_LIST_END NULL};
|
#define NODE_EXT_LIST_END NULL};
|
||||||
|
|
||||||
#include "browser/api/atom_api_extensions.h" // NOLINT
|
#include "common/api/atom_extensions.h" // NOLINT
|
||||||
|
|
||||||
node::node_module_struct* get_builtin_module(const char *name) {
|
node::node_module_struct* GetBuiltinModule(const char *name, bool is_browser) {
|
||||||
char buf[128];
|
char buf[128];
|
||||||
node::node_module_struct *cur = NULL;
|
node::node_module_struct *cur = NULL;
|
||||||
snprintf(buf, sizeof(buf), "atom_api_%s", name);
|
if (is_browser)
|
||||||
|
snprintf(buf, sizeof(buf), "atom_browser_%s", name);
|
||||||
|
else
|
||||||
|
snprintf(buf, sizeof(buf), "atom_renderer_%s", name);
|
||||||
/* TODO: you could look these up in a hash, but there are only
|
/* TODO: you could look these up in a hash, but there are only
|
||||||
* a few, and once loaded they are cached. */
|
* a few, and once loaded they are cached. */
|
||||||
for (int i = 0; node_module_list[i] != NULL; i++) {
|
for (int i = 0; node_module_list[i] != NULL; i++) {
|
||||||
|
@ -49,6 +50,4 @@ node::node_module_struct* get_builtin_module(const char *name) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace api
|
|
||||||
|
|
||||||
} // namespace atom
|
} // namespace atom
|
|
@ -8,6 +8,6 @@
|
||||||
|
|
||||||
NODE_EXT_LIST_START
|
NODE_EXT_LIST_START
|
||||||
|
|
||||||
NODE_EXT_LIST_ITEM(atom_api_window)
|
NODE_EXT_LIST_ITEM(atom_browser_window)
|
||||||
|
|
||||||
NODE_EXT_LIST_END
|
NODE_EXT_LIST_END
|
|
@ -7,6 +7,7 @@
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
|
#include "common/api/atom_bindings.h"
|
||||||
#include "common/node_bindings.h"
|
#include "common/node_bindings.h"
|
||||||
#include "renderer/atom_renderer_client.h"
|
#include "renderer/atom_renderer_client.h"
|
||||||
#include "third_party/WebKit/Source/WebKit/chromium/public/WebFrame.h"
|
#include "third_party/WebKit/Source/WebKit/chromium/public/WebFrame.h"
|
||||||
|
@ -67,6 +68,7 @@ void AtomRenderViewObserver::DidClearWindowObject(WebFrame* frame) {
|
||||||
web_frames().push_back(frame);
|
web_frames().push_back(frame);
|
||||||
|
|
||||||
renderer_client_->node_bindings()->BindTo(frame);
|
renderer_client_->node_bindings()->BindTo(frame);
|
||||||
|
renderer_client_->atom_bindings()->BindToFrame(frame);
|
||||||
}
|
}
|
||||||
|
|
||||||
void AtomRenderViewObserver::FrameWillClose(WebFrame* frame) {
|
void AtomRenderViewObserver::FrameWillClose(WebFrame* frame) {
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
|
|
||||||
#include "renderer/atom_renderer_client.h"
|
#include "renderer/atom_renderer_client.h"
|
||||||
|
|
||||||
|
#include "common/api/atom_bindings.h"
|
||||||
#include "common/node_bindings.h"
|
#include "common/node_bindings.h"
|
||||||
#include "renderer/atom_render_view_observer.h"
|
#include "renderer/atom_render_view_observer.h"
|
||||||
#include "vendor/node/src/node_internals.h"
|
#include "vendor/node/src/node_internals.h"
|
||||||
|
@ -15,7 +16,8 @@ extern void SetNodeContext(v8::Persistent<v8::Context> context);
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
|
||||||
AtomRendererClient::AtomRendererClient()
|
AtomRendererClient::AtomRendererClient()
|
||||||
: node_bindings_(NodeBindings::Create(false)) {
|
: atom_bindings_(new AtomBindings),
|
||||||
|
node_bindings_(NodeBindings::Create(false)) {
|
||||||
}
|
}
|
||||||
|
|
||||||
AtomRendererClient::~AtomRendererClient() {
|
AtomRendererClient::~AtomRendererClient() {
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
|
||||||
|
class AtomBindings;
|
||||||
class NodeBindings;
|
class NodeBindings;
|
||||||
|
|
||||||
class AtomRendererClient : public content::ContentRendererClient {
|
class AtomRendererClient : public content::ContentRendererClient {
|
||||||
|
@ -16,12 +17,14 @@ class AtomRendererClient : public content::ContentRendererClient {
|
||||||
AtomRendererClient();
|
AtomRendererClient();
|
||||||
virtual ~AtomRendererClient();
|
virtual ~AtomRendererClient();
|
||||||
|
|
||||||
|
AtomBindings* atom_bindings() const { return atom_bindings_.get(); }
|
||||||
NodeBindings* node_bindings() const { return node_bindings_.get(); }
|
NodeBindings* node_bindings() const { return node_bindings_.get(); }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
virtual void RenderThreadStarted() OVERRIDE;
|
virtual void RenderThreadStarted() OVERRIDE;
|
||||||
virtual void RenderViewCreated(content::RenderView*) OVERRIDE;
|
virtual void RenderViewCreated(content::RenderView*) OVERRIDE;
|
||||||
|
|
||||||
|
scoped_ptr<AtomBindings> atom_bindings_;
|
||||||
scoped_ptr<NodeBindings> node_bindings_;
|
scoped_ptr<NodeBindings> node_bindings_;
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(AtomRendererClient);
|
DISALLOW_COPY_AND_ASSIGN(AtomRendererClient);
|
||||||
|
|
Loading…
Add table
Reference in a new issue