chore: remove native_mate (Part 11) (#20719)
* refactor: convert Menu and globalShortcut to gin * refactor: convert api::Cookies to gin * refactor: convert View and WebContentsView to gin * refactor: convert WebContents related classes to gin * refactor: convert powerMonitor to gin * refactor: prepare for header change * refactor: remove last uses of mate::EventEmitter * refactor: remove mate::EventEmitter * refactor: move trackable_object to gin_helper * fix: custom converter should not use Handle * fix: no more need to check if icon is empty It was a bug that the Handle<NativeImage> can be non-empty when the image file does not exist. The bug was caused by the converter code writing out the image even when the convertion fails. The bug was work-arounded by adding an additional check, but since the original bug had been fixed, the additional check is no longer needed. * fix: should always set frameId even when callback is null * fix: do not mix gin/mate handles for NativeImage
This commit is contained in:
parent
0e0d4fe990
commit
0fe6767d6b
80 changed files with 823 additions and 1087 deletions
|
@ -112,10 +112,6 @@ filenames = {
|
||||||
"shell/browser/api/atom_api_browser_window_views.cc",
|
"shell/browser/api/atom_api_browser_window_views.cc",
|
||||||
"shell/browser/api/event.cc",
|
"shell/browser/api/event.cc",
|
||||||
"shell/browser/api/event.h",
|
"shell/browser/api/event.h",
|
||||||
"shell/browser/api/event_emitter_deprecated.cc",
|
|
||||||
"shell/browser/api/event_emitter_deprecated.h",
|
|
||||||
"shell/browser/api/trackable_object.cc",
|
|
||||||
"shell/browser/api/trackable_object.h",
|
|
||||||
"shell/browser/api/frame_subscriber.cc",
|
"shell/browser/api/frame_subscriber.cc",
|
||||||
"shell/browser/api/frame_subscriber.h",
|
"shell/browser/api/frame_subscriber.h",
|
||||||
"shell/browser/api/gpu_info_enumerator.cc",
|
"shell/browser/api/gpu_info_enumerator.cc",
|
||||||
|
@ -468,7 +464,11 @@ filenames = {
|
||||||
"shell/common/crash_reporter/linux/crash_dump_handler.h",
|
"shell/common/crash_reporter/linux/crash_dump_handler.h",
|
||||||
"shell/common/crash_reporter/win/crash_service_main.cc",
|
"shell/common/crash_reporter/win/crash_service_main.cc",
|
||||||
"shell/common/crash_reporter/win/crash_service_main.h",
|
"shell/common/crash_reporter/win/crash_service_main.h",
|
||||||
|
"shell/common/gin_converters/accelerator_converter.cc",
|
||||||
|
"shell/common/gin_converters/accelerator_converter.h",
|
||||||
"shell/common/gin_converters/callback_converter.h",
|
"shell/common/gin_converters/callback_converter.h",
|
||||||
|
"shell/common/gin_converters/content_converter.cc",
|
||||||
|
"shell/common/gin_converters/content_converter.h",
|
||||||
"shell/common/gin_converters/file_dialog_converter.cc",
|
"shell/common/gin_converters/file_dialog_converter.cc",
|
||||||
"shell/common/gin_converters/file_dialog_converter.h",
|
"shell/common/gin_converters/file_dialog_converter.h",
|
||||||
"shell/common/gin_converters/file_path_converter.h",
|
"shell/common/gin_converters/file_path_converter.h",
|
||||||
|
@ -502,6 +502,8 @@ filenames = {
|
||||||
"shell/common/gin_helper/function_template.h",
|
"shell/common/gin_helper/function_template.h",
|
||||||
"shell/common/gin_helper/object_template_builder.cc",
|
"shell/common/gin_helper/object_template_builder.cc",
|
||||||
"shell/common/gin_helper/object_template_builder.h",
|
"shell/common/gin_helper/object_template_builder.h",
|
||||||
|
"shell/common/gin_helper/trackable_object.cc",
|
||||||
|
"shell/common/gin_helper/trackable_object.h",
|
||||||
"shell/common/heap_snapshot.cc",
|
"shell/common/heap_snapshot.cc",
|
||||||
"shell/common/heap_snapshot.h",
|
"shell/common/heap_snapshot.h",
|
||||||
"shell/common/key_weak_map.h",
|
"shell/common/key_weak_map.h",
|
||||||
|
@ -513,25 +515,18 @@ filenames = {
|
||||||
"shell/common/mouse_util.h",
|
"shell/common/mouse_util.h",
|
||||||
"shell/common/mac/main_application_bundle.h",
|
"shell/common/mac/main_application_bundle.h",
|
||||||
"shell/common/mac/main_application_bundle.mm",
|
"shell/common/mac/main_application_bundle.mm",
|
||||||
"shell/common/native_mate_converters/accelerator_converter.cc",
|
|
||||||
"shell/common/native_mate_converters/accelerator_converter.h",
|
|
||||||
"shell/common/native_mate_converters/blink_converter.cc",
|
"shell/common/native_mate_converters/blink_converter.cc",
|
||||||
"shell/common/native_mate_converters/blink_converter.h",
|
"shell/common/native_mate_converters/blink_converter.h",
|
||||||
"shell/common/native_mate_converters/callback_converter_deprecated.cc",
|
"shell/common/native_mate_converters/callback_converter_deprecated.cc",
|
||||||
"shell/common/native_mate_converters/callback_converter_deprecated.h",
|
"shell/common/native_mate_converters/callback_converter_deprecated.h",
|
||||||
"shell/common/native_mate_converters/content_converter.cc",
|
|
||||||
"shell/common/native_mate_converters/content_converter.h",
|
|
||||||
"shell/common/native_mate_converters/file_dialog_converter.h",
|
"shell/common/native_mate_converters/file_dialog_converter.h",
|
||||||
"shell/common/native_mate_converters/file_path_converter.h",
|
"shell/common/native_mate_converters/file_path_converter.h",
|
||||||
"shell/common/native_mate_converters/gurl_converter.h",
|
"shell/common/native_mate_converters/gurl_converter.h",
|
||||||
"shell/common/native_mate_converters/image_converter.h",
|
"shell/common/native_mate_converters/image_converter.h",
|
||||||
"shell/common/native_mate_converters/native_window_converter.h",
|
"shell/common/native_mate_converters/native_window_converter.h",
|
||||||
"shell/common/native_mate_converters/net_converter.h",
|
"shell/common/native_mate_converters/net_converter.h",
|
||||||
"shell/common/native_mate_converters/network_converter.cc",
|
|
||||||
"shell/common/native_mate_converters/network_converter.h",
|
|
||||||
"shell/common/native_mate_converters/once_callback.h",
|
"shell/common/native_mate_converters/once_callback.h",
|
||||||
"shell/common/native_mate_converters/string16_converter.h",
|
"shell/common/native_mate_converters/string16_converter.h",
|
||||||
"shell/common/native_mate_converters/ui_base_types_converter.h",
|
|
||||||
"shell/common/native_mate_converters/v8_value_converter.cc",
|
"shell/common/native_mate_converters/v8_value_converter.cc",
|
||||||
"shell/common/native_mate_converters/v8_value_converter.h",
|
"shell/common/native_mate_converters/v8_value_converter.h",
|
||||||
"shell/common/native_mate_converters/value_converter.cc",
|
"shell/common/native_mate_converters/value_converter.cc",
|
||||||
|
|
|
@ -18,7 +18,6 @@
|
||||||
#include "content/public/browser/gpu_data_manager_observer.h"
|
#include "content/public/browser/gpu_data_manager_observer.h"
|
||||||
#include "content/public/browser/render_process_host.h"
|
#include "content/public/browser/render_process_host.h"
|
||||||
#include "gin/handle.h"
|
#include "gin/handle.h"
|
||||||
#include "native_mate/wrappable.h"
|
|
||||||
#include "net/base/completion_once_callback.h"
|
#include "net/base/completion_once_callback.h"
|
||||||
#include "net/base/completion_repeating_callback.h"
|
#include "net/base/completion_repeating_callback.h"
|
||||||
#include "net/ssl/client_cert_identity.h"
|
#include "net/ssl/client_cert_identity.h"
|
||||||
|
@ -48,7 +47,7 @@ enum class JumpListResult : int;
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
class App : public AtomBrowserClient::Delegate,
|
class App : public AtomBrowserClient::Delegate,
|
||||||
public gin_helper::EventEmitter<mate::Wrappable<App>>,
|
public gin_helper::EventEmitter<App>,
|
||||||
public BrowserObserver,
|
public BrowserObserver,
|
||||||
public content::GpuDataManagerObserver,
|
public content::GpuDataManagerObserver,
|
||||||
public content::BrowserChildProcessObserver {
|
public content::BrowserChildProcessObserver {
|
||||||
|
|
|
@ -8,7 +8,6 @@
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include "gin/handle.h"
|
#include "gin/handle.h"
|
||||||
#include "native_mate/wrappable.h"
|
|
||||||
#include "shell/browser/auto_updater.h"
|
#include "shell/browser/auto_updater.h"
|
||||||
#include "shell/browser/window_list_observer.h"
|
#include "shell/browser/window_list_observer.h"
|
||||||
#include "shell/common/gin_helper/event_emitter.h"
|
#include "shell/common/gin_helper/event_emitter.h"
|
||||||
|
@ -17,10 +16,9 @@ namespace electron {
|
||||||
|
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
class AutoUpdater
|
class AutoUpdater : public gin_helper::EventEmitter<AutoUpdater>,
|
||||||
: public gin_helper::EventEmitter<mate::Wrappable<AutoUpdater>>,
|
public auto_updater::Delegate,
|
||||||
public auto_updater::Delegate,
|
public WindowListObserver {
|
||||||
public WindowListObserver {
|
|
||||||
public:
|
public:
|
||||||
static gin::Handle<AutoUpdater> Create(v8::Isolate* isolate);
|
static gin::Handle<AutoUpdater> Create(v8::Isolate* isolate);
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,6 @@
|
||||||
|
|
||||||
#include "shell/browser/api/atom_api_browser_view.h"
|
#include "shell/browser/api/atom_api_browser_view.h"
|
||||||
|
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "shell/browser/api/atom_api_web_contents.h"
|
#include "shell/browser/api/atom_api_web_contents.h"
|
||||||
#include "shell/browser/browser.h"
|
#include "shell/browser/browser.h"
|
||||||
#include "shell/browser/native_browser_view.h"
|
#include "shell/browser/native_browser_view.h"
|
||||||
|
@ -64,11 +63,8 @@ BrowserView::BrowserView(gin::Arguments* args,
|
||||||
gin::Dictionary::CreateEmpty(isolate);
|
gin::Dictionary::CreateEmpty(isolate);
|
||||||
options.Get(options::kWebPreferences, &web_preferences);
|
options.Get(options::kWebPreferences, &web_preferences);
|
||||||
web_preferences.Set("type", "browserView");
|
web_preferences.Set("type", "browserView");
|
||||||
mate::Handle<class WebContents> web_contents = WebContents::Create(
|
gin::Handle<class WebContents> web_contents =
|
||||||
isolate,
|
WebContents::Create(isolate, web_preferences);
|
||||||
// TODO(zcbenz): No need to do convertion after converting constructor
|
|
||||||
// of WebContents to gin.
|
|
||||||
mate::Dictionary(isolate, web_preferences.GetHandle()));
|
|
||||||
|
|
||||||
web_contents_.Reset(isolate, web_contents.ToV8());
|
web_contents_.Reset(isolate, web_contents.ToV8());
|
||||||
api_web_contents_ = web_contents.get();
|
api_web_contents_ = web_contents.get();
|
||||||
|
|
|
@ -10,9 +10,9 @@
|
||||||
|
|
||||||
#include "content/public/browser/web_contents_observer.h"
|
#include "content/public/browser/web_contents_observer.h"
|
||||||
#include "gin/handle.h"
|
#include "gin/handle.h"
|
||||||
#include "shell/browser/api/trackable_object.h"
|
|
||||||
#include "shell/browser/native_browser_view.h"
|
#include "shell/browser/native_browser_view.h"
|
||||||
#include "shell/common/gin_helper/error_thrower.h"
|
#include "shell/common/gin_helper/error_thrower.h"
|
||||||
|
#include "shell/common/gin_helper/trackable_object.h"
|
||||||
|
|
||||||
namespace gfx {
|
namespace gfx {
|
||||||
class Rect;
|
class Rect;
|
||||||
|
@ -30,7 +30,7 @@ namespace api {
|
||||||
|
|
||||||
class WebContents;
|
class WebContents;
|
||||||
|
|
||||||
class BrowserView : public mate::TrackableObject<BrowserView>,
|
class BrowserView : public gin_helper::TrackableObject<BrowserView>,
|
||||||
public content::WebContentsObserver {
|
public content::WebContentsObserver {
|
||||||
public:
|
public:
|
||||||
static mate::WrappableBase* New(gin_helper::ErrorThrower thrower,
|
static mate::WrappableBase* New(gin_helper::ErrorThrower thrower,
|
||||||
|
|
|
@ -12,15 +12,15 @@
|
||||||
#include "content/browser/web_contents/web_contents_impl.h" // nogncheck
|
#include "content/browser/web_contents/web_contents_impl.h" // nogncheck
|
||||||
#include "content/public/browser/render_process_host.h"
|
#include "content/public/browser/render_process_host.h"
|
||||||
#include "content/public/browser/render_view_host.h"
|
#include "content/public/browser/render_view_host.h"
|
||||||
#include "gin/converter.h"
|
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "shell/browser/browser.h"
|
#include "shell/browser/browser.h"
|
||||||
#include "shell/browser/unresponsive_suppressor.h"
|
#include "shell/browser/unresponsive_suppressor.h"
|
||||||
#include "shell/browser/web_contents_preferences.h"
|
#include "shell/browser/web_contents_preferences.h"
|
||||||
#include "shell/browser/window_list.h"
|
#include "shell/browser/window_list.h"
|
||||||
#include "shell/common/api/constructor.h"
|
#include "shell/common/api/constructor.h"
|
||||||
#include "shell/common/color_util.h"
|
#include "shell/common/color_util.h"
|
||||||
#include "shell/common/native_mate_converters/value_converter.h"
|
#include "shell/common/gin_converters/value_converter_gin_adapter.h"
|
||||||
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
|
#include "shell/common/gin_helper/object_template_builder.h"
|
||||||
#include "shell/common/node_includes.h"
|
#include "shell/common/node_includes.h"
|
||||||
#include "shell/common/options_switches.h"
|
#include "shell/common/options_switches.h"
|
||||||
#include "ui/gl/gpu_switching_manager.h"
|
#include "ui/gl/gpu_switching_manager.h"
|
||||||
|
@ -30,13 +30,14 @@ namespace electron {
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
BrowserWindow::BrowserWindow(gin::Arguments* args,
|
BrowserWindow::BrowserWindow(gin::Arguments* args,
|
||||||
const mate::Dictionary& options)
|
const gin_helper::Dictionary& options)
|
||||||
: TopLevelWindow(args->isolate(), options), weak_factory_(this) {
|
: TopLevelWindow(args->isolate(), options), weak_factory_(this) {
|
||||||
mate::Handle<class WebContents> web_contents;
|
gin::Handle<class WebContents> web_contents;
|
||||||
|
|
||||||
// Use options.webPreferences in WebContents.
|
// Use options.webPreferences in WebContents.
|
||||||
v8::Isolate* isolate = args->isolate();
|
v8::Isolate* isolate = args->isolate();
|
||||||
mate::Dictionary web_preferences = mate::Dictionary::CreateEmpty(isolate);
|
gin_helper::Dictionary web_preferences =
|
||||||
|
gin::Dictionary::CreateEmpty(isolate);
|
||||||
options.Get(options::kWebPreferences, &web_preferences);
|
options.Get(options::kWebPreferences, &web_preferences);
|
||||||
|
|
||||||
// Copy the backgroundColor to webContents.
|
// Copy the backgroundColor to webContents.
|
||||||
|
@ -66,8 +67,8 @@ BrowserWindow::BrowserWindow(gin::Arguments* args,
|
||||||
auto* existing_preferences =
|
auto* existing_preferences =
|
||||||
WebContentsPreferences::From(web_contents->web_contents());
|
WebContentsPreferences::From(web_contents->web_contents());
|
||||||
base::DictionaryValue web_preferences_dict;
|
base::DictionaryValue web_preferences_dict;
|
||||||
if (mate::ConvertFromV8(isolate, web_preferences.GetHandle(),
|
if (gin::ConvertFromV8(isolate, web_preferences.GetHandle(),
|
||||||
&web_preferences_dict)) {
|
&web_preferences_dict)) {
|
||||||
existing_preferences->Clear();
|
existing_preferences->Clear();
|
||||||
existing_preferences->Merge(web_preferences_dict);
|
existing_preferences->Merge(web_preferences_dict);
|
||||||
}
|
}
|
||||||
|
@ -82,7 +83,7 @@ BrowserWindow::BrowserWindow(gin::Arguments* args,
|
||||||
Observe(api_web_contents_->web_contents());
|
Observe(api_web_contents_->web_contents());
|
||||||
|
|
||||||
// Keep a copy of the options for later use.
|
// Keep a copy of the options for later use.
|
||||||
mate::Dictionary(isolate, web_contents->GetWrapper())
|
gin_helper::Dictionary(isolate, web_contents->GetWrapper())
|
||||||
.Set("browserWindowOptions", options);
|
.Set("browserWindowOptions", options);
|
||||||
|
|
||||||
// Associate with BrowserWindow.
|
// Associate with BrowserWindow.
|
||||||
|
@ -195,8 +196,8 @@ void BrowserWindow::OnCloseContents() {
|
||||||
v8::Locker locker(isolate());
|
v8::Locker locker(isolate());
|
||||||
v8::HandleScope handle_scope(isolate());
|
v8::HandleScope handle_scope(isolate());
|
||||||
for (v8::Local<v8::Value> value : child_windows_.Values(isolate())) {
|
for (v8::Local<v8::Value> value : child_windows_.Values(isolate())) {
|
||||||
mate::Handle<BrowserWindow> child;
|
gin::Handle<BrowserWindow> child;
|
||||||
if (mate::ConvertFromV8(isolate(), value, &child) && !child.IsEmpty())
|
if (gin::ConvertFromV8(isolate(), value, &child) && !child.IsEmpty())
|
||||||
child->window()->CloseImmediately();
|
child->window()->CloseImmediately();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -456,9 +457,9 @@ mate::WrappableBase* BrowserWindow::New(gin_helper::ErrorThrower thrower,
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
mate::Dictionary options;
|
gin_helper::Dictionary options;
|
||||||
if (!(args->Length() == 1 && args->GetNext(&options))) {
|
if (!(args->Length() == 1 && args->GetNext(&options))) {
|
||||||
options = mate::Dictionary::CreateEmpty(args->isolate());
|
options = gin::Dictionary::CreateEmpty(args->isolate());
|
||||||
}
|
}
|
||||||
|
|
||||||
return new BrowserWindow(args, options);
|
return new BrowserWindow(args, options);
|
||||||
|
@ -467,8 +468,8 @@ mate::WrappableBase* BrowserWindow::New(gin_helper::ErrorThrower thrower,
|
||||||
// static
|
// static
|
||||||
void BrowserWindow::BuildPrototype(v8::Isolate* isolate,
|
void BrowserWindow::BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::FunctionTemplate> prototype) {
|
v8::Local<v8::FunctionTemplate> prototype) {
|
||||||
prototype->SetClassName(mate::StringToV8(isolate, "BrowserWindow"));
|
prototype->SetClassName(gin::StringToV8(isolate, "BrowserWindow"));
|
||||||
mate::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
gin_helper::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
||||||
.SetMethod("focusOnWebView", &BrowserWindow::FocusOnWebView)
|
.SetMethod("focusOnWebView", &BrowserWindow::FocusOnWebView)
|
||||||
.SetMethod("blurWebView", &BrowserWindow::BlurWebView)
|
.SetMethod("blurWebView", &BrowserWindow::BlurWebView)
|
||||||
.SetMethod("isWebViewFocused", &BrowserWindow::IsWebViewFocused)
|
.SetMethod("isWebViewFocused", &BrowserWindow::IsWebViewFocused)
|
||||||
|
@ -499,7 +500,7 @@ void Initialize(v8::Local<v8::Object> exports,
|
||||||
v8::Local<v8::Context> context,
|
v8::Local<v8::Context> context,
|
||||||
void* priv) {
|
void* priv) {
|
||||||
v8::Isolate* isolate = context->GetIsolate();
|
v8::Isolate* isolate = context->GetIsolate();
|
||||||
mate::Dictionary dict(isolate, exports);
|
gin_helper::Dictionary dict(isolate, exports);
|
||||||
dict.Set("BrowserWindow",
|
dict.Set("BrowserWindow",
|
||||||
mate::CreateConstructor<BrowserWindow>(
|
mate::CreateConstructor<BrowserWindow>(
|
||||||
isolate, base::BindRepeating(&BrowserWindow::New)));
|
isolate, base::BindRepeating(&BrowserWindow::New)));
|
||||||
|
|
|
@ -38,7 +38,7 @@ class BrowserWindow : public TopLevelWindow,
|
||||||
}
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
BrowserWindow(gin::Arguments* args, const mate::Dictionary& options);
|
BrowserWindow(gin::Arguments* args, const gin_helper::Dictionary& options);
|
||||||
~BrowserWindow() override;
|
~BrowserWindow() override;
|
||||||
|
|
||||||
// content::RenderWidgetHost::InputEventObserver:
|
// content::RenderWidgetHost::InputEventObserver:
|
||||||
|
|
|
@ -15,14 +15,15 @@
|
||||||
#include "content/public/browser/storage_partition.h"
|
#include "content/public/browser/storage_partition.h"
|
||||||
#include "gin/dictionary.h"
|
#include "gin/dictionary.h"
|
||||||
#include "gin/object_template_builder.h"
|
#include "gin/object_template_builder.h"
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "net/cookies/canonical_cookie.h"
|
#include "net/cookies/canonical_cookie.h"
|
||||||
#include "net/cookies/cookie_store.h"
|
#include "net/cookies/cookie_store.h"
|
||||||
#include "net/cookies/cookie_util.h"
|
#include "net/cookies/cookie_util.h"
|
||||||
#include "shell/browser/atom_browser_context.h"
|
#include "shell/browser/atom_browser_context.h"
|
||||||
#include "shell/browser/cookie_change_notifier.h"
|
#include "shell/browser/cookie_change_notifier.h"
|
||||||
#include "shell/common/native_mate_converters/gurl_converter.h"
|
#include "shell/common/gin_converters/gurl_converter.h"
|
||||||
#include "shell/common/native_mate_converters/value_converter.h"
|
#include "shell/common/gin_converters/value_converter_gin_adapter.h"
|
||||||
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
|
#include "shell/common/gin_helper/object_template_builder.h"
|
||||||
|
|
||||||
using content::BrowserThread;
|
using content::BrowserThread;
|
||||||
|
|
||||||
|
@ -175,7 +176,7 @@ Cookies::Cookies(v8::Isolate* isolate, AtomBrowserContext* browser_context)
|
||||||
|
|
||||||
Cookies::~Cookies() = default;
|
Cookies::~Cookies() = default;
|
||||||
|
|
||||||
v8::Local<v8::Promise> Cookies::Get(const mate::Dictionary& filter) {
|
v8::Local<v8::Promise> Cookies::Get(const gin_helper::Dictionary& filter) {
|
||||||
util::Promise<net::CookieList> promise(isolate());
|
util::Promise<net::CookieList> promise(isolate());
|
||||||
v8::Local<v8::Promise> handle = promise.GetHandle();
|
v8::Local<v8::Promise> handle = promise.GetHandle();
|
||||||
|
|
||||||
|
@ -184,7 +185,7 @@ v8::Local<v8::Promise> Cookies::Get(const mate::Dictionary& filter) {
|
||||||
auto* manager = storage_partition->GetCookieManagerForBrowserProcess();
|
auto* manager = storage_partition->GetCookieManagerForBrowserProcess();
|
||||||
|
|
||||||
base::DictionaryValue dict;
|
base::DictionaryValue dict;
|
||||||
mate::ConvertFromV8(isolate(), filter.GetHandle(), &dict);
|
gin::ConvertFromV8(isolate(), filter.GetHandle(), &dict);
|
||||||
|
|
||||||
std::string url;
|
std::string url;
|
||||||
filter.Get("url", &url);
|
filter.Get("url", &url);
|
||||||
|
@ -339,7 +340,7 @@ gin::Handle<Cookies> Cookies::Create(v8::Isolate* isolate,
|
||||||
void Cookies::BuildPrototype(v8::Isolate* isolate,
|
void Cookies::BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::FunctionTemplate> prototype) {
|
v8::Local<v8::FunctionTemplate> prototype) {
|
||||||
prototype->SetClassName(gin::StringToV8(isolate, "Cookies"));
|
prototype->SetClassName(gin::StringToV8(isolate, "Cookies"));
|
||||||
mate::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
gin_helper::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
||||||
.SetMethod("get", &Cookies::Get)
|
.SetMethod("get", &Cookies::Get)
|
||||||
.SetMethod("remove", &Cookies::Remove)
|
.SetMethod("remove", &Cookies::Remove)
|
||||||
.SetMethod("set", &Cookies::Set)
|
.SetMethod("set", &Cookies::Set)
|
||||||
|
|
|
@ -11,15 +11,15 @@
|
||||||
#include "base/callback_list.h"
|
#include "base/callback_list.h"
|
||||||
#include "gin/handle.h"
|
#include "gin/handle.h"
|
||||||
#include "net/cookies/canonical_cookie.h"
|
#include "net/cookies/canonical_cookie.h"
|
||||||
#include "shell/browser/api/trackable_object.h"
|
|
||||||
#include "shell/browser/net/cookie_details.h"
|
#include "shell/browser/net/cookie_details.h"
|
||||||
|
#include "shell/common/gin_helper/trackable_object.h"
|
||||||
#include "shell/common/promise_util.h"
|
#include "shell/common/promise_util.h"
|
||||||
|
|
||||||
namespace base {
|
namespace base {
|
||||||
class DictionaryValue;
|
class DictionaryValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace mate {
|
namespace gin_helper {
|
||||||
class Dictionary;
|
class Dictionary;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -33,12 +33,12 @@ class AtomBrowserContext;
|
||||||
|
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
class Cookies : public mate::TrackableObject<Cookies> {
|
class Cookies : public gin_helper::TrackableObject<Cookies> {
|
||||||
public:
|
public:
|
||||||
static gin::Handle<Cookies> Create(v8::Isolate* isolate,
|
static gin::Handle<Cookies> Create(v8::Isolate* isolate,
|
||||||
AtomBrowserContext* browser_context);
|
AtomBrowserContext* browser_context);
|
||||||
|
|
||||||
// mate::TrackableObject:
|
// gin_helper::TrackableObject:
|
||||||
static void BuildPrototype(v8::Isolate* isolate,
|
static void BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::FunctionTemplate> prototype);
|
v8::Local<v8::FunctionTemplate> prototype);
|
||||||
|
|
||||||
|
@ -46,7 +46,7 @@ class Cookies : public mate::TrackableObject<Cookies> {
|
||||||
Cookies(v8::Isolate* isolate, AtomBrowserContext* browser_context);
|
Cookies(v8::Isolate* isolate, AtomBrowserContext* browser_context);
|
||||||
~Cookies() override;
|
~Cookies() override;
|
||||||
|
|
||||||
v8::Local<v8::Promise> Get(const mate::Dictionary& filter);
|
v8::Local<v8::Promise> Get(const gin_helper::Dictionary& filter);
|
||||||
v8::Local<v8::Promise> Set(const base::DictionaryValue& details);
|
v8::Local<v8::Promise> Set(const base::DictionaryValue& details);
|
||||||
v8::Local<v8::Promise> Remove(const GURL& url, const std::string& name);
|
v8::Local<v8::Promise> Remove(const GURL& url, const std::string& name);
|
||||||
v8::Local<v8::Promise> FlushStore();
|
v8::Local<v8::Promise> FlushStore();
|
||||||
|
|
|
@ -12,8 +12,9 @@
|
||||||
#include "base/json/json_writer.h"
|
#include "base/json/json_writer.h"
|
||||||
#include "content/public/browser/devtools_agent_host.h"
|
#include "content/public/browser/devtools_agent_host.h"
|
||||||
#include "content/public/browser/web_contents.h"
|
#include "content/public/browser/web_contents.h"
|
||||||
#include "native_mate/dictionary.h"
|
#include "shell/common/gin_converters/value_converter_gin_adapter.h"
|
||||||
#include "shell/common/native_mate_converters/value_converter.h"
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
|
#include "shell/common/gin_helper/object_template_builder.h"
|
||||||
#include "shell/common/node_includes.h"
|
#include "shell/common/node_includes.h"
|
||||||
|
|
||||||
using content::DevToolsAgentHost;
|
using content::DevToolsAgentHost;
|
||||||
|
@ -93,7 +94,7 @@ void Debugger::RenderFrameHostChanged(content::RenderFrameHost* old_rfh,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Debugger::Attach(mate::Arguments* args) {
|
void Debugger::Attach(gin_helper::Arguments* args) {
|
||||||
std::string protocol_version;
|
std::string protocol_version;
|
||||||
args->GetNext(&protocol_version);
|
args->GetNext(&protocol_version);
|
||||||
|
|
||||||
|
@ -128,7 +129,7 @@ void Debugger::Detach() {
|
||||||
AgentHostClosed(agent_host_.get());
|
AgentHostClosed(agent_host_.get());
|
||||||
}
|
}
|
||||||
|
|
||||||
v8::Local<v8::Promise> Debugger::SendCommand(mate::Arguments* args) {
|
v8::Local<v8::Promise> Debugger::SendCommand(gin_helper::Arguments* args) {
|
||||||
electron::util::Promise<base::DictionaryValue> promise(isolate());
|
electron::util::Promise<base::DictionaryValue> promise(isolate());
|
||||||
v8::Local<v8::Promise> handle = promise.GetHandle();
|
v8::Local<v8::Promise> handle = promise.GetHandle();
|
||||||
|
|
||||||
|
@ -168,16 +169,16 @@ void Debugger::ClearPendingRequests() {
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::Handle<Debugger> Debugger::Create(v8::Isolate* isolate,
|
gin::Handle<Debugger> Debugger::Create(v8::Isolate* isolate,
|
||||||
content::WebContents* web_contents) {
|
content::WebContents* web_contents) {
|
||||||
return mate::CreateHandle(isolate, new Debugger(isolate, web_contents));
|
return gin::CreateHandle(isolate, new Debugger(isolate, web_contents));
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void Debugger::BuildPrototype(v8::Isolate* isolate,
|
void Debugger::BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::FunctionTemplate> prototype) {
|
v8::Local<v8::FunctionTemplate> prototype) {
|
||||||
prototype->SetClassName(mate::StringToV8(isolate, "Debugger"));
|
prototype->SetClassName(gin::StringToV8(isolate, "Debugger"));
|
||||||
mate::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
gin_helper::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
||||||
.SetMethod("attach", &Debugger::Attach)
|
.SetMethod("attach", &Debugger::Attach)
|
||||||
.SetMethod("isAttached", &Debugger::IsAttached)
|
.SetMethod("isAttached", &Debugger::IsAttached)
|
||||||
.SetMethod("detach", &Debugger::Detach)
|
.SetMethod("detach", &Debugger::Detach)
|
||||||
|
@ -197,7 +198,7 @@ void Initialize(v8::Local<v8::Object> exports,
|
||||||
v8::Local<v8::Context> context,
|
v8::Local<v8::Context> context,
|
||||||
void* priv) {
|
void* priv) {
|
||||||
v8::Isolate* isolate = context->GetIsolate();
|
v8::Isolate* isolate = context->GetIsolate();
|
||||||
mate::Dictionary(isolate, exports)
|
gin_helper::Dictionary(isolate, exports)
|
||||||
.Set("Debugger", Debugger::GetConstructor(isolate)
|
.Set("Debugger", Debugger::GetConstructor(isolate)
|
||||||
->GetFunction(context)
|
->GetFunction(context)
|
||||||
.ToLocalChecked());
|
.ToLocalChecked());
|
||||||
|
|
|
@ -12,8 +12,8 @@
|
||||||
#include "base/values.h"
|
#include "base/values.h"
|
||||||
#include "content/public/browser/devtools_agent_host_client.h"
|
#include "content/public/browser/devtools_agent_host_client.h"
|
||||||
#include "content/public/browser/web_contents_observer.h"
|
#include "content/public/browser/web_contents_observer.h"
|
||||||
#include "native_mate/handle.h"
|
#include "gin/handle.h"
|
||||||
#include "shell/browser/api/trackable_object.h"
|
#include "shell/common/gin_helper/trackable_object.h"
|
||||||
#include "shell/common/promise_util.h"
|
#include "shell/common/promise_util.h"
|
||||||
|
|
||||||
namespace content {
|
namespace content {
|
||||||
|
@ -21,22 +21,18 @@ class DevToolsAgentHost;
|
||||||
class WebContents;
|
class WebContents;
|
||||||
} // namespace content
|
} // namespace content
|
||||||
|
|
||||||
namespace mate {
|
|
||||||
class Arguments;
|
|
||||||
}
|
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
class Debugger : public mate::TrackableObject<Debugger>,
|
class Debugger : public gin_helper::TrackableObject<Debugger>,
|
||||||
public content::DevToolsAgentHostClient,
|
public content::DevToolsAgentHostClient,
|
||||||
public content::WebContentsObserver {
|
public content::WebContentsObserver {
|
||||||
public:
|
public:
|
||||||
static mate::Handle<Debugger> Create(v8::Isolate* isolate,
|
static gin::Handle<Debugger> Create(v8::Isolate* isolate,
|
||||||
content::WebContents* web_contents);
|
content::WebContents* web_contents);
|
||||||
|
|
||||||
// mate::TrackableObject:
|
// gin_helper::TrackableObject:
|
||||||
static void BuildPrototype(v8::Isolate* isolate,
|
static void BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::FunctionTemplate> prototype);
|
v8::Local<v8::FunctionTemplate> prototype);
|
||||||
|
|
||||||
|
@ -57,10 +53,10 @@ class Debugger : public mate::TrackableObject<Debugger>,
|
||||||
using PendingRequestMap =
|
using PendingRequestMap =
|
||||||
std::map<int, electron::util::Promise<base::DictionaryValue>>;
|
std::map<int, electron::util::Promise<base::DictionaryValue>>;
|
||||||
|
|
||||||
void Attach(mate::Arguments* args);
|
void Attach(gin_helper::Arguments* args);
|
||||||
bool IsAttached();
|
bool IsAttached();
|
||||||
void Detach();
|
void Detach();
|
||||||
v8::Local<v8::Promise> SendCommand(mate::Arguments* args);
|
v8::Local<v8::Promise> SendCommand(gin_helper::Arguments* args);
|
||||||
void ClearPendingRequests();
|
void ClearPendingRequests();
|
||||||
|
|
||||||
content::WebContents* web_contents_; // Weak Reference.
|
content::WebContents* web_contents_; // Weak Reference.
|
||||||
|
|
|
@ -12,17 +12,13 @@
|
||||||
#include "chrome/browser/media/webrtc/desktop_media_list_observer.h"
|
#include "chrome/browser/media/webrtc/desktop_media_list_observer.h"
|
||||||
#include "chrome/browser/media/webrtc/native_desktop_media_list.h"
|
#include "chrome/browser/media/webrtc/native_desktop_media_list.h"
|
||||||
#include "gin/handle.h"
|
#include "gin/handle.h"
|
||||||
#include "shell/browser/api/trackable_object.h"
|
#include "shell/common/gin_helper/trackable_object.h"
|
||||||
#include "shell/common/gin_helper/event_emitter.h"
|
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
class DesktopCapturer
|
class DesktopCapturer : public gin_helper::TrackableObject<DesktopCapturer> {
|
||||||
: public mate::TrackableObject<
|
|
||||||
DesktopCapturer,
|
|
||||||
gin_helper::EventEmitter<mate::Wrappable<DesktopCapturer>>> {
|
|
||||||
public:
|
public:
|
||||||
struct Source {
|
struct Source {
|
||||||
DesktopMediaList::Source media_list_source;
|
DesktopMediaList::Source media_list_source;
|
||||||
|
|
|
@ -8,15 +8,16 @@
|
||||||
|
|
||||||
#include "base/strings/utf_string_conversions.h"
|
#include "base/strings/utf_string_conversions.h"
|
||||||
#include "base/threading/thread_task_runner_handle.h"
|
#include "base/threading/thread_task_runner_handle.h"
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "net/base/filename_util.h"
|
#include "net/base/filename_util.h"
|
||||||
#include "shell/browser/atom_browser_main_parts.h"
|
#include "shell/browser/atom_browser_main_parts.h"
|
||||||
#include "shell/common/native_mate_converters/file_dialog_converter.h"
|
#include "shell/common/gin_converters/file_dialog_converter.h"
|
||||||
#include "shell/common/native_mate_converters/file_path_converter.h"
|
#include "shell/common/gin_converters/file_path_converter.h"
|
||||||
#include "shell/common/native_mate_converters/gurl_converter.h"
|
#include "shell/common/gin_converters/gurl_converter.h"
|
||||||
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
|
#include "shell/common/gin_helper/object_template_builder.h"
|
||||||
#include "shell/common/node_includes.h"
|
#include "shell/common/node_includes.h"
|
||||||
|
|
||||||
namespace mate {
|
namespace gin {
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct Converter<download::DownloadItem::DownloadState> {
|
struct Converter<download::DownloadItem::DownloadState> {
|
||||||
|
@ -44,7 +45,7 @@ struct Converter<download::DownloadItem::DownloadState> {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace mate
|
} // namespace gin
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
|
||||||
|
@ -52,7 +53,7 @@ namespace api {
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
std::map<uint32_t, v8::Global<v8::Object>> g_download_item_objects;
|
std::map<uint32_t, v8::Global<v8::Value>> g_download_item_objects;
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
|
@ -188,9 +189,9 @@ double DownloadItem::GetStartTime() const {
|
||||||
// static
|
// static
|
||||||
void DownloadItem::BuildPrototype(v8::Isolate* isolate,
|
void DownloadItem::BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::FunctionTemplate> prototype) {
|
v8::Local<v8::FunctionTemplate> prototype) {
|
||||||
prototype->SetClassName(mate::StringToV8(isolate, "DownloadItem"));
|
prototype->SetClassName(gin::StringToV8(isolate, "DownloadItem"));
|
||||||
gin_helper::Destroyable::MakeDestroyable(isolate, prototype);
|
gin_helper::Destroyable::MakeDestroyable(isolate, prototype);
|
||||||
mate::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
gin_helper::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
||||||
.SetMethod("pause", &DownloadItem::Pause)
|
.SetMethod("pause", &DownloadItem::Pause)
|
||||||
.SetMethod("isPaused", &DownloadItem::IsPaused)
|
.SetMethod("isPaused", &DownloadItem::IsPaused)
|
||||||
.SetMethod("resume", &DownloadItem::Resume)
|
.SetMethod("resume", &DownloadItem::Resume)
|
||||||
|
@ -218,17 +219,17 @@ void DownloadItem::BuildPrototype(v8::Isolate* isolate,
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::Handle<DownloadItem> DownloadItem::Create(v8::Isolate* isolate,
|
gin::Handle<DownloadItem> DownloadItem::Create(v8::Isolate* isolate,
|
||||||
download::DownloadItem* item) {
|
download::DownloadItem* item) {
|
||||||
auto* existing = TrackableObject::FromWrappedClass(isolate, item);
|
auto* existing = TrackableObject::FromWrappedClass(isolate, item);
|
||||||
if (existing)
|
if (existing)
|
||||||
return mate::CreateHandle(isolate, static_cast<DownloadItem*>(existing));
|
return gin::CreateHandle(isolate, static_cast<DownloadItem*>(existing));
|
||||||
|
|
||||||
auto handle = mate::CreateHandle(isolate, new DownloadItem(isolate, item));
|
auto handle = gin::CreateHandle(isolate, new DownloadItem(isolate, item));
|
||||||
|
|
||||||
// Reference this object in case it got garbage collected.
|
// Reference this object in case it got garbage collected.
|
||||||
g_download_item_objects[handle->weak_map_id()] =
|
g_download_item_objects[handle->weak_map_id()] =
|
||||||
v8::Global<v8::Object>(isolate, handle.ToV8());
|
v8::Global<v8::Value>(isolate, handle.ToV8());
|
||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -243,7 +244,7 @@ void Initialize(v8::Local<v8::Object> exports,
|
||||||
v8::Local<v8::Context> context,
|
v8::Local<v8::Context> context,
|
||||||
void* priv) {
|
void* priv) {
|
||||||
v8::Isolate* isolate = context->GetIsolate();
|
v8::Isolate* isolate = context->GetIsolate();
|
||||||
mate::Dictionary(isolate, exports)
|
gin_helper::Dictionary(isolate, exports)
|
||||||
.Set("DownloadItem", electron::api::DownloadItem::GetConstructor(isolate)
|
.Set("DownloadItem", electron::api::DownloadItem::GetConstructor(isolate)
|
||||||
->GetFunction(context)
|
->GetFunction(context)
|
||||||
.ToLocalChecked());
|
.ToLocalChecked());
|
||||||
|
|
|
@ -10,20 +10,20 @@
|
||||||
|
|
||||||
#include "base/files/file_path.h"
|
#include "base/files/file_path.h"
|
||||||
#include "components/download/public/common/download_item.h"
|
#include "components/download/public/common/download_item.h"
|
||||||
#include "native_mate/handle.h"
|
#include "gin/handle.h"
|
||||||
#include "shell/browser/api/trackable_object.h"
|
|
||||||
#include "shell/browser/ui/file_dialog.h"
|
#include "shell/browser/ui/file_dialog.h"
|
||||||
|
#include "shell/common/gin_helper/trackable_object.h"
|
||||||
#include "url/gurl.h"
|
#include "url/gurl.h"
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
class DownloadItem : public mate::TrackableObject<DownloadItem>,
|
class DownloadItem : public gin_helper::TrackableObject<DownloadItem>,
|
||||||
public download::DownloadItem::Observer {
|
public download::DownloadItem::Observer {
|
||||||
public:
|
public:
|
||||||
static mate::Handle<DownloadItem> Create(v8::Isolate* isolate,
|
static gin::Handle<DownloadItem> Create(v8::Isolate* isolate,
|
||||||
download::DownloadItem* item);
|
download::DownloadItem* item);
|
||||||
|
|
||||||
static void BuildPrototype(v8::Isolate* isolate,
|
static void BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::FunctionTemplate> prototype);
|
v8::Local<v8::FunctionTemplate> prototype);
|
||||||
|
|
|
@ -9,10 +9,11 @@
|
||||||
|
|
||||||
#include "base/stl_util.h"
|
#include "base/stl_util.h"
|
||||||
#include "base/strings/utf_string_conversions.h"
|
#include "base/strings/utf_string_conversions.h"
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "shell/browser/api/atom_api_system_preferences.h"
|
#include "shell/browser/api/atom_api_system_preferences.h"
|
||||||
#include "shell/common/native_mate_converters/accelerator_converter.h"
|
#include "shell/common/gin_converters/accelerator_converter.h"
|
||||||
#include "shell/common/native_mate_converters/callback_converter_deprecated.h"
|
#include "shell/common/gin_converters/callback_converter.h"
|
||||||
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
|
#include "shell/common/gin_helper/object_template_builder.h"
|
||||||
#include "shell/common/node_includes.h"
|
#include "shell/common/node_includes.h"
|
||||||
|
|
||||||
#if defined(OS_MACOSX)
|
#if defined(OS_MACOSX)
|
||||||
|
@ -131,15 +132,15 @@ void GlobalShortcut::UnregisterAll() {
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::Handle<GlobalShortcut> GlobalShortcut::Create(v8::Isolate* isolate) {
|
gin::Handle<GlobalShortcut> GlobalShortcut::Create(v8::Isolate* isolate) {
|
||||||
return mate::CreateHandle(isolate, new GlobalShortcut(isolate));
|
return gin::CreateHandle(isolate, new GlobalShortcut(isolate));
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void GlobalShortcut::BuildPrototype(v8::Isolate* isolate,
|
void GlobalShortcut::BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::FunctionTemplate> prototype) {
|
v8::Local<v8::FunctionTemplate> prototype) {
|
||||||
prototype->SetClassName(mate::StringToV8(isolate, "GlobalShortcut"));
|
prototype->SetClassName(gin::StringToV8(isolate, "GlobalShortcut"));
|
||||||
mate::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
gin_helper::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
||||||
.SetMethod("registerAll", &GlobalShortcut::RegisterAll)
|
.SetMethod("registerAll", &GlobalShortcut::RegisterAll)
|
||||||
.SetMethod("register", &GlobalShortcut::Register)
|
.SetMethod("register", &GlobalShortcut::Register)
|
||||||
.SetMethod("isRegistered", &GlobalShortcut::IsRegistered)
|
.SetMethod("isRegistered", &GlobalShortcut::IsRegistered)
|
||||||
|
@ -158,7 +159,7 @@ void Initialize(v8::Local<v8::Object> exports,
|
||||||
v8::Local<v8::Context> context,
|
v8::Local<v8::Context> context,
|
||||||
void* priv) {
|
void* priv) {
|
||||||
v8::Isolate* isolate = context->GetIsolate();
|
v8::Isolate* isolate = context->GetIsolate();
|
||||||
mate::Dictionary dict(isolate, exports);
|
gin_helper::Dictionary dict(isolate, exports);
|
||||||
dict.Set("globalShortcut", electron::api::GlobalShortcut::Create(isolate));
|
dict.Set("globalShortcut", electron::api::GlobalShortcut::Create(isolate));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,8 +11,8 @@
|
||||||
|
|
||||||
#include "base/callback.h"
|
#include "base/callback.h"
|
||||||
#include "chrome/browser/extensions/global_shortcut_listener.h"
|
#include "chrome/browser/extensions/global_shortcut_listener.h"
|
||||||
#include "native_mate/handle.h"
|
#include "gin/handle.h"
|
||||||
#include "shell/browser/api/trackable_object.h"
|
#include "shell/common/gin_helper/trackable_object.h"
|
||||||
#include "ui/base/accelerators/accelerator.h"
|
#include "ui/base/accelerators/accelerator.h"
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
@ -20,9 +20,9 @@ namespace electron {
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
class GlobalShortcut : public extensions::GlobalShortcutListener::Observer,
|
class GlobalShortcut : public extensions::GlobalShortcutListener::Observer,
|
||||||
public mate::TrackableObject<GlobalShortcut> {
|
public gin_helper::TrackableObject<GlobalShortcut> {
|
||||||
public:
|
public:
|
||||||
static mate::Handle<GlobalShortcut> Create(v8::Isolate* isolate);
|
static gin::Handle<GlobalShortcut> Create(v8::Isolate* isolate);
|
||||||
|
|
||||||
static void BuildPrototype(v8::Isolate* isolate,
|
static void BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::FunctionTemplate> prototype);
|
v8::Local<v8::FunctionTemplate> prototype);
|
||||||
|
|
|
@ -9,7 +9,6 @@
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "gin/handle.h"
|
#include "gin/handle.h"
|
||||||
#include "native_mate/wrappable.h"
|
|
||||||
#include "shell/browser/mac/in_app_purchase.h"
|
#include "shell/browser/mac/in_app_purchase.h"
|
||||||
#include "shell/browser/mac/in_app_purchase_observer.h"
|
#include "shell/browser/mac/in_app_purchase_observer.h"
|
||||||
#include "shell/browser/mac/in_app_purchase_product.h"
|
#include "shell/browser/mac/in_app_purchase_product.h"
|
||||||
|
@ -20,9 +19,8 @@ namespace electron {
|
||||||
|
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
class InAppPurchase
|
class InAppPurchase : public gin_helper::EventEmitter<InAppPurchase>,
|
||||||
: public gin_helper::EventEmitter<mate::Wrappable<InAppPurchase>>,
|
public in_app_purchase::TransactionObserver {
|
||||||
public in_app_purchase::TransactionObserver {
|
|
||||||
public:
|
public:
|
||||||
static gin::Handle<InAppPurchase> Create(v8::Isolate* isolate);
|
static gin::Handle<InAppPurchase> Create(v8::Isolate* isolate);
|
||||||
|
|
||||||
|
|
|
@ -6,13 +6,12 @@
|
||||||
|
|
||||||
#include <map>
|
#include <map>
|
||||||
|
|
||||||
#include "native_mate/constructor.h"
|
|
||||||
#include "shell/browser/native_window.h"
|
#include "shell/browser/native_window.h"
|
||||||
|
#include "shell/common/gin_converters/accelerator_converter.h"
|
||||||
#include "shell/common/gin_converters/callback_converter.h"
|
#include "shell/common/gin_converters/callback_converter.h"
|
||||||
#include "shell/common/gin_converters/image_converter.h"
|
#include "shell/common/gin_converters/image_converter.h"
|
||||||
#include "shell/common/gin_helper/dictionary.h"
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
#include "shell/common/gin_helper/object_template_builder.h"
|
#include "shell/common/gin_helper/object_template_builder.h"
|
||||||
#include "shell/common/native_mate_converters/accelerator_converter.h"
|
|
||||||
#include "shell/common/node_includes.h"
|
#include "shell/common/node_includes.h"
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
@ -88,7 +87,7 @@ bool Menu::GetAcceleratorForCommandIdWithParams(
|
||||||
v8::HandleScope handle_scope(isolate());
|
v8::HandleScope handle_scope(isolate());
|
||||||
v8::Local<v8::Value> val =
|
v8::Local<v8::Value> val =
|
||||||
get_accelerator_.Run(GetWrapper(), command_id, use_default_accelerator);
|
get_accelerator_.Run(GetWrapper(), command_id, use_default_accelerator);
|
||||||
return mate::ConvertFromV8(isolate(), val, accelerator);
|
return gin::ConvertFromV8(isolate(), val, accelerator);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Menu::ShouldRegisterAcceleratorForCommandId(int command_id) const {
|
bool Menu::ShouldRegisterAcceleratorForCommandId(int command_id) const {
|
||||||
|
@ -100,9 +99,9 @@ bool Menu::ShouldRegisterAcceleratorForCommandId(int command_id) const {
|
||||||
void Menu::ExecuteCommand(int command_id, int flags) {
|
void Menu::ExecuteCommand(int command_id, int flags) {
|
||||||
v8::Locker locker(isolate());
|
v8::Locker locker(isolate());
|
||||||
v8::HandleScope handle_scope(isolate());
|
v8::HandleScope handle_scope(isolate());
|
||||||
execute_command_.Run(GetWrapper(),
|
execute_command_.Run(
|
||||||
mate::internal::CreateEventFromFlags(isolate(), flags),
|
GetWrapper(),
|
||||||
command_id);
|
gin_helper::internal::CreateEventFromFlags(isolate(), flags), command_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Menu::OnMenuWillShow(ui::SimpleMenuModel* source) {
|
void Menu::OnMenuWillShow(ui::SimpleMenuModel* source) {
|
||||||
|
|
|
@ -11,14 +11,14 @@
|
||||||
#include "base/callback.h"
|
#include "base/callback.h"
|
||||||
#include "gin/arguments.h"
|
#include "gin/arguments.h"
|
||||||
#include "shell/browser/api/atom_api_top_level_window.h"
|
#include "shell/browser/api/atom_api_top_level_window.h"
|
||||||
#include "shell/browser/api/trackable_object.h"
|
|
||||||
#include "shell/browser/ui/atom_menu_model.h"
|
#include "shell/browser/ui/atom_menu_model.h"
|
||||||
|
#include "shell/common/gin_helper/trackable_object.h"
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
class Menu : public mate::TrackableObject<Menu>,
|
class Menu : public gin_helper::TrackableObject<Menu>,
|
||||||
public AtomMenuModel::Delegate,
|
public AtomMenuModel::Delegate,
|
||||||
public AtomMenuModel::Observer {
|
public AtomMenuModel::Observer {
|
||||||
public:
|
public:
|
||||||
|
@ -122,7 +122,7 @@ class Menu : public mate::TrackableObject<Menu>,
|
||||||
|
|
||||||
} // namespace electron
|
} // namespace electron
|
||||||
|
|
||||||
namespace mate {
|
namespace gin {
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct Converter<electron::AtomMenuModel*> {
|
struct Converter<electron::AtomMenuModel*> {
|
||||||
|
@ -143,6 +143,19 @@ struct Converter<electron::AtomMenuModel*> {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
} // namespace gin
|
||||||
|
|
||||||
|
namespace mate {
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct Converter<electron::AtomMenuModel*> {
|
||||||
|
static bool FromV8(v8::Isolate* isolate,
|
||||||
|
v8::Local<v8::Value> val,
|
||||||
|
electron::AtomMenuModel** out) {
|
||||||
|
return gin::ConvertFromV8(isolate, val, out);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
} // namespace mate
|
} // namespace mate
|
||||||
|
|
||||||
#endif // SHELL_BROWSER_API_ATOM_API_MENU_H_
|
#endif // SHELL_BROWSER_API_ATOM_API_MENU_H_
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
#ifndef SHELL_BROWSER_API_ATOM_API_NATIVE_THEME_H_
|
#ifndef SHELL_BROWSER_API_ATOM_API_NATIVE_THEME_H_
|
||||||
#define SHELL_BROWSER_API_ATOM_API_NATIVE_THEME_H_
|
#define SHELL_BROWSER_API_ATOM_API_NATIVE_THEME_H_
|
||||||
|
|
||||||
#include "native_mate/wrappable.h"
|
|
||||||
#include "shell/common/gin_helper/event_emitter.h"
|
#include "shell/common/gin_helper/event_emitter.h"
|
||||||
#include "ui/native_theme/native_theme.h"
|
#include "ui/native_theme/native_theme.h"
|
||||||
#include "ui/native_theme/native_theme_observer.h"
|
#include "ui/native_theme/native_theme_observer.h"
|
||||||
|
@ -14,9 +13,8 @@ namespace electron {
|
||||||
|
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
class NativeTheme
|
class NativeTheme : public gin_helper::EventEmitter<NativeTheme>,
|
||||||
: public gin_helper::EventEmitter<mate::Wrappable<NativeTheme>>,
|
public ui::NativeThemeObserver {
|
||||||
public ui::NativeThemeObserver {
|
|
||||||
public:
|
public:
|
||||||
static v8::Local<v8::Value> Create(v8::Isolate* isolate);
|
static v8::Local<v8::Value> Create(v8::Isolate* isolate);
|
||||||
|
|
||||||
|
|
|
@ -11,15 +11,14 @@
|
||||||
#include "components/net_log/chrome_net_log.h"
|
#include "components/net_log/chrome_net_log.h"
|
||||||
#include "content/public/browser/storage_partition.h"
|
#include "content/public/browser/storage_partition.h"
|
||||||
#include "electron/electron_version.h"
|
#include "electron/electron_version.h"
|
||||||
#include "native_mate/converter.h"
|
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "native_mate/handle.h"
|
|
||||||
#include "shell/browser/atom_browser_context.h"
|
#include "shell/browser/atom_browser_context.h"
|
||||||
#include "shell/browser/net/system_network_context_manager.h"
|
#include "shell/browser/net/system_network_context_manager.h"
|
||||||
#include "shell/common/native_mate_converters/file_path_converter.h"
|
#include "shell/common/gin_converters/file_path_converter.h"
|
||||||
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
|
#include "shell/common/gin_helper/object_template_builder.h"
|
||||||
#include "shell/common/node_includes.h"
|
#include "shell/common/node_includes.h"
|
||||||
|
|
||||||
namespace mate {
|
namespace gin {
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct Converter<net::NetLogCaptureMode> {
|
struct Converter<net::NetLogCaptureMode> {
|
||||||
|
@ -41,7 +40,7 @@ struct Converter<net::NetLogCaptureMode> {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace mate
|
} // namespace gin
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
|
||||||
|
@ -84,7 +83,7 @@ NetLog::NetLog(v8::Isolate* isolate, AtomBrowserContext* browser_context)
|
||||||
NetLog::~NetLog() = default;
|
NetLog::~NetLog() = default;
|
||||||
|
|
||||||
v8::Local<v8::Promise> NetLog::StartLogging(base::FilePath log_path,
|
v8::Local<v8::Promise> NetLog::StartLogging(base::FilePath log_path,
|
||||||
mate::Arguments* args) {
|
gin_helper::Arguments* args) {
|
||||||
if (log_path.empty()) {
|
if (log_path.empty()) {
|
||||||
args->ThrowError("The first parameter must be a valid string");
|
args->ThrowError("The first parameter must be a valid string");
|
||||||
return v8::Local<v8::Promise>();
|
return v8::Local<v8::Promise>();
|
||||||
|
@ -93,20 +92,20 @@ v8::Local<v8::Promise> NetLog::StartLogging(base::FilePath log_path,
|
||||||
net::NetLogCaptureMode capture_mode = net::NetLogCaptureMode::kDefault;
|
net::NetLogCaptureMode capture_mode = net::NetLogCaptureMode::kDefault;
|
||||||
uint64_t max_file_size = network::mojom::NetLogExporter::kUnlimitedFileSize;
|
uint64_t max_file_size = network::mojom::NetLogExporter::kUnlimitedFileSize;
|
||||||
|
|
||||||
mate::Dictionary dict;
|
gin_helper::Dictionary dict;
|
||||||
if (args->GetNext(&dict)) {
|
if (args->GetNext(&dict)) {
|
||||||
v8::Local<v8::Value> capture_mode_v8;
|
v8::Local<v8::Value> capture_mode_v8;
|
||||||
if (dict.Get("captureMode", &capture_mode_v8)) {
|
if (dict.Get("captureMode", &capture_mode_v8)) {
|
||||||
if (!mate::ConvertFromV8(args->isolate(), capture_mode_v8,
|
if (!gin::ConvertFromV8(args->isolate(), capture_mode_v8,
|
||||||
&capture_mode)) {
|
&capture_mode)) {
|
||||||
args->ThrowError("Invalid value for captureMode");
|
args->ThrowError("Invalid value for captureMode");
|
||||||
return v8::Local<v8::Promise>();
|
return v8::Local<v8::Promise>();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
v8::Local<v8::Value> max_file_size_v8;
|
v8::Local<v8::Value> max_file_size_v8;
|
||||||
if (dict.Get("maxFileSize", &max_file_size_v8)) {
|
if (dict.Get("maxFileSize", &max_file_size_v8)) {
|
||||||
if (!mate::ConvertFromV8(args->isolate(), max_file_size_v8,
|
if (!gin::ConvertFromV8(args->isolate(), max_file_size_v8,
|
||||||
&max_file_size)) {
|
&max_file_size)) {
|
||||||
args->ThrowError("Invalid value for maxFileSize");
|
args->ThrowError("Invalid value for maxFileSize");
|
||||||
return v8::Local<v8::Promise>();
|
return v8::Local<v8::Promise>();
|
||||||
}
|
}
|
||||||
|
@ -187,7 +186,7 @@ bool NetLog::IsCurrentlyLogging() const {
|
||||||
return !!net_log_exporter_;
|
return !!net_log_exporter_;
|
||||||
}
|
}
|
||||||
|
|
||||||
v8::Local<v8::Promise> NetLog::StopLogging(mate::Arguments* args) {
|
v8::Local<v8::Promise> NetLog::StopLogging(gin_helper::Arguments* args) {
|
||||||
util::Promise<void*> promise(isolate());
|
util::Promise<void*> promise(isolate());
|
||||||
v8::Local<v8::Promise> handle = promise.GetHandle();
|
v8::Local<v8::Promise> handle = promise.GetHandle();
|
||||||
|
|
||||||
|
@ -211,16 +210,16 @@ v8::Local<v8::Promise> NetLog::StopLogging(mate::Arguments* args) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::Handle<NetLog> NetLog::Create(v8::Isolate* isolate,
|
gin::Handle<NetLog> NetLog::Create(v8::Isolate* isolate,
|
||||||
AtomBrowserContext* browser_context) {
|
AtomBrowserContext* browser_context) {
|
||||||
return mate::CreateHandle(isolate, new NetLog(isolate, browser_context));
|
return gin::CreateHandle(isolate, new NetLog(isolate, browser_context));
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void NetLog::BuildPrototype(v8::Isolate* isolate,
|
void NetLog::BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::FunctionTemplate> prototype) {
|
v8::Local<v8::FunctionTemplate> prototype) {
|
||||||
prototype->SetClassName(mate::StringToV8(isolate, "NetLog"));
|
prototype->SetClassName(gin::StringToV8(isolate, "NetLog"));
|
||||||
mate::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
gin_helper::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
||||||
.SetProperty("currentlyLogging", &NetLog::IsCurrentlyLogging)
|
.SetProperty("currentlyLogging", &NetLog::IsCurrentlyLogging)
|
||||||
.SetMethod("startLogging", &NetLog::StartLogging)
|
.SetMethod("startLogging", &NetLog::StartLogging)
|
||||||
.SetMethod("stopLogging", &NetLog::StopLogging);
|
.SetMethod("stopLogging", &NetLog::StopLogging);
|
||||||
|
|
|
@ -12,9 +12,9 @@
|
||||||
#include "base/callback.h"
|
#include "base/callback.h"
|
||||||
#include "base/optional.h"
|
#include "base/optional.h"
|
||||||
#include "base/values.h"
|
#include "base/values.h"
|
||||||
#include "native_mate/handle.h"
|
#include "gin/handle.h"
|
||||||
#include "services/network/public/mojom/net_log.mojom.h"
|
#include "services/network/public/mojom/net_log.mojom.h"
|
||||||
#include "shell/browser/api/trackable_object.h"
|
#include "shell/common/gin_helper/trackable_object.h"
|
||||||
#include "shell/common/promise_util.h"
|
#include "shell/common/promise_util.h"
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
@ -23,17 +23,17 @@ class AtomBrowserContext;
|
||||||
|
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
class NetLog : public mate::TrackableObject<NetLog> {
|
class NetLog : public gin_helper::TrackableObject<NetLog> {
|
||||||
public:
|
public:
|
||||||
static mate::Handle<NetLog> Create(v8::Isolate* isolate,
|
static gin::Handle<NetLog> Create(v8::Isolate* isolate,
|
||||||
AtomBrowserContext* browser_context);
|
AtomBrowserContext* browser_context);
|
||||||
|
|
||||||
static void BuildPrototype(v8::Isolate* isolate,
|
static void BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::FunctionTemplate> prototype);
|
v8::Local<v8::FunctionTemplate> prototype);
|
||||||
|
|
||||||
v8::Local<v8::Promise> StartLogging(base::FilePath log_path,
|
v8::Local<v8::Promise> StartLogging(base::FilePath log_path,
|
||||||
mate::Arguments* args);
|
gin_helper::Arguments* args);
|
||||||
v8::Local<v8::Promise> StopLogging(mate::Arguments* args);
|
v8::Local<v8::Promise> StopLogging(gin_helper::Arguments* args);
|
||||||
bool IsCurrentlyLogging() const;
|
bool IsCurrentlyLogging() const;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
|
@ -6,7 +6,6 @@
|
||||||
|
|
||||||
#include "base/guid.h"
|
#include "base/guid.h"
|
||||||
#include "base/strings/utf_string_conversions.h"
|
#include "base/strings/utf_string_conversions.h"
|
||||||
#include "native_mate/constructor.h"
|
|
||||||
#include "shell/browser/api/atom_api_menu.h"
|
#include "shell/browser/api/atom_api_menu.h"
|
||||||
#include "shell/browser/atom_browser_client.h"
|
#include "shell/browser/atom_browser_client.h"
|
||||||
#include "shell/browser/browser.h"
|
#include "shell/browser/browser.h"
|
||||||
|
|
|
@ -10,11 +10,11 @@
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "base/strings/utf_string_conversions.h"
|
#include "base/strings/utf_string_conversions.h"
|
||||||
#include "shell/browser/api/trackable_object.h"
|
|
||||||
#include "shell/browser/notifications/notification.h"
|
#include "shell/browser/notifications/notification.h"
|
||||||
#include "shell/browser/notifications/notification_delegate.h"
|
#include "shell/browser/notifications/notification_delegate.h"
|
||||||
#include "shell/browser/notifications/notification_presenter.h"
|
#include "shell/browser/notifications/notification_presenter.h"
|
||||||
#include "shell/common/gin_helper/error_thrower.h"
|
#include "shell/common/gin_helper/error_thrower.h"
|
||||||
|
#include "shell/common/gin_helper/trackable_object.h"
|
||||||
#include "ui/gfx/image/image.h"
|
#include "ui/gfx/image/image.h"
|
||||||
|
|
||||||
namespace gin {
|
namespace gin {
|
||||||
|
@ -25,7 +25,7 @@ namespace electron {
|
||||||
|
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
class Notification : public mate::TrackableObject<Notification>,
|
class Notification : public gin_helper::TrackableObject<Notification>,
|
||||||
public NotificationDelegate {
|
public NotificationDelegate {
|
||||||
public:
|
public:
|
||||||
static mate::WrappableBase* New(gin_helper::ErrorThrower thrower,
|
static mate::WrappableBase* New(gin_helper::ErrorThrower thrower,
|
||||||
|
|
|
@ -7,29 +7,33 @@
|
||||||
#include "base/power_monitor/power_monitor.h"
|
#include "base/power_monitor/power_monitor.h"
|
||||||
#include "base/power_monitor/power_monitor_device_source.h"
|
#include "base/power_monitor/power_monitor_device_source.h"
|
||||||
#include "gin/dictionary.h"
|
#include "gin/dictionary.h"
|
||||||
|
#include "gin/handle.h"
|
||||||
#include "shell/browser/browser.h"
|
#include "shell/browser/browser.h"
|
||||||
#include "shell/common/gin_converters/callback_converter.h"
|
#include "shell/common/gin_converters/callback_converter.h"
|
||||||
|
#include "shell/common/gin_helper/object_template_builder.h"
|
||||||
#include "shell/common/node_includes.h"
|
#include "shell/common/node_includes.h"
|
||||||
|
|
||||||
namespace mate {
|
namespace gin {
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct Converter<ui::IdleState> {
|
struct Converter<ui::IdleState> {
|
||||||
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate,
|
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate,
|
||||||
const ui::IdleState& in) {
|
const ui::IdleState& in) {
|
||||||
switch (in) {
|
switch (in) {
|
||||||
case ui::IDLE_STATE_ACTIVE:
|
case ui::IDLE_STATE_ACTIVE:
|
||||||
return mate::StringToV8(isolate, "active");
|
return StringToV8(isolate, "active");
|
||||||
case ui::IDLE_STATE_IDLE:
|
case ui::IDLE_STATE_IDLE:
|
||||||
return mate::StringToV8(isolate, "idle");
|
return StringToV8(isolate, "idle");
|
||||||
case ui::IDLE_STATE_LOCKED:
|
case ui::IDLE_STATE_LOCKED:
|
||||||
return mate::StringToV8(isolate, "locked");
|
return StringToV8(isolate, "locked");
|
||||||
case ui::IDLE_STATE_UNKNOWN:
|
case ui::IDLE_STATE_UNKNOWN:
|
||||||
default:
|
default:
|
||||||
return mate::StringToV8(isolate, "unknown");
|
return StringToV8(isolate, "unknown");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
} // namespace mate
|
|
||||||
|
} // namespace gin
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
|
||||||
|
@ -88,7 +92,7 @@ ui::IdleState PowerMonitor::GetSystemIdleState(v8::Isolate* isolate,
|
||||||
if (idle_threshold > 0) {
|
if (idle_threshold > 0) {
|
||||||
return ui::CalculateIdleState(idle_threshold);
|
return ui::CalculateIdleState(idle_threshold);
|
||||||
} else {
|
} else {
|
||||||
isolate->ThrowException(v8::Exception::TypeError(mate::StringToV8(
|
isolate->ThrowException(v8::Exception::TypeError(gin::StringToV8(
|
||||||
isolate, "Invalid idle threshold, must be greater than 0")));
|
isolate, "Invalid idle threshold, must be greater than 0")));
|
||||||
return ui::IDLE_STATE_UNKNOWN;
|
return ui::IDLE_STATE_UNKNOWN;
|
||||||
}
|
}
|
||||||
|
@ -102,21 +106,21 @@ int PowerMonitor::GetSystemIdleTime() {
|
||||||
v8::Local<v8::Value> PowerMonitor::Create(v8::Isolate* isolate) {
|
v8::Local<v8::Value> PowerMonitor::Create(v8::Isolate* isolate) {
|
||||||
if (!Browser::Get()->is_ready()) {
|
if (!Browser::Get()->is_ready()) {
|
||||||
isolate->ThrowException(v8::Exception::Error(
|
isolate->ThrowException(v8::Exception::Error(
|
||||||
mate::StringToV8(isolate,
|
gin::StringToV8(isolate,
|
||||||
"The 'powerMonitor' module can't be used before the "
|
"The 'powerMonitor' module can't be used before the "
|
||||||
"app 'ready' event")));
|
"app 'ready' event")));
|
||||||
return v8::Null(isolate);
|
return v8::Null(isolate);
|
||||||
}
|
}
|
||||||
|
|
||||||
return mate::CreateHandle(isolate, new PowerMonitor(isolate)).ToV8();
|
return gin::CreateHandle(isolate, new PowerMonitor(isolate)).ToV8();
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void PowerMonitor::BuildPrototype(v8::Isolate* isolate,
|
void PowerMonitor::BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::FunctionTemplate> prototype) {
|
v8::Local<v8::FunctionTemplate> prototype) {
|
||||||
prototype->SetClassName(mate::StringToV8(isolate, "PowerMonitor"));
|
prototype->SetClassName(gin::StringToV8(isolate, "PowerMonitor"));
|
||||||
gin_helper::Destroyable::MakeDestroyable(isolate, prototype);
|
gin_helper::Destroyable::MakeDestroyable(isolate, prototype);
|
||||||
mate::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
gin_helper::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
||||||
#if defined(OS_LINUX)
|
#if defined(OS_LINUX)
|
||||||
.SetMethod("blockShutdown", &PowerMonitor::BlockShutdown)
|
.SetMethod("blockShutdown", &PowerMonitor::BlockShutdown)
|
||||||
.SetMethod("unblockShutdown", &PowerMonitor::UnblockShutdown)
|
.SetMethod("unblockShutdown", &PowerMonitor::UnblockShutdown)
|
||||||
|
|
|
@ -6,16 +6,15 @@
|
||||||
#define SHELL_BROWSER_API_ATOM_API_POWER_MONITOR_H_
|
#define SHELL_BROWSER_API_ATOM_API_POWER_MONITOR_H_
|
||||||
|
|
||||||
#include "base/compiler_specific.h"
|
#include "base/compiler_specific.h"
|
||||||
#include "native_mate/handle.h"
|
|
||||||
#include "shell/browser/api/trackable_object.h"
|
|
||||||
#include "shell/browser/lib/power_observer.h"
|
#include "shell/browser/lib/power_observer.h"
|
||||||
|
#include "shell/common/gin_helper/trackable_object.h"
|
||||||
#include "ui/base/idle/idle.h"
|
#include "ui/base/idle/idle.h"
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
class PowerMonitor : public mate::TrackableObject<PowerMonitor>,
|
class PowerMonitor : public gin_helper::TrackableObject<PowerMonitor>,
|
||||||
public PowerObserver {
|
public PowerObserver {
|
||||||
public:
|
public:
|
||||||
static v8::Local<v8::Value> Create(v8::Isolate* isolate);
|
static v8::Local<v8::Value> Create(v8::Isolate* isolate);
|
||||||
|
|
|
@ -10,9 +10,9 @@
|
||||||
|
|
||||||
#include "content/public/browser/content_browser_client.h"
|
#include "content/public/browser/content_browser_client.h"
|
||||||
#include "gin/handle.h"
|
#include "gin/handle.h"
|
||||||
#include "shell/browser/api/trackable_object.h"
|
|
||||||
#include "shell/browser/net/atom_url_loader_factory.h"
|
#include "shell/browser/net/atom_url_loader_factory.h"
|
||||||
#include "shell/common/gin_helper/dictionary.h"
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
|
#include "shell/common/gin_helper/trackable_object.h"
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
|
||||||
|
@ -35,7 +35,7 @@ enum class ProtocolError {
|
||||||
};
|
};
|
||||||
|
|
||||||
// Protocol implementation based on network services.
|
// Protocol implementation based on network services.
|
||||||
class Protocol : public mate::TrackableObject<Protocol> {
|
class Protocol : public gin_helper::TrackableObject<Protocol> {
|
||||||
public:
|
public:
|
||||||
static gin::Handle<Protocol> Create(v8::Isolate* isolate,
|
static gin::Handle<Protocol> Create(v8::Isolate* isolate,
|
||||||
AtomBrowserContext* browser_context);
|
AtomBrowserContext* browser_context);
|
||||||
|
|
|
@ -7,7 +7,6 @@
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "native_mate/wrappable.h"
|
|
||||||
#include "shell/common/gin_helper/error_thrower.h"
|
#include "shell/common/gin_helper/error_thrower.h"
|
||||||
#include "shell/common/gin_helper/event_emitter.h"
|
#include "shell/common/gin_helper/event_emitter.h"
|
||||||
#include "ui/display/display_observer.h"
|
#include "ui/display/display_observer.h"
|
||||||
|
@ -23,7 +22,7 @@ namespace electron {
|
||||||
|
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
class Screen : public gin_helper::EventEmitter<mate::Wrappable<Screen>>,
|
class Screen : public gin_helper::EventEmitter<Screen>,
|
||||||
public display::DisplayObserver {
|
public display::DisplayObserver {
|
||||||
public:
|
public:
|
||||||
static v8::Local<v8::Value> Create(gin_helper::ErrorThrower error_thrower);
|
static v8::Local<v8::Value> Create(gin_helper::ErrorThrower error_thrower);
|
||||||
|
|
|
@ -32,8 +32,6 @@
|
||||||
#include "content/public/browser/storage_partition.h"
|
#include "content/public/browser/storage_partition.h"
|
||||||
#include "mojo/public/cpp/bindings/pending_remote.h"
|
#include "mojo/public/cpp/bindings/pending_remote.h"
|
||||||
#include "mojo/public/cpp/bindings/self_owned_receiver.h"
|
#include "mojo/public/cpp/bindings/self_owned_receiver.h"
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "native_mate/object_template_builder_deprecated.h"
|
|
||||||
#include "net/base/completion_repeating_callback.h"
|
#include "net/base/completion_repeating_callback.h"
|
||||||
#include "net/base/load_flags.h"
|
#include "net/base/load_flags.h"
|
||||||
#include "net/http/http_auth_handler_factory.h"
|
#include "net/http/http_auth_handler_factory.h"
|
||||||
|
@ -54,13 +52,14 @@
|
||||||
#include "shell/browser/media/media_device_id_salt.h"
|
#include "shell/browser/media/media_device_id_salt.h"
|
||||||
#include "shell/browser/net/cert_verifier_client.h"
|
#include "shell/browser/net/cert_verifier_client.h"
|
||||||
#include "shell/browser/session_preferences.h"
|
#include "shell/browser/session_preferences.h"
|
||||||
#include "shell/common/native_mate_converters/callback_converter_deprecated.h"
|
#include "shell/common/gin_converters/callback_converter.h"
|
||||||
#include "shell/common/native_mate_converters/content_converter.h"
|
#include "shell/common/gin_converters/content_converter.h"
|
||||||
#include "shell/common/native_mate_converters/file_path_converter.h"
|
#include "shell/common/gin_converters/file_path_converter.h"
|
||||||
#include "shell/common/native_mate_converters/gurl_converter.h"
|
#include "shell/common/gin_converters/gurl_converter.h"
|
||||||
#include "shell/common/native_mate_converters/net_converter.h"
|
#include "shell/common/gin_converters/net_converter.h"
|
||||||
#include "shell/common/native_mate_converters/once_callback.h"
|
#include "shell/common/gin_converters/value_converter_gin_adapter.h"
|
||||||
#include "shell/common/native_mate_converters/value_converter.h"
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
|
#include "shell/common/gin_helper/object_template_builder.h"
|
||||||
#include "shell/common/node_includes.h"
|
#include "shell/common/node_includes.h"
|
||||||
#include "shell/common/options_switches.h"
|
#include "shell/common/options_switches.h"
|
||||||
#include "ui/base/l10n/l10n_util.h"
|
#include "ui/base/l10n/l10n_util.h"
|
||||||
|
@ -122,14 +121,14 @@ uint32_t GetQuotaMask(const std::vector<std::string>& quota_types) {
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
namespace mate {
|
namespace gin {
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct Converter<ClearStorageDataOptions> {
|
struct Converter<ClearStorageDataOptions> {
|
||||||
static bool FromV8(v8::Isolate* isolate,
|
static bool FromV8(v8::Isolate* isolate,
|
||||||
v8::Local<v8::Value> val,
|
v8::Local<v8::Value> val,
|
||||||
ClearStorageDataOptions* out) {
|
ClearStorageDataOptions* out) {
|
||||||
mate::Dictionary options;
|
gin_helper::Dictionary options;
|
||||||
if (!ConvertFromV8(isolate, val, &options))
|
if (!ConvertFromV8(isolate, val, &options))
|
||||||
return false;
|
return false;
|
||||||
options.Get("origin", &out->origin);
|
options.Get("origin", &out->origin);
|
||||||
|
@ -142,7 +141,7 @@ struct Converter<ClearStorageDataOptions> {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace mate
|
} // namespace gin
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
|
||||||
|
@ -153,7 +152,7 @@ namespace {
|
||||||
const char kPersistPrefix[] = "persist:";
|
const char kPersistPrefix[] = "persist:";
|
||||||
|
|
||||||
// Referenced session objects.
|
// Referenced session objects.
|
||||||
std::map<uint32_t, v8::Global<v8::Object>> g_sessions;
|
std::map<uint32_t, v8::Global<v8::Value>> g_sessions;
|
||||||
|
|
||||||
void DownloadIdCallback(content::DownloadManager* download_manager,
|
void DownloadIdCallback(content::DownloadManager* download_manager,
|
||||||
const base::FilePath& path,
|
const base::FilePath& path,
|
||||||
|
@ -239,7 +238,7 @@ void Session::OnDownloadCreated(content::DownloadManager* manager,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
v8::Local<v8::Promise> Session::ResolveProxy(mate::Arguments* args) {
|
v8::Local<v8::Promise> Session::ResolveProxy(gin_helper::Arguments* args) {
|
||||||
v8::Isolate* isolate = args->isolate();
|
v8::Isolate* isolate = args->isolate();
|
||||||
util::Promise<std::string> promise(isolate);
|
util::Promise<std::string> promise(isolate);
|
||||||
v8::Local<v8::Promise> handle = promise.GetHandle();
|
v8::Local<v8::Promise> handle = promise.GetHandle();
|
||||||
|
@ -292,7 +291,7 @@ v8::Local<v8::Promise> Session::ClearCache() {
|
||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
v8::Local<v8::Promise> Session::ClearStorageData(mate::Arguments* args) {
|
v8::Local<v8::Promise> Session::ClearStorageData(gin_helper::Arguments* args) {
|
||||||
v8::Isolate* isolate = args->isolate();
|
v8::Isolate* isolate = args->isolate();
|
||||||
util::Promise<void*> promise(isolate);
|
util::Promise<void*> promise(isolate);
|
||||||
v8::Local<v8::Promise> handle = promise.GetHandle();
|
v8::Local<v8::Promise> handle = promise.GetHandle();
|
||||||
|
@ -322,12 +321,12 @@ void Session::FlushStorageData() {
|
||||||
storage_partition->Flush();
|
storage_partition->Flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
v8::Local<v8::Promise> Session::SetProxy(mate::Arguments* args) {
|
v8::Local<v8::Promise> Session::SetProxy(gin_helper::Arguments* args) {
|
||||||
v8::Isolate* isolate = args->isolate();
|
v8::Isolate* isolate = args->isolate();
|
||||||
util::Promise<void*> promise(isolate);
|
util::Promise<void*> promise(isolate);
|
||||||
v8::Local<v8::Promise> handle = promise.GetHandle();
|
v8::Local<v8::Promise> handle = promise.GetHandle();
|
||||||
|
|
||||||
mate::Dictionary options;
|
gin_helper::Dictionary options;
|
||||||
args->GetNext(&options);
|
args->GetNext(&options);
|
||||||
|
|
||||||
if (!browser_context_->in_memory_pref_store()) {
|
if (!browser_context_->in_memory_pref_store()) {
|
||||||
|
@ -368,7 +367,7 @@ void Session::SetDownloadPath(const base::FilePath& path) {
|
||||||
path);
|
path);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::EnableNetworkEmulation(const mate::Dictionary& options) {
|
void Session::EnableNetworkEmulation(const gin_helper::Dictionary& options) {
|
||||||
auto conditions = network::mojom::NetworkConditions::New();
|
auto conditions = network::mojom::NetworkConditions::New();
|
||||||
|
|
||||||
options.Get("offline", &conditions->offline);
|
options.Get("offline", &conditions->offline);
|
||||||
|
@ -395,9 +394,9 @@ void Session::DisableNetworkEmulation() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::SetCertVerifyProc(v8::Local<v8::Value> val,
|
void Session::SetCertVerifyProc(v8::Local<v8::Value> val,
|
||||||
mate::Arguments* args) {
|
gin_helper::Arguments* args) {
|
||||||
CertVerifierClient::CertVerifyProc proc;
|
CertVerifierClient::CertVerifyProc proc;
|
||||||
if (!(val->IsNull() || mate::ConvertFromV8(args->isolate(), val, &proc))) {
|
if (!(val->IsNull() || gin::ConvertFromV8(args->isolate(), val, &proc))) {
|
||||||
args->ThrowError("Must pass null or function");
|
args->ThrowError("Must pass null or function");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -418,7 +417,7 @@ void Session::SetCertVerifyProc(v8::Local<v8::Value> val,
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::SetPermissionRequestHandler(v8::Local<v8::Value> val,
|
void Session::SetPermissionRequestHandler(v8::Local<v8::Value> val,
|
||||||
mate::Arguments* args) {
|
gin_helper::Arguments* args) {
|
||||||
auto* permission_manager = static_cast<AtomPermissionManager*>(
|
auto* permission_manager = static_cast<AtomPermissionManager*>(
|
||||||
browser_context()->GetPermissionControllerDelegate());
|
browser_context()->GetPermissionControllerDelegate());
|
||||||
if (val->IsNull()) {
|
if (val->IsNull()) {
|
||||||
|
@ -427,7 +426,7 @@ void Session::SetPermissionRequestHandler(v8::Local<v8::Value> val,
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
auto handler = std::make_unique<AtomPermissionManager::RequestHandler>();
|
auto handler = std::make_unique<AtomPermissionManager::RequestHandler>();
|
||||||
if (!mate::ConvertFromV8(args->isolate(), val, handler.get())) {
|
if (!gin::ConvertFromV8(args->isolate(), val, handler.get())) {
|
||||||
args->ThrowError("Must pass null or function");
|
args->ThrowError("Must pass null or function");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -445,9 +444,9 @@ void Session::SetPermissionRequestHandler(v8::Local<v8::Value> val,
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::SetPermissionCheckHandler(v8::Local<v8::Value> val,
|
void Session::SetPermissionCheckHandler(v8::Local<v8::Value> val,
|
||||||
mate::Arguments* args) {
|
gin_helper::Arguments* args) {
|
||||||
AtomPermissionManager::CheckHandler handler;
|
AtomPermissionManager::CheckHandler handler;
|
||||||
if (!(val->IsNull() || mate::ConvertFromV8(args->isolate(), val, &handler))) {
|
if (!(val->IsNull() || gin::ConvertFromV8(args->isolate(), val, &handler))) {
|
||||||
args->ThrowError("Must pass null or function");
|
args->ThrowError("Must pass null or function");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -456,7 +455,8 @@ void Session::SetPermissionCheckHandler(v8::Local<v8::Value> val,
|
||||||
permission_manager->SetPermissionCheckHandler(handler);
|
permission_manager->SetPermissionCheckHandler(handler);
|
||||||
}
|
}
|
||||||
|
|
||||||
v8::Local<v8::Promise> Session::ClearHostResolverCache(mate::Arguments* args) {
|
v8::Local<v8::Promise> Session::ClearHostResolverCache(
|
||||||
|
gin_helper::Arguments* args) {
|
||||||
v8::Isolate* isolate = args->isolate();
|
v8::Isolate* isolate = args->isolate();
|
||||||
util::Promise<void*> promise(isolate);
|
util::Promise<void*> promise(isolate);
|
||||||
v8::Local<v8::Promise> handle = promise.GetHandle();
|
v8::Local<v8::Promise> handle = promise.GetHandle();
|
||||||
|
@ -494,7 +494,7 @@ void Session::AllowNTLMCredentialsForDomains(const std::string& domains) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::SetUserAgent(const std::string& user_agent,
|
void Session::SetUserAgent(const std::string& user_agent,
|
||||||
mate::Arguments* args) {
|
gin_helper::Arguments* args) {
|
||||||
browser_context_->SetUserAgent(user_agent);
|
browser_context_->SetUserAgent(user_agent);
|
||||||
content::BrowserContext::GetDefaultStoragePartition(browser_context_.get())
|
content::BrowserContext::GetDefaultStoragePartition(browser_context_.get())
|
||||||
->GetNetworkContext()
|
->GetNetworkContext()
|
||||||
|
@ -525,7 +525,7 @@ void Session::DownloadURL(const GURL& url) {
|
||||||
download_manager->DownloadUrl(std::move(download_params));
|
download_manager->DownloadUrl(std::move(download_params));
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::CreateInterruptedDownload(const mate::Dictionary& options) {
|
void Session::CreateInterruptedDownload(const gin_helper::Dictionary& options) {
|
||||||
int64_t offset = 0, length = 0;
|
int64_t offset = 0, length = 0;
|
||||||
double start_time = base::Time::Now().ToDoubleT();
|
double start_time = base::Time::Now().ToDoubleT();
|
||||||
std::string mime_type, last_modified, etag;
|
std::string mime_type, last_modified, etag;
|
||||||
|
@ -540,12 +540,12 @@ void Session::CreateInterruptedDownload(const mate::Dictionary& options) {
|
||||||
options.Get("eTag", &etag);
|
options.Get("eTag", &etag);
|
||||||
options.Get("startTime", &start_time);
|
options.Get("startTime", &start_time);
|
||||||
if (path.empty() || url_chain.empty() || length == 0) {
|
if (path.empty() || url_chain.empty() || length == 0) {
|
||||||
isolate()->ThrowException(v8::Exception::Error(mate::StringToV8(
|
isolate()->ThrowException(v8::Exception::Error(gin::StringToV8(
|
||||||
isolate(), "Must pass non-empty path, urlChain and length.")));
|
isolate(), "Must pass non-empty path, urlChain and length.")));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (offset >= length) {
|
if (offset >= length) {
|
||||||
isolate()->ThrowException(v8::Exception::Error(mate::StringToV8(
|
isolate()->ThrowException(v8::Exception::Error(gin::StringToV8(
|
||||||
isolate(), "Must pass an offset value less than length.")));
|
isolate(), "Must pass an offset value less than length.")));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -619,8 +619,8 @@ static void StartPreconnectOnUI(
|
||||||
browser_context->GetPreconnectManager()->Start(url, requests);
|
browser_context->GetPreconnectManager()->Start(url, requests);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Session::Preconnect(const mate::Dictionary& options,
|
void Session::Preconnect(const gin_helper::Dictionary& options,
|
||||||
mate::Arguments* args) {
|
gin_helper::Arguments* args) {
|
||||||
GURL url;
|
GURL url;
|
||||||
if (!options.Get("url", &url) || !url.is_valid()) {
|
if (!options.Get("url", &url) || !url.is_valid()) {
|
||||||
args->ThrowError("Must pass non-empty valid url to session.preconnect.");
|
args->ThrowError("Must pass non-empty valid url to session.preconnect.");
|
||||||
|
@ -647,25 +647,25 @@ void Session::Preconnect(const mate::Dictionary& options,
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::Handle<Session> Session::CreateFrom(v8::Isolate* isolate,
|
gin::Handle<Session> Session::CreateFrom(v8::Isolate* isolate,
|
||||||
AtomBrowserContext* browser_context) {
|
AtomBrowserContext* browser_context) {
|
||||||
auto* existing = TrackableObject::FromWrappedClass(isolate, browser_context);
|
auto* existing = TrackableObject::FromWrappedClass(isolate, browser_context);
|
||||||
if (existing)
|
if (existing)
|
||||||
return mate::CreateHandle(isolate, static_cast<Session*>(existing));
|
return gin::CreateHandle(isolate, static_cast<Session*>(existing));
|
||||||
|
|
||||||
auto handle =
|
auto handle =
|
||||||
mate::CreateHandle(isolate, new Session(isolate, browser_context));
|
gin::CreateHandle(isolate, new Session(isolate, browser_context));
|
||||||
|
|
||||||
// The Sessions should never be garbage collected, since the common pattern is
|
// The Sessions should never be garbage collected, since the common pattern is
|
||||||
// to use partition strings, instead of using the Session object directly.
|
// to use partition strings, instead of using the Session object directly.
|
||||||
g_sessions[handle->weak_map_id()] =
|
g_sessions[handle->weak_map_id()] =
|
||||||
v8::Global<v8::Object>(isolate, handle.ToV8());
|
v8::Global<v8::Value>(isolate, handle.ToV8());
|
||||||
|
|
||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::Handle<Session> Session::FromPartition(
|
gin::Handle<Session> Session::FromPartition(
|
||||||
v8::Isolate* isolate,
|
v8::Isolate* isolate,
|
||||||
const std::string& partition,
|
const std::string& partition,
|
||||||
const base::DictionaryValue& options) {
|
const base::DictionaryValue& options) {
|
||||||
|
@ -685,9 +685,9 @@ mate::Handle<Session> Session::FromPartition(
|
||||||
// static
|
// static
|
||||||
void Session::BuildPrototype(v8::Isolate* isolate,
|
void Session::BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::FunctionTemplate> prototype) {
|
v8::Local<v8::FunctionTemplate> prototype) {
|
||||||
prototype->SetClassName(mate::StringToV8(isolate, "Session"));
|
prototype->SetClassName(gin::StringToV8(isolate, "Session"));
|
||||||
gin_helper::Destroyable::MakeDestroyable(isolate, prototype);
|
gin_helper::Destroyable::MakeDestroyable(isolate, prototype);
|
||||||
mate::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
gin_helper::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
||||||
.SetMethod("resolveProxy", &Session::ResolveProxy)
|
.SetMethod("resolveProxy", &Session::ResolveProxy)
|
||||||
.SetMethod("getCacheSize", &Session::GetCacheSize)
|
.SetMethod("getCacheSize", &Session::GetCacheSize)
|
||||||
.SetMethod("clearCache", &Session::ClearCache)
|
.SetMethod("clearCache", &Session::ClearCache)
|
||||||
|
@ -736,7 +736,7 @@ using electron::api::Protocol;
|
||||||
using electron::api::Session;
|
using electron::api::Session;
|
||||||
|
|
||||||
v8::Local<v8::Value> FromPartition(const std::string& partition,
|
v8::Local<v8::Value> FromPartition(const std::string& partition,
|
||||||
mate::Arguments* args) {
|
gin_helper::Arguments* args) {
|
||||||
if (!electron::Browser::Get()->is_ready()) {
|
if (!electron::Browser::Get()->is_ready()) {
|
||||||
args->ThrowError("Session can only be received when app is ready");
|
args->ThrowError("Session can only be received when app is ready");
|
||||||
return v8::Null(args->isolate());
|
return v8::Null(args->isolate());
|
||||||
|
@ -751,7 +751,7 @@ void Initialize(v8::Local<v8::Object> exports,
|
||||||
v8::Local<v8::Context> context,
|
v8::Local<v8::Context> context,
|
||||||
void* priv) {
|
void* priv) {
|
||||||
v8::Isolate* isolate = context->GetIsolate();
|
v8::Isolate* isolate = context->GetIsolate();
|
||||||
mate::Dictionary dict(isolate, exports);
|
gin_helper::Dictionary dict(isolate, exports);
|
||||||
dict.Set(
|
dict.Set(
|
||||||
"Session",
|
"Session",
|
||||||
Session::GetConstructor(isolate)->GetFunction(context).ToLocalChecked());
|
Session::GetConstructor(isolate)->GetFunction(context).ToLocalChecked());
|
||||||
|
|
|
@ -11,9 +11,9 @@
|
||||||
#include "base/values.h"
|
#include "base/values.h"
|
||||||
#include "content/public/browser/download_manager.h"
|
#include "content/public/browser/download_manager.h"
|
||||||
#include "electron/buildflags/buildflags.h"
|
#include "electron/buildflags/buildflags.h"
|
||||||
#include "native_mate/handle.h"
|
#include "gin/handle.h"
|
||||||
#include "shell/browser/api/trackable_object.h"
|
|
||||||
#include "shell/browser/net/resolve_proxy_helper.h"
|
#include "shell/browser/net/resolve_proxy_helper.h"
|
||||||
|
#include "shell/common/gin_helper/trackable_object.h"
|
||||||
#include "shell/common/promise_util.h"
|
#include "shell/common/promise_util.h"
|
||||||
|
|
||||||
class GURL;
|
class GURL;
|
||||||
|
@ -22,10 +22,9 @@ namespace base {
|
||||||
class FilePath;
|
class FilePath;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace mate {
|
namespace gin_helper {
|
||||||
class Arguments;
|
|
||||||
class Dictionary;
|
class Dictionary;
|
||||||
} // namespace mate
|
}
|
||||||
|
|
||||||
namespace net {
|
namespace net {
|
||||||
class ProxyConfig;
|
class ProxyConfig;
|
||||||
|
@ -37,56 +36,58 @@ class AtomBrowserContext;
|
||||||
|
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
class Session : public mate::TrackableObject<Session>,
|
class Session : public gin_helper::TrackableObject<Session>,
|
||||||
public content::DownloadManager::Observer {
|
public content::DownloadManager::Observer {
|
||||||
public:
|
public:
|
||||||
// Gets or creates Session from the |browser_context|.
|
// Gets or creates Session from the |browser_context|.
|
||||||
static mate::Handle<Session> CreateFrom(v8::Isolate* isolate,
|
static gin::Handle<Session> CreateFrom(v8::Isolate* isolate,
|
||||||
AtomBrowserContext* browser_context);
|
AtomBrowserContext* browser_context);
|
||||||
|
|
||||||
// Gets the Session of |partition|.
|
// Gets the Session of |partition|.
|
||||||
static mate::Handle<Session> FromPartition(
|
static gin::Handle<Session> FromPartition(
|
||||||
v8::Isolate* isolate,
|
v8::Isolate* isolate,
|
||||||
const std::string& partition,
|
const std::string& partition,
|
||||||
const base::DictionaryValue& options = base::DictionaryValue());
|
const base::DictionaryValue& options = base::DictionaryValue());
|
||||||
|
|
||||||
AtomBrowserContext* browser_context() const { return browser_context_.get(); }
|
AtomBrowserContext* browser_context() const { return browser_context_.get(); }
|
||||||
|
|
||||||
// mate::TrackableObject:
|
// gin_helper::TrackableObject:
|
||||||
static void BuildPrototype(v8::Isolate* isolate,
|
static void BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::FunctionTemplate> prototype);
|
v8::Local<v8::FunctionTemplate> prototype);
|
||||||
|
|
||||||
// Methods.
|
// Methods.
|
||||||
v8::Local<v8::Promise> ResolveProxy(mate::Arguments* args);
|
v8::Local<v8::Promise> ResolveProxy(gin_helper::Arguments* args);
|
||||||
v8::Local<v8::Promise> GetCacheSize();
|
v8::Local<v8::Promise> GetCacheSize();
|
||||||
v8::Local<v8::Promise> ClearCache();
|
v8::Local<v8::Promise> ClearCache();
|
||||||
v8::Local<v8::Promise> ClearStorageData(mate::Arguments* args);
|
v8::Local<v8::Promise> ClearStorageData(gin_helper::Arguments* args);
|
||||||
void FlushStorageData();
|
void FlushStorageData();
|
||||||
v8::Local<v8::Promise> SetProxy(mate::Arguments* args);
|
v8::Local<v8::Promise> SetProxy(gin_helper::Arguments* args);
|
||||||
void SetDownloadPath(const base::FilePath& path);
|
void SetDownloadPath(const base::FilePath& path);
|
||||||
void EnableNetworkEmulation(const mate::Dictionary& options);
|
void EnableNetworkEmulation(const gin_helper::Dictionary& options);
|
||||||
void DisableNetworkEmulation();
|
void DisableNetworkEmulation();
|
||||||
void SetCertVerifyProc(v8::Local<v8::Value> proc, mate::Arguments* args);
|
void SetCertVerifyProc(v8::Local<v8::Value> proc,
|
||||||
|
gin_helper::Arguments* args);
|
||||||
void SetPermissionRequestHandler(v8::Local<v8::Value> val,
|
void SetPermissionRequestHandler(v8::Local<v8::Value> val,
|
||||||
mate::Arguments* args);
|
gin_helper::Arguments* args);
|
||||||
void SetPermissionCheckHandler(v8::Local<v8::Value> val,
|
void SetPermissionCheckHandler(v8::Local<v8::Value> val,
|
||||||
mate::Arguments* args);
|
gin_helper::Arguments* args);
|
||||||
v8::Local<v8::Promise> ClearHostResolverCache(mate::Arguments* args);
|
v8::Local<v8::Promise> ClearHostResolverCache(gin_helper::Arguments* args);
|
||||||
v8::Local<v8::Promise> ClearAuthCache();
|
v8::Local<v8::Promise> ClearAuthCache();
|
||||||
void AllowNTLMCredentialsForDomains(const std::string& domains);
|
void AllowNTLMCredentialsForDomains(const std::string& domains);
|
||||||
void SetUserAgent(const std::string& user_agent, mate::Arguments* args);
|
void SetUserAgent(const std::string& user_agent, gin_helper::Arguments* args);
|
||||||
std::string GetUserAgent();
|
std::string GetUserAgent();
|
||||||
v8::Local<v8::Promise> GetBlobData(v8::Isolate* isolate,
|
v8::Local<v8::Promise> GetBlobData(v8::Isolate* isolate,
|
||||||
const std::string& uuid);
|
const std::string& uuid);
|
||||||
void DownloadURL(const GURL& url);
|
void DownloadURL(const GURL& url);
|
||||||
void CreateInterruptedDownload(const mate::Dictionary& options);
|
void CreateInterruptedDownload(const gin_helper::Dictionary& options);
|
||||||
void SetPreloads(const std::vector<base::FilePath::StringType>& preloads);
|
void SetPreloads(const std::vector<base::FilePath::StringType>& preloads);
|
||||||
std::vector<base::FilePath::StringType> GetPreloads() const;
|
std::vector<base::FilePath::StringType> GetPreloads() const;
|
||||||
v8::Local<v8::Value> Cookies(v8::Isolate* isolate);
|
v8::Local<v8::Value> Cookies(v8::Isolate* isolate);
|
||||||
v8::Local<v8::Value> Protocol(v8::Isolate* isolate);
|
v8::Local<v8::Value> Protocol(v8::Isolate* isolate);
|
||||||
v8::Local<v8::Value> WebRequest(v8::Isolate* isolate);
|
v8::Local<v8::Value> WebRequest(v8::Isolate* isolate);
|
||||||
v8::Local<v8::Value> NetLog(v8::Isolate* isolate);
|
v8::Local<v8::Value> NetLog(v8::Isolate* isolate);
|
||||||
void Preconnect(const mate::Dictionary& options, mate::Arguments* args);
|
void Preconnect(const gin_helper::Dictionary& options,
|
||||||
|
gin_helper::Arguments* args);
|
||||||
|
|
||||||
#if BUILDFLAG(ENABLE_ELECTRON_EXTENSIONS)
|
#if BUILDFLAG(ENABLE_ELECTRON_EXTENSIONS)
|
||||||
void LoadChromeExtension(const base::FilePath extension_path);
|
void LoadChromeExtension(const base::FilePath extension_path);
|
||||||
|
|
|
@ -9,7 +9,6 @@
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include "gin/handle.h"
|
#include "gin/handle.h"
|
||||||
#include "native_mate/wrappable.h"
|
|
||||||
#include "shell/common/gin_helper/error_thrower.h"
|
#include "shell/common/gin_helper/error_thrower.h"
|
||||||
#include "shell/common/gin_helper/event_emitter.h"
|
#include "shell/common/gin_helper/event_emitter.h"
|
||||||
#include "shell/common/promise_util.h"
|
#include "shell/common/promise_util.h"
|
||||||
|
@ -36,12 +35,11 @@ enum NotificationCenterKind {
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
class SystemPreferences
|
class SystemPreferences : public gin_helper::EventEmitter<SystemPreferences>
|
||||||
: public gin_helper::EventEmitter<mate::Wrappable<SystemPreferences>>
|
|
||||||
#if defined(OS_WIN)
|
#if defined(OS_WIN)
|
||||||
,
|
,
|
||||||
public BrowserObserver,
|
public BrowserObserver,
|
||||||
public gfx::SysColorChangeListener
|
public gfx::SysColorChangeListener
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -74,10 +74,10 @@ v8::Local<v8::Value> ToBuffer(v8::Isolate* isolate, void* val, int size) {
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
TopLevelWindow::TopLevelWindow(v8::Isolate* isolate,
|
TopLevelWindow::TopLevelWindow(v8::Isolate* isolate,
|
||||||
const mate::Dictionary& options)
|
const gin_helper::Dictionary& options)
|
||||||
: weak_factory_(this) {
|
: weak_factory_(this) {
|
||||||
// The parent window.
|
// The parent window.
|
||||||
mate::Handle<TopLevelWindow> parent;
|
gin::Handle<TopLevelWindow> parent;
|
||||||
if (options.Get("parent", &parent) && !parent.IsEmpty())
|
if (options.Get("parent", &parent) && !parent.IsEmpty())
|
||||||
parent_window_.Reset(isolate, parent.ToV8());
|
parent_window_.Reset(isolate, parent.ToV8());
|
||||||
|
|
||||||
|
@ -98,14 +98,14 @@ TopLevelWindow::TopLevelWindow(v8::Isolate* isolate,
|
||||||
|
|
||||||
#if defined(TOOLKIT_VIEWS)
|
#if defined(TOOLKIT_VIEWS)
|
||||||
// Sets the window icon.
|
// Sets the window icon.
|
||||||
mate::Handle<NativeImage> icon;
|
gin::Handle<NativeImage> icon;
|
||||||
if (options.Get(options::kIcon, &icon) && !icon.IsEmpty())
|
if (options.Get(options::kIcon, &icon) && !icon.IsEmpty())
|
||||||
SetIcon(icon);
|
SetIcon(icon);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
TopLevelWindow::TopLevelWindow(gin_helper::Arguments* args,
|
TopLevelWindow::TopLevelWindow(gin_helper::Arguments* args,
|
||||||
const mate::Dictionary& options)
|
const gin_helper::Dictionary& options)
|
||||||
: TopLevelWindow(args->isolate(), options) {
|
: TopLevelWindow(args->isolate(), options) {
|
||||||
InitWithArgs(args);
|
InitWithArgs(args);
|
||||||
// Init window after everything has been setup.
|
// Init window after everything has been setup.
|
||||||
|
@ -124,15 +124,12 @@ TopLevelWindow::~TopLevelWindow() {
|
||||||
void TopLevelWindow::InitWith(v8::Isolate* isolate,
|
void TopLevelWindow::InitWith(v8::Isolate* isolate,
|
||||||
v8::Local<v8::Object> wrapper) {
|
v8::Local<v8::Object> wrapper) {
|
||||||
AttachAsUserData(window_.get());
|
AttachAsUserData(window_.get());
|
||||||
mate::TrackableObject<
|
gin_helper::TrackableObject<TopLevelWindow>::InitWith(isolate, wrapper);
|
||||||
TopLevelWindow, gin_helper::EventEmitter<
|
|
||||||
mate::Wrappable<TopLevelWindow>>>::InitWith(isolate,
|
|
||||||
wrapper);
|
|
||||||
|
|
||||||
// We can only append this window to parent window's child windows after this
|
// We can only append this window to parent window's child windows after this
|
||||||
// window's JS wrapper gets initialized.
|
// window's JS wrapper gets initialized.
|
||||||
if (!parent_window_.IsEmpty()) {
|
if (!parent_window_.IsEmpty()) {
|
||||||
mate::Handle<TopLevelWindow> parent;
|
gin::Handle<TopLevelWindow> parent;
|
||||||
gin::ConvertFromV8(isolate, GetParentWindow(), &parent);
|
gin::ConvertFromV8(isolate, GetParentWindow(), &parent);
|
||||||
DCHECK(!parent.IsEmpty());
|
DCHECK(!parent.IsEmpty());
|
||||||
parent->child_windows_.Set(isolate, weak_map_id(), wrapper);
|
parent->child_windows_.Set(isolate, weak_map_id(), wrapper);
|
||||||
|
@ -299,7 +296,7 @@ void TopLevelWindow::OnWindowMessage(UINT message,
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void TopLevelWindow::SetContentView(mate::Handle<View> view) {
|
void TopLevelWindow::SetContentView(gin::Handle<View> view) {
|
||||||
ResetBrowserViews();
|
ResetBrowserViews();
|
||||||
content_view_.Reset(isolate(), view.ToV8());
|
content_view_.Reset(isolate(), view.ToV8());
|
||||||
window_->SetContentView(view->view());
|
window_->SetContentView(view->view());
|
||||||
|
@ -676,7 +673,7 @@ void TopLevelWindow::SetFocusable(bool focusable) {
|
||||||
|
|
||||||
void TopLevelWindow::SetMenu(v8::Isolate* isolate, v8::Local<v8::Value> value) {
|
void TopLevelWindow::SetMenu(v8::Isolate* isolate, v8::Local<v8::Value> value) {
|
||||||
auto context = isolate->GetCurrentContext();
|
auto context = isolate->GetCurrentContext();
|
||||||
mate::Handle<Menu> menu;
|
gin::Handle<Menu> menu;
|
||||||
v8::Local<v8::Object> object;
|
v8::Local<v8::Object> object;
|
||||||
if (value->IsObject() && value->ToObject(context).ToLocal(&object) &&
|
if (value->IsObject() && value->ToObject(context).ToLocal(&object) &&
|
||||||
gin::V8ToString(isolate, object->GetConstructorName()) == "Menu" &&
|
gin::V8ToString(isolate, object->GetConstructorName()) == "Menu" &&
|
||||||
|
@ -704,12 +701,12 @@ void TopLevelWindow::SetParentWindow(v8::Local<v8::Value> value,
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
mate::Handle<TopLevelWindow> parent;
|
gin::Handle<TopLevelWindow> parent;
|
||||||
if (value->IsNull() || value->IsUndefined()) {
|
if (value->IsNull() || value->IsUndefined()) {
|
||||||
RemoveFromParentChildWindows();
|
RemoveFromParentChildWindows();
|
||||||
parent_window_.Reset();
|
parent_window_.Reset();
|
||||||
window_->SetParentWindow(nullptr);
|
window_->SetParentWindow(nullptr);
|
||||||
} else if (mate::ConvertFromV8(isolate(), value, &parent)) {
|
} else if (gin::ConvertFromV8(isolate(), value, &parent)) {
|
||||||
RemoveFromParentChildWindows();
|
RemoveFromParentChildWindows();
|
||||||
parent_window_.Reset(isolate(), value);
|
parent_window_.Reset(isolate(), value);
|
||||||
window_->SetParentWindow(parent->window_.get());
|
window_->SetParentWindow(parent->window_.get());
|
||||||
|
@ -725,7 +722,7 @@ void TopLevelWindow::SetBrowserView(v8::Local<v8::Value> value) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void TopLevelWindow::AddBrowserView(v8::Local<v8::Value> value) {
|
void TopLevelWindow::AddBrowserView(v8::Local<v8::Value> value) {
|
||||||
mate::Handle<BrowserView> browser_view;
|
gin::Handle<BrowserView> browser_view;
|
||||||
if (value->IsObject() &&
|
if (value->IsObject() &&
|
||||||
gin::ConvertFromV8(isolate(), value, &browser_view)) {
|
gin::ConvertFromV8(isolate(), value, &browser_view)) {
|
||||||
auto get_that_view = browser_views_.find(browser_view->weak_map_id());
|
auto get_that_view = browser_views_.find(browser_view->weak_map_id());
|
||||||
|
@ -738,7 +735,7 @@ void TopLevelWindow::AddBrowserView(v8::Local<v8::Value> value) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void TopLevelWindow::RemoveBrowserView(v8::Local<v8::Value> value) {
|
void TopLevelWindow::RemoveBrowserView(v8::Local<v8::Value> value) {
|
||||||
mate::Handle<BrowserView> browser_view;
|
gin::Handle<BrowserView> browser_view;
|
||||||
if (value->IsObject() &&
|
if (value->IsObject() &&
|
||||||
gin::ConvertFromV8(isolate(), value, &browser_view)) {
|
gin::ConvertFromV8(isolate(), value, &browser_view)) {
|
||||||
auto get_that_view = browser_views_.find(browser_view->weak_map_id());
|
auto get_that_view = browser_views_.find(browser_view->weak_map_id());
|
||||||
|
@ -960,7 +957,7 @@ bool TopLevelWindow::SetThumbarButtons(gin_helper::Arguments* args) {
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(TOOLKIT_VIEWS)
|
#if defined(TOOLKIT_VIEWS)
|
||||||
void TopLevelWindow::SetIcon(mate::Handle<NativeImage> icon) {
|
void TopLevelWindow::SetIcon(gin::Handle<NativeImage> icon) {
|
||||||
#if defined(OS_WIN)
|
#if defined(OS_WIN)
|
||||||
static_cast<NativeWindowViews*>(window_.get())
|
static_cast<NativeWindowViews*>(window_.get())
|
||||||
->SetIcon(icon->GetHICON(GetSystemMetrics(SM_CXSMICON)),
|
->SetIcon(icon->GetHICON(GetSystemMetrics(SM_CXSMICON)),
|
||||||
|
@ -1028,7 +1025,7 @@ int32_t TopLevelWindow::GetID() const {
|
||||||
|
|
||||||
void TopLevelWindow::ResetBrowserViews() {
|
void TopLevelWindow::ResetBrowserViews() {
|
||||||
for (auto& item : browser_views_) {
|
for (auto& item : browser_views_) {
|
||||||
mate::Handle<BrowserView> browser_view;
|
gin::Handle<BrowserView> browser_view;
|
||||||
if (gin::ConvertFromV8(isolate(),
|
if (gin::ConvertFromV8(isolate(),
|
||||||
v8::Local<v8::Value>::New(isolate(), item.second),
|
v8::Local<v8::Value>::New(isolate(), item.second),
|
||||||
&browser_view) &&
|
&browser_view) &&
|
||||||
|
@ -1047,7 +1044,7 @@ void TopLevelWindow::RemoveFromParentChildWindows() {
|
||||||
if (parent_window_.IsEmpty())
|
if (parent_window_.IsEmpty())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
mate::Handle<TopLevelWindow> parent;
|
gin::Handle<TopLevelWindow> parent;
|
||||||
if (!gin::ConvertFromV8(isolate(), GetParentWindow(), &parent) ||
|
if (!gin::ConvertFromV8(isolate(), GetParentWindow(), &parent) ||
|
||||||
parent.IsEmpty()) {
|
parent.IsEmpty()) {
|
||||||
return;
|
return;
|
||||||
|
@ -1058,7 +1055,8 @@ void TopLevelWindow::RemoveFromParentChildWindows() {
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::WrappableBase* TopLevelWindow::New(gin_helper::Arguments* args) {
|
mate::WrappableBase* TopLevelWindow::New(gin_helper::Arguments* args) {
|
||||||
mate::Dictionary options = mate::Dictionary::CreateEmpty(args->isolate());
|
gin_helper::Dictionary options =
|
||||||
|
gin::Dictionary::CreateEmpty(args->isolate());
|
||||||
args->GetNext(&options);
|
args->GetNext(&options);
|
||||||
|
|
||||||
return new TopLevelWindow(args, options);
|
return new TopLevelWindow(args, options);
|
||||||
|
|
|
@ -13,11 +13,11 @@
|
||||||
#include "base/task/post_task.h"
|
#include "base/task/post_task.h"
|
||||||
#include "content/public/browser/browser_task_traits.h"
|
#include "content/public/browser/browser_task_traits.h"
|
||||||
#include "content/public/browser/browser_thread.h"
|
#include "content/public/browser/browser_thread.h"
|
||||||
#include "shell/browser/api/trackable_object.h"
|
#include "gin/handle.h"
|
||||||
#include "shell/browser/native_window.h"
|
#include "shell/browser/native_window.h"
|
||||||
#include "shell/browser/native_window_observer.h"
|
#include "shell/browser/native_window_observer.h"
|
||||||
#include "shell/common/api/atom_api_native_image.h"
|
#include "shell/common/api/atom_api_native_image.h"
|
||||||
#include "shell/common/gin_helper/event_emitter.h"
|
#include "shell/common/gin_helper/trackable_object.h"
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
|
||||||
|
@ -25,11 +25,8 @@ namespace api {
|
||||||
|
|
||||||
class View;
|
class View;
|
||||||
|
|
||||||
class TopLevelWindow
|
class TopLevelWindow : public gin_helper::TrackableObject<TopLevelWindow>,
|
||||||
: public mate::TrackableObject<
|
public NativeWindowObserver {
|
||||||
TopLevelWindow,
|
|
||||||
gin_helper::EventEmitter<mate::Wrappable<TopLevelWindow>>>,
|
|
||||||
public NativeWindowObserver {
|
|
||||||
public:
|
public:
|
||||||
static mate::WrappableBase* New(gin_helper::Arguments* args);
|
static mate::WrappableBase* New(gin_helper::Arguments* args);
|
||||||
|
|
||||||
|
@ -44,9 +41,10 @@ class TopLevelWindow
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
// Common constructor.
|
// Common constructor.
|
||||||
TopLevelWindow(v8::Isolate* isolate, const mate::Dictionary& options);
|
TopLevelWindow(v8::Isolate* isolate, const gin_helper::Dictionary& options);
|
||||||
// Creating independent TopLevelWindow instance.
|
// Creating independent TopLevelWindow instance.
|
||||||
TopLevelWindow(gin_helper::Arguments* args, const mate::Dictionary& options);
|
TopLevelWindow(gin_helper::Arguments* args,
|
||||||
|
const gin_helper::Dictionary& options);
|
||||||
~TopLevelWindow() override;
|
~TopLevelWindow() override;
|
||||||
|
|
||||||
// TrackableObject:
|
// TrackableObject:
|
||||||
|
@ -91,7 +89,7 @@ class TopLevelWindow
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Public APIs of NativeWindow.
|
// Public APIs of NativeWindow.
|
||||||
void SetContentView(mate::Handle<View> view);
|
void SetContentView(gin::Handle<View> view);
|
||||||
void Close();
|
void Close();
|
||||||
virtual void Focus();
|
virtual void Focus();
|
||||||
virtual void Blur();
|
virtual void Blur();
|
||||||
|
@ -215,7 +213,7 @@ class TopLevelWindow
|
||||||
// Extra APIs added in JS.
|
// Extra APIs added in JS.
|
||||||
bool SetThumbarButtons(gin_helper::Arguments* args);
|
bool SetThumbarButtons(gin_helper::Arguments* args);
|
||||||
#if defined(TOOLKIT_VIEWS)
|
#if defined(TOOLKIT_VIEWS)
|
||||||
void SetIcon(mate::Handle<NativeImage> icon);
|
void SetIcon(gin::Handle<NativeImage> icon);
|
||||||
#endif
|
#endif
|
||||||
#if defined(OS_WIN)
|
#if defined(OS_WIN)
|
||||||
typedef base::RepeatingCallback<void(v8::Local<v8::Value>,
|
typedef base::RepeatingCallback<void(v8::Local<v8::Value>,
|
||||||
|
|
|
@ -10,11 +10,10 @@
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "gin/handle.h"
|
#include "gin/handle.h"
|
||||||
#include "shell/browser/api/trackable_object.h"
|
|
||||||
#include "shell/browser/ui/tray_icon.h"
|
#include "shell/browser/ui/tray_icon.h"
|
||||||
#include "shell/browser/ui/tray_icon_observer.h"
|
#include "shell/browser/ui/tray_icon_observer.h"
|
||||||
#include "shell/common/gin_helper/error_thrower.h"
|
#include "shell/common/gin_helper/error_thrower.h"
|
||||||
#include "shell/common/gin_helper/event_emitter.h"
|
#include "shell/common/gin_helper/trackable_object.h"
|
||||||
|
|
||||||
namespace gfx {
|
namespace gfx {
|
||||||
class Image;
|
class Image;
|
||||||
|
@ -33,10 +32,7 @@ namespace api {
|
||||||
class Menu;
|
class Menu;
|
||||||
class NativeImage;
|
class NativeImage;
|
||||||
|
|
||||||
class Tray : public mate::TrackableObject<
|
class Tray : public gin_helper::TrackableObject<Tray>, public TrayIconObserver {
|
||||||
Tray,
|
|
||||||
gin_helper::EventEmitter<mate::Wrappable<Tray>>>,
|
|
||||||
public TrayIconObserver {
|
|
||||||
public:
|
public:
|
||||||
static mate::WrappableBase* New(gin_helper::ErrorThrower thrower,
|
static mate::WrappableBase* New(gin_helper::ErrorThrower thrower,
|
||||||
gin::Handle<NativeImage> image,
|
gin::Handle<NativeImage> image,
|
||||||
|
|
|
@ -177,7 +177,7 @@ URLRequest::URLRequest(gin::Arguments* args) : weak_factory_(this) {
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string partition;
|
std::string partition;
|
||||||
mate::Handle<api::Session> session;
|
gin::Handle<api::Session> session;
|
||||||
if (!dict.Get("session", &session)) {
|
if (!dict.Get("session", &session)) {
|
||||||
if (dict.Get("partition", &partition))
|
if (dict.Get("partition", &partition))
|
||||||
session = Session::FromPartition(args->isolate(), partition);
|
session = Session::FromPartition(args->isolate(), partition);
|
||||||
|
|
|
@ -13,7 +13,6 @@
|
||||||
#include "gin/arguments.h"
|
#include "gin/arguments.h"
|
||||||
#include "gin/dictionary.h"
|
#include "gin/dictionary.h"
|
||||||
#include "mojo/public/cpp/system/data_pipe_producer.h"
|
#include "mojo/public/cpp/system/data_pipe_producer.h"
|
||||||
#include "native_mate/wrappable.h"
|
|
||||||
#include "services/network/public/cpp/shared_url_loader_factory.h"
|
#include "services/network/public/cpp/shared_url_loader_factory.h"
|
||||||
#include "services/network/public/cpp/simple_url_loader.h"
|
#include "services/network/public/cpp/simple_url_loader.h"
|
||||||
#include "services/network/public/cpp/simple_url_loader_stream_consumer.h"
|
#include "services/network/public/cpp/simple_url_loader_stream_consumer.h"
|
||||||
|
@ -26,7 +25,7 @@ namespace api {
|
||||||
|
|
||||||
class UploadDataPipeGetter;
|
class UploadDataPipeGetter;
|
||||||
|
|
||||||
class URLRequest : public gin_helper::EventEmitter<mate::Wrappable<URLRequest>>,
|
class URLRequest : public gin_helper::EventEmitter<URLRequest>,
|
||||||
public network::SimpleURLLoaderStreamConsumer {
|
public network::SimpleURLLoaderStreamConsumer {
|
||||||
public:
|
public:
|
||||||
static mate::WrappableBase* New(gin::Arguments* args);
|
static mate::WrappableBase* New(gin::Arguments* args);
|
||||||
|
|
|
@ -4,7 +4,8 @@
|
||||||
|
|
||||||
#include "shell/browser/api/atom_api_view.h"
|
#include "shell/browser/api/atom_api_view.h"
|
||||||
|
|
||||||
#include "native_mate/dictionary.h"
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
|
#include "shell/common/gin_helper/object_template_builder.h"
|
||||||
#include "shell/common/node_includes.h"
|
#include "shell/common/node_includes.h"
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
@ -23,16 +24,16 @@ View::~View() {
|
||||||
}
|
}
|
||||||
|
|
||||||
#if BUILDFLAG(ENABLE_VIEW_API)
|
#if BUILDFLAG(ENABLE_VIEW_API)
|
||||||
void View::SetLayoutManager(mate::Handle<LayoutManager> layout_manager) {
|
void View::SetLayoutManager(gin::Handle<LayoutManager> layout_manager) {
|
||||||
layout_manager_.Reset(isolate(), layout_manager->GetWrapper());
|
layout_manager_.Reset(isolate(), layout_manager->GetWrapper());
|
||||||
view()->SetLayoutManager(layout_manager->TakeOver());
|
view()->SetLayoutManager(layout_manager->TakeOver());
|
||||||
}
|
}
|
||||||
|
|
||||||
void View::AddChildView(mate::Handle<View> child) {
|
void View::AddChildView(gin::Handle<View> child) {
|
||||||
AddChildViewAt(child, child_views_.size());
|
AddChildViewAt(child, child_views_.size());
|
||||||
}
|
}
|
||||||
|
|
||||||
void View::AddChildViewAt(mate::Handle<View> child, size_t index) {
|
void View::AddChildViewAt(gin::Handle<View> child, size_t index) {
|
||||||
if (index > child_views_.size())
|
if (index > child_views_.size())
|
||||||
return;
|
return;
|
||||||
child_views_.emplace(child_views_.begin() + index, // index
|
child_views_.emplace(child_views_.begin() + index, // index
|
||||||
|
@ -51,9 +52,9 @@ mate::WrappableBase* View::New(gin::Arguments* args) {
|
||||||
// static
|
// static
|
||||||
void View::BuildPrototype(v8::Isolate* isolate,
|
void View::BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::FunctionTemplate> prototype) {
|
v8::Local<v8::FunctionTemplate> prototype) {
|
||||||
prototype->SetClassName(mate::StringToV8(isolate, "View"));
|
prototype->SetClassName(gin::StringToV8(isolate, "View"));
|
||||||
#if BUILDFLAG(ENABLE_VIEW_API)
|
#if BUILDFLAG(ENABLE_VIEW_API)
|
||||||
mate::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
gin_helper::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
||||||
.SetMethod("setLayoutManager", &View::SetLayoutManager)
|
.SetMethod("setLayoutManager", &View::SetLayoutManager)
|
||||||
.SetMethod("addChildView", &View::AddChildView)
|
.SetMethod("addChildView", &View::AddChildView)
|
||||||
.SetMethod("addChildViewAt", &View::AddChildViewAt);
|
.SetMethod("addChildViewAt", &View::AddChildViewAt);
|
||||||
|
@ -75,11 +76,11 @@ void Initialize(v8::Local<v8::Object> exports,
|
||||||
v8::Isolate* isolate = context->GetIsolate();
|
v8::Isolate* isolate = context->GetIsolate();
|
||||||
View::SetConstructor(isolate, base::BindRepeating(&View::New));
|
View::SetConstructor(isolate, base::BindRepeating(&View::New));
|
||||||
|
|
||||||
mate::Dictionary constructor(
|
gin_helper::Dictionary constructor(
|
||||||
isolate,
|
isolate,
|
||||||
View::GetConstructor(isolate)->GetFunction(context).ToLocalChecked());
|
View::GetConstructor(isolate)->GetFunction(context).ToLocalChecked());
|
||||||
|
|
||||||
mate::Dictionary dict(isolate, exports);
|
gin_helper::Dictionary dict(isolate, exports);
|
||||||
dict.Set("View", constructor);
|
dict.Set("View", constructor);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "electron/buildflags/buildflags.h"
|
#include "electron/buildflags/buildflags.h"
|
||||||
#include "native_mate/handle.h"
|
#include "gin/handle.h"
|
||||||
#include "shell/browser/api/views/atom_api_layout_manager.h"
|
#include "shell/browser/api/views/atom_api_layout_manager.h"
|
||||||
#include "ui/views/view.h"
|
#include "ui/views/view.h"
|
||||||
|
|
||||||
|
@ -17,7 +17,7 @@ namespace electron {
|
||||||
|
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
class View : public mate::TrackableObject<View> {
|
class View : public gin_helper::TrackableObject<View> {
|
||||||
public:
|
public:
|
||||||
static mate::WrappableBase* New(gin::Arguments* args);
|
static mate::WrappableBase* New(gin::Arguments* args);
|
||||||
|
|
||||||
|
@ -25,9 +25,9 @@ class View : public mate::TrackableObject<View> {
|
||||||
v8::Local<v8::FunctionTemplate> prototype);
|
v8::Local<v8::FunctionTemplate> prototype);
|
||||||
|
|
||||||
#if BUILDFLAG(ENABLE_VIEW_API)
|
#if BUILDFLAG(ENABLE_VIEW_API)
|
||||||
void SetLayoutManager(mate::Handle<LayoutManager> layout_manager);
|
void SetLayoutManager(gin::Handle<LayoutManager> layout_manager);
|
||||||
void AddChildView(mate::Handle<View> view);
|
void AddChildView(gin::Handle<View> view);
|
||||||
void AddChildViewAt(mate::Handle<View> view, size_t index);
|
void AddChildViewAt(gin::Handle<View> view, size_t index);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
views::View* view() const { return view_; }
|
views::View* view() const { return view_; }
|
||||||
|
@ -54,7 +54,7 @@ class View : public mate::TrackableObject<View> {
|
||||||
|
|
||||||
} // namespace electron
|
} // namespace electron
|
||||||
|
|
||||||
namespace mate {
|
namespace gin {
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct Converter<views::View*> {
|
struct Converter<views::View*> {
|
||||||
|
@ -69,6 +69,6 @@ struct Converter<views::View*> {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace mate
|
} // namespace gin
|
||||||
|
|
||||||
#endif // SHELL_BROWSER_API_ATOM_API_VIEW_H_
|
#endif // SHELL_BROWSER_API_ATOM_API_VIEW_H_
|
||||||
|
|
|
@ -45,9 +45,6 @@
|
||||||
#include "electron/buildflags/buildflags.h"
|
#include "electron/buildflags/buildflags.h"
|
||||||
#include "electron/shell/common/api/api.mojom.h"
|
#include "electron/shell/common/api/api.mojom.h"
|
||||||
#include "mojo/public/cpp/system/platform_handle.h"
|
#include "mojo/public/cpp/system/platform_handle.h"
|
||||||
#include "native_mate/converter.h"
|
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "native_mate/object_template_builder_deprecated.h"
|
|
||||||
#include "ppapi/buildflags/buildflags.h"
|
#include "ppapi/buildflags/buildflags.h"
|
||||||
#include "shell/browser/api/atom_api_browser_window.h"
|
#include "shell/browser/api/atom_api_browser_window.h"
|
||||||
#include "shell/browser/api/atom_api_debugger.h"
|
#include "shell/browser/api/atom_api_debugger.h"
|
||||||
|
@ -72,20 +69,18 @@
|
||||||
#include "shell/browser/web_view_guest_delegate.h"
|
#include "shell/browser/web_view_guest_delegate.h"
|
||||||
#include "shell/common/api/atom_api_native_image.h"
|
#include "shell/common/api/atom_api_native_image.h"
|
||||||
#include "shell/common/color_util.h"
|
#include "shell/common/color_util.h"
|
||||||
|
#include "shell/common/gin_converters/blink_converter_gin_adapter.h"
|
||||||
#include "shell/common/gin_converters/callback_converter.h"
|
#include "shell/common/gin_converters/callback_converter.h"
|
||||||
|
#include "shell/common/gin_converters/content_converter.h"
|
||||||
|
#include "shell/common/gin_converters/file_path_converter.h"
|
||||||
#include "shell/common/gin_converters/gfx_converter.h"
|
#include "shell/common/gin_converters/gfx_converter.h"
|
||||||
|
#include "shell/common/gin_converters/gurl_converter.h"
|
||||||
|
#include "shell/common/gin_converters/image_converter.h"
|
||||||
|
#include "shell/common/gin_converters/net_converter.h"
|
||||||
|
#include "shell/common/gin_converters/value_converter_gin_adapter.h"
|
||||||
#include "shell/common/gin_helper/dictionary.h"
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
|
#include "shell/common/gin_helper/object_template_builder.h"
|
||||||
#include "shell/common/mouse_util.h"
|
#include "shell/common/mouse_util.h"
|
||||||
#include "shell/common/native_mate_converters/blink_converter.h"
|
|
||||||
#include "shell/common/native_mate_converters/content_converter.h"
|
|
||||||
#include "shell/common/native_mate_converters/file_path_converter.h"
|
|
||||||
#include "shell/common/native_mate_converters/gurl_converter.h"
|
|
||||||
#include "shell/common/native_mate_converters/image_converter.h"
|
|
||||||
#include "shell/common/native_mate_converters/net_converter.h"
|
|
||||||
#include "shell/common/native_mate_converters/network_converter.h"
|
|
||||||
#include "shell/common/native_mate_converters/once_callback.h"
|
|
||||||
#include "shell/common/native_mate_converters/string16_converter.h"
|
|
||||||
#include "shell/common/native_mate_converters/value_converter.h"
|
|
||||||
#include "shell/common/node_includes.h"
|
#include "shell/common/node_includes.h"
|
||||||
#include "shell/common/options_switches.h"
|
#include "shell/common/options_switches.h"
|
||||||
#include "third_party/blink/public/common/associated_interfaces/associated_interface_provider.h"
|
#include "third_party/blink/public/common/associated_interfaces/associated_interface_provider.h"
|
||||||
|
@ -125,7 +120,7 @@
|
||||||
#include "shell/browser/extensions/atom_extension_web_contents_observer.h"
|
#include "shell/browser/extensions/atom_extension_web_contents_observer.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
namespace mate {
|
namespace gin {
|
||||||
|
|
||||||
#if BUILDFLAG(ENABLE_PRINTING)
|
#if BUILDFLAG(ENABLE_PRINTING)
|
||||||
template <>
|
template <>
|
||||||
|
@ -221,7 +216,7 @@ struct Converter<WindowOpenDisposition> {
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return mate::ConvertToV8(isolate, disposition);
|
return gin::ConvertToV8(isolate, disposition);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -275,7 +270,7 @@ struct Converter<electron::api::WebContents::Type> {
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return mate::ConvertToV8(isolate, type);
|
return gin::ConvertToV8(isolate, type);
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool FromV8(v8::Isolate* isolate,
|
static bool FromV8(v8::Isolate* isolate,
|
||||||
|
@ -307,14 +302,14 @@ struct Converter<scoped_refptr<content::DevToolsAgentHost>> {
|
||||||
static v8::Local<v8::Value> ToV8(
|
static v8::Local<v8::Value> ToV8(
|
||||||
v8::Isolate* isolate,
|
v8::Isolate* isolate,
|
||||||
const scoped_refptr<content::DevToolsAgentHost>& val) {
|
const scoped_refptr<content::DevToolsAgentHost>& val) {
|
||||||
mate::Dictionary dict(isolate, v8::Object::New(isolate));
|
gin_helper::Dictionary dict(isolate, v8::Object::New(isolate));
|
||||||
dict.Set("id", val->GetId());
|
dict.Set("id", val->GetId());
|
||||||
dict.Set("url", val->GetURL().spec());
|
dict.Set("url", val->GetURL().spec());
|
||||||
return dict.GetHandle();
|
return dict.GetHandle();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace mate
|
} // namespace gin
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
|
||||||
|
@ -326,7 +321,7 @@ namespace {
|
||||||
void OnCapturePageDone(util::Promise<gfx::Image> promise,
|
void OnCapturePageDone(util::Promise<gfx::Image> promise,
|
||||||
const SkBitmap& bitmap) {
|
const SkBitmap& bitmap) {
|
||||||
// Hack to enable transparency in captured image
|
// Hack to enable transparency in captured image
|
||||||
promise.Resolve(gfx::Image::CreateFrom1xBitmap(bitmap));
|
promise.ResolveWithGin(gfx::Image::CreateFrom1xBitmap(bitmap));
|
||||||
}
|
}
|
||||||
|
|
||||||
base::Optional<base::TimeDelta> GetCursorBlinkInterval() {
|
base::Optional<base::TimeDelta> GetCursorBlinkInterval() {
|
||||||
|
@ -359,7 +354,7 @@ WebContents::WebContents(v8::Isolate* isolate,
|
||||||
false);
|
false);
|
||||||
Init(isolate);
|
Init(isolate);
|
||||||
AttachAsUserData(web_contents);
|
AttachAsUserData(web_contents);
|
||||||
InitZoomController(web_contents, mate::Dictionary::CreateEmpty(isolate));
|
InitZoomController(web_contents, gin::Dictionary::CreateEmpty(isolate));
|
||||||
registry_.AddInterface(base::BindRepeating(&WebContents::BindElectronBrowser,
|
registry_.AddInterface(base::BindRepeating(&WebContents::BindElectronBrowser,
|
||||||
base::Unretained(this)));
|
base::Unretained(this)));
|
||||||
bindings_.set_connection_error_handler(base::BindRepeating(
|
bindings_.set_connection_error_handler(base::BindRepeating(
|
||||||
|
@ -377,10 +372,11 @@ WebContents::WebContents(v8::Isolate* isolate,
|
||||||
auto session = Session::CreateFrom(isolate, GetBrowserContext());
|
auto session = Session::CreateFrom(isolate, GetBrowserContext());
|
||||||
session_.Reset(isolate, session.ToV8());
|
session_.Reset(isolate, session.ToV8());
|
||||||
InitWithSessionAndOptions(isolate, std::move(web_contents), session,
|
InitWithSessionAndOptions(isolate, std::move(web_contents), session,
|
||||||
mate::Dictionary::CreateEmpty(isolate));
|
gin::Dictionary::CreateEmpty(isolate));
|
||||||
}
|
}
|
||||||
|
|
||||||
WebContents::WebContents(v8::Isolate* isolate, const mate::Dictionary& options)
|
WebContents::WebContents(v8::Isolate* isolate,
|
||||||
|
const gin_helper::Dictionary& options)
|
||||||
: weak_factory_(this) {
|
: weak_factory_(this) {
|
||||||
// Read options.
|
// Read options.
|
||||||
options.Get("backgroundThrottling", &background_throttling_);
|
options.Get("backgroundThrottling", &background_throttling_);
|
||||||
|
@ -405,7 +401,7 @@ WebContents::WebContents(v8::Isolate* isolate, const mate::Dictionary& options)
|
||||||
|
|
||||||
// Obtain the session.
|
// Obtain the session.
|
||||||
std::string partition;
|
std::string partition;
|
||||||
mate::Handle<api::Session> session;
|
gin::Handle<api::Session> session;
|
||||||
if (options.Get("session", &session) && !session.IsEmpty()) {
|
if (options.Get("session", &session) && !session.IsEmpty()) {
|
||||||
} else if (options.Get("partition", &partition)) {
|
} else if (options.Get("partition", &partition)) {
|
||||||
session = Session::FromPartition(isolate, partition);
|
session = Session::FromPartition(isolate, partition);
|
||||||
|
@ -465,7 +461,7 @@ WebContents::WebContents(v8::Isolate* isolate, const mate::Dictionary& options)
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebContents::InitZoomController(content::WebContents* web_contents,
|
void WebContents::InitZoomController(content::WebContents* web_contents,
|
||||||
const mate::Dictionary& options) {
|
const gin_helper::Dictionary& options) {
|
||||||
WebContentsZoomController::CreateForWebContents(web_contents);
|
WebContentsZoomController::CreateForWebContents(web_contents);
|
||||||
zoom_controller_ = WebContentsZoomController::FromWebContents(web_contents);
|
zoom_controller_ = WebContentsZoomController::FromWebContents(web_contents);
|
||||||
double zoom_factor;
|
double zoom_factor;
|
||||||
|
@ -476,8 +472,8 @@ void WebContents::InitZoomController(content::WebContents* web_contents,
|
||||||
void WebContents::InitWithSessionAndOptions(
|
void WebContents::InitWithSessionAndOptions(
|
||||||
v8::Isolate* isolate,
|
v8::Isolate* isolate,
|
||||||
std::unique_ptr<content::WebContents> owned_web_contents,
|
std::unique_ptr<content::WebContents> owned_web_contents,
|
||||||
mate::Handle<api::Session> session,
|
gin::Handle<api::Session> session,
|
||||||
const mate::Dictionary& options) {
|
const gin_helper::Dictionary& options) {
|
||||||
Observe(owned_web_contents.get());
|
Observe(owned_web_contents.get());
|
||||||
// TODO(zcbenz): Make InitWithWebContents take unique_ptr.
|
// TODO(zcbenz): Make InitWithWebContents take unique_ptr.
|
||||||
// At the time of writing we are going through a refactoring and I don't want
|
// At the time of writing we are going through a refactoring and I don't want
|
||||||
|
@ -672,8 +668,7 @@ void WebContents::BeforeUnloadFired(content::WebContents* tab,
|
||||||
|
|
||||||
void WebContents::SetContentsBounds(content::WebContents* source,
|
void WebContents::SetContentsBounds(content::WebContents* source,
|
||||||
const gfx::Rect& pos) {
|
const gfx::Rect& pos) {
|
||||||
// TODO(zcbenz): Use implicit convertion after removing mate::EventEmitter.
|
Emit("move", pos);
|
||||||
Emit("move", gin::ConvertToV8(isolate(), pos));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebContents::CloseContents(content::WebContents* source) {
|
void WebContents::CloseContents(content::WebContents* source) {
|
||||||
|
@ -1054,7 +1049,7 @@ void WebContents::MessageTo(bool internal,
|
||||||
int32_t web_contents_id,
|
int32_t web_contents_id,
|
||||||
const std::string& channel,
|
const std::string& channel,
|
||||||
blink::CloneableMessage arguments) {
|
blink::CloneableMessage arguments) {
|
||||||
auto* web_contents = mate::TrackableObject<WebContents>::FromWeakMapID(
|
auto* web_contents = gin_helper::TrackableObject<WebContents>::FromWeakMapID(
|
||||||
isolate(), web_contents_id);
|
isolate(), web_contents_id);
|
||||||
|
|
||||||
if (web_contents) {
|
if (web_contents) {
|
||||||
|
@ -1346,7 +1341,8 @@ bool WebContents::Equal(const WebContents* web_contents) const {
|
||||||
return ID() == web_contents->ID();
|
return ID() == web_contents->ID();
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebContents::LoadURL(const GURL& url, const mate::Dictionary& options) {
|
void WebContents::LoadURL(const GURL& url,
|
||||||
|
const gin_helper::Dictionary& options) {
|
||||||
if (!url.is_valid() || url.spec().size() > url::kMaxURLChars) {
|
if (!url.is_valid() || url.spec().size() > url::kMaxURLChars) {
|
||||||
Emit("did-fail-load", static_cast<int>(net::ERR_INVALID_URL),
|
Emit("did-fail-load", static_cast<int>(net::ERR_INVALID_URL),
|
||||||
net::ErrorToShortString(net::ERR_INVALID_URL),
|
net::ErrorToShortString(net::ERR_INVALID_URL),
|
||||||
|
@ -1487,7 +1483,7 @@ bool WebContents::IsCrashed() const {
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebContents::SetUserAgent(const std::string& user_agent,
|
void WebContents::SetUserAgent(const std::string& user_agent,
|
||||||
mate::Arguments* args) {
|
gin_helper::Arguments* args) {
|
||||||
web_contents()->SetUserAgentOverride(user_agent, false);
|
web_contents()->SetUserAgentOverride(user_agent, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1507,7 +1503,7 @@ v8::Local<v8::Promise> WebContents::SavePage(
|
||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebContents::OpenDevTools(mate::Arguments* args) {
|
void WebContents::OpenDevTools(gin_helper::Arguments* args) {
|
||||||
if (type_ == Type::REMOTE)
|
if (type_ == Type::REMOTE)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -1520,7 +1516,7 @@ void WebContents::OpenDevTools(mate::Arguments* args) {
|
||||||
}
|
}
|
||||||
bool activate = true;
|
bool activate = true;
|
||||||
if (args && args->Length() == 1) {
|
if (args && args->Length() == 1) {
|
||||||
mate::Dictionary options;
|
gin_helper::Dictionary options;
|
||||||
if (args->GetNext(&options)) {
|
if (args->GetNext(&options)) {
|
||||||
options.Get("mode", &state);
|
options.Get("mode", &state);
|
||||||
options.Get("activate", &activate);
|
options.Get("activate", &activate);
|
||||||
|
@ -1693,8 +1689,9 @@ bool WebContents::IsCurrentlyAudible() {
|
||||||
}
|
}
|
||||||
|
|
||||||
#if BUILDFLAG(ENABLE_PRINTING)
|
#if BUILDFLAG(ENABLE_PRINTING)
|
||||||
void WebContents::Print(mate::Arguments* args) {
|
void WebContents::Print(gin_helper::Arguments* args) {
|
||||||
mate::Dictionary options = mate::Dictionary::CreateEmpty(args->isolate());
|
gin_helper::Dictionary options =
|
||||||
|
gin::Dictionary::CreateEmpty(args->isolate());
|
||||||
base::DictionaryValue settings;
|
base::DictionaryValue settings;
|
||||||
|
|
||||||
if (args->Length() >= 1 && !args->GetNext(&options)) {
|
if (args->Length() >= 1 && !args->GetNext(&options)) {
|
||||||
|
@ -1719,7 +1716,8 @@ void WebContents::Print(mate::Arguments* args) {
|
||||||
print_background);
|
print_background);
|
||||||
|
|
||||||
// Set custom margin settings
|
// Set custom margin settings
|
||||||
mate::Dictionary margins = mate::Dictionary::CreateEmpty(args->isolate());
|
gin_helper::Dictionary margins =
|
||||||
|
gin::Dictionary::CreateEmpty(args->isolate());
|
||||||
if (options.Get("margins", &margins)) {
|
if (options.Get("margins", &margins)) {
|
||||||
printing::MarginType margin_type = printing::DEFAULT_MARGINS;
|
printing::MarginType margin_type = printing::DEFAULT_MARGINS;
|
||||||
margins.Get("marginType", &margin_type);
|
margins.Get("marginType", &margin_type);
|
||||||
|
@ -1805,7 +1803,7 @@ void WebContents::Print(mate::Arguments* args) {
|
||||||
settings.SetBoolean(printing::kSettingRasterizePdf, false);
|
settings.SetBoolean(printing::kSettingRasterizePdf, false);
|
||||||
|
|
||||||
// Set custom page ranges to print
|
// Set custom page ranges to print
|
||||||
std::vector<mate::Dictionary> page_ranges;
|
std::vector<gin_helper::Dictionary> page_ranges;
|
||||||
if (options.Get("pageRanges", &page_ranges)) {
|
if (options.Get("pageRanges", &page_ranges)) {
|
||||||
std::unique_ptr<base::ListValue> page_range_list(new base::ListValue());
|
std::unique_ptr<base::ListValue> page_range_list(new base::ListValue());
|
||||||
for (auto& range : page_ranges) {
|
for (auto& range : page_ranges) {
|
||||||
|
@ -1830,7 +1828,7 @@ void WebContents::Print(mate::Arguments* args) {
|
||||||
settings.SetInteger(printing::kSettingDuplexMode, duplex_mode);
|
settings.SetInteger(printing::kSettingDuplexMode, duplex_mode);
|
||||||
|
|
||||||
// Set custom dots per inch (dpi)
|
// Set custom dots per inch (dpi)
|
||||||
mate::Dictionary dpi_settings;
|
gin_helper::Dictionary dpi_settings;
|
||||||
int dpi = 72;
|
int dpi = 72;
|
||||||
if (options.Get("dpi", &dpi_settings)) {
|
if (options.Get("dpi", &dpi_settings)) {
|
||||||
int horizontal = 72;
|
int horizontal = 72;
|
||||||
|
@ -1878,7 +1876,7 @@ v8::Local<v8::Promise> WebContents::PrintToPDF(
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void WebContents::AddWorkSpace(mate::Arguments* args,
|
void WebContents::AddWorkSpace(gin_helper::Arguments* args,
|
||||||
const base::FilePath& path) {
|
const base::FilePath& path) {
|
||||||
if (path.empty()) {
|
if (path.empty()) {
|
||||||
args->ThrowError("path cannot be empty");
|
args->ThrowError("path cannot be empty");
|
||||||
|
@ -1887,7 +1885,7 @@ void WebContents::AddWorkSpace(mate::Arguments* args,
|
||||||
DevToolsAddFileSystem(std::string(), path);
|
DevToolsAddFileSystem(std::string(), path);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebContents::RemoveWorkSpace(mate::Arguments* args,
|
void WebContents::RemoveWorkSpace(gin_helper::Arguments* args,
|
||||||
const base::FilePath& path) {
|
const base::FilePath& path) {
|
||||||
if (path.empty()) {
|
if (path.empty()) {
|
||||||
args->ThrowError("path cannot be empty");
|
args->ThrowError("path cannot be empty");
|
||||||
|
@ -1940,7 +1938,7 @@ void WebContents::ReplaceMisspelling(const base::string16& word) {
|
||||||
web_contents()->ReplaceMisspelling(word);
|
web_contents()->ReplaceMisspelling(word);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t WebContents::FindInPage(mate::Arguments* args) {
|
uint32_t WebContents::FindInPage(gin_helper::Arguments* args) {
|
||||||
base::string16 search_text;
|
base::string16 search_text;
|
||||||
if (!args->GetNext(&search_text) || search_text.empty()) {
|
if (!args->GetNext(&search_text) || search_text.empty()) {
|
||||||
args->ThrowError("Must provide a non-empty search content");
|
args->ThrowError("Must provide a non-empty search content");
|
||||||
|
@ -1948,7 +1946,7 @@ uint32_t WebContents::FindInPage(mate::Arguments* args) {
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t request_id = GetNextRequestId();
|
uint32_t request_id = GetNextRequestId();
|
||||||
mate::Dictionary dict;
|
gin_helper::Dictionary dict;
|
||||||
auto options = blink::mojom::FindOptions::New();
|
auto options = blink::mojom::FindOptions::New();
|
||||||
if (args->GetNext(&dict)) {
|
if (args->GetNext(&dict)) {
|
||||||
dict.Get("forward", &options->forward);
|
dict.Get("forward", &options->forward);
|
||||||
|
@ -2007,9 +2005,9 @@ bool WebContents::SendIPCMessage(bool internal,
|
||||||
const std::string& channel,
|
const std::string& channel,
|
||||||
v8::Local<v8::Value> args) {
|
v8::Local<v8::Value> args) {
|
||||||
blink::CloneableMessage message;
|
blink::CloneableMessage message;
|
||||||
if (!mate::ConvertFromV8(isolate(), args, &message)) {
|
if (!gin::ConvertFromV8(isolate(), args, &message)) {
|
||||||
isolate()->ThrowException(v8::Exception::Error(
|
isolate()->ThrowException(v8::Exception::Error(
|
||||||
mate::StringToV8(isolate(), "Failed to serialize arguments")));
|
gin::StringToV8(isolate(), "Failed to serialize arguments")));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return SendIPCMessageWithSender(internal, send_to_all, channel,
|
return SendIPCMessageWithSender(internal, send_to_all, channel,
|
||||||
|
@ -2046,9 +2044,9 @@ bool WebContents::SendIPCMessageToFrame(bool internal,
|
||||||
const std::string& channel,
|
const std::string& channel,
|
||||||
v8::Local<v8::Value> args) {
|
v8::Local<v8::Value> args) {
|
||||||
blink::CloneableMessage message;
|
blink::CloneableMessage message;
|
||||||
if (!mate::ConvertFromV8(isolate(), args, &message)) {
|
if (!gin::ConvertFromV8(isolate(), args, &message)) {
|
||||||
isolate()->ThrowException(v8::Exception::Error(
|
isolate()->ThrowException(v8::Exception::Error(
|
||||||
mate::StringToV8(isolate(), "Failed to serialize arguments")));
|
gin::StringToV8(isolate(), "Failed to serialize arguments")));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
auto frames = web_contents()->GetAllFrames();
|
auto frames = web_contents()->GetAllFrames();
|
||||||
|
@ -2094,7 +2092,7 @@ void WebContents::SendInputEvent(v8::Isolate* isolate,
|
||||||
content::NativeWebKeyboardEvent keyboard_event(
|
content::NativeWebKeyboardEvent keyboard_event(
|
||||||
blink::WebKeyboardEvent::kRawKeyDown,
|
blink::WebKeyboardEvent::kRawKeyDown,
|
||||||
blink::WebInputEvent::kNoModifiers, ui::EventTimeForNow());
|
blink::WebInputEvent::kNoModifiers, ui::EventTimeForNow());
|
||||||
if (mate::ConvertFromV8(isolate, input_event, &keyboard_event)) {
|
if (gin::ConvertFromV8(isolate, input_event, &keyboard_event)) {
|
||||||
rwh->ForwardKeyboardEvent(keyboard_event);
|
rwh->ForwardKeyboardEvent(keyboard_event);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -2127,14 +2125,10 @@ void WebContents::SendInputEvent(v8::Isolate* isolate,
|
||||||
}
|
}
|
||||||
|
|
||||||
isolate->ThrowException(
|
isolate->ThrowException(
|
||||||
v8::Exception::Error(mate::StringToV8(isolate, "Invalid event object")));
|
v8::Exception::Error(gin::StringToV8(isolate, "Invalid event object")));
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebContents::BeginFrameSubscription(mate::Arguments* mate_args) {
|
void WebContents::BeginFrameSubscription(gin_helper::Arguments* args) {
|
||||||
// TODO(zcbenz): Remove this after converting WebContents to gin.
|
|
||||||
gin::Arguments gin_args(mate_args->info());
|
|
||||||
gin_helper::Arguments* args = static_cast<gin_helper::Arguments*>(&gin_args);
|
|
||||||
|
|
||||||
bool only_dirty = false;
|
bool only_dirty = false;
|
||||||
FrameSubscriber::FrameCaptureCallback callback;
|
FrameSubscriber::FrameCaptureCallback callback;
|
||||||
|
|
||||||
|
@ -2152,32 +2146,19 @@ void WebContents::EndFrameSubscription() {
|
||||||
frame_subscriber_.reset();
|
frame_subscriber_.reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebContents::StartDrag(const mate::Dictionary& item,
|
void WebContents::StartDrag(const gin_helper::Dictionary& item,
|
||||||
mate::Arguments* args) {
|
gin_helper::Arguments* args) {
|
||||||
base::FilePath file;
|
base::FilePath file;
|
||||||
std::vector<base::FilePath> files;
|
std::vector<base::FilePath> files;
|
||||||
if (!item.Get("files", &files) && item.Get("file", &file)) {
|
if (!item.Get("files", &files) && item.Get("file", &file)) {
|
||||||
files.push_back(file);
|
files.push_back(file);
|
||||||
}
|
}
|
||||||
|
|
||||||
mate::Handle<NativeImage> icon;
|
gin::Handle<NativeImage> icon;
|
||||||
if (!item.Get("icon", &icon) && !file.empty()) {
|
if (!item.Get("icon", &icon)) {
|
||||||
// TODO(zcbenz): Set default icon from file.
|
|
||||||
}
|
|
||||||
|
|
||||||
// Error checking.
|
|
||||||
if (icon.IsEmpty()) {
|
|
||||||
args->ThrowError("Must specify 'icon' option");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
#if defined(OS_MACOSX)
|
|
||||||
// NSWindow.dragImage requires a non-empty NSImage
|
|
||||||
if (icon->image().IsEmpty()) {
|
|
||||||
args->ThrowError("Must specify non-empty 'icon' option");
|
args->ThrowError("Must specify non-empty 'icon' option");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
// Start dragging.
|
// Start dragging.
|
||||||
if (!files.empty()) {
|
if (!files.empty()) {
|
||||||
|
@ -2188,11 +2169,7 @@ void WebContents::StartDrag(const mate::Dictionary& item,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
v8::Local<v8::Promise> WebContents::CapturePage(mate::Arguments* mate_args) {
|
v8::Local<v8::Promise> WebContents::CapturePage(gin_helper::Arguments* args) {
|
||||||
// TODO(zcbenz): Remove this after converting WebContents to gin.
|
|
||||||
gin::Arguments gin_args(mate_args->info());
|
|
||||||
gin::Arguments* args = &gin_args;
|
|
||||||
|
|
||||||
gfx::Rect rect;
|
gfx::Rect rect;
|
||||||
util::Promise<gfx::Image> promise(isolate());
|
util::Promise<gfx::Image> promise(isolate());
|
||||||
v8::Local<v8::Promise> handle = promise.GetHandle();
|
v8::Local<v8::Promise> handle = promise.GetHandle();
|
||||||
|
@ -2202,7 +2179,7 @@ v8::Local<v8::Promise> WebContents::CapturePage(mate::Arguments* mate_args) {
|
||||||
|
|
||||||
auto* const view = web_contents()->GetRenderWidgetHostView();
|
auto* const view = web_contents()->GetRenderWidgetHostView();
|
||||||
if (!view) {
|
if (!view) {
|
||||||
promise.Resolve(gfx::Image());
|
promise.ResolveWithGin(gfx::Image());
|
||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2233,11 +2210,8 @@ void WebContents::OnCursorChange(const content::WebCursor& cursor) {
|
||||||
Emit("cursor-changed", CursorTypeToString(info),
|
Emit("cursor-changed", CursorTypeToString(info),
|
||||||
gfx::Image::CreateFrom1xBitmap(info.custom_image),
|
gfx::Image::CreateFrom1xBitmap(info.custom_image),
|
||||||
info.image_scale_factor,
|
info.image_scale_factor,
|
||||||
// TODO(zcbenz): Use implicit convertion after removing
|
gfx::Size(info.custom_image.width(), info.custom_image.height()),
|
||||||
// mate::EventEmitter.
|
info.hotspot);
|
||||||
gin::ConvertToV8(isolate(), gfx::Size(info.custom_image.width(),
|
|
||||||
info.custom_image.height())),
|
|
||||||
gin::ConvertToV8(isolate(), info.hotspot));
|
|
||||||
} else {
|
} else {
|
||||||
Emit("cursor-changed", CursorTypeToString(info));
|
Emit("cursor-changed", CursorTypeToString(info));
|
||||||
}
|
}
|
||||||
|
@ -2374,7 +2348,7 @@ v8::Local<v8::Value> WebContents::GetWebPreferences(
|
||||||
auto* web_preferences = WebContentsPreferences::From(web_contents());
|
auto* web_preferences = WebContentsPreferences::From(web_contents());
|
||||||
if (!web_preferences)
|
if (!web_preferences)
|
||||||
return v8::Null(isolate);
|
return v8::Null(isolate);
|
||||||
return mate::ConvertToV8(isolate, *web_preferences->preference());
|
return gin::ConvertToV8(isolate, *web_preferences->preference());
|
||||||
}
|
}
|
||||||
|
|
||||||
v8::Local<v8::Value> WebContents::GetLastWebPreferences(
|
v8::Local<v8::Value> WebContents::GetLastWebPreferences(
|
||||||
|
@ -2382,7 +2356,7 @@ v8::Local<v8::Value> WebContents::GetLastWebPreferences(
|
||||||
auto* web_preferences = WebContentsPreferences::From(web_contents());
|
auto* web_preferences = WebContentsPreferences::From(web_contents());
|
||||||
if (!web_preferences)
|
if (!web_preferences)
|
||||||
return v8::Null(isolate);
|
return v8::Null(isolate);
|
||||||
return mate::ConvertToV8(isolate, *web_preferences->last_preference());
|
return gin::ConvertToV8(isolate, *web_preferences->last_preference());
|
||||||
}
|
}
|
||||||
|
|
||||||
v8::Local<v8::Value> WebContents::GetOwnerBrowserWindow() const {
|
v8::Local<v8::Value> WebContents::GetOwnerBrowserWindow() const {
|
||||||
|
@ -2505,9 +2479,9 @@ v8::Local<v8::Promise> WebContents::TakeHeapSnapshot(
|
||||||
// static
|
// static
|
||||||
void WebContents::BuildPrototype(v8::Isolate* isolate,
|
void WebContents::BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::FunctionTemplate> prototype) {
|
v8::Local<v8::FunctionTemplate> prototype) {
|
||||||
prototype->SetClassName(mate::StringToV8(isolate, "WebContents"));
|
prototype->SetClassName(gin::StringToV8(isolate, "WebContents"));
|
||||||
gin_helper::Destroyable::MakeDestroyable(isolate, prototype);
|
gin_helper::Destroyable::MakeDestroyable(isolate, prototype);
|
||||||
mate::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
gin_helper::ObjectTemplateBuilder(isolate, prototype->PrototypeTemplate())
|
||||||
.SetMethod("setBackgroundThrottling",
|
.SetMethod("setBackgroundThrottling",
|
||||||
&WebContents::SetBackgroundThrottling)
|
&WebContents::SetBackgroundThrottling)
|
||||||
.SetMethod("getProcessId", &WebContents::GetProcessID)
|
.SetMethod("getProcessId", &WebContents::GetProcessID)
|
||||||
|
@ -2631,40 +2605,40 @@ AtomBrowserContext* WebContents::GetBrowserContext() const {
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::Handle<WebContents> WebContents::Create(v8::Isolate* isolate,
|
gin::Handle<WebContents> WebContents::Create(
|
||||||
const mate::Dictionary& options) {
|
v8::Isolate* isolate,
|
||||||
return mate::CreateHandle(isolate, new WebContents(isolate, options));
|
const gin_helper::Dictionary& options) {
|
||||||
|
return gin::CreateHandle(isolate, new WebContents(isolate, options));
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::Handle<WebContents> WebContents::CreateAndTake(
|
gin::Handle<WebContents> WebContents::CreateAndTake(
|
||||||
v8::Isolate* isolate,
|
v8::Isolate* isolate,
|
||||||
std::unique_ptr<content::WebContents> web_contents,
|
std::unique_ptr<content::WebContents> web_contents,
|
||||||
Type type) {
|
Type type) {
|
||||||
return mate::CreateHandle(
|
return gin::CreateHandle(
|
||||||
isolate, new WebContents(isolate, std::move(web_contents), type));
|
isolate, new WebContents(isolate, std::move(web_contents), type));
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::Handle<WebContents> WebContents::From(
|
gin::Handle<WebContents> WebContents::From(v8::Isolate* isolate,
|
||||||
v8::Isolate* isolate,
|
content::WebContents* web_contents) {
|
||||||
content::WebContents* web_contents) {
|
|
||||||
auto* existing = TrackableObject::FromWrappedClass(isolate, web_contents);
|
auto* existing = TrackableObject::FromWrappedClass(isolate, web_contents);
|
||||||
if (existing)
|
if (existing)
|
||||||
return mate::CreateHandle(isolate, static_cast<WebContents*>(existing));
|
return gin::CreateHandle(isolate, static_cast<WebContents*>(existing));
|
||||||
else
|
else
|
||||||
return mate::Handle<WebContents>();
|
return gin::Handle<WebContents>();
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::Handle<WebContents> WebContents::FromOrCreate(
|
gin::Handle<WebContents> WebContents::FromOrCreate(
|
||||||
v8::Isolate* isolate,
|
v8::Isolate* isolate,
|
||||||
content::WebContents* web_contents) {
|
content::WebContents* web_contents) {
|
||||||
auto existing = From(isolate, web_contents);
|
auto existing = From(isolate, web_contents);
|
||||||
if (!existing.IsEmpty())
|
if (!existing.IsEmpty())
|
||||||
return existing;
|
return existing;
|
||||||
else
|
else
|
||||||
return mate::CreateHandle(isolate, new WebContents(isolate, web_contents));
|
return gin::CreateHandle(isolate, new WebContents(isolate, web_contents));
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace api
|
} // namespace api
|
||||||
|
@ -2680,7 +2654,7 @@ void Initialize(v8::Local<v8::Object> exports,
|
||||||
v8::Local<v8::Context> context,
|
v8::Local<v8::Context> context,
|
||||||
void* priv) {
|
void* priv) {
|
||||||
v8::Isolate* isolate = context->GetIsolate();
|
v8::Isolate* isolate = context->GetIsolate();
|
||||||
mate::Dictionary dict(isolate, exports);
|
gin_helper::Dictionary dict(isolate, exports);
|
||||||
dict.Set("WebContents", WebContents::GetConstructor(isolate)
|
dict.Set("WebContents", WebContents::GetConstructor(isolate)
|
||||||
->GetFunction(context)
|
->GetFunction(context)
|
||||||
.ToLocalChecked());
|
.ToLocalChecked());
|
||||||
|
|
|
@ -22,13 +22,13 @@
|
||||||
#include "content/public/common/favicon_url.h"
|
#include "content/public/common/favicon_url.h"
|
||||||
#include "electron/buildflags/buildflags.h"
|
#include "electron/buildflags/buildflags.h"
|
||||||
#include "electron/shell/common/api/api.mojom.h"
|
#include "electron/shell/common/api/api.mojom.h"
|
||||||
#include "native_mate/handle.h"
|
#include "gin/handle.h"
|
||||||
#include "printing/buildflags/buildflags.h"
|
#include "printing/buildflags/buildflags.h"
|
||||||
#include "services/service_manager/public/cpp/binder_registry.h"
|
#include "services/service_manager/public/cpp/binder_registry.h"
|
||||||
#include "shell/browser/api/frame_subscriber.h"
|
#include "shell/browser/api/frame_subscriber.h"
|
||||||
#include "shell/browser/api/save_page_handler.h"
|
#include "shell/browser/api/save_page_handler.h"
|
||||||
#include "shell/browser/api/trackable_object.h"
|
|
||||||
#include "shell/browser/common_web_contents_delegate.h"
|
#include "shell/browser/common_web_contents_delegate.h"
|
||||||
|
#include "shell/common/gin_helper/trackable_object.h"
|
||||||
#include "ui/gfx/image/image.h"
|
#include "ui/gfx/image/image.h"
|
||||||
|
|
||||||
#if BUILDFLAG(ENABLE_PRINTING)
|
#if BUILDFLAG(ENABLE_PRINTING)
|
||||||
|
@ -40,10 +40,9 @@ namespace blink {
|
||||||
struct WebDeviceEmulationParams;
|
struct WebDeviceEmulationParams;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace mate {
|
namespace gin_helper {
|
||||||
class Arguments;
|
|
||||||
class Dictionary;
|
class Dictionary;
|
||||||
} // namespace mate
|
}
|
||||||
|
|
||||||
namespace network {
|
namespace network {
|
||||||
class ResourceRequestBody;
|
class ResourceRequestBody;
|
||||||
|
@ -78,7 +77,7 @@ class ExtendedWebContentsObserver : public base::CheckedObserver {
|
||||||
};
|
};
|
||||||
|
|
||||||
// Wrapper around the content::WebContents.
|
// Wrapper around the content::WebContents.
|
||||||
class WebContents : public mate::TrackableObject<WebContents>,
|
class WebContents : public gin_helper::TrackableObject<WebContents>,
|
||||||
public CommonWebContentsDelegate,
|
public CommonWebContentsDelegate,
|
||||||
public content::WebContentsObserver,
|
public content::WebContentsObserver,
|
||||||
public mojom::ElectronBrowser {
|
public mojom::ElectronBrowser {
|
||||||
|
@ -93,26 +92,26 @@ class WebContents : public mate::TrackableObject<WebContents>,
|
||||||
};
|
};
|
||||||
|
|
||||||
// Create a new WebContents and return the V8 wrapper of it.
|
// Create a new WebContents and return the V8 wrapper of it.
|
||||||
static mate::Handle<WebContents> Create(v8::Isolate* isolate,
|
static gin::Handle<WebContents> Create(v8::Isolate* isolate,
|
||||||
const mate::Dictionary& options);
|
const gin_helper::Dictionary& options);
|
||||||
|
|
||||||
// Create a new V8 wrapper for an existing |web_content|.
|
// Create a new V8 wrapper for an existing |web_content|.
|
||||||
//
|
//
|
||||||
// The lifetime of |web_contents| will be managed by this class.
|
// The lifetime of |web_contents| will be managed by this class.
|
||||||
static mate::Handle<WebContents> CreateAndTake(
|
static gin::Handle<WebContents> CreateAndTake(
|
||||||
v8::Isolate* isolate,
|
v8::Isolate* isolate,
|
||||||
std::unique_ptr<content::WebContents> web_contents,
|
std::unique_ptr<content::WebContents> web_contents,
|
||||||
Type type);
|
Type type);
|
||||||
|
|
||||||
// Get the V8 wrapper of |web_content|, return empty handle if not wrapped.
|
// Get the V8 wrapper of |web_content|, return empty handle if not wrapped.
|
||||||
static mate::Handle<WebContents> From(v8::Isolate* isolate,
|
static gin::Handle<WebContents> From(v8::Isolate* isolate,
|
||||||
content::WebContents* web_content);
|
content::WebContents* web_content);
|
||||||
|
|
||||||
// Get the V8 wrapper of the |web_contents|, or create one if not existed.
|
// Get the V8 wrapper of the |web_contents|, or create one if not existed.
|
||||||
//
|
//
|
||||||
// The lifetime of |web_contents| is NOT managed by this class, and the type
|
// The lifetime of |web_contents| is NOT managed by this class, and the type
|
||||||
// of this wrapper is always REMOTE.
|
// of this wrapper is always REMOTE.
|
||||||
static mate::Handle<WebContents> FromOrCreate(
|
static gin::Handle<WebContents> FromOrCreate(
|
||||||
v8::Isolate* isolate,
|
v8::Isolate* isolate,
|
||||||
content::WebContents* web_contents);
|
content::WebContents* web_contents);
|
||||||
|
|
||||||
|
@ -143,7 +142,7 @@ class WebContents : public mate::TrackableObject<WebContents>,
|
||||||
const std::string& document_url) const;
|
const std::string& document_url) const;
|
||||||
Type GetType() const;
|
Type GetType() const;
|
||||||
bool Equal(const WebContents* web_contents) const;
|
bool Equal(const WebContents* web_contents) const;
|
||||||
void LoadURL(const GURL& url, const mate::Dictionary& options);
|
void LoadURL(const GURL& url, const gin_helper::Dictionary& options);
|
||||||
void DownloadURL(const GURL& url);
|
void DownloadURL(const GURL& url);
|
||||||
GURL GetURL() const;
|
GURL GetURL() const;
|
||||||
base::string16 GetTitle() const;
|
base::string16 GetTitle() const;
|
||||||
|
@ -158,12 +157,12 @@ class WebContents : public mate::TrackableObject<WebContents>,
|
||||||
const std::string GetWebRTCIPHandlingPolicy() const;
|
const std::string GetWebRTCIPHandlingPolicy() const;
|
||||||
void SetWebRTCIPHandlingPolicy(const std::string& webrtc_ip_handling_policy);
|
void SetWebRTCIPHandlingPolicy(const std::string& webrtc_ip_handling_policy);
|
||||||
bool IsCrashed() const;
|
bool IsCrashed() const;
|
||||||
void SetUserAgent(const std::string& user_agent, mate::Arguments* args);
|
void SetUserAgent(const std::string& user_agent, gin_helper::Arguments* args);
|
||||||
std::string GetUserAgent();
|
std::string GetUserAgent();
|
||||||
void InsertCSS(const std::string& css);
|
void InsertCSS(const std::string& css);
|
||||||
v8::Local<v8::Promise> SavePage(const base::FilePath& full_file_path,
|
v8::Local<v8::Promise> SavePage(const base::FilePath& full_file_path,
|
||||||
const content::SavePageType& save_type);
|
const content::SavePageType& save_type);
|
||||||
void OpenDevTools(mate::Arguments* args);
|
void OpenDevTools(gin_helper::Arguments* args);
|
||||||
void CloseDevTools();
|
void CloseDevTools();
|
||||||
bool IsDevToolsOpened();
|
bool IsDevToolsOpened();
|
||||||
bool IsDevToolsFocused();
|
bool IsDevToolsFocused();
|
||||||
|
@ -184,15 +183,15 @@ class WebContents : public mate::TrackableObject<WebContents>,
|
||||||
v8::Local<v8::Value> GetNativeView() const;
|
v8::Local<v8::Value> GetNativeView() const;
|
||||||
|
|
||||||
#if BUILDFLAG(ENABLE_PRINTING)
|
#if BUILDFLAG(ENABLE_PRINTING)
|
||||||
void Print(mate::Arguments* args);
|
void Print(gin_helper::Arguments* args);
|
||||||
std::vector<printing::PrinterBasicInfo> GetPrinterList();
|
std::vector<printing::PrinterBasicInfo> GetPrinterList();
|
||||||
// Print current page as PDF.
|
// Print current page as PDF.
|
||||||
v8::Local<v8::Promise> PrintToPDF(const base::DictionaryValue& settings);
|
v8::Local<v8::Promise> PrintToPDF(const base::DictionaryValue& settings);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// DevTools workspace api.
|
// DevTools workspace api.
|
||||||
void AddWorkSpace(mate::Arguments* args, const base::FilePath& path);
|
void AddWorkSpace(gin_helper::Arguments* args, const base::FilePath& path);
|
||||||
void RemoveWorkSpace(mate::Arguments* args, const base::FilePath& path);
|
void RemoveWorkSpace(gin_helper::Arguments* args, const base::FilePath& path);
|
||||||
|
|
||||||
// Editing commands.
|
// Editing commands.
|
||||||
void Undo();
|
void Undo();
|
||||||
|
@ -206,7 +205,7 @@ class WebContents : public mate::TrackableObject<WebContents>,
|
||||||
void Unselect();
|
void Unselect();
|
||||||
void Replace(const base::string16& word);
|
void Replace(const base::string16& word);
|
||||||
void ReplaceMisspelling(const base::string16& word);
|
void ReplaceMisspelling(const base::string16& word);
|
||||||
uint32_t FindInPage(mate::Arguments* args);
|
uint32_t FindInPage(gin_helper::Arguments* args);
|
||||||
void StopFindInPage(content::StopFindAction action);
|
void StopFindInPage(content::StopFindAction action);
|
||||||
void ShowDefinitionForSelection();
|
void ShowDefinitionForSelection();
|
||||||
void CopyImageAt(int x, int y);
|
void CopyImageAt(int x, int y);
|
||||||
|
@ -238,15 +237,16 @@ class WebContents : public mate::TrackableObject<WebContents>,
|
||||||
void SendInputEvent(v8::Isolate* isolate, v8::Local<v8::Value> input_event);
|
void SendInputEvent(v8::Isolate* isolate, v8::Local<v8::Value> input_event);
|
||||||
|
|
||||||
// Subscribe to the frame updates.
|
// Subscribe to the frame updates.
|
||||||
void BeginFrameSubscription(mate::Arguments* args);
|
void BeginFrameSubscription(gin_helper::Arguments* args);
|
||||||
void EndFrameSubscription();
|
void EndFrameSubscription();
|
||||||
|
|
||||||
// Dragging native items.
|
// Dragging native items.
|
||||||
void StartDrag(const mate::Dictionary& item, mate::Arguments* args);
|
void StartDrag(const gin_helper::Dictionary& item,
|
||||||
|
gin_helper::Arguments* args);
|
||||||
|
|
||||||
// Captures the page with |rect|, |callback| would be called when capturing is
|
// Captures the page with |rect|, |callback| would be called when capturing is
|
||||||
// done.
|
// done.
|
||||||
v8::Local<v8::Promise> CapturePage(mate::Arguments* args);
|
v8::Local<v8::Promise> CapturePage(gin_helper::Arguments* args);
|
||||||
|
|
||||||
// Methods for creating <webview>.
|
// Methods for creating <webview>.
|
||||||
bool IsGuest() const;
|
bool IsGuest() const;
|
||||||
|
@ -335,14 +335,14 @@ class WebContents : public mate::TrackableObject<WebContents>,
|
||||||
std::unique_ptr<content::WebContents> web_contents,
|
std::unique_ptr<content::WebContents> web_contents,
|
||||||
Type type);
|
Type type);
|
||||||
// Creates a new content::WebContents.
|
// Creates a new content::WebContents.
|
||||||
WebContents(v8::Isolate* isolate, const mate::Dictionary& options);
|
WebContents(v8::Isolate* isolate, const gin_helper::Dictionary& options);
|
||||||
~WebContents() override;
|
~WebContents() override;
|
||||||
|
|
||||||
void InitWithSessionAndOptions(
|
void InitWithSessionAndOptions(
|
||||||
v8::Isolate* isolate,
|
v8::Isolate* isolate,
|
||||||
std::unique_ptr<content::WebContents> web_contents,
|
std::unique_ptr<content::WebContents> web_contents,
|
||||||
mate::Handle<class Session> session,
|
gin::Handle<class Session> session,
|
||||||
const mate::Dictionary& options);
|
const gin_helper::Dictionary& options);
|
||||||
|
|
||||||
// content::WebContentsDelegate:
|
// content::WebContentsDelegate:
|
||||||
bool DidAddMessageToConsole(content::WebContents* source,
|
bool DidAddMessageToConsole(content::WebContents* source,
|
||||||
|
@ -526,7 +526,7 @@ class WebContents : public mate::TrackableObject<WebContents>,
|
||||||
IPC::Message* reply_msg);
|
IPC::Message* reply_msg);
|
||||||
|
|
||||||
void InitZoomController(content::WebContents* web_contents,
|
void InitZoomController(content::WebContents* web_contents,
|
||||||
const mate::Dictionary& options);
|
const gin_helper::Dictionary& options);
|
||||||
|
|
||||||
v8::Global<v8::Value> session_;
|
v8::Global<v8::Value> session_;
|
||||||
v8::Global<v8::Value> devtools_web_contents_;
|
v8::Global<v8::Value> devtools_web_contents_;
|
||||||
|
|
|
@ -5,11 +5,11 @@
|
||||||
#include "shell/browser/api/atom_api_web_contents_view.h"
|
#include "shell/browser/api/atom_api_web_contents_view.h"
|
||||||
|
|
||||||
#include "content/public/browser/web_contents_user_data.h"
|
#include "content/public/browser/web_contents_user_data.h"
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "shell/browser/api/atom_api_web_contents.h"
|
#include "shell/browser/api/atom_api_web_contents.h"
|
||||||
#include "shell/browser/browser.h"
|
#include "shell/browser/browser.h"
|
||||||
#include "shell/browser/ui/inspectable_web_contents_view.h"
|
#include "shell/browser/ui/inspectable_web_contents_view.h"
|
||||||
#include "shell/common/api/constructor.h"
|
#include "shell/common/api/constructor.h"
|
||||||
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
#include "shell/common/node_includes.h"
|
#include "shell/common/node_includes.h"
|
||||||
|
|
||||||
#if defined(OS_MACOSX)
|
#if defined(OS_MACOSX)
|
||||||
|
@ -44,7 +44,7 @@ namespace electron {
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
WebContentsView::WebContentsView(v8::Isolate* isolate,
|
WebContentsView::WebContentsView(v8::Isolate* isolate,
|
||||||
mate::Handle<WebContents> web_contents,
|
gin::Handle<WebContents> web_contents,
|
||||||
InspectableWebContents* iwc)
|
InspectableWebContents* iwc)
|
||||||
#if defined(OS_MACOSX)
|
#if defined(OS_MACOSX)
|
||||||
: View(new DelayedNativeViewHost(iwc->GetView()->GetNativeView())),
|
: View(new DelayedNativeViewHost(iwc->GetView()->GetNativeView())),
|
||||||
|
@ -80,22 +80,18 @@ void WebContentsView::WebContentsDestroyed() {
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::WrappableBase* WebContentsView::New(
|
mate::WrappableBase* WebContentsView::New(
|
||||||
gin::Arguments* args,
|
gin_helper::Arguments* args,
|
||||||
mate::Handle<WebContents> web_contents) {
|
gin::Handle<WebContents> web_contents) {
|
||||||
// Currently we only support InspectableWebContents, e.g. the WebContents
|
// Currently we only support InspectableWebContents, e.g. the WebContents
|
||||||
// created by users directly. To support devToolsWebContents we need to create
|
// created by users directly. To support devToolsWebContents we need to create
|
||||||
// a wrapper view.
|
// a wrapper view.
|
||||||
if (!web_contents->managed_web_contents()) {
|
if (!web_contents->managed_web_contents()) {
|
||||||
const char* error = "The WebContents must be created by user";
|
args->ThrowError("The WebContents must be created by user");
|
||||||
args->isolate()->ThrowException(
|
|
||||||
v8::Exception::Error(mate::StringToV8(args->isolate(), error)));
|
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
// Check if the WebContents has already been added to a view.
|
// Check if the WebContents has already been added to a view.
|
||||||
if (WebContentsViewRelay::FromWebContents(web_contents->web_contents())) {
|
if (WebContentsViewRelay::FromWebContents(web_contents->web_contents())) {
|
||||||
const char* error = "The WebContents has already been added to a View";
|
args->ThrowError("The WebContents has already been added to a View");
|
||||||
args->isolate()->ThrowException(
|
|
||||||
v8::Exception::Error(mate::StringToV8(args->isolate(), error)));
|
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
// Constructor call.
|
// Constructor call.
|
||||||
|
@ -123,7 +119,7 @@ void Initialize(v8::Local<v8::Object> exports,
|
||||||
v8::Local<v8::Context> context,
|
v8::Local<v8::Context> context,
|
||||||
void* priv) {
|
void* priv) {
|
||||||
v8::Isolate* isolate = context->GetIsolate();
|
v8::Isolate* isolate = context->GetIsolate();
|
||||||
mate::Dictionary dict(isolate, exports);
|
gin_helper::Dictionary dict(isolate, exports);
|
||||||
dict.Set("WebContentsView",
|
dict.Set("WebContentsView",
|
||||||
mate::CreateConstructor<WebContentsView>(
|
mate::CreateConstructor<WebContentsView>(
|
||||||
isolate, base::BindRepeating(&WebContentsView::New)));
|
isolate, base::BindRepeating(&WebContentsView::New)));
|
||||||
|
|
|
@ -6,7 +6,6 @@
|
||||||
#define SHELL_BROWSER_API_ATOM_API_WEB_CONTENTS_VIEW_H_
|
#define SHELL_BROWSER_API_ATOM_API_WEB_CONTENTS_VIEW_H_
|
||||||
|
|
||||||
#include "content/public/browser/web_contents_observer.h"
|
#include "content/public/browser/web_contents_observer.h"
|
||||||
#include "native_mate/handle.h"
|
|
||||||
#include "shell/browser/api/atom_api_view.h"
|
#include "shell/browser/api/atom_api_view.h"
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
@ -19,15 +18,15 @@ class WebContents;
|
||||||
|
|
||||||
class WebContentsView : public View, public content::WebContentsObserver {
|
class WebContentsView : public View, public content::WebContentsObserver {
|
||||||
public:
|
public:
|
||||||
static mate::WrappableBase* New(gin::Arguments* args,
|
static mate::WrappableBase* New(gin_helper::Arguments* args,
|
||||||
mate::Handle<WebContents> web_contents);
|
gin::Handle<WebContents> web_contents);
|
||||||
|
|
||||||
static void BuildPrototype(v8::Isolate* isolate,
|
static void BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::FunctionTemplate> prototype);
|
v8::Local<v8::FunctionTemplate> prototype);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
WebContentsView(v8::Isolate* isolate,
|
WebContentsView(v8::Isolate* isolate,
|
||||||
mate::Handle<WebContents> web_contents,
|
gin::Handle<WebContents> web_contents,
|
||||||
InspectableWebContents* iwc);
|
InspectableWebContents* iwc);
|
||||||
~WebContentsView() override;
|
~WebContentsView() override;
|
||||||
|
|
||||||
|
|
|
@ -3,12 +3,12 @@
|
||||||
// found in the LICENSE file.
|
// found in the LICENSE file.
|
||||||
|
|
||||||
#include "content/public/browser/browser_context.h"
|
#include "content/public/browser/browser_context.h"
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "shell/browser/web_contents_preferences.h"
|
#include "shell/browser/web_contents_preferences.h"
|
||||||
#include "shell/browser/web_contents_zoom_controller.h"
|
#include "shell/browser/web_contents_zoom_controller.h"
|
||||||
#include "shell/browser/web_view_manager.h"
|
#include "shell/browser/web_view_manager.h"
|
||||||
#include "shell/common/native_mate_converters/content_converter.h"
|
#include "shell/common/gin_converters/content_converter.h"
|
||||||
#include "shell/common/native_mate_converters/value_converter.h"
|
#include "shell/common/gin_converters/value_converter_gin_adapter.h"
|
||||||
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
#include "shell/common/node_includes.h"
|
#include "shell/common/node_includes.h"
|
||||||
#include "shell/common/options_switches.h"
|
#include "shell/common/options_switches.h"
|
||||||
|
|
||||||
|
@ -45,7 +45,7 @@ void Initialize(v8::Local<v8::Object> exports,
|
||||||
v8::Local<v8::Value> unused,
|
v8::Local<v8::Value> unused,
|
||||||
v8::Local<v8::Context> context,
|
v8::Local<v8::Context> context,
|
||||||
void* priv) {
|
void* priv) {
|
||||||
mate::Dictionary dict(context->GetIsolate(), exports);
|
gin_helper::Dictionary dict(context->GetIsolate(), exports);
|
||||||
dict.SetMethod("addGuest", &AddGuest);
|
dict.SetMethod("addGuest", &AddGuest);
|
||||||
dict.SetMethod("removeGuest", &RemoveGuest);
|
dict.SetMethod("removeGuest", &RemoveGuest);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,96 +0,0 @@
|
||||||
// Copyright (c) 2014 GitHub, Inc.
|
|
||||||
// Use of this source code is governed by the MIT license that can be
|
|
||||||
// found in the LICENSE file.
|
|
||||||
|
|
||||||
#include "shell/browser/api/event_emitter_deprecated.h"
|
|
||||||
|
|
||||||
#include <utility>
|
|
||||||
|
|
||||||
#include "content/public/browser/render_frame_host.h"
|
|
||||||
#include "native_mate/arguments.h"
|
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "native_mate/object_template_builder_deprecated.h"
|
|
||||||
#include "shell/browser/api/event.h"
|
|
||||||
#include "shell/common/node_includes.h"
|
|
||||||
#include "ui/events/event_constants.h"
|
|
||||||
|
|
||||||
namespace mate {
|
|
||||||
|
|
||||||
namespace {
|
|
||||||
|
|
||||||
v8::Persistent<v8::ObjectTemplate> event_template;
|
|
||||||
|
|
||||||
void PreventDefault(mate::Arguments* args) {
|
|
||||||
mate::Dictionary self(args->isolate(), args->GetThis());
|
|
||||||
self.Set("defaultPrevented", true);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create a pure JavaScript Event object.
|
|
||||||
v8::Local<v8::Object> CreateEventObject(v8::Isolate* isolate) {
|
|
||||||
if (event_template.IsEmpty()) {
|
|
||||||
event_template.Reset(
|
|
||||||
isolate,
|
|
||||||
ObjectTemplateBuilder(isolate, v8::ObjectTemplate::New(isolate))
|
|
||||||
.SetMethod("preventDefault", &PreventDefault)
|
|
||||||
.Build());
|
|
||||||
}
|
|
||||||
|
|
||||||
return v8::Local<v8::ObjectTemplate>::New(isolate, event_template)
|
|
||||||
->NewInstance(isolate->GetCurrentContext())
|
|
||||||
.ToLocalChecked();
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace
|
|
||||||
|
|
||||||
namespace internal {
|
|
||||||
|
|
||||||
v8::Local<v8::Object> CreateJSEvent(
|
|
||||||
v8::Isolate* isolate,
|
|
||||||
v8::Local<v8::Object> object,
|
|
||||||
content::RenderFrameHost* sender,
|
|
||||||
base::Optional<electron::mojom::ElectronBrowser::MessageSyncCallback>
|
|
||||||
callback) {
|
|
||||||
v8::Local<v8::Object> event;
|
|
||||||
bool use_native_event = sender && callback;
|
|
||||||
|
|
||||||
if (use_native_event) {
|
|
||||||
mate::Handle<mate::Event> native_event = mate::Event::Create(isolate);
|
|
||||||
native_event->SetCallback(std::move(callback));
|
|
||||||
event = v8::Local<v8::Object>::Cast(native_event.ToV8());
|
|
||||||
} else {
|
|
||||||
event = CreateEventObject(isolate);
|
|
||||||
}
|
|
||||||
mate::Dictionary dict(isolate, event);
|
|
||||||
dict.Set("sender", object);
|
|
||||||
if (sender)
|
|
||||||
dict.Set("frameId", sender->GetRoutingID());
|
|
||||||
return event;
|
|
||||||
}
|
|
||||||
|
|
||||||
v8::Local<v8::Object> CreateCustomEvent(v8::Isolate* isolate,
|
|
||||||
v8::Local<v8::Object> object,
|
|
||||||
v8::Local<v8::Object> custom_event) {
|
|
||||||
v8::Local<v8::Object> event = CreateEventObject(isolate);
|
|
||||||
(void)event->SetPrototype(custom_event->CreationContext(), custom_event);
|
|
||||||
mate::Dictionary(isolate, event).Set("sender", object);
|
|
||||||
return event;
|
|
||||||
}
|
|
||||||
|
|
||||||
v8::Local<v8::Object> CreateEventFromFlags(v8::Isolate* isolate, int flags) {
|
|
||||||
const int mouse_button_flags =
|
|
||||||
(ui::EF_RIGHT_MOUSE_BUTTON | ui::EF_LEFT_MOUSE_BUTTON |
|
|
||||||
ui::EF_MIDDLE_MOUSE_BUTTON | ui::EF_BACK_MOUSE_BUTTON |
|
|
||||||
ui::EF_FORWARD_MOUSE_BUTTON);
|
|
||||||
const int is_mouse_click = static_cast<bool>(flags & mouse_button_flags);
|
|
||||||
mate::Dictionary obj = mate::Dictionary::CreateEmpty(isolate);
|
|
||||||
obj.Set("shiftKey", static_cast<bool>(flags & ui::EF_SHIFT_DOWN));
|
|
||||||
obj.Set("ctrlKey", static_cast<bool>(flags & ui::EF_CONTROL_DOWN));
|
|
||||||
obj.Set("altKey", static_cast<bool>(flags & ui::EF_ALT_DOWN));
|
|
||||||
obj.Set("metaKey", static_cast<bool>(flags & ui::EF_COMMAND_DOWN));
|
|
||||||
obj.Set("triggeredByAccelerator", !is_mouse_click);
|
|
||||||
return obj.GetHandle();
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace internal
|
|
||||||
|
|
||||||
} // namespace mate
|
|
|
@ -1,128 +0,0 @@
|
||||||
// Copyright (c) 2014 GitHub, Inc.
|
|
||||||
// Use of this source code is governed by the MIT license that can be
|
|
||||||
// found in the LICENSE file.
|
|
||||||
|
|
||||||
#ifndef SHELL_BROWSER_API_EVENT_EMITTER_DEPRECATED_H_
|
|
||||||
#define SHELL_BROWSER_API_EVENT_EMITTER_DEPRECATED_H_
|
|
||||||
|
|
||||||
#include <utility>
|
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
#include "base/optional.h"
|
|
||||||
#include "content/public/browser/browser_thread.h"
|
|
||||||
#include "electron/shell/common/api/api.mojom.h"
|
|
||||||
#include "native_mate/wrappable.h"
|
|
||||||
#include "shell/common/api/event_emitter_caller_deprecated.h"
|
|
||||||
|
|
||||||
namespace content {
|
|
||||||
class RenderFrameHost;
|
|
||||||
}
|
|
||||||
|
|
||||||
namespace mate {
|
|
||||||
|
|
||||||
namespace internal {
|
|
||||||
|
|
||||||
v8::Local<v8::Object> CreateJSEvent(
|
|
||||||
v8::Isolate* isolate,
|
|
||||||
v8::Local<v8::Object> object,
|
|
||||||
content::RenderFrameHost* sender,
|
|
||||||
base::Optional<electron::mojom::ElectronBrowser::MessageSyncCallback>
|
|
||||||
callback);
|
|
||||||
v8::Local<v8::Object> CreateCustomEvent(v8::Isolate* isolate,
|
|
||||||
v8::Local<v8::Object> object,
|
|
||||||
v8::Local<v8::Object> event);
|
|
||||||
v8::Local<v8::Object> CreateEventFromFlags(v8::Isolate* isolate, int flags);
|
|
||||||
|
|
||||||
} // namespace internal
|
|
||||||
|
|
||||||
// Provide helperers to emit event in JavaScript.
|
|
||||||
template <typename T>
|
|
||||||
class EventEmitter : public Wrappable<T> {
|
|
||||||
public:
|
|
||||||
typedef std::vector<v8::Local<v8::Value>> ValueArray;
|
|
||||||
|
|
||||||
// Make the convinient methods visible:
|
|
||||||
// https://isocpp.org/wiki/faq/templates#nondependent-name-lookup-members
|
|
||||||
v8::Isolate* isolate() const { return Wrappable<T>::isolate(); }
|
|
||||||
v8::Local<v8::Object> GetWrapper() const {
|
|
||||||
return Wrappable<T>::GetWrapper();
|
|
||||||
}
|
|
||||||
v8::MaybeLocal<v8::Object> GetWrapper(v8::Isolate* isolate) const {
|
|
||||||
return Wrappable<T>::GetWrapper(isolate);
|
|
||||||
}
|
|
||||||
|
|
||||||
// this.emit(name, event, args...);
|
|
||||||
template <typename... Args>
|
|
||||||
bool EmitCustomEvent(base::StringPiece name,
|
|
||||||
v8::Local<v8::Object> event,
|
|
||||||
Args&&... args) {
|
|
||||||
return EmitWithEvent(
|
|
||||||
name, internal::CreateCustomEvent(isolate(), GetWrapper(), event),
|
|
||||||
std::forward<Args>(args)...);
|
|
||||||
}
|
|
||||||
|
|
||||||
// this.emit(name, new Event(flags), args...);
|
|
||||||
template <typename... Args>
|
|
||||||
bool EmitWithFlags(base::StringPiece name, int flags, Args&&... args) {
|
|
||||||
return EmitCustomEvent(name,
|
|
||||||
internal::CreateEventFromFlags(isolate(), flags),
|
|
||||||
std::forward<Args>(args)...);
|
|
||||||
}
|
|
||||||
|
|
||||||
// this.emit(name, new Event(), args...);
|
|
||||||
template <typename... Args>
|
|
||||||
bool Emit(base::StringPiece name, Args&&... args) {
|
|
||||||
return EmitWithSender(name, nullptr, base::nullopt,
|
|
||||||
std::forward<Args>(args)...);
|
|
||||||
}
|
|
||||||
|
|
||||||
// this.emit(name, new Event(sender, message), args...);
|
|
||||||
template <typename... Args>
|
|
||||||
bool EmitWithSender(
|
|
||||||
base::StringPiece name,
|
|
||||||
content::RenderFrameHost* sender,
|
|
||||||
base::Optional<electron::mojom::ElectronBrowser::InvokeCallback> callback,
|
|
||||||
Args&&... args) {
|
|
||||||
DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
|
|
||||||
v8::Locker locker(isolate());
|
|
||||||
v8::HandleScope handle_scope(isolate());
|
|
||||||
v8::Local<v8::Object> wrapper = GetWrapper();
|
|
||||||
if (wrapper.IsEmpty()) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
v8::Local<v8::Object> event = internal::CreateJSEvent(
|
|
||||||
isolate(), wrapper, sender, std::move(callback));
|
|
||||||
return EmitWithEvent(name, event, std::forward<Args>(args)...);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected:
|
|
||||||
EventEmitter() {}
|
|
||||||
|
|
||||||
private:
|
|
||||||
// this.emit(name, event, args...);
|
|
||||||
template <typename... Args>
|
|
||||||
bool EmitWithEvent(base::StringPiece name,
|
|
||||||
v8::Local<v8::Object> event,
|
|
||||||
Args&&... args) {
|
|
||||||
DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
|
|
||||||
// It's possible that |this| will be deleted by EmitEvent, so save anything
|
|
||||||
// we need from |this| before calling EmitEvent.
|
|
||||||
auto* isolate = this->isolate();
|
|
||||||
v8::Locker locker(isolate);
|
|
||||||
v8::HandleScope handle_scope(isolate);
|
|
||||||
auto context = isolate->GetCurrentContext();
|
|
||||||
EmitEvent(isolate, GetWrapper(), name, event, std::forward<Args>(args)...);
|
|
||||||
v8::Local<v8::Value> defaultPrevented;
|
|
||||||
if (event->Get(context, StringToV8(isolate, "defaultPrevented"))
|
|
||||||
.ToLocal(&defaultPrevented)) {
|
|
||||||
return defaultPrevented->BooleanValue(isolate);
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(EventEmitter);
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace mate
|
|
||||||
|
|
||||||
#endif // SHELL_BROWSER_API_EVENT_EMITTER_DEPRECATED_H_
|
|
|
@ -7,14 +7,14 @@
|
||||||
|
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
|
||||||
#include "shell/browser/api/trackable_object.h"
|
#include "shell/common/gin_helper/trackable_object.h"
|
||||||
#include "ui/views/layout/layout_manager.h"
|
#include "ui/views/layout/layout_manager.h"
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
|
||||||
namespace api {
|
namespace api {
|
||||||
|
|
||||||
class LayoutManager : public mate::TrackableObject<LayoutManager> {
|
class LayoutManager : public gin_helper::TrackableObject<LayoutManager> {
|
||||||
public:
|
public:
|
||||||
static mate::WrappableBase* New(mate::Arguments* args);
|
static mate::WrappableBase* New(mate::Arguments* args);
|
||||||
|
|
||||||
|
|
|
@ -34,7 +34,6 @@
|
||||||
#include "services/service_manager/public/cpp/connector.h"
|
#include "services/service_manager/public/cpp/connector.h"
|
||||||
#include "shell/app/atom_main_delegate.h"
|
#include "shell/app/atom_main_delegate.h"
|
||||||
#include "shell/browser/api/atom_api_app.h"
|
#include "shell/browser/api/atom_api_app.h"
|
||||||
#include "shell/browser/api/trackable_object.h"
|
|
||||||
#include "shell/browser/atom_browser_client.h"
|
#include "shell/browser/atom_browser_client.h"
|
||||||
#include "shell/browser/atom_browser_context.h"
|
#include "shell/browser/atom_browser_context.h"
|
||||||
#include "shell/browser/atom_paths.h"
|
#include "shell/browser/atom_paths.h"
|
||||||
|
@ -49,6 +48,7 @@
|
||||||
#include "shell/common/api/electron_bindings.h"
|
#include "shell/common/api/electron_bindings.h"
|
||||||
#include "shell/common/application_info.h"
|
#include "shell/common/application_info.h"
|
||||||
#include "shell/common/asar/asar_util.h"
|
#include "shell/common/asar/asar_util.h"
|
||||||
|
#include "shell/common/gin_helper/trackable_object.h"
|
||||||
#include "shell/common/node_bindings.h"
|
#include "shell/common/node_bindings.h"
|
||||||
#include "shell/common/node_includes.h"
|
#include "shell/common/node_includes.h"
|
||||||
#include "ui/base/idle/idle.h"
|
#include "ui/base/idle/idle.h"
|
||||||
|
|
|
@ -3,25 +3,25 @@
|
||||||
// found in the LICENSE file.
|
// found in the LICENSE file.
|
||||||
|
|
||||||
#include "shell/browser/lib/bluetooth_chooser.h"
|
#include "shell/browser/lib/bluetooth_chooser.h"
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "shell/common/native_mate_converters/once_callback.h"
|
|
||||||
#include "shell/common/native_mate_converters/string16_converter.h"
|
|
||||||
|
|
||||||
namespace mate {
|
#include "shell/common/gin_converters/callback_converter.h"
|
||||||
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
|
|
||||||
|
namespace gin {
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct Converter<electron::BluetoothChooser::DeviceInfo> {
|
struct Converter<electron::BluetoothChooser::DeviceInfo> {
|
||||||
static v8::Local<v8::Value> ToV8(
|
static v8::Local<v8::Value> ToV8(
|
||||||
v8::Isolate* isolate,
|
v8::Isolate* isolate,
|
||||||
const electron::BluetoothChooser::DeviceInfo& val) {
|
const electron::BluetoothChooser::DeviceInfo& val) {
|
||||||
mate::Dictionary dict = mate::Dictionary::CreateEmpty(isolate);
|
gin_helper::Dictionary dict = gin::Dictionary::CreateEmpty(isolate);
|
||||||
dict.Set("deviceName", val.device_name);
|
dict.Set("deviceName", val.device_name);
|
||||||
dict.Set("deviceId", val.device_id);
|
dict.Set("deviceId", val.device_id);
|
||||||
return mate::ConvertToV8(isolate, dict);
|
return gin::ConvertToV8(isolate, dict);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace mate
|
} // namespace gin
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
|
||||||
|
|
|
@ -11,10 +11,10 @@
|
||||||
|
|
||||||
#include "base/memory/ptr_util.h"
|
#include "base/memory/ptr_util.h"
|
||||||
#include "base/strings/utf_string_conversions.h"
|
#include "base/strings/utf_string_conversions.h"
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "shell/browser/browser.h"
|
#include "shell/browser/browser.h"
|
||||||
#include "shell/browser/window_list.h"
|
#include "shell/browser/window_list.h"
|
||||||
#include "shell/common/color_util.h"
|
#include "shell/common/color_util.h"
|
||||||
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
#include "shell/common/options_switches.h"
|
#include "shell/common/options_switches.h"
|
||||||
#include "ui/views/widget/widget.h"
|
#include "ui/views/widget/widget.h"
|
||||||
|
|
||||||
|
@ -45,7 +45,7 @@ gfx::Size GetExpandedWindowSize(const NativeWindow* window, gfx::Size size) {
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
NativeWindow::NativeWindow(const mate::Dictionary& options,
|
NativeWindow::NativeWindow(const gin_helper::Dictionary& options,
|
||||||
NativeWindow* parent)
|
NativeWindow* parent)
|
||||||
: widget_(new views::Widget), parent_(parent), weak_factory_(this) {
|
: widget_(new views::Widget), parent_(parent), weak_factory_(this) {
|
||||||
options.Get(options::kFrame, &has_frame_);
|
options.Get(options::kFrame, &has_frame_);
|
||||||
|
@ -67,7 +67,7 @@ NativeWindow::~NativeWindow() {
|
||||||
NotifyWindowClosed();
|
NotifyWindowClosed();
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeWindow::InitFromOptions(const mate::Dictionary& options) {
|
void NativeWindow::InitFromOptions(const gin_helper::Dictionary& options) {
|
||||||
// Setup window from options.
|
// Setup window from options.
|
||||||
int x = -1, y = -1;
|
int x = -1, y = -1;
|
||||||
bool center;
|
bool center;
|
||||||
|
|
|
@ -37,10 +37,13 @@ class RectF;
|
||||||
class Size;
|
class Size;
|
||||||
} // namespace gfx
|
} // namespace gfx
|
||||||
|
|
||||||
namespace mate {
|
namespace gin_helper {
|
||||||
class Dictionary;
|
class Dictionary;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace mate {
|
||||||
class PersistentDictionary;
|
class PersistentDictionary;
|
||||||
} // namespace mate
|
}
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
|
||||||
|
@ -60,10 +63,10 @@ class NativeWindow : public base::SupportsUserData,
|
||||||
|
|
||||||
// Create window with existing WebContents, the caller is responsible for
|
// Create window with existing WebContents, the caller is responsible for
|
||||||
// managing the window's live.
|
// managing the window's live.
|
||||||
static NativeWindow* Create(const mate::Dictionary& options,
|
static NativeWindow* Create(const gin_helper::Dictionary& options,
|
||||||
NativeWindow* parent = nullptr);
|
NativeWindow* parent = nullptr);
|
||||||
|
|
||||||
void InitFromOptions(const mate::Dictionary& options);
|
void InitFromOptions(const gin_helper::Dictionary& options);
|
||||||
|
|
||||||
virtual void SetContentView(views::View* view) = 0;
|
virtual void SetContentView(views::View* view) = 0;
|
||||||
|
|
||||||
|
@ -304,7 +307,7 @@ class NativeWindow : public base::SupportsUserData,
|
||||||
std::list<NativeBrowserView*> browser_views() const { return browser_views_; }
|
std::list<NativeBrowserView*> browser_views() const { return browser_views_; }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
NativeWindow(const mate::Dictionary& options, NativeWindow* parent);
|
NativeWindow(const gin_helper::Dictionary& options, NativeWindow* parent);
|
||||||
|
|
||||||
// views::WidgetDelegate:
|
// views::WidgetDelegate:
|
||||||
views::Widget* GetWidget() override;
|
views::Widget* GetWidget() override;
|
||||||
|
|
|
@ -28,7 +28,7 @@ class RootViewMac;
|
||||||
|
|
||||||
class NativeWindowMac : public NativeWindow {
|
class NativeWindowMac : public NativeWindow {
|
||||||
public:
|
public:
|
||||||
NativeWindowMac(const mate::Dictionary& options, NativeWindow* parent);
|
NativeWindowMac(const gin_helper::Dictionary& options, NativeWindow* parent);
|
||||||
~NativeWindowMac() override;
|
~NativeWindowMac() override;
|
||||||
|
|
||||||
// NativeWindow:
|
// NativeWindow:
|
||||||
|
|
|
@ -17,7 +17,6 @@
|
||||||
#include "components/remote_cocoa/app_shim/native_widget_ns_window_bridge.h"
|
#include "components/remote_cocoa/app_shim/native_widget_ns_window_bridge.h"
|
||||||
#include "content/public/browser/browser_accessibility_state.h"
|
#include "content/public/browser/browser_accessibility_state.h"
|
||||||
#include "content/public/browser/desktop_media_id.h"
|
#include "content/public/browser/desktop_media_id.h"
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "shell/browser/native_browser_view_mac.h"
|
#include "shell/browser/native_browser_view_mac.h"
|
||||||
#include "shell/browser/ui/cocoa/atom_native_widget_mac.h"
|
#include "shell/browser/ui/cocoa/atom_native_widget_mac.h"
|
||||||
#include "shell/browser/ui/cocoa/atom_ns_window.h"
|
#include "shell/browser/ui/cocoa/atom_ns_window.h"
|
||||||
|
@ -29,6 +28,7 @@
|
||||||
#include "shell/browser/ui/inspectable_web_contents_view.h"
|
#include "shell/browser/ui/inspectable_web_contents_view.h"
|
||||||
#include "shell/browser/window_list.h"
|
#include "shell/browser/window_list.h"
|
||||||
#include "shell/common/deprecate_util.h"
|
#include "shell/common/deprecate_util.h"
|
||||||
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
#include "shell/common/options_switches.h"
|
#include "shell/common/options_switches.h"
|
||||||
#include "skia/ext/skia_utils_mac.h"
|
#include "skia/ext/skia_utils_mac.h"
|
||||||
#include "third_party/webrtc/modules/desktop_capture/mac/window_list_utils.h"
|
#include "third_party/webrtc/modules/desktop_capture/mac/window_list_utils.h"
|
||||||
|
@ -244,7 +244,7 @@
|
||||||
|
|
||||||
@end
|
@end
|
||||||
|
|
||||||
namespace mate {
|
namespace gin {
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct Converter<electron::NativeWindowMac::TitleBarStyle> {
|
struct Converter<electron::NativeWindowMac::TitleBarStyle> {
|
||||||
|
@ -268,7 +268,7 @@ struct Converter<electron::NativeWindowMac::TitleBarStyle> {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace mate
|
} // namespace gin
|
||||||
|
|
||||||
namespace electron {
|
namespace electron {
|
||||||
|
|
||||||
|
@ -318,7 +318,7 @@ void ViewDidMoveToSuperview(NSView* self, SEL _cmd) {
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
NativeWindowMac::NativeWindowMac(const mate::Dictionary& options,
|
NativeWindowMac::NativeWindowMac(const gin_helper::Dictionary& options,
|
||||||
NativeWindow* parent)
|
NativeWindow* parent)
|
||||||
: NativeWindow(options, parent), root_view_(new RootViewMac(this)) {
|
: NativeWindow(options, parent), root_view_(new RootViewMac(this)) {
|
||||||
int width = 800, height = 600;
|
int width = 800, height = 600;
|
||||||
|
@ -1659,7 +1659,7 @@ void NativeWindowMac::SetCollectionBehavior(bool on, NSUInteger flag) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
NativeWindow* NativeWindow::Create(const mate::Dictionary& options,
|
NativeWindow* NativeWindow::Create(const gin_helper::Dictionary& options,
|
||||||
NativeWindow* parent) {
|
NativeWindow* parent) {
|
||||||
return new NativeWindowMac(options, parent);
|
return new NativeWindowMac(options, parent);
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,7 +18,6 @@
|
||||||
#include "base/strings/utf_string_conversions.h"
|
#include "base/strings/utf_string_conversions.h"
|
||||||
#include "content/public/browser/browser_thread.h"
|
#include "content/public/browser/browser_thread.h"
|
||||||
#include "content/public/browser/desktop_media_id.h"
|
#include "content/public/browser/desktop_media_id.h"
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "shell/browser/api/atom_api_web_contents.h"
|
#include "shell/browser/api/atom_api_web_contents.h"
|
||||||
#include "shell/browser/native_browser_view_views.h"
|
#include "shell/browser/native_browser_view_views.h"
|
||||||
#include "shell/browser/ui/inspectable_web_contents.h"
|
#include "shell/browser/ui/inspectable_web_contents.h"
|
||||||
|
@ -28,7 +27,8 @@
|
||||||
#include "shell/browser/web_view_manager.h"
|
#include "shell/browser/web_view_manager.h"
|
||||||
#include "shell/browser/window_list.h"
|
#include "shell/browser/window_list.h"
|
||||||
#include "shell/common/atom_constants.h"
|
#include "shell/common/atom_constants.h"
|
||||||
#include "shell/common/native_mate_converters/image_converter.h"
|
#include "shell/common/gin_converters/image_converter.h"
|
||||||
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
#include "shell/common/options_switches.h"
|
#include "shell/common/options_switches.h"
|
||||||
#include "ui/aura/window_tree_host.h"
|
#include "ui/aura/window_tree_host.h"
|
||||||
#include "ui/base/hit_test.h"
|
#include "ui/base/hit_test.h"
|
||||||
|
@ -126,7 +126,7 @@ class NativeWindowClientView : public views::ClientView {
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
NativeWindowViews::NativeWindowViews(const mate::Dictionary& options,
|
NativeWindowViews::NativeWindowViews(const gin_helper::Dictionary& options,
|
||||||
NativeWindow* parent)
|
NativeWindow* parent)
|
||||||
: NativeWindow(options, parent),
|
: NativeWindow(options, parent),
|
||||||
root_view_(new RootView(this)),
|
root_view_(new RootView(this)),
|
||||||
|
@ -1454,7 +1454,7 @@ void NativeWindowViews::MoveBehindTaskBarIfNeeded() {
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
NativeWindow* NativeWindow::Create(const mate::Dictionary& options,
|
NativeWindow* NativeWindow::Create(const gin_helper::Dictionary& options,
|
||||||
NativeWindow* parent) {
|
NativeWindow* parent) {
|
||||||
return new NativeWindowViews(options, parent);
|
return new NativeWindowViews(options, parent);
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,7 +37,8 @@ class NativeWindowViews : public NativeWindow,
|
||||||
public views::WidgetObserver,
|
public views::WidgetObserver,
|
||||||
public ui::EventHandler {
|
public ui::EventHandler {
|
||||||
public:
|
public:
|
||||||
NativeWindowViews(const mate::Dictionary& options, NativeWindow* parent);
|
NativeWindowViews(const gin_helper::Dictionary& options,
|
||||||
|
NativeWindow* parent);
|
||||||
~NativeWindowViews() override;
|
~NativeWindowViews() override;
|
||||||
|
|
||||||
// NativeWindow:
|
// NativeWindow:
|
||||||
|
|
|
@ -388,8 +388,8 @@ void AtomURLLoaderFactory::StartLoadingHttp(
|
||||||
if (value->IsNull()) {
|
if (value->IsNull()) {
|
||||||
browser_context = AtomBrowserContext::From(base::GenerateGUID(), true);
|
browser_context = AtomBrowserContext::From(base::GenerateGUID(), true);
|
||||||
} else {
|
} else {
|
||||||
mate::Handle<api::Session> session;
|
gin::Handle<api::Session> session;
|
||||||
if (mate::ConvertFromV8(dict.isolate(), value, &session) &&
|
if (gin::ConvertFromV8(dict.isolate(), value, &session) &&
|
||||||
!session.IsEmpty()) {
|
!session.IsEmpty()) {
|
||||||
browser_context = session->browser_context();
|
browser_context = session->browser_context();
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,12 +19,12 @@
|
||||||
#include "content/public/common/content_switches.h"
|
#include "content/public/common/content_switches.h"
|
||||||
#include "content/public/common/web_preferences.h"
|
#include "content/public/common/web_preferences.h"
|
||||||
#include "electron/buildflags/buildflags.h"
|
#include "electron/buildflags/buildflags.h"
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "net/base/filename_util.h"
|
#include "net/base/filename_util.h"
|
||||||
#include "services/service_manager/sandbox/switches.h"
|
#include "services/service_manager/sandbox/switches.h"
|
||||||
#include "shell/browser/native_window.h"
|
#include "shell/browser/native_window.h"
|
||||||
#include "shell/browser/web_view_manager.h"
|
#include "shell/browser/web_view_manager.h"
|
||||||
#include "shell/common/native_mate_converters/value_converter.h"
|
#include "shell/common/gin_converters/value_converter_gin_adapter.h"
|
||||||
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
#include "shell/common/options_switches.h"
|
#include "shell/common/options_switches.h"
|
||||||
|
|
||||||
#if defined(OS_WIN)
|
#if defined(OS_WIN)
|
||||||
|
@ -101,16 +101,16 @@ std::vector<WebContentsPreferences*> WebContentsPreferences::instances_;
|
||||||
|
|
||||||
WebContentsPreferences::WebContentsPreferences(
|
WebContentsPreferences::WebContentsPreferences(
|
||||||
content::WebContents* web_contents,
|
content::WebContents* web_contents,
|
||||||
const mate::Dictionary& web_preferences)
|
const gin_helper::Dictionary& web_preferences)
|
||||||
: web_contents_(web_contents) {
|
: web_contents_(web_contents) {
|
||||||
v8::Isolate* isolate = web_preferences.isolate();
|
v8::Isolate* isolate = web_preferences.isolate();
|
||||||
mate::Dictionary copied(isolate, web_preferences.GetHandle()->Clone());
|
gin_helper::Dictionary copied(isolate, web_preferences.GetHandle()->Clone());
|
||||||
// Following fields should not be stored.
|
// Following fields should not be stored.
|
||||||
copied.Delete("embedder");
|
copied.Delete("embedder");
|
||||||
copied.Delete("session");
|
copied.Delete("session");
|
||||||
copied.Delete("type");
|
copied.Delete("type");
|
||||||
|
|
||||||
mate::ConvertFromV8(isolate, copied.GetHandle(), &preference_);
|
gin::ConvertFromV8(isolate, copied.GetHandle(), &preference_);
|
||||||
web_contents->SetUserData(UserDataKey(), base::WrapUnique(this));
|
web_contents->SetUserData(UserDataKey(), base::WrapUnique(this));
|
||||||
|
|
||||||
instances_.push_back(this);
|
instances_.push_back(this);
|
||||||
|
|
|
@ -19,7 +19,7 @@ namespace content {
|
||||||
struct WebPreferences;
|
struct WebPreferences;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace mate {
|
namespace gin_helper {
|
||||||
class Dictionary;
|
class Dictionary;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -33,7 +33,7 @@ class WebContentsPreferences
|
||||||
static WebContentsPreferences* From(content::WebContents* web_contents);
|
static WebContentsPreferences* From(content::WebContents* web_contents);
|
||||||
|
|
||||||
WebContentsPreferences(content::WebContents* web_contents,
|
WebContentsPreferences(content::WebContents* web_contents,
|
||||||
const mate::Dictionary& web_preferences);
|
const gin_helper::Dictionary& web_preferences);
|
||||||
~WebContentsPreferences() override;
|
~WebContentsPreferences() override;
|
||||||
|
|
||||||
// Set WebPreferences defaults onto the JS object.
|
// Set WebPreferences defaults onto the JS object.
|
||||||
|
|
|
@ -259,7 +259,7 @@ float NativeImage::GetAspectRatio() {
|
||||||
return static_cast<float>(size.width()) / static_cast<float>(size.height());
|
return static_cast<float>(size.width()) / static_cast<float>(size.height());
|
||||||
}
|
}
|
||||||
|
|
||||||
mate::Handle<NativeImage> NativeImage::Resize(
|
gin::Handle<NativeImage> NativeImage::Resize(
|
||||||
v8::Isolate* isolate,
|
v8::Isolate* isolate,
|
||||||
const base::DictionaryValue& options) {
|
const base::DictionaryValue& options) {
|
||||||
gfx::Size size = GetSize();
|
gfx::Size size = GetSize();
|
||||||
|
@ -290,16 +290,16 @@ mate::Handle<NativeImage> NativeImage::Resize(
|
||||||
|
|
||||||
gfx::ImageSkia resized = gfx::ImageSkiaOperations::CreateResizedImage(
|
gfx::ImageSkia resized = gfx::ImageSkiaOperations::CreateResizedImage(
|
||||||
image_.AsImageSkia(), method, size);
|
image_.AsImageSkia(), method, size);
|
||||||
return mate::CreateHandle(isolate,
|
return gin::CreateHandle(isolate,
|
||||||
new NativeImage(isolate, gfx::Image(resized)));
|
new NativeImage(isolate, gfx::Image(resized)));
|
||||||
}
|
}
|
||||||
|
|
||||||
mate::Handle<NativeImage> NativeImage::Crop(v8::Isolate* isolate,
|
gin::Handle<NativeImage> NativeImage::Crop(v8::Isolate* isolate,
|
||||||
const gfx::Rect& rect) {
|
const gfx::Rect& rect) {
|
||||||
gfx::ImageSkia cropped =
|
gfx::ImageSkia cropped =
|
||||||
gfx::ImageSkiaOperations::ExtractSubset(image_.AsImageSkia(), rect);
|
gfx::ImageSkiaOperations::ExtractSubset(image_.AsImageSkia(), rect);
|
||||||
return mate::CreateHandle(isolate,
|
return gin::CreateHandle(isolate,
|
||||||
new NativeImage(isolate, gfx::Image(cropped)));
|
new NativeImage(isolate, gfx::Image(cropped)));
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeImage::AddRepresentation(const gin_helper::Dictionary& options) {
|
void NativeImage::AddRepresentation(const gin_helper::Dictionary& options) {
|
||||||
|
@ -350,48 +350,48 @@ bool NativeImage::IsTemplateImage() {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::Handle<NativeImage> NativeImage::CreateEmpty(v8::Isolate* isolate) {
|
gin::Handle<NativeImage> NativeImage::CreateEmpty(v8::Isolate* isolate) {
|
||||||
return mate::CreateHandle(isolate, new NativeImage(isolate, gfx::Image()));
|
return gin::CreateHandle(isolate, new NativeImage(isolate, gfx::Image()));
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::Handle<NativeImage> NativeImage::Create(v8::Isolate* isolate,
|
gin::Handle<NativeImage> NativeImage::Create(v8::Isolate* isolate,
|
||||||
const gfx::Image& image) {
|
const gfx::Image& image) {
|
||||||
return mate::CreateHandle(isolate, new NativeImage(isolate, image));
|
return gin::CreateHandle(isolate, new NativeImage(isolate, image));
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::Handle<NativeImage> NativeImage::CreateFromPNG(v8::Isolate* isolate,
|
gin::Handle<NativeImage> NativeImage::CreateFromPNG(v8::Isolate* isolate,
|
||||||
const char* buffer,
|
const char* buffer,
|
||||||
size_t length) {
|
size_t length) {
|
||||||
gfx::Image image = gfx::Image::CreateFrom1xPNGBytes(
|
gfx::Image image = gfx::Image::CreateFrom1xPNGBytes(
|
||||||
reinterpret_cast<const unsigned char*>(buffer), length);
|
reinterpret_cast<const unsigned char*>(buffer), length);
|
||||||
return Create(isolate, image);
|
return Create(isolate, image);
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::Handle<NativeImage> NativeImage::CreateFromJPEG(v8::Isolate* isolate,
|
gin::Handle<NativeImage> NativeImage::CreateFromJPEG(v8::Isolate* isolate,
|
||||||
const char* buffer,
|
const char* buffer,
|
||||||
size_t length) {
|
size_t length) {
|
||||||
gfx::Image image = gfx::ImageFrom1xJPEGEncodedData(
|
gfx::Image image = gfx::ImageFrom1xJPEGEncodedData(
|
||||||
reinterpret_cast<const unsigned char*>(buffer), length);
|
reinterpret_cast<const unsigned char*>(buffer), length);
|
||||||
return Create(isolate, image);
|
return Create(isolate, image);
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::Handle<NativeImage> NativeImage::CreateFromPath(
|
gin::Handle<NativeImage> NativeImage::CreateFromPath(
|
||||||
v8::Isolate* isolate,
|
v8::Isolate* isolate,
|
||||||
const base::FilePath& path) {
|
const base::FilePath& path) {
|
||||||
base::FilePath image_path = NormalizePath(path);
|
base::FilePath image_path = NormalizePath(path);
|
||||||
#if defined(OS_WIN)
|
#if defined(OS_WIN)
|
||||||
if (image_path.MatchesExtension(FILE_PATH_LITERAL(".ico"))) {
|
if (image_path.MatchesExtension(FILE_PATH_LITERAL(".ico"))) {
|
||||||
return mate::CreateHandle(isolate, new NativeImage(isolate, image_path));
|
return gin::CreateHandle(isolate, new NativeImage(isolate, image_path));
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
gfx::ImageSkia image_skia;
|
gfx::ImageSkia image_skia;
|
||||||
electron::util::PopulateImageSkiaRepsFromPath(&image_skia, image_path);
|
electron::util::PopulateImageSkiaRepsFromPath(&image_skia, image_path);
|
||||||
gfx::Image image(image_skia);
|
gfx::Image image(image_skia);
|
||||||
mate::Handle<NativeImage> handle = Create(isolate, image);
|
gin::Handle<NativeImage> handle = Create(isolate, image);
|
||||||
#if defined(OS_MACOSX)
|
#if defined(OS_MACOSX)
|
||||||
if (IsTemplateFilename(image_path))
|
if (IsTemplateFilename(image_path))
|
||||||
handle->SetTemplateImage(true);
|
handle->SetTemplateImage(true);
|
||||||
|
@ -400,13 +400,13 @@ mate::Handle<NativeImage> NativeImage::CreateFromPath(
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::Handle<NativeImage> NativeImage::CreateFromBitmap(
|
gin::Handle<NativeImage> NativeImage::CreateFromBitmap(
|
||||||
gin_helper::ErrorThrower thrower,
|
gin_helper::ErrorThrower thrower,
|
||||||
v8::Local<v8::Value> buffer,
|
v8::Local<v8::Value> buffer,
|
||||||
const gin_helper::Dictionary& options) {
|
const gin_helper::Dictionary& options) {
|
||||||
if (!node::Buffer::HasInstance(buffer)) {
|
if (!node::Buffer::HasInstance(buffer)) {
|
||||||
thrower.ThrowError("buffer must be a node Buffer");
|
thrower.ThrowError("buffer must be a node Buffer");
|
||||||
return mate::Handle<NativeImage>();
|
return gin::Handle<NativeImage>();
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned int width = 0;
|
unsigned int width = 0;
|
||||||
|
@ -415,12 +415,12 @@ mate::Handle<NativeImage> NativeImage::CreateFromBitmap(
|
||||||
|
|
||||||
if (!options.Get("width", &width)) {
|
if (!options.Get("width", &width)) {
|
||||||
thrower.ThrowError("width is required");
|
thrower.ThrowError("width is required");
|
||||||
return mate::Handle<NativeImage>();
|
return gin::Handle<NativeImage>();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!options.Get("height", &height)) {
|
if (!options.Get("height", &height)) {
|
||||||
thrower.ThrowError("height is required");
|
thrower.ThrowError("height is required");
|
||||||
return mate::Handle<NativeImage>();
|
return gin::Handle<NativeImage>();
|
||||||
}
|
}
|
||||||
|
|
||||||
auto info = SkImageInfo::MakeN32(width, height, kPremul_SkAlphaType);
|
auto info = SkImageInfo::MakeN32(width, height, kPremul_SkAlphaType);
|
||||||
|
@ -428,7 +428,7 @@ mate::Handle<NativeImage> NativeImage::CreateFromBitmap(
|
||||||
|
|
||||||
if (size_bytes != node::Buffer::Length(buffer)) {
|
if (size_bytes != node::Buffer::Length(buffer)) {
|
||||||
thrower.ThrowError("invalid buffer size");
|
thrower.ThrowError("invalid buffer size");
|
||||||
return mate::Handle<NativeImage>();
|
return gin::Handle<NativeImage>();
|
||||||
}
|
}
|
||||||
|
|
||||||
options.Get("scaleFactor", &scale_factor);
|
options.Get("scaleFactor", &scale_factor);
|
||||||
|
@ -448,13 +448,13 @@ mate::Handle<NativeImage> NativeImage::CreateFromBitmap(
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::Handle<NativeImage> NativeImage::CreateFromBuffer(
|
gin::Handle<NativeImage> NativeImage::CreateFromBuffer(
|
||||||
gin_helper::ErrorThrower thrower,
|
gin_helper::ErrorThrower thrower,
|
||||||
v8::Local<v8::Value> buffer,
|
v8::Local<v8::Value> buffer,
|
||||||
gin::Arguments* args) {
|
gin::Arguments* args) {
|
||||||
if (!node::Buffer::HasInstance(buffer)) {
|
if (!node::Buffer::HasInstance(buffer)) {
|
||||||
thrower.ThrowError("buffer must be a node Buffer");
|
thrower.ThrowError("buffer must be a node Buffer");
|
||||||
return mate::Handle<NativeImage>();
|
return gin::Handle<NativeImage>();
|
||||||
}
|
}
|
||||||
|
|
||||||
int width = 0;
|
int width = 0;
|
||||||
|
@ -476,8 +476,8 @@ mate::Handle<NativeImage> NativeImage::CreateFromBuffer(
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
mate::Handle<NativeImage> NativeImage::CreateFromDataURL(v8::Isolate* isolate,
|
gin::Handle<NativeImage> NativeImage::CreateFromDataURL(v8::Isolate* isolate,
|
||||||
const GURL& url) {
|
const GURL& url) {
|
||||||
std::string mime_type, charset, data;
|
std::string mime_type, charset, data;
|
||||||
if (net::DataURL::Parse(url, &mime_type, &charset, &data)) {
|
if (net::DataURL::Parse(url, &mime_type, &charset, &data)) {
|
||||||
if (mime_type == "image/png")
|
if (mime_type == "image/png")
|
||||||
|
@ -490,7 +490,7 @@ mate::Handle<NativeImage> NativeImage::CreateFromDataURL(v8::Isolate* isolate,
|
||||||
}
|
}
|
||||||
|
|
||||||
#if !defined(OS_MACOSX)
|
#if !defined(OS_MACOSX)
|
||||||
mate::Handle<NativeImage> NativeImage::CreateFromNamedImage(
|
gin::Handle<NativeImage> NativeImage::CreateFromNamedImage(
|
||||||
gin::Arguments* args,
|
gin::Arguments* args,
|
||||||
const std::string& name) {
|
const std::string& name) {
|
||||||
return CreateEmpty(args->isolate());
|
return CreateEmpty(args->isolate());
|
||||||
|
@ -526,32 +526,31 @@ void NativeImage::BuildPrototype(v8::Isolate* isolate,
|
||||||
|
|
||||||
namespace gin {
|
namespace gin {
|
||||||
|
|
||||||
v8::Local<v8::Value> Converter<mate::Handle<electron::api::NativeImage>>::ToV8(
|
v8::Local<v8::Value> Converter<electron::api::NativeImage*>::ToV8(
|
||||||
v8::Isolate* isolate,
|
v8::Isolate* isolate,
|
||||||
const mate::Handle<electron::api::NativeImage>& val) {
|
electron::api::NativeImage* val) {
|
||||||
return val.ToV8();
|
if (val)
|
||||||
|
return val->GetWrapper();
|
||||||
|
else
|
||||||
|
return v8::Null(isolate);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Converter<mate::Handle<electron::api::NativeImage>>::FromV8(
|
bool Converter<electron::api::NativeImage*>::FromV8(
|
||||||
v8::Isolate* isolate,
|
v8::Isolate* isolate,
|
||||||
v8::Local<v8::Value> val,
|
v8::Local<v8::Value> val,
|
||||||
mate::Handle<electron::api::NativeImage>* out) {
|
electron::api::NativeImage** out) {
|
||||||
// Try converting from file path.
|
// Try converting from file path.
|
||||||
base::FilePath path;
|
base::FilePath path;
|
||||||
if (ConvertFromV8(isolate, val, &path)) {
|
if (ConvertFromV8(isolate, val, &path)) {
|
||||||
*out = electron::api::NativeImage::CreateFromPath(isolate, path);
|
*out = electron::api::NativeImage::CreateFromPath(isolate, path).get();
|
||||||
// Should throw when failed to initialize from path.
|
// Should throw when failed to initialize from path.
|
||||||
return !(*out)->image().IsEmpty();
|
return !(*out)->image().IsEmpty();
|
||||||
}
|
}
|
||||||
|
|
||||||
auto* wrapper = static_cast<mate::WrappableBase*>(
|
*out = static_cast<electron::api::NativeImage*>(
|
||||||
mate::internal::FromV8Impl(isolate, val));
|
static_cast<mate::WrappableBase*>(
|
||||||
if (!wrapper)
|
mate::internal::FromV8Impl(isolate, val)));
|
||||||
return false;
|
return *out != nullptr;
|
||||||
|
|
||||||
*out = mate::CreateHandle(isolate,
|
|
||||||
static_cast<electron::api::NativeImage*>(wrapper));
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace gin
|
} // namespace gin
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include "base/values.h"
|
#include "base/values.h"
|
||||||
#include "native_mate/handle.h"
|
#include "gin/handle.h"
|
||||||
#include "native_mate/wrappable.h"
|
#include "native_mate/wrappable.h"
|
||||||
#include "shell/common/gin_helper/error_thrower.h"
|
#include "shell/common/gin_helper/error_thrower.h"
|
||||||
#include "ui/gfx/image/image.h"
|
#include "ui/gfx/image/image.h"
|
||||||
|
@ -40,30 +40,29 @@ namespace api {
|
||||||
|
|
||||||
class NativeImage : public mate::Wrappable<NativeImage> {
|
class NativeImage : public mate::Wrappable<NativeImage> {
|
||||||
public:
|
public:
|
||||||
static mate::Handle<NativeImage> CreateEmpty(v8::Isolate* isolate);
|
static gin::Handle<NativeImage> CreateEmpty(v8::Isolate* isolate);
|
||||||
static mate::Handle<NativeImage> Create(v8::Isolate* isolate,
|
static gin::Handle<NativeImage> Create(v8::Isolate* isolate,
|
||||||
const gfx::Image& image);
|
const gfx::Image& image);
|
||||||
static mate::Handle<NativeImage> CreateFromPNG(v8::Isolate* isolate,
|
static gin::Handle<NativeImage> CreateFromPNG(v8::Isolate* isolate,
|
||||||
|
const char* buffer,
|
||||||
|
size_t length);
|
||||||
|
static gin::Handle<NativeImage> CreateFromJPEG(v8::Isolate* isolate,
|
||||||
const char* buffer,
|
const char* buffer,
|
||||||
size_t length);
|
size_t length);
|
||||||
static mate::Handle<NativeImage> CreateFromJPEG(v8::Isolate* isolate,
|
static gin::Handle<NativeImage> CreateFromPath(v8::Isolate* isolate,
|
||||||
const char* buffer,
|
const base::FilePath& path);
|
||||||
size_t length);
|
static gin::Handle<NativeImage> CreateFromBitmap(
|
||||||
static mate::Handle<NativeImage> CreateFromPath(v8::Isolate* isolate,
|
|
||||||
const base::FilePath& path);
|
|
||||||
static mate::Handle<NativeImage> CreateFromBitmap(
|
|
||||||
gin_helper::ErrorThrower thrower,
|
gin_helper::ErrorThrower thrower,
|
||||||
v8::Local<v8::Value> buffer,
|
v8::Local<v8::Value> buffer,
|
||||||
const gin_helper::Dictionary& options);
|
const gin_helper::Dictionary& options);
|
||||||
static mate::Handle<NativeImage> CreateFromBuffer(
|
static gin::Handle<NativeImage> CreateFromBuffer(
|
||||||
gin_helper::ErrorThrower thrower,
|
gin_helper::ErrorThrower thrower,
|
||||||
v8::Local<v8::Value> buffer,
|
v8::Local<v8::Value> buffer,
|
||||||
gin::Arguments* args);
|
gin::Arguments* args);
|
||||||
static mate::Handle<NativeImage> CreateFromDataURL(v8::Isolate* isolate,
|
static gin::Handle<NativeImage> CreateFromDataURL(v8::Isolate* isolate,
|
||||||
const GURL& url);
|
const GURL& url);
|
||||||
static mate::Handle<NativeImage> CreateFromNamedImage(
|
static gin::Handle<NativeImage> CreateFromNamedImage(gin::Arguments* args,
|
||||||
gin::Arguments* args,
|
const std::string& name);
|
||||||
const std::string& name);
|
|
||||||
|
|
||||||
static void BuildPrototype(v8::Isolate* isolate,
|
static void BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::FunctionTemplate> prototype);
|
v8::Local<v8::FunctionTemplate> prototype);
|
||||||
|
@ -87,9 +86,9 @@ class NativeImage : public mate::Wrappable<NativeImage> {
|
||||||
v8::Local<v8::Value> ToBitmap(gin::Arguments* args);
|
v8::Local<v8::Value> ToBitmap(gin::Arguments* args);
|
||||||
v8::Local<v8::Value> GetBitmap(gin::Arguments* args);
|
v8::Local<v8::Value> GetBitmap(gin::Arguments* args);
|
||||||
v8::Local<v8::Value> GetNativeHandle(gin_helper::ErrorThrower thrower);
|
v8::Local<v8::Value> GetNativeHandle(gin_helper::ErrorThrower thrower);
|
||||||
mate::Handle<NativeImage> Resize(v8::Isolate* isolate,
|
gin::Handle<NativeImage> Resize(v8::Isolate* isolate,
|
||||||
const base::DictionaryValue& options);
|
const base::DictionaryValue& options);
|
||||||
mate::Handle<NativeImage> Crop(v8::Isolate* isolate, const gfx::Rect& rect);
|
gin::Handle<NativeImage> Crop(v8::Isolate* isolate, const gfx::Rect& rect);
|
||||||
std::string ToDataURL(gin::Arguments* args);
|
std::string ToDataURL(gin::Arguments* args);
|
||||||
bool IsEmpty();
|
bool IsEmpty();
|
||||||
gfx::Size GetSize();
|
gfx::Size GetSize();
|
||||||
|
@ -119,36 +118,14 @@ namespace gin {
|
||||||
|
|
||||||
// A custom converter that allows converting path to NativeImage.
|
// A custom converter that allows converting path to NativeImage.
|
||||||
template <>
|
template <>
|
||||||
struct Converter<mate::Handle<electron::api::NativeImage>> {
|
struct Converter<electron::api::NativeImage*> {
|
||||||
static v8::Local<v8::Value> ToV8(
|
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate,
|
||||||
v8::Isolate* isolate,
|
electron::api::NativeImage* val);
|
||||||
const mate::Handle<electron::api::NativeImage>& val);
|
|
||||||
static bool FromV8(v8::Isolate* isolate,
|
static bool FromV8(v8::Isolate* isolate,
|
||||||
v8::Local<v8::Value> val,
|
v8::Local<v8::Value> val,
|
||||||
mate::Handle<electron::api::NativeImage>* out);
|
electron::api::NativeImage** out);
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace gin
|
} // namespace gin
|
||||||
|
|
||||||
namespace mate {
|
|
||||||
|
|
||||||
// Keep compatibility with native_mate code.
|
|
||||||
//
|
|
||||||
// TODO(zcbenz): Remove this after removing native_mate.
|
|
||||||
template <>
|
|
||||||
struct Converter<mate::Handle<electron::api::NativeImage>> {
|
|
||||||
static v8::Local<v8::Value> ToV8(
|
|
||||||
v8::Isolate* isolate,
|
|
||||||
const mate::Handle<electron::api::NativeImage>& val) {
|
|
||||||
return gin::ConvertToV8(isolate, val);
|
|
||||||
}
|
|
||||||
static bool FromV8(v8::Isolate* isolate,
|
|
||||||
v8::Local<v8::Value> val,
|
|
||||||
mate::Handle<electron::api::NativeImage>* out) {
|
|
||||||
return gin::ConvertFromV8(isolate, val, out);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace mate
|
|
||||||
|
|
||||||
#endif // SHELL_COMMON_API_ATOM_API_NATIVE_IMAGE_H_
|
#endif // SHELL_COMMON_API_ATOM_API_NATIVE_IMAGE_H_
|
||||||
|
|
|
@ -33,7 +33,7 @@ double safeShift(double in, double def) {
|
||||||
return def;
|
return def;
|
||||||
}
|
}
|
||||||
|
|
||||||
mate::Handle<NativeImage> NativeImage::CreateFromNamedImage(
|
gin::Handle<NativeImage> NativeImage::CreateFromNamedImage(
|
||||||
gin::Arguments* args,
|
gin::Arguments* args,
|
||||||
const std::string& name) {
|
const std::string& name) {
|
||||||
@autoreleasepool {
|
@autoreleasepool {
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
|
|
||||||
#include "base/hash/hash.h"
|
#include "base/hash/hash.h"
|
||||||
#include "electron/buildflags/buildflags.h"
|
#include "electron/buildflags/buildflags.h"
|
||||||
|
#include "shell/common/gin_converters/content_converter.h"
|
||||||
#include "shell/common/gin_converters/gurl_converter.h"
|
#include "shell/common/gin_converters/gurl_converter.h"
|
||||||
#include "shell/common/gin_helper/dictionary.h"
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
#include "shell/common/node_includes.h"
|
#include "shell/common/node_includes.h"
|
||||||
|
@ -19,10 +20,6 @@
|
||||||
#include "shell/common/api/remote/remote_object_freer.h"
|
#include "shell/common/api/remote/remote_object_freer.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// TODO(zcbenz): Remove the includes after removing native_mate.
|
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "shell/common/native_mate_converters/content_converter.h"
|
|
||||||
|
|
||||||
namespace std {
|
namespace std {
|
||||||
|
|
||||||
// The hash function used by DoubleIDWeakMap.
|
// The hash function used by DoubleIDWeakMap.
|
||||||
|
@ -125,11 +122,8 @@ void Initialize(v8::Local<v8::Object> exports,
|
||||||
dict.SetMethod("getObjectHash", &GetObjectHash);
|
dict.SetMethod("getObjectHash", &GetObjectHash);
|
||||||
dict.SetMethod("takeHeapSnapshot", &TakeHeapSnapshot);
|
dict.SetMethod("takeHeapSnapshot", &TakeHeapSnapshot);
|
||||||
#if BUILDFLAG(ENABLE_REMOTE_MODULE)
|
#if BUILDFLAG(ENABLE_REMOTE_MODULE)
|
||||||
// TODO(zcbenz): Use gin_helper::Dictionary when content_converter.h is moved
|
dict.SetMethod("setRemoteCallbackFreer",
|
||||||
// to gin.
|
&electron::RemoteCallbackFreer::BindTo);
|
||||||
mate::Dictionary mdict(context->GetIsolate(), exports);
|
|
||||||
mdict.SetMethod("setRemoteCallbackFreer",
|
|
||||||
&electron::RemoteCallbackFreer::BindTo);
|
|
||||||
dict.SetMethod("setRemoteObjectFreer", &electron::RemoteObjectFreer::BindTo);
|
dict.SetMethod("setRemoteObjectFreer", &electron::RemoteObjectFreer::BindTo);
|
||||||
dict.SetMethod("addRemoteObjectRef", &electron::RemoteObjectFreer::AddRef);
|
dict.SetMethod("addRemoteObjectRef", &electron::RemoteObjectFreer::AddRef);
|
||||||
dict.SetMethod("createIDWeakMap",
|
dict.SetMethod("createIDWeakMap",
|
||||||
|
|
|
@ -2,13 +2,13 @@
|
||||||
// Use of this source code is governed by the MIT license that can be
|
// Use of this source code is governed by the MIT license that can be
|
||||||
// found in the LICENSE file.
|
// found in the LICENSE file.
|
||||||
|
|
||||||
#include "shell/common/native_mate_converters/accelerator_converter.h"
|
#include "shell/common/gin_converters/accelerator_converter.h"
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include "shell/browser/ui/accelerator_util.h"
|
#include "shell/browser/ui/accelerator_util.h"
|
||||||
|
|
||||||
namespace mate {
|
namespace gin {
|
||||||
|
|
||||||
// static
|
// static
|
||||||
bool Converter<ui::Accelerator>::FromV8(v8::Isolate* isolate,
|
bool Converter<ui::Accelerator>::FromV8(v8::Isolate* isolate,
|
||||||
|
@ -20,4 +20,4 @@ bool Converter<ui::Accelerator>::FromV8(v8::Isolate* isolate,
|
||||||
return accelerator_util::StringToAccelerator(keycode, out);
|
return accelerator_util::StringToAccelerator(keycode, out);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace mate
|
} // namespace gin
|
|
@ -2,16 +2,16 @@
|
||||||
// Use of this source code is governed by the MIT license that can be
|
// Use of this source code is governed by the MIT license that can be
|
||||||
// found in the LICENSE file.
|
// found in the LICENSE file.
|
||||||
|
|
||||||
#ifndef SHELL_COMMON_NATIVE_MATE_CONVERTERS_ACCELERATOR_CONVERTER_H_
|
#ifndef SHELL_COMMON_GIN_CONVERTERS_ACCELERATOR_CONVERTER_H_
|
||||||
#define SHELL_COMMON_NATIVE_MATE_CONVERTERS_ACCELERATOR_CONVERTER_H_
|
#define SHELL_COMMON_GIN_CONVERTERS_ACCELERATOR_CONVERTER_H_
|
||||||
|
|
||||||
#include "native_mate/converter.h"
|
#include "gin/converter.h"
|
||||||
|
|
||||||
namespace ui {
|
namespace ui {
|
||||||
class Accelerator;
|
class Accelerator;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace mate {
|
namespace gin {
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct Converter<ui::Accelerator> {
|
struct Converter<ui::Accelerator> {
|
||||||
|
@ -20,6 +20,6 @@ struct Converter<ui::Accelerator> {
|
||||||
ui::Accelerator* out);
|
ui::Accelerator* out);
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace mate
|
} // namespace gin
|
||||||
|
|
||||||
#endif // SHELL_COMMON_NATIVE_MATE_CONVERTERS_ACCELERATOR_CONVERTER_H_
|
#endif // SHELL_COMMON_GIN_CONVERTERS_ACCELERATOR_CONVERTER_H_
|
|
@ -12,6 +12,15 @@
|
||||||
|
|
||||||
namespace gin {
|
namespace gin {
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct Converter<blink::WebKeyboardEvent> {
|
||||||
|
static bool FromV8(v8::Isolate* isolate,
|
||||||
|
v8::Local<v8::Value> val,
|
||||||
|
blink::WebKeyboardEvent* out) {
|
||||||
|
return mate::ConvertFromV8(isolate, val, out);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct Converter<blink::CloneableMessage> {
|
struct Converter<blink::CloneableMessage> {
|
||||||
static bool FromV8(v8::Isolate* isolate,
|
static bool FromV8(v8::Isolate* isolate,
|
||||||
|
@ -25,6 +34,46 @@ struct Converter<blink::CloneableMessage> {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct Converter<blink::WebDeviceEmulationParams> {
|
||||||
|
static bool FromV8(v8::Isolate* isolate,
|
||||||
|
v8::Local<v8::Value> val,
|
||||||
|
blink::WebDeviceEmulationParams* out) {
|
||||||
|
return mate::ConvertFromV8(isolate, val, out);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct Converter<blink::WebContextMenuData::MediaType> {
|
||||||
|
static v8::Local<v8::Value> ToV8(
|
||||||
|
v8::Isolate* isolate,
|
||||||
|
const blink::WebContextMenuData::MediaType& in) {
|
||||||
|
return mate::ConvertToV8(isolate, in);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct Converter<blink::WebContextMenuData::InputFieldType> {
|
||||||
|
static v8::Local<v8::Value> ToV8(
|
||||||
|
v8::Isolate* isolate,
|
||||||
|
const blink::WebContextMenuData::InputFieldType& in) {
|
||||||
|
return mate::ConvertToV8(isolate, in);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct Converter<network::mojom::ReferrerPolicy> {
|
||||||
|
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate,
|
||||||
|
const network::mojom::ReferrerPolicy& in) {
|
||||||
|
return mate::ConvertToV8(isolate, in);
|
||||||
|
}
|
||||||
|
static bool FromV8(v8::Isolate* isolate,
|
||||||
|
v8::Local<v8::Value> val,
|
||||||
|
network::mojom::ReferrerPolicy* out) {
|
||||||
|
return mate::ConvertFromV8(isolate, val, out);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
} // namespace gin
|
} // namespace gin
|
||||||
|
|
||||||
#endif // SHELL_COMMON_GIN_CONVERTERS_BLINK_CONVERTER_GIN_ADAPTER_H_
|
#endif // SHELL_COMMON_GIN_CONVERTERS_BLINK_CONVERTER_GIN_ADAPTER_H_
|
||||||
|
|
|
@ -2,22 +2,22 @@
|
||||||
// Use of this source code is governed by the MIT license that can be
|
// Use of this source code is governed by the MIT license that can be
|
||||||
// found in the LICENSE file.
|
// found in the LICENSE file.
|
||||||
|
|
||||||
#include "shell/common/native_mate_converters/content_converter.h"
|
#include "shell/common/gin_converters/content_converter.h"
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
|
#include "content/public/browser/native_web_keyboard_event.h"
|
||||||
#include "content/public/browser/web_contents.h"
|
#include "content/public/browser/web_contents.h"
|
||||||
#include "content/public/common/context_menu_params.h"
|
#include "content/public/common/context_menu_params.h"
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "shell/browser/api/atom_api_web_contents.h"
|
#include "shell/browser/api/atom_api_web_contents.h"
|
||||||
#include "shell/browser/web_contents_permission_helper.h"
|
#include "shell/browser/web_contents_permission_helper.h"
|
||||||
#include "shell/common/native_mate_converters/blink_converter.h"
|
#include "shell/common/gin_converters/blink_converter_gin_adapter.h"
|
||||||
#include "shell/common/native_mate_converters/callback_converter_deprecated.h"
|
#include "shell/common/gin_converters/callback_converter.h"
|
||||||
#include "shell/common/native_mate_converters/gurl_converter.h"
|
#include "shell/common/gin_converters/gurl_converter.h"
|
||||||
#include "shell/common/native_mate_converters/string16_converter.h"
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
#include "shell/common/native_mate_converters/ui_base_types_converter.h"
|
#include "ui/events/keycodes/dom/keycode_converter.h"
|
||||||
#include "shell/common/native_mate_converters/value_converter.h"
|
#include "ui/events/keycodes/keyboard_code_conversion.h"
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
|
@ -38,7 +38,7 @@ v8::Local<v8::Value> MenuItemToV8(
|
||||||
content::WebContents* web_contents,
|
content::WebContents* web_contents,
|
||||||
const content::CustomContextMenuContext& context,
|
const content::CustomContextMenuContext& context,
|
||||||
const content::MenuItem& item) {
|
const content::MenuItem& item) {
|
||||||
mate::Dictionary v8_item = mate::Dictionary::CreateEmpty(isolate);
|
gin_helper::Dictionary v8_item = gin::Dictionary::CreateEmpty(isolate);
|
||||||
switch (item.type) {
|
switch (item.type) {
|
||||||
case content::MenuItem::CHECKABLE_OPTION:
|
case content::MenuItem::CHECKABLE_OPTION:
|
||||||
case content::MenuItem::GROUP:
|
case content::MenuItem::GROUP:
|
||||||
|
@ -69,12 +69,31 @@ v8::Local<v8::Value> MenuToV8(v8::Isolate* isolate,
|
||||||
v8_menu.reserve(menu.size());
|
v8_menu.reserve(menu.size());
|
||||||
for (const auto& menu_item : menu)
|
for (const auto& menu_item : menu)
|
||||||
v8_menu.push_back(MenuItemToV8(isolate, web_contents, context, menu_item));
|
v8_menu.push_back(MenuItemToV8(isolate, web_contents, context, menu_item));
|
||||||
return mate::ConvertToV8(isolate, v8_menu);
|
return gin::ConvertToV8(isolate, v8_menu);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
namespace mate {
|
namespace gin {
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct Converter<ui::MenuSourceType> {
|
||||||
|
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate,
|
||||||
|
const ui::MenuSourceType& in) {
|
||||||
|
switch (in) {
|
||||||
|
case ui::MENU_SOURCE_MOUSE:
|
||||||
|
return StringToV8(isolate, "mouse");
|
||||||
|
case ui::MENU_SOURCE_KEYBOARD:
|
||||||
|
return StringToV8(isolate, "keyboard");
|
||||||
|
case ui::MENU_SOURCE_TOUCH:
|
||||||
|
return StringToV8(isolate, "touch");
|
||||||
|
case ui::MENU_SOURCE_TOUCH_EDIT_MENU:
|
||||||
|
return StringToV8(isolate, "touchMenu");
|
||||||
|
default:
|
||||||
|
return StringToV8(isolate, "none");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
// static
|
// static
|
||||||
v8::Local<v8::Value> Converter<content::MenuItem::Type>::ToV8(
|
v8::Local<v8::Value> Converter<content::MenuItem::Type>::ToV8(
|
||||||
|
@ -100,7 +119,7 @@ v8::Local<v8::Value> Converter<ContextMenuParamsWithWebContents>::ToV8(
|
||||||
v8::Isolate* isolate,
|
v8::Isolate* isolate,
|
||||||
const ContextMenuParamsWithWebContents& val) {
|
const ContextMenuParamsWithWebContents& val) {
|
||||||
const auto& params = val.first;
|
const auto& params = val.first;
|
||||||
mate::Dictionary dict = mate::Dictionary::CreateEmpty(isolate);
|
gin_helper::Dictionary dict = gin::Dictionary::CreateEmpty(isolate);
|
||||||
dict.Set("x", params.x);
|
dict.Set("x", params.x);
|
||||||
dict.Set("y", params.y);
|
dict.Set("y", params.y);
|
||||||
dict.Set("linkURL", params.link_url);
|
dict.Set("linkURL", params.link_url);
|
||||||
|
@ -109,13 +128,13 @@ v8::Local<v8::Value> Converter<ContextMenuParamsWithWebContents>::ToV8(
|
||||||
dict.Set("frameURL", params.frame_url);
|
dict.Set("frameURL", params.frame_url);
|
||||||
dict.Set("srcURL", params.src_url);
|
dict.Set("srcURL", params.src_url);
|
||||||
dict.Set("mediaType", params.media_type);
|
dict.Set("mediaType", params.media_type);
|
||||||
dict.Set("mediaFlags", MediaFlagsToV8(isolate, params.media_flags));
|
dict.Set("mediaFlags", mate::MediaFlagsToV8(isolate, params.media_flags));
|
||||||
bool has_image_contents =
|
bool has_image_contents =
|
||||||
(params.media_type == blink::WebContextMenuData::kMediaTypeImage) &&
|
(params.media_type == blink::WebContextMenuData::kMediaTypeImage) &&
|
||||||
params.has_image_contents;
|
params.has_image_contents;
|
||||||
dict.Set("hasImageContents", has_image_contents);
|
dict.Set("hasImageContents", has_image_contents);
|
||||||
dict.Set("isEditable", params.is_editable);
|
dict.Set("isEditable", params.is_editable);
|
||||||
dict.Set("editFlags", EditFlagsToV8(isolate, params.edit_flags));
|
dict.Set("editFlags", mate::EditFlagsToV8(isolate, params.edit_flags));
|
||||||
dict.Set("selectionText", params.selection_text);
|
dict.Set("selectionText", params.selection_text);
|
||||||
dict.Set("titleText", params.title_text);
|
dict.Set("titleText", params.title_text);
|
||||||
dict.Set("misspelledWord", params.misspelled_word);
|
dict.Set("misspelledWord", params.misspelled_word);
|
||||||
|
@ -126,7 +145,7 @@ v8::Local<v8::Value> Converter<ContextMenuParamsWithWebContents>::ToV8(
|
||||||
if (params.custom_context.is_pepper_menu)
|
if (params.custom_context.is_pepper_menu)
|
||||||
dict.Set("menu", MenuToV8(isolate, val.second, params.custom_context,
|
dict.Set("menu", MenuToV8(isolate, val.second, params.custom_context,
|
||||||
params.custom_items));
|
params.custom_items));
|
||||||
return mate::ConvertToV8(isolate, dict);
|
return gin::ConvertToV8(isolate, dict);
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
|
@ -215,7 +234,7 @@ bool Converter<content::WebContents*>::FromV8(v8::Isolate* isolate,
|
||||||
v8::Local<v8::Value> val,
|
v8::Local<v8::Value> val,
|
||||||
content::WebContents** out) {
|
content::WebContents** out) {
|
||||||
electron::api::WebContents* web_contents = nullptr;
|
electron::api::WebContents* web_contents = nullptr;
|
||||||
if (!ConvertFromV8(isolate, val, &web_contents) || !web_contents)
|
if (!gin::ConvertFromV8(isolate, val, &web_contents) || !web_contents)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
*out = web_contents->web_contents();
|
*out = web_contents->web_contents();
|
||||||
|
@ -226,17 +245,17 @@ bool Converter<content::WebContents*>::FromV8(v8::Isolate* isolate,
|
||||||
v8::Local<v8::Value> Converter<content::Referrer>::ToV8(
|
v8::Local<v8::Value> Converter<content::Referrer>::ToV8(
|
||||||
v8::Isolate* isolate,
|
v8::Isolate* isolate,
|
||||||
const content::Referrer& val) {
|
const content::Referrer& val) {
|
||||||
mate::Dictionary dict = mate::Dictionary::CreateEmpty(isolate);
|
gin_helper::Dictionary dict = gin::Dictionary::CreateEmpty(isolate);
|
||||||
dict.Set("url", ConvertToV8(isolate, val.url));
|
dict.Set("url", ConvertToV8(isolate, val.url));
|
||||||
dict.Set("policy", ConvertToV8(isolate, val.policy));
|
dict.Set("policy", ConvertToV8(isolate, val.policy));
|
||||||
return mate::ConvertToV8(isolate, dict);
|
return gin::ConvertToV8(isolate, dict);
|
||||||
}
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
bool Converter<content::Referrer>::FromV8(v8::Isolate* isolate,
|
bool Converter<content::Referrer>::FromV8(v8::Isolate* isolate,
|
||||||
v8::Local<v8::Value> val,
|
v8::Local<v8::Value> val,
|
||||||
content::Referrer* out) {
|
content::Referrer* out) {
|
||||||
mate::Dictionary dict;
|
gin_helper::Dictionary dict;
|
||||||
if (!ConvertFromV8(isolate, val, &dict))
|
if (!ConvertFromV8(isolate, val, &dict))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
@ -249,4 +268,42 @@ bool Converter<content::Referrer>::FromV8(v8::Isolate* isolate,
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace mate
|
// static
|
||||||
|
bool Converter<content::NativeWebKeyboardEvent>::FromV8(
|
||||||
|
v8::Isolate* isolate,
|
||||||
|
v8::Local<v8::Value> val,
|
||||||
|
content::NativeWebKeyboardEvent* out) {
|
||||||
|
gin_helper::Dictionary dict;
|
||||||
|
if (!ConvertFromV8(isolate, val, &dict))
|
||||||
|
return false;
|
||||||
|
if (!ConvertFromV8(isolate, val, static_cast<blink::WebKeyboardEvent*>(out)))
|
||||||
|
return false;
|
||||||
|
dict.Get("skipInBrowser", &out->skip_in_browser);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
v8::Local<v8::Value> Converter<content::NativeWebKeyboardEvent>::ToV8(
|
||||||
|
v8::Isolate* isolate,
|
||||||
|
const content::NativeWebKeyboardEvent& in) {
|
||||||
|
gin_helper::Dictionary dict = gin::Dictionary::CreateEmpty(isolate);
|
||||||
|
|
||||||
|
if (in.GetType() == blink::WebInputEvent::Type::kRawKeyDown)
|
||||||
|
dict.Set("type", "keyDown");
|
||||||
|
else if (in.GetType() == blink::WebInputEvent::Type::kKeyUp)
|
||||||
|
dict.Set("type", "keyUp");
|
||||||
|
dict.Set("key", ui::KeycodeConverter::DomKeyToKeyString(in.dom_key));
|
||||||
|
dict.Set("code", ui::KeycodeConverter::DomCodeToCodeString(
|
||||||
|
static_cast<ui::DomCode>(in.dom_code)));
|
||||||
|
|
||||||
|
using Modifiers = blink::WebInputEvent::Modifiers;
|
||||||
|
dict.Set("isAutoRepeat", (in.GetModifiers() & Modifiers::kIsAutoRepeat) != 0);
|
||||||
|
dict.Set("shift", (in.GetModifiers() & Modifiers::kShiftKey) != 0);
|
||||||
|
dict.Set("control", (in.GetModifiers() & Modifiers::kControlKey) != 0);
|
||||||
|
dict.Set("alt", (in.GetModifiers() & Modifiers::kAltKey) != 0);
|
||||||
|
dict.Set("meta", (in.GetModifiers() & Modifiers::kMetaKey) != 0);
|
||||||
|
|
||||||
|
return dict.GetHandle();
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace gin
|
|
@ -2,8 +2,8 @@
|
||||||
// Use of this source code is governed by the MIT license that can be
|
// Use of this source code is governed by the MIT license that can be
|
||||||
// found in the LICENSE file.
|
// found in the LICENSE file.
|
||||||
|
|
||||||
#ifndef SHELL_COMMON_NATIVE_MATE_CONVERTERS_CONTENT_CONVERTER_H_
|
#ifndef SHELL_COMMON_GIN_CONVERTERS_CONTENT_CONVERTER_H_
|
||||||
#define SHELL_COMMON_NATIVE_MATE_CONVERTERS_CONTENT_CONVERTER_H_
|
#define SHELL_COMMON_GIN_CONVERTERS_CONTENT_CONVERTER_H_
|
||||||
|
|
||||||
#include <utility>
|
#include <utility>
|
||||||
|
|
||||||
|
@ -11,18 +11,19 @@
|
||||||
#include "content/public/common/menu_item.h"
|
#include "content/public/common/menu_item.h"
|
||||||
#include "content/public/common/referrer.h"
|
#include "content/public/common/referrer.h"
|
||||||
#include "content/public/common/stop_find_action.h"
|
#include "content/public/common/stop_find_action.h"
|
||||||
#include "native_mate/converter.h"
|
#include "gin/converter.h"
|
||||||
#include "third_party/blink/public/mojom/permissions/permission_status.mojom.h"
|
#include "third_party/blink/public/mojom/permissions/permission_status.mojom.h"
|
||||||
|
|
||||||
namespace content {
|
namespace content {
|
||||||
struct ContextMenuParams;
|
struct ContextMenuParams;
|
||||||
|
struct NativeWebKeyboardEvent;
|
||||||
class WebContents;
|
class WebContents;
|
||||||
} // namespace content
|
} // namespace content
|
||||||
|
|
||||||
using ContextMenuParamsWithWebContents =
|
using ContextMenuParamsWithWebContents =
|
||||||
std::pair<content::ContextMenuParams, content::WebContents*>;
|
std::pair<content::ContextMenuParams, content::WebContents*>;
|
||||||
|
|
||||||
namespace mate {
|
namespace gin {
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct Converter<content::MenuItem::Type> {
|
struct Converter<content::MenuItem::Type> {
|
||||||
|
@ -74,6 +75,15 @@ struct Converter<content::Referrer> {
|
||||||
content::Referrer* out);
|
content::Referrer* out);
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace mate
|
template <>
|
||||||
|
struct Converter<content::NativeWebKeyboardEvent> {
|
||||||
|
static bool FromV8(v8::Isolate* isolate,
|
||||||
|
v8::Local<v8::Value> val,
|
||||||
|
content::NativeWebKeyboardEvent* out);
|
||||||
|
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate,
|
||||||
|
const content::NativeWebKeyboardEvent& in);
|
||||||
|
};
|
||||||
|
|
||||||
#endif // SHELL_COMMON_NATIVE_MATE_CONVERTERS_CONTENT_CONVERTER_H_
|
} // namespace gin
|
||||||
|
|
||||||
|
#endif // SHELL_COMMON_GIN_CONVERTERS_CONTENT_CONVERTER_H_
|
|
@ -27,9 +27,8 @@ bool Converter<gfx::Image>::FromV8(v8::Isolate* isolate,
|
||||||
if (val->IsNull())
|
if (val->IsNull())
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
// TODO(deermichel): remove mate:: after dropping mate
|
gin::Handle<electron::api::NativeImage> native_image;
|
||||||
mate::Handle<electron::api::NativeImage> native_image;
|
if (!gin::ConvertFromV8(isolate, val, &native_image))
|
||||||
if (!mate::ConvertFromV8(isolate, val, &native_image))
|
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
*out = native_image->image();
|
*out = native_image->image();
|
||||||
|
@ -38,7 +37,8 @@ bool Converter<gfx::Image>::FromV8(v8::Isolate* isolate,
|
||||||
|
|
||||||
v8::Local<v8::Value> Converter<gfx::Image>::ToV8(v8::Isolate* isolate,
|
v8::Local<v8::Value> Converter<gfx::Image>::ToV8(v8::Isolate* isolate,
|
||||||
const gfx::Image& val) {
|
const gfx::Image& val) {
|
||||||
return ConvertToV8(isolate, electron::api::NativeImage::Create(isolate, val));
|
return gin::ConvertToV8(isolate,
|
||||||
|
electron::api::NativeImage::Create(isolate, val));
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace gin
|
} // namespace gin
|
||||||
|
|
|
@ -285,6 +285,58 @@ v8::Local<v8::Value> Converter<network::ResourceRequestBody>::ToV8(
|
||||||
return arr;
|
return arr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
v8::Local<v8::Value>
|
||||||
|
Converter<scoped_refptr<network::ResourceRequestBody>>::ToV8(
|
||||||
|
v8::Isolate* isolate,
|
||||||
|
const scoped_refptr<network::ResourceRequestBody>& val) {
|
||||||
|
if (!val)
|
||||||
|
return v8::Null(isolate);
|
||||||
|
return ConvertToV8(isolate, *val);
|
||||||
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
bool Converter<scoped_refptr<network::ResourceRequestBody>>::FromV8(
|
||||||
|
v8::Isolate* isolate,
|
||||||
|
v8::Local<v8::Value> val,
|
||||||
|
scoped_refptr<network::ResourceRequestBody>* out) {
|
||||||
|
auto list = std::make_unique<base::ListValue>();
|
||||||
|
if (!ConvertFromV8(isolate, val, list.get()))
|
||||||
|
return false;
|
||||||
|
*out = new network::ResourceRequestBody();
|
||||||
|
for (size_t i = 0; i < list->GetSize(); ++i) {
|
||||||
|
base::DictionaryValue* dict = nullptr;
|
||||||
|
std::string type;
|
||||||
|
if (!list->GetDictionary(i, &dict))
|
||||||
|
return false;
|
||||||
|
dict->GetString("type", &type);
|
||||||
|
if (type == "rawData") {
|
||||||
|
base::Value* bytes = nullptr;
|
||||||
|
dict->GetBinary("bytes", &bytes);
|
||||||
|
(*out)->AppendBytes(
|
||||||
|
reinterpret_cast<const char*>(bytes->GetBlob().data()),
|
||||||
|
base::checked_cast<int>(bytes->GetBlob().size()));
|
||||||
|
} else if (type == "file") {
|
||||||
|
std::string file;
|
||||||
|
int offset = 0, length = -1;
|
||||||
|
double modification_time = 0.0;
|
||||||
|
dict->GetStringWithoutPathExpansion("filePath", &file);
|
||||||
|
dict->GetInteger("offset", &offset);
|
||||||
|
dict->GetInteger("file", &length);
|
||||||
|
dict->GetDouble("modificationTime", &modification_time);
|
||||||
|
(*out)->AppendFileRange(base::FilePath::FromUTF8Unsafe(file),
|
||||||
|
static_cast<uint64_t>(offset),
|
||||||
|
static_cast<uint64_t>(length),
|
||||||
|
base::Time::FromDoubleT(modification_time));
|
||||||
|
} else if (type == "blob") {
|
||||||
|
std::string uuid;
|
||||||
|
dict->GetString("blobUUID", &uuid);
|
||||||
|
(*out)->AppendBlob(uuid);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
v8::Local<v8::Value> Converter<network::ResourceRequest>::ToV8(
|
v8::Local<v8::Value> Converter<network::ResourceRequest>::ToV8(
|
||||||
v8::Isolate* isolate,
|
v8::Isolate* isolate,
|
||||||
|
|
|
@ -75,6 +75,16 @@ struct Converter<network::ResourceRequestBody> {
|
||||||
const network::ResourceRequestBody& val);
|
const network::ResourceRequestBody& val);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct Converter<scoped_refptr<network::ResourceRequestBody>> {
|
||||||
|
static v8::Local<v8::Value> ToV8(
|
||||||
|
v8::Isolate* isolate,
|
||||||
|
const scoped_refptr<network::ResourceRequestBody>& val);
|
||||||
|
static bool FromV8(v8::Isolate* isolate,
|
||||||
|
v8::Local<v8::Value> val,
|
||||||
|
scoped_refptr<network::ResourceRequestBody>* out);
|
||||||
|
};
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct Converter<network::ResourceRequest> {
|
struct Converter<network::ResourceRequest> {
|
||||||
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate,
|
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate,
|
||||||
|
|
|
@ -39,6 +39,13 @@ struct Converter<unsigned long> { // NOLINT(runtime/int)
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct Converter<std::nullptr_t> {
|
||||||
|
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate, std::nullptr_t val) {
|
||||||
|
return v8::Null(isolate);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct Converter<const char*> {
|
struct Converter<const char*> {
|
||||||
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate, const char* val) {
|
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate, const char* val) {
|
||||||
|
|
|
@ -4,6 +4,8 @@
|
||||||
|
|
||||||
#include "shell/common/gin_helper/event_emitter.h"
|
#include "shell/common/gin_helper/event_emitter.h"
|
||||||
|
|
||||||
|
#include "content/public/browser/render_frame_host.h"
|
||||||
|
#include "shell/browser/api/event.h"
|
||||||
#include "shell/common/gin_helper/dictionary.h"
|
#include "shell/common/gin_helper/dictionary.h"
|
||||||
#include "shell/common/gin_helper/object_template_builder.h"
|
#include "shell/common/gin_helper/object_template_builder.h"
|
||||||
#include "ui/events/event_constants.h"
|
#include "ui/events/event_constants.h"
|
||||||
|
@ -62,6 +64,30 @@ v8::Local<v8::Object> CreateEventFromFlags(v8::Isolate* isolate, int flags) {
|
||||||
return obj.GetHandle();
|
return obj.GetHandle();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
v8::Local<v8::Object> CreateNativeEvent(
|
||||||
|
v8::Isolate* isolate,
|
||||||
|
v8::Local<v8::Object> sender,
|
||||||
|
content::RenderFrameHost* frame,
|
||||||
|
base::Optional<electron::mojom::ElectronBrowser::MessageSyncCallback>
|
||||||
|
callback) {
|
||||||
|
v8::Local<v8::Object> event;
|
||||||
|
if (frame && callback) {
|
||||||
|
mate::Handle<mate::Event> native_event = mate::Event::Create(isolate);
|
||||||
|
native_event->SetCallback(std::move(callback));
|
||||||
|
event = v8::Local<v8::Object>::Cast(native_event.ToV8());
|
||||||
|
} else {
|
||||||
|
// No need to create native event if we do not need to send reply.
|
||||||
|
event = CreateEvent(isolate);
|
||||||
|
}
|
||||||
|
|
||||||
|
Dictionary dict(isolate, event);
|
||||||
|
dict.Set("sender", sender);
|
||||||
|
// Should always set frameId even when callback is null.
|
||||||
|
if (frame)
|
||||||
|
dict.Set("frameId", frame->GetRoutingID());
|
||||||
|
return event;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace internal
|
} // namespace internal
|
||||||
|
|
||||||
} // namespace gin_helper
|
} // namespace gin_helper
|
||||||
|
|
|
@ -9,9 +9,15 @@
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "base/optional.h"
|
#include "base/optional.h"
|
||||||
|
#include "content/public/browser/browser_thread.h"
|
||||||
#include "electron/shell/common/api/api.mojom.h"
|
#include "electron/shell/common/api/api.mojom.h"
|
||||||
|
#include "native_mate/wrappable.h"
|
||||||
#include "shell/common/gin_helper/event_emitter_caller.h"
|
#include "shell/common/gin_helper/event_emitter_caller.h"
|
||||||
|
|
||||||
|
namespace content {
|
||||||
|
class RenderFrameHost;
|
||||||
|
}
|
||||||
|
|
||||||
namespace gin_helper {
|
namespace gin_helper {
|
||||||
|
|
||||||
namespace internal {
|
namespace internal {
|
||||||
|
@ -21,16 +27,21 @@ v8::Local<v8::Object> CreateEvent(
|
||||||
v8::Local<v8::Object> sender = v8::Local<v8::Object>(),
|
v8::Local<v8::Object> sender = v8::Local<v8::Object>(),
|
||||||
v8::Local<v8::Object> custom_event = v8::Local<v8::Object>());
|
v8::Local<v8::Object> custom_event = v8::Local<v8::Object>());
|
||||||
v8::Local<v8::Object> CreateEventFromFlags(v8::Isolate* isolate, int flags);
|
v8::Local<v8::Object> CreateEventFromFlags(v8::Isolate* isolate, int flags);
|
||||||
|
v8::Local<v8::Object> CreateNativeEvent(
|
||||||
|
v8::Isolate* isolate,
|
||||||
|
v8::Local<v8::Object> sender,
|
||||||
|
content::RenderFrameHost* frame,
|
||||||
|
base::Optional<electron::mojom::ElectronBrowser::MessageSyncCallback>
|
||||||
|
callback);
|
||||||
|
|
||||||
} // namespace internal
|
} // namespace internal
|
||||||
|
|
||||||
// Provide helperers to emit event in JavaScript.
|
// Provide helperers to emit event in JavaScript.
|
||||||
//
|
template <typename T>
|
||||||
// TODO(zcbenz): Inherit from Wrappable directly after removing native_mate.
|
class EventEmitter : public mate::Wrappable<T> {
|
||||||
template <typename Base>
|
|
||||||
class EventEmitter : public Base {
|
|
||||||
public:
|
public:
|
||||||
typedef std::vector<v8::Local<v8::Value>> ValueArray;
|
using Base = mate::Wrappable<T>;
|
||||||
|
using ValueArray = std::vector<v8::Local<v8::Value>>;
|
||||||
|
|
||||||
// Make the convinient methods visible:
|
// Make the convinient methods visible:
|
||||||
// https://isocpp.org/wiki/faq/templates#nondependent-name-lookup-members
|
// https://isocpp.org/wiki/faq/templates#nondependent-name-lookup-members
|
||||||
|
@ -64,13 +75,30 @@ class EventEmitter : public Base {
|
||||||
v8::Locker locker(isolate());
|
v8::Locker locker(isolate());
|
||||||
v8::HandleScope handle_scope(isolate());
|
v8::HandleScope handle_scope(isolate());
|
||||||
v8::Local<v8::Object> wrapper = GetWrapper();
|
v8::Local<v8::Object> wrapper = GetWrapper();
|
||||||
if (wrapper.IsEmpty()) {
|
if (wrapper.IsEmpty())
|
||||||
return false;
|
return false;
|
||||||
}
|
|
||||||
v8::Local<v8::Object> event = internal::CreateEvent(isolate(), wrapper);
|
v8::Local<v8::Object> event = internal::CreateEvent(isolate(), wrapper);
|
||||||
return EmitWithEvent(name, event, std::forward<Args>(args)...);
|
return EmitWithEvent(name, event, std::forward<Args>(args)...);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// this.emit(name, new Event(sender, message), args...);
|
||||||
|
template <typename... Args>
|
||||||
|
bool EmitWithSender(
|
||||||
|
base::StringPiece name,
|
||||||
|
content::RenderFrameHost* sender,
|
||||||
|
base::Optional<electron::mojom::ElectronBrowser::InvokeCallback> callback,
|
||||||
|
Args&&... args) {
|
||||||
|
DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
|
||||||
|
v8::Locker locker(isolate());
|
||||||
|
v8::HandleScope handle_scope(isolate());
|
||||||
|
v8::Local<v8::Object> wrapper = GetWrapper();
|
||||||
|
if (wrapper.IsEmpty())
|
||||||
|
return false;
|
||||||
|
v8::Local<v8::Object> event = internal::CreateNativeEvent(
|
||||||
|
isolate(), wrapper, sender, std::move(callback));
|
||||||
|
return EmitWithEvent(name, event, std::forward<Args>(args)...);
|
||||||
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
EventEmitter() {}
|
EventEmitter() {}
|
||||||
|
|
||||||
|
|
|
@ -2,15 +2,16 @@
|
||||||
// Use of this source code is governed by the MIT license that can be
|
// Use of this source code is governed by the MIT license that can be
|
||||||
// found in the LICENSE file.
|
// found in the LICENSE file.
|
||||||
|
|
||||||
#include "shell/browser/api/trackable_object.h"
|
#include "shell/common/gin_helper/trackable_object.h"
|
||||||
|
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
|
||||||
#include "base/bind.h"
|
#include "base/bind.h"
|
||||||
#include "base/supports_user_data.h"
|
#include "base/supports_user_data.h"
|
||||||
#include "shell/browser/atom_browser_main_parts.h"
|
#include "shell/browser/atom_browser_main_parts.h"
|
||||||
|
#include "shell/common/api/locker.h"
|
||||||
|
|
||||||
namespace mate {
|
namespace gin_helper {
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
|
@ -31,6 +32,10 @@ class IDUserData : public base::SupportsUserData::Data {
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
TrackableObjectBase::TrackableObjectBase() : weak_factory_(this) {
|
TrackableObjectBase::TrackableObjectBase() : weak_factory_(this) {
|
||||||
|
// TODO(zcbenz): Make TrackedObject work in renderer process.
|
||||||
|
DCHECK(mate::Locker::IsBrowserProcess())
|
||||||
|
<< "This class only works for browser process";
|
||||||
|
|
||||||
electron::AtomBrowserMainParts::Get()->RegisterDestructionCallback(
|
electron::AtomBrowserMainParts::Get()->RegisterDestructionCallback(
|
||||||
GetDestroyClosure());
|
GetDestroyClosure());
|
||||||
}
|
}
|
||||||
|
@ -63,4 +68,4 @@ int32_t TrackableObjectBase::GetIDFromWrappedClass(
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace mate
|
} // namespace gin_helper
|
|
@ -2,22 +2,21 @@
|
||||||
// Use of this source code is governed by the MIT license that can be
|
// Use of this source code is governed by the MIT license that can be
|
||||||
// found in the LICENSE file.
|
// found in the LICENSE file.
|
||||||
|
|
||||||
#ifndef SHELL_BROWSER_API_TRACKABLE_OBJECT_H_
|
#ifndef SHELL_COMMON_GIN_HELPER_TRACKABLE_OBJECT_H_
|
||||||
#define SHELL_BROWSER_API_TRACKABLE_OBJECT_H_
|
#define SHELL_COMMON_GIN_HELPER_TRACKABLE_OBJECT_H_
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "base/bind.h"
|
#include "base/bind.h"
|
||||||
#include "base/memory/weak_ptr.h"
|
#include "base/memory/weak_ptr.h"
|
||||||
#include "native_mate/object_template_builder_deprecated.h"
|
#include "shell/common/gin_helper/event_emitter.h"
|
||||||
#include "shell/browser/api/event_emitter_deprecated.h"
|
|
||||||
#include "shell/common/key_weak_map.h"
|
#include "shell/common/key_weak_map.h"
|
||||||
|
|
||||||
namespace base {
|
namespace base {
|
||||||
class SupportsUserData;
|
class SupportsUserData;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace mate {
|
namespace gin_helper {
|
||||||
|
|
||||||
// Users should use TrackableObject instead.
|
// Users should use TrackableObject instead.
|
||||||
class TrackableObjectBase {
|
class TrackableObjectBase {
|
||||||
|
@ -51,21 +50,19 @@ class TrackableObjectBase {
|
||||||
|
|
||||||
// All instances of TrackableObject will be kept in a weak map and can be got
|
// All instances of TrackableObject will be kept in a weak map and can be got
|
||||||
// from its ID.
|
// from its ID.
|
||||||
//
|
template <typename T>
|
||||||
// TODO(zcbenz): Remove "typename B" after removing native_mate.
|
class TrackableObject : public TrackableObjectBase, public EventEmitter<T> {
|
||||||
template <typename T, typename B = mate::EventEmitter<T>>
|
|
||||||
class TrackableObject : public TrackableObjectBase, public B {
|
|
||||||
public:
|
public:
|
||||||
// Mark the JS object as destroyed.
|
// Mark the JS object as destroyed.
|
||||||
void MarkDestroyed() {
|
void MarkDestroyed() {
|
||||||
v8::Local<v8::Object> wrapper = Wrappable<T>::GetWrapper();
|
v8::Local<v8::Object> wrapper = mate::Wrappable<T>::GetWrapper();
|
||||||
if (!wrapper.IsEmpty()) {
|
if (!wrapper.IsEmpty()) {
|
||||||
wrapper->SetAlignedPointerInInternalField(0, nullptr);
|
wrapper->SetAlignedPointerInInternalField(0, nullptr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool IsDestroyed() {
|
bool IsDestroyed() {
|
||||||
v8::Local<v8::Object> wrapper = Wrappable<T>::GetWrapper();
|
v8::Local<v8::Object> wrapper = mate::Wrappable<T>::GetWrapper();
|
||||||
return wrapper->InternalFieldCount() == 0 ||
|
return wrapper->InternalFieldCount() == 0 ||
|
||||||
wrapper->GetAlignedPointerFromInternalField(0) == nullptr;
|
wrapper->GetAlignedPointerFromInternalField(0) == nullptr;
|
||||||
}
|
}
|
||||||
|
@ -80,7 +77,7 @@ class TrackableObject : public TrackableObjectBase, public B {
|
||||||
return nullptr;
|
return nullptr;
|
||||||
|
|
||||||
T* self = nullptr;
|
T* self = nullptr;
|
||||||
mate::ConvertFromV8(isolate, object.ToLocalChecked(), &self);
|
gin::ConvertFromV8(isolate, object.ToLocalChecked(), &self);
|
||||||
return self;
|
return self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -113,7 +110,7 @@ class TrackableObject : public TrackableObjectBase, public B {
|
||||||
~TrackableObject() override { RemoveFromWeakMap(); }
|
~TrackableObject() override { RemoveFromWeakMap(); }
|
||||||
|
|
||||||
void InitWith(v8::Isolate* isolate, v8::Local<v8::Object> wrapper) override {
|
void InitWith(v8::Isolate* isolate, v8::Local<v8::Object> wrapper) override {
|
||||||
WrappableBase::InitWith(isolate, wrapper);
|
mate::WrappableBase::InitWith(isolate, wrapper);
|
||||||
if (!weak_map_) {
|
if (!weak_map_) {
|
||||||
weak_map_ = new electron::KeyWeakMap<int32_t>;
|
weak_map_ = new electron::KeyWeakMap<int32_t>;
|
||||||
}
|
}
|
||||||
|
@ -127,12 +124,12 @@ class TrackableObject : public TrackableObjectBase, public B {
|
||||||
DISALLOW_COPY_AND_ASSIGN(TrackableObject);
|
DISALLOW_COPY_AND_ASSIGN(TrackableObject);
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T, typename B>
|
template <typename T>
|
||||||
int32_t TrackableObject<T, B>::next_id_ = 0;
|
int32_t TrackableObject<T>::next_id_ = 0;
|
||||||
|
|
||||||
template <typename T, typename B>
|
template <typename T>
|
||||||
electron::KeyWeakMap<int32_t>* TrackableObject<T, B>::weak_map_ = nullptr;
|
electron::KeyWeakMap<int32_t>* TrackableObject<T>::weak_map_ = nullptr;
|
||||||
|
|
||||||
} // namespace mate
|
} // namespace gin_helper
|
||||||
|
|
||||||
#endif // SHELL_BROWSER_API_TRACKABLE_OBJECT_H_
|
#endif // SHELL_COMMON_GIN_HELPER_TRACKABLE_OBJECT_H_
|
|
@ -11,7 +11,6 @@
|
||||||
|
|
||||||
#include "base/strings/string_util.h"
|
#include "base/strings/string_util.h"
|
||||||
#include "base/strings/utf_string_conversions.h"
|
#include "base/strings/utf_string_conversions.h"
|
||||||
#include "content/public/browser/native_web_keyboard_event.h"
|
|
||||||
#include "gin/converter.h"
|
#include "gin/converter.h"
|
||||||
#include "mojo/public/cpp/base/values_mojom_traits.h"
|
#include "mojo/public/cpp/base/values_mojom_traits.h"
|
||||||
#include "mojo/public/mojom/base/values.mojom.h"
|
#include "mojo/public/mojom/base/values.mojom.h"
|
||||||
|
@ -20,6 +19,7 @@
|
||||||
#include "shell/common/keyboard_util.h"
|
#include "shell/common/keyboard_util.h"
|
||||||
#include "shell/common/native_mate_converters/value_converter.h"
|
#include "shell/common/native_mate_converters/value_converter.h"
|
||||||
#include "third_party/blink/public/platform/web_input_event.h"
|
#include "third_party/blink/public/platform/web_input_event.h"
|
||||||
|
#include "third_party/blink/public/platform/web_keyboard_event.h"
|
||||||
#include "third_party/blink/public/platform/web_mouse_event.h"
|
#include "third_party/blink/public/platform/web_mouse_event.h"
|
||||||
#include "third_party/blink/public/platform/web_mouse_wheel_event.h"
|
#include "third_party/blink/public/platform/web_mouse_wheel_event.h"
|
||||||
#include "third_party/blink/public/web/web_device_emulation_params.h"
|
#include "third_party/blink/public/web/web_device_emulation_params.h"
|
||||||
|
@ -216,42 +216,6 @@ bool Converter<blink::WebKeyboardEvent>::FromV8(v8::Isolate* isolate,
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Converter<content::NativeWebKeyboardEvent>::FromV8(
|
|
||||||
v8::Isolate* isolate,
|
|
||||||
v8::Local<v8::Value> val,
|
|
||||||
content::NativeWebKeyboardEvent* out) {
|
|
||||||
mate::Dictionary dict;
|
|
||||||
if (!ConvertFromV8(isolate, val, &dict))
|
|
||||||
return false;
|
|
||||||
if (!ConvertFromV8(isolate, val, static_cast<blink::WebKeyboardEvent*>(out)))
|
|
||||||
return false;
|
|
||||||
dict.Get("skipInBrowser", &out->skip_in_browser);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
v8::Local<v8::Value> Converter<content::NativeWebKeyboardEvent>::ToV8(
|
|
||||||
v8::Isolate* isolate,
|
|
||||||
const content::NativeWebKeyboardEvent& in) {
|
|
||||||
mate::Dictionary dict = mate::Dictionary::CreateEmpty(isolate);
|
|
||||||
|
|
||||||
if (in.GetType() == blink::WebInputEvent::Type::kRawKeyDown)
|
|
||||||
dict.Set("type", "keyDown");
|
|
||||||
else if (in.GetType() == blink::WebInputEvent::Type::kKeyUp)
|
|
||||||
dict.Set("type", "keyUp");
|
|
||||||
dict.Set("key", ui::KeycodeConverter::DomKeyToKeyString(in.dom_key));
|
|
||||||
dict.Set("code", ui::KeycodeConverter::DomCodeToCodeString(
|
|
||||||
static_cast<ui::DomCode>(in.dom_code)));
|
|
||||||
|
|
||||||
using Modifiers = blink::WebInputEvent::Modifiers;
|
|
||||||
dict.Set("isAutoRepeat", (in.GetModifiers() & Modifiers::kIsAutoRepeat) != 0);
|
|
||||||
dict.Set("shift", (in.GetModifiers() & Modifiers::kShiftKey) != 0);
|
|
||||||
dict.Set("control", (in.GetModifiers() & Modifiers::kControlKey) != 0);
|
|
||||||
dict.Set("alt", (in.GetModifiers() & Modifiers::kAltKey) != 0);
|
|
||||||
dict.Set("meta", (in.GetModifiers() & Modifiers::kMetaKey) != 0);
|
|
||||||
|
|
||||||
return dict.GetHandle();
|
|
||||||
}
|
|
||||||
|
|
||||||
bool Converter<blink::WebMouseEvent>::FromV8(v8::Isolate* isolate,
|
bool Converter<blink::WebMouseEvent>::FromV8(v8::Isolate* isolate,
|
||||||
v8::Local<v8::Value> val,
|
v8::Local<v8::Value> val,
|
||||||
blink::WebMouseEvent* out) {
|
blink::WebMouseEvent* out) {
|
||||||
|
|
|
@ -21,10 +21,6 @@ struct WebPoint;
|
||||||
struct WebSize;
|
struct WebSize;
|
||||||
} // namespace blink
|
} // namespace blink
|
||||||
|
|
||||||
namespace content {
|
|
||||||
struct NativeWebKeyboardEvent;
|
|
||||||
}
|
|
||||||
|
|
||||||
namespace mate {
|
namespace mate {
|
||||||
|
|
||||||
blink::WebInputEvent::Type GetWebInputEventType(v8::Isolate* isolate,
|
blink::WebInputEvent::Type GetWebInputEventType(v8::Isolate* isolate,
|
||||||
|
@ -44,15 +40,6 @@ struct Converter<blink::WebKeyboardEvent> {
|
||||||
blink::WebKeyboardEvent* out);
|
blink::WebKeyboardEvent* out);
|
||||||
};
|
};
|
||||||
|
|
||||||
template <>
|
|
||||||
struct Converter<content::NativeWebKeyboardEvent> {
|
|
||||||
static bool FromV8(v8::Isolate* isolate,
|
|
||||||
v8::Local<v8::Value> val,
|
|
||||||
content::NativeWebKeyboardEvent* out);
|
|
||||||
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate,
|
|
||||||
const content::NativeWebKeyboardEvent& in);
|
|
||||||
};
|
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct Converter<blink::WebMouseEvent> {
|
struct Converter<blink::WebMouseEvent> {
|
||||||
static bool FromV8(v8::Isolate* isolate,
|
static bool FromV8(v8::Isolate* isolate,
|
||||||
|
|
|
@ -1,94 +0,0 @@
|
||||||
// Copyright (c) 2018 GitHub, Inc.
|
|
||||||
// Use of this source code is governed by the MIT license that can be
|
|
||||||
// found in the LICENSE file.
|
|
||||||
|
|
||||||
#include "shell/common/native_mate_converters/network_converter.h"
|
|
||||||
|
|
||||||
#include <memory>
|
|
||||||
#include <string>
|
|
||||||
#include <utility>
|
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
#include "base/numerics/safe_conversions.h"
|
|
||||||
#include "native_mate/dictionary.h"
|
|
||||||
#include "services/network/public/cpp/resource_request_body.h"
|
|
||||||
#include "shell/common/native_mate_converters/value_converter.h"
|
|
||||||
|
|
||||||
namespace mate {
|
|
||||||
|
|
||||||
// static
|
|
||||||
v8::Local<v8::Value>
|
|
||||||
Converter<scoped_refptr<network::ResourceRequestBody>>::ToV8(
|
|
||||||
v8::Isolate* isolate,
|
|
||||||
const scoped_refptr<network::ResourceRequestBody>& val) {
|
|
||||||
if (!val)
|
|
||||||
return v8::Null(isolate);
|
|
||||||
auto list = std::make_unique<base::ListValue>();
|
|
||||||
for (const auto& element : *(val->elements())) {
|
|
||||||
auto post_data_dict = std::make_unique<base::DictionaryValue>();
|
|
||||||
auto type = element.type();
|
|
||||||
if (type == network::mojom::DataElementType::kBytes) {
|
|
||||||
auto bytes = std::make_unique<base::Value>(std::vector<char>(
|
|
||||||
element.bytes(), element.bytes() + (element.length())));
|
|
||||||
post_data_dict->SetString("type", "rawData");
|
|
||||||
post_data_dict->Set("bytes", std::move(bytes));
|
|
||||||
} else if (type == network::mojom::DataElementType::kFile) {
|
|
||||||
post_data_dict->SetString("type", "file");
|
|
||||||
post_data_dict->SetKey("filePath",
|
|
||||||
base::Value(element.path().AsUTF8Unsafe()));
|
|
||||||
post_data_dict->SetInteger("offset", static_cast<int>(element.offset()));
|
|
||||||
post_data_dict->SetInteger("length", static_cast<int>(element.length()));
|
|
||||||
post_data_dict->SetDouble(
|
|
||||||
"modificationTime", element.expected_modification_time().ToDoubleT());
|
|
||||||
} else if (type == network::mojom::DataElementType::kBlob) {
|
|
||||||
post_data_dict->SetString("type", "blob");
|
|
||||||
post_data_dict->SetString("blobUUID", element.blob_uuid());
|
|
||||||
}
|
|
||||||
list->Append(std::move(post_data_dict));
|
|
||||||
}
|
|
||||||
return ConvertToV8(isolate, *list);
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
bool Converter<scoped_refptr<network::ResourceRequestBody>>::FromV8(
|
|
||||||
v8::Isolate* isolate,
|
|
||||||
v8::Local<v8::Value> val,
|
|
||||||
scoped_refptr<network::ResourceRequestBody>* out) {
|
|
||||||
auto list = std::make_unique<base::ListValue>();
|
|
||||||
if (!ConvertFromV8(isolate, val, list.get()))
|
|
||||||
return false;
|
|
||||||
*out = new network::ResourceRequestBody();
|
|
||||||
for (size_t i = 0; i < list->GetSize(); ++i) {
|
|
||||||
base::DictionaryValue* dict = nullptr;
|
|
||||||
std::string type;
|
|
||||||
if (!list->GetDictionary(i, &dict))
|
|
||||||
return false;
|
|
||||||
dict->GetString("type", &type);
|
|
||||||
if (type == "rawData") {
|
|
||||||
base::Value* bytes = nullptr;
|
|
||||||
dict->GetBinary("bytes", &bytes);
|
|
||||||
(*out)->AppendBytes(
|
|
||||||
reinterpret_cast<const char*>(bytes->GetBlob().data()),
|
|
||||||
base::checked_cast<int>(bytes->GetBlob().size()));
|
|
||||||
} else if (type == "file") {
|
|
||||||
std::string file;
|
|
||||||
int offset = 0, length = -1;
|
|
||||||
double modification_time = 0.0;
|
|
||||||
dict->GetStringWithoutPathExpansion("filePath", &file);
|
|
||||||
dict->GetInteger("offset", &offset);
|
|
||||||
dict->GetInteger("file", &length);
|
|
||||||
dict->GetDouble("modificationTime", &modification_time);
|
|
||||||
(*out)->AppendFileRange(base::FilePath::FromUTF8Unsafe(file),
|
|
||||||
static_cast<uint64_t>(offset),
|
|
||||||
static_cast<uint64_t>(length),
|
|
||||||
base::Time::FromDoubleT(modification_time));
|
|
||||||
} else if (type == "blob") {
|
|
||||||
std::string uuid;
|
|
||||||
dict->GetString("blobUUID", &uuid);
|
|
||||||
(*out)->AppendBlob(uuid);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace mate
|
|
|
@ -1,29 +0,0 @@
|
||||||
// Copyright (c) 2018 GitHub, Inc.
|
|
||||||
// Use of this source code is governed by the MIT license that can be
|
|
||||||
// found in the LICENSE file.
|
|
||||||
|
|
||||||
#ifndef SHELL_COMMON_NATIVE_MATE_CONVERTERS_NETWORK_CONVERTER_H_
|
|
||||||
#define SHELL_COMMON_NATIVE_MATE_CONVERTERS_NETWORK_CONVERTER_H_
|
|
||||||
|
|
||||||
#include "base/memory/scoped_refptr.h"
|
|
||||||
#include "native_mate/converter.h"
|
|
||||||
|
|
||||||
namespace network {
|
|
||||||
class ResourceRequestBody;
|
|
||||||
}
|
|
||||||
|
|
||||||
namespace mate {
|
|
||||||
|
|
||||||
template <>
|
|
||||||
struct Converter<scoped_refptr<network::ResourceRequestBody>> {
|
|
||||||
static v8::Local<v8::Value> ToV8(
|
|
||||||
v8::Isolate* isolate,
|
|
||||||
const scoped_refptr<network::ResourceRequestBody>& val);
|
|
||||||
static bool FromV8(v8::Isolate* isolate,
|
|
||||||
v8::Local<v8::Value> val,
|
|
||||||
scoped_refptr<network::ResourceRequestBody>* out);
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace mate
|
|
||||||
|
|
||||||
#endif // SHELL_COMMON_NATIVE_MATE_CONVERTERS_NETWORK_CONVERTER_H_
|
|
|
@ -1,34 +0,0 @@
|
||||||
// Copyright (c) 2016 GitHub, Inc.
|
|
||||||
// Use of this source code is governed by the MIT license that can be
|
|
||||||
// found in the LICENSE file.
|
|
||||||
|
|
||||||
#ifndef SHELL_COMMON_NATIVE_MATE_CONVERTERS_UI_BASE_TYPES_CONVERTER_H_
|
|
||||||
#define SHELL_COMMON_NATIVE_MATE_CONVERTERS_UI_BASE_TYPES_CONVERTER_H_
|
|
||||||
|
|
||||||
#include "native_mate/converter.h"
|
|
||||||
#include "ui/base/ui_base_types.h"
|
|
||||||
|
|
||||||
namespace mate {
|
|
||||||
|
|
||||||
template <>
|
|
||||||
struct Converter<ui::MenuSourceType> {
|
|
||||||
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate,
|
|
||||||
const ui::MenuSourceType& in) {
|
|
||||||
switch (in) {
|
|
||||||
case ui::MENU_SOURCE_MOUSE:
|
|
||||||
return mate::StringToV8(isolate, "mouse");
|
|
||||||
case ui::MENU_SOURCE_KEYBOARD:
|
|
||||||
return mate::StringToV8(isolate, "keyboard");
|
|
||||||
case ui::MENU_SOURCE_TOUCH:
|
|
||||||
return mate::StringToV8(isolate, "touch");
|
|
||||||
case ui::MENU_SOURCE_TOUCH_EDIT_MENU:
|
|
||||||
return mate::StringToV8(isolate, "touchMenu");
|
|
||||||
default:
|
|
||||||
return mate::StringToV8(isolate, "none");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace mate
|
|
||||||
|
|
||||||
#endif // SHELL_COMMON_NATIVE_MATE_CONVERTERS_UI_BASE_TYPES_CONVERTER_H_
|
|
|
@ -689,13 +689,11 @@ describe('webContents module', () => {
|
||||||
|
|
||||||
expect(() => {
|
expect(() => {
|
||||||
w.webContents.startDrag({ file: __filename } as any)
|
w.webContents.startDrag({ file: __filename } as any)
|
||||||
}).to.throw(`Must specify 'icon' option`)
|
}).to.throw(`Must specify non-empty 'icon' option`)
|
||||||
|
|
||||||
if (process.platform === 'darwin') {
|
expect(() => {
|
||||||
expect(() => {
|
w.webContents.startDrag({ file: __filename, icon: __filename })
|
||||||
w.webContents.startDrag({ file: __filename, icon: __filename })
|
}).to.throw(`Must specify non-empty 'icon' option`)
|
||||||
}).to.throw(`Must specify non-empty 'icon' option`)
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue