Initial empty window javascript binding.
This commit is contained in:
parent
488d72e41b
commit
7da34e65f7
10 changed files with 206 additions and 5 deletions
4
atom.gyp
4
atom.gyp
|
@ -12,6 +12,8 @@
|
||||||
'lib_sources': [
|
'lib_sources': [
|
||||||
'app/atom_main_delegate.cc',
|
'app/atom_main_delegate.cc',
|
||||||
'app/atom_main_delegate.h',
|
'app/atom_main_delegate.h',
|
||||||
|
'browser/api/atom_api_event_emitter.cc',
|
||||||
|
'browser/api/atom_api_event_emitter.h',
|
||||||
'browser/api/atom_api_extensions.cc',
|
'browser/api/atom_api_extensions.cc',
|
||||||
'browser/api/atom_api_extensions.h',
|
'browser/api/atom_api_extensions.h',
|
||||||
'browser/api/atom_api_window.cc',
|
'browser/api/atom_api_window.cc',
|
||||||
|
@ -20,6 +22,8 @@
|
||||||
'browser/api/atom_bindings.h',
|
'browser/api/atom_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.h',
|
||||||
'browser/atom_browser_main_parts.cc',
|
'browser/atom_browser_main_parts.cc',
|
||||||
'browser/atom_browser_main_parts.h',
|
'browser/atom_browser_main_parts.h',
|
||||||
'browser/atom_event_processing_window.h',
|
'browser/atom_event_processing_window.h',
|
||||||
|
|
20
browser/api/atom_api_event_emitter.cc
Normal file
20
browser/api/atom_api_event_emitter.cc
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
// 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_api_event_emitter.h"
|
||||||
|
|
||||||
|
namespace atom {
|
||||||
|
|
||||||
|
namespace api {
|
||||||
|
|
||||||
|
EventEmitter::EventEmitter(v8::Handle<v8::Object> wrapper) {
|
||||||
|
Wrap(wrapper);
|
||||||
|
}
|
||||||
|
|
||||||
|
EventEmitter::~EventEmitter() {
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace api
|
||||||
|
|
||||||
|
} // namespace atom
|
37
browser/api/atom_api_event_emitter.h
Normal file
37
browser/api/atom_api_event_emitter.h
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
// 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_API_EVENT_EMITTER_H_
|
||||||
|
#define ATOM_BROWSER_API_ATOM_API_EVENT_EMITTER_H_
|
||||||
|
|
||||||
|
#include "base/basictypes.h"
|
||||||
|
#include "base/memory/scoped_ptr.h"
|
||||||
|
#include "vendor/node/src/node_object_wrap.h"
|
||||||
|
|
||||||
|
namespace atom {
|
||||||
|
|
||||||
|
namespace api {
|
||||||
|
|
||||||
|
// Class interiting EventEmitter should assume it's a javascript object which
|
||||||
|
// interits require('events').EventEmitter, this class provides many helper
|
||||||
|
// methods to do event processing in C++.
|
||||||
|
class EventEmitter : public node::ObjectWrap {
|
||||||
|
public:
|
||||||
|
virtual ~EventEmitter();
|
||||||
|
|
||||||
|
// Small accessor to return handle_, this follows Google C++ Style.
|
||||||
|
v8::Persistent<v8::Object>& handle() { return handle_; }
|
||||||
|
|
||||||
|
protected:
|
||||||
|
explicit EventEmitter(v8::Handle<v8::Object> wrapper);
|
||||||
|
|
||||||
|
private:
|
||||||
|
DISALLOW_COPY_AND_ASSIGN(EventEmitter);
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace api
|
||||||
|
|
||||||
|
} // namespace atom
|
||||||
|
|
||||||
|
#endif // ATOM_BROWSER_API_ATOM_API_EVENT_EMITTER_H_
|
|
@ -4,12 +4,56 @@
|
||||||
|
|
||||||
#include "browser/api/atom_api_window.h"
|
#include "browser/api/atom_api_window.h"
|
||||||
|
|
||||||
|
#include "base/values.h"
|
||||||
|
#include "browser/atom_browser_context.h"
|
||||||
|
#include "browser/native_window.h"
|
||||||
|
#include "content/public/renderer/v8_value_converter.h"
|
||||||
|
|
||||||
|
using content::V8ValueConverter;
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
|
||||||
static void Initialize(v8::Handle<v8::Object> target) {
|
namespace api {
|
||||||
target->Set(v8::String::New("hello"), v8::String::New("world"));
|
|
||||||
|
Window::Window(v8::Handle<v8::Object> wrapper, base::DictionaryValue* options)
|
||||||
|
: EventEmitter(wrapper),
|
||||||
|
window_(NativeWindow::Create(AtomBrowserContext::Get(), options)) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Window::~Window() {
|
||||||
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
v8::Handle<v8::Value> Window::New(const v8::Arguments &args) {
|
||||||
|
v8::HandleScope scope;
|
||||||
|
|
||||||
|
if (!args[0]->IsObject())
|
||||||
|
return node::ThrowTypeError("Bad argument");
|
||||||
|
|
||||||
|
scoped_ptr<V8ValueConverter> converter(V8ValueConverter::create());
|
||||||
|
scoped_ptr<base::Value> options(
|
||||||
|
converter->FromV8Value(args[0], v8::Context::GetCurrent()));
|
||||||
|
|
||||||
|
if (!options || !options->IsType(base::Value::TYPE_DICTIONARY))
|
||||||
|
return node::ThrowTypeError("Bad argument");
|
||||||
|
|
||||||
|
new Window(args.This(), static_cast<base::DictionaryValue*>(options.get()));
|
||||||
|
|
||||||
|
return args.This();
|
||||||
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
void Window::Initialize(v8::Handle<v8::Object> target) {
|
||||||
|
v8::HandleScope scope;
|
||||||
|
|
||||||
|
v8::Local<v8::FunctionTemplate> t = v8::FunctionTemplate::New(Window::New);
|
||||||
|
t->InstanceTemplate()->SetInternalFieldCount(1);
|
||||||
|
t->SetClassName(v8::String::NewSymbol("Window"));
|
||||||
|
target->Set(v8::String::NewSymbol("Window"), t->GetFunction());
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace api
|
||||||
|
|
||||||
} // namespace atom
|
} // namespace atom
|
||||||
|
|
||||||
NODE_MODULE(atom_api_window, atom::Initialize)
|
NODE_MODULE(atom_api_window, atom::api::Window::Initialize)
|
||||||
|
|
|
@ -5,11 +5,40 @@
|
||||||
#ifndef ATOM_BROWSER_API_ATOM_API_WINDOW_H_
|
#ifndef ATOM_BROWSER_API_ATOM_API_WINDOW_H_
|
||||||
#define ATOM_BROWSER_API_ATOM_API_WINDOW_H_
|
#define ATOM_BROWSER_API_ATOM_API_WINDOW_H_
|
||||||
|
|
||||||
#include "vendor/node/src/node.h"
|
#include "browser/api/atom_api_event_emitter.h"
|
||||||
#include "vendor/node/src/node_object_wrap.h"
|
|
||||||
|
namespace base {
|
||||||
|
class DictionaryValue;
|
||||||
|
}
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
|
||||||
|
class NativeWindow;
|
||||||
|
|
||||||
|
namespace api {
|
||||||
|
|
||||||
|
class Window : public EventEmitter {
|
||||||
|
public:
|
||||||
|
virtual ~Window();
|
||||||
|
|
||||||
|
static void Initialize(v8::Handle<v8::Object> target);
|
||||||
|
|
||||||
|
NativeWindow* window() { return window_.get(); }
|
||||||
|
|
||||||
|
protected:
|
||||||
|
explicit Window(v8::Handle<v8::Object> wrapper,
|
||||||
|
base::DictionaryValue* options);
|
||||||
|
|
||||||
|
private:
|
||||||
|
static v8::Handle<v8::Value> New(const v8::Arguments &args);
|
||||||
|
|
||||||
|
scoped_ptr<NativeWindow> window_;
|
||||||
|
|
||||||
|
DISALLOW_COPY_AND_ASSIGN(Window);
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace api
|
||||||
|
|
||||||
} // namespace atom
|
} // namespace atom
|
||||||
|
|
||||||
#endif // ATOM_BROWSER_API_ATOM_API_WINDOW_H_
|
#endif // ATOM_BROWSER_API_ATOM_API_WINDOW_H_
|
||||||
|
|
28
browser/atom_browser_context.cc
Normal file
28
browser/atom_browser_context.cc
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
// 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/atom_browser_context.h"
|
||||||
|
|
||||||
|
namespace atom {
|
||||||
|
|
||||||
|
// static
|
||||||
|
AtomBrowserContext* AtomBrowserContext::self_;
|
||||||
|
|
||||||
|
AtomBrowserContext::AtomBrowserContext() {
|
||||||
|
DCHECK(!self_);
|
||||||
|
|
||||||
|
self_ = this;
|
||||||
|
}
|
||||||
|
|
||||||
|
AtomBrowserContext::~AtomBrowserContext() {
|
||||||
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
AtomBrowserContext* AtomBrowserContext::Get() {
|
||||||
|
DCHECK(self_);
|
||||||
|
|
||||||
|
return self_;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace atom
|
28
browser/atom_browser_context.h
Normal file
28
browser/atom_browser_context.h
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
// 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_ATOM_BROWSER_CONTEXT_H_
|
||||||
|
#define ATOM_BROWSER_ATOM_BROWSER_CONTEXT_H_
|
||||||
|
|
||||||
|
#include "brightray/browser/browser_context.h"
|
||||||
|
|
||||||
|
namespace atom {
|
||||||
|
|
||||||
|
class AtomBrowserContext : public brightray::BrowserContext {
|
||||||
|
public:
|
||||||
|
AtomBrowserContext();
|
||||||
|
virtual ~AtomBrowserContext();
|
||||||
|
|
||||||
|
// We assume there is only one BrowserContext per browser process.
|
||||||
|
static AtomBrowserContext* Get();
|
||||||
|
|
||||||
|
private:
|
||||||
|
static AtomBrowserContext* self_;
|
||||||
|
|
||||||
|
DISALLOW_COPY_AND_ASSIGN(AtomBrowserContext);
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace atom
|
||||||
|
|
||||||
|
#endif // ATOM_BROWSER_ATOM_BROWSER_CONTEXT_H_
|
|
@ -6,6 +6,7 @@
|
||||||
|
|
||||||
#include "base/values.h"
|
#include "base/values.h"
|
||||||
#include "browser/api/atom_bindings.h"
|
#include "browser/api/atom_bindings.h"
|
||||||
|
#include "browser/atom_browser_context.h"
|
||||||
#include "browser/native_window.h"
|
#include "browser/native_window.h"
|
||||||
#include "brightray/browser/browser_context.h"
|
#include "brightray/browser/browser_context.h"
|
||||||
#include "brightray/browser/inspectable_web_contents.h"
|
#include "brightray/browser/inspectable_web_contents.h"
|
||||||
|
@ -23,6 +24,10 @@ AtomBrowserMainParts::AtomBrowserMainParts()
|
||||||
AtomBrowserMainParts::~AtomBrowserMainParts() {
|
AtomBrowserMainParts::~AtomBrowserMainParts() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
brightray::BrowserContext* AtomBrowserMainParts::CreateBrowserContext() {
|
||||||
|
return new AtomBrowserContext();
|
||||||
|
}
|
||||||
|
|
||||||
void AtomBrowserMainParts::PostEarlyInitialization() {
|
void AtomBrowserMainParts::PostEarlyInitialization() {
|
||||||
brightray::BrowserMainParts::PostEarlyInitialization();
|
brightray::BrowserMainParts::PostEarlyInitialization();
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,10 @@ class AtomBrowserMainParts : public brightray::BrowserMainParts {
|
||||||
virtual ~AtomBrowserMainParts();
|
virtual ~AtomBrowserMainParts();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
// Implementations of brightray::BrowserMainParts.
|
||||||
|
virtual brightray::BrowserContext* CreateBrowserContext() OVERRIDE;
|
||||||
|
|
||||||
|
// Implementations of content::BrowserMainParts.
|
||||||
virtual void PostEarlyInitialization() OVERRIDE;
|
virtual void PostEarlyInitialization() OVERRIDE;
|
||||||
virtual void PreMainMessageLoopStart() OVERRIDE;
|
virtual void PreMainMessageLoopStart() OVERRIDE;
|
||||||
virtual void PreMainMessageLoopRun() OVERRIDE;
|
virtual void PreMainMessageLoopRun() OVERRIDE;
|
||||||
|
|
|
@ -4,6 +4,8 @@
|
||||||
|
|
||||||
#include "browser/native_window_mac.h"
|
#include "browser/native_window_mac.h"
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
|
||||||
// FIXME: The foundation_util.h is aborting our compilation, do not
|
// FIXME: The foundation_util.h is aborting our compilation, do not
|
||||||
// include it.
|
// include it.
|
||||||
#define BASE_MAC_FOUNDATION_UTIL_H_
|
#define BASE_MAC_FOUNDATION_UTIL_H_
|
||||||
|
|
Loading…
Reference in a new issue