refactor: remove WebContents::CreateFrom (#15241)

This commit is contained in:
Cheng Zhao 2018-10-19 17:52:07 +09:00 committed by GitHub
parent b3f134de06
commit 94aa0762f0
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 85 additions and 51 deletions

View file

@ -683,7 +683,7 @@ void App::OnLogin(scoped_refptr<LoginHandler> login_handler,
content::WebContents* web_contents = login_handler->GetWebContents(); content::WebContents* web_contents = login_handler->GetWebContents();
if (web_contents) { if (web_contents) {
prevent_default = Emit( prevent_default = Emit(
"login", WebContents::CreateFrom(isolate(), web_contents), "login", WebContents::FromOrCreate(isolate(), web_contents),
request_details, login_handler->auth_info(), request_details, login_handler->auth_info(),
base::Bind(&PassLoginInformation, base::RetainedRef(login_handler))); base::Bind(&PassLoginInformation, base::RetainedRef(login_handler)));
} }
@ -714,10 +714,13 @@ bool App::CanCreateWindow(
content::WebContents* web_contents = content::WebContents* web_contents =
content::WebContents::FromRenderFrameHost(opener); content::WebContents::FromRenderFrameHost(opener);
if (web_contents) { if (web_contents) {
auto api_web_contents = WebContents::CreateFrom(isolate(), web_contents); auto api_web_contents = WebContents::From(isolate(), web_contents);
// No need to emit any event if the WebContents is not available in JS.
if (!api_web_contents.IsEmpty()) {
api_web_contents->OnCreateWindow(target_url, referrer, frame_name, api_web_contents->OnCreateWindow(target_url, referrer, frame_name,
disposition, additional_features, body); disposition, additional_features, body);
} }
}
return false; return false;
} }
@ -735,7 +738,7 @@ void App::AllowCertificateError(
v8::Locker locker(isolate()); v8::Locker locker(isolate());
v8::HandleScope handle_scope(isolate()); v8::HandleScope handle_scope(isolate());
bool prevent_default = Emit( bool prevent_default = Emit(
"certificate-error", WebContents::CreateFrom(isolate(), web_contents), "certificate-error", WebContents::FromOrCreate(isolate(), web_contents),
request_url, net::ErrorToString(cert_error), ssl_info.cert, callback); request_url, net::ErrorToString(cert_error), ssl_info.cert, callback);
// Deny the certificate by default. // Deny the certificate by default.
@ -762,7 +765,7 @@ void App::SelectClientCertificate(
bool prevent_default = bool prevent_default =
Emit("select-client-certificate", Emit("select-client-certificate",
WebContents::CreateFrom(isolate(), web_contents), WebContents::FromOrCreate(isolate(), web_contents),
cert_request_info->host_and_port.ToString(), std::move(client_certs), cert_request_info->host_and_port.ToString(), std::move(client_certs),
base::Bind(&OnClientCertificateSelected, isolate(), shared_delegate, base::Bind(&OnClientCertificateSelected, isolate(), shared_delegate,
shared_identities)); shared_identities));

View file

@ -26,7 +26,7 @@ bool IsWebContents(v8::Isolate* isolate, content::RenderProcessHost* process) {
if (!web_contents) if (!web_contents)
return false; return false;
auto api_web_contents = WebContents::CreateFrom(isolate, web_contents); auto api_web_contents = WebContents::FromOrCreate(isolate, web_contents);
auto type = api_web_contents->GetType(); auto type = api_web_contents->GetType();
return type == WebContents::Type::BROWSER_WINDOW || return type == WebContents::Type::BROWSER_WINDOW ||
type == WebContents::Type::WEB_VIEW; type == WebContents::Type::WEB_VIEW;

View file

@ -310,21 +310,24 @@ struct WebContents::FrameDispatchHelper {
}; };
WebContents::WebContents(v8::Isolate* isolate, WebContents::WebContents(v8::Isolate* isolate,
content::WebContents* web_contents, content::WebContents* web_contents)
Type type) : content::WebContentsObserver(web_contents), type_(REMOTE) {
: content::WebContentsObserver(web_contents), type_(type) {
const mate::Dictionary options = mate::Dictionary::CreateEmpty(isolate);
if (type == REMOTE) {
web_contents->SetUserAgentOverride(GetBrowserContext()->GetUserAgent(), web_contents->SetUserAgentOverride(GetBrowserContext()->GetUserAgent(),
false); false);
Init(isolate); Init(isolate);
AttachAsUserData(web_contents); AttachAsUserData(web_contents);
InitZoomController(web_contents, options); InitZoomController(web_contents, mate::Dictionary::CreateEmpty(isolate));
} else { }
WebContents::WebContents(v8::Isolate* isolate,
content::WebContents* web_contents,
Type type)
: content::WebContentsObserver(web_contents), type_(type) {
DCHECK(type != REMOTE) << "Can't take ownership of a remote WebContents";
auto session = Session::CreateFrom(isolate, GetBrowserContext()); auto session = Session::CreateFrom(isolate, GetBrowserContext());
session_.Reset(isolate, session.ToV8()); session_.Reset(isolate, session.ToV8());
InitWithSessionAndOptions(isolate, web_contents, session, options); InitWithSessionAndOptions(isolate, web_contents, session,
} mate::Dictionary::CreateEmpty(isolate));
} }
WebContents::WebContents(v8::Isolate* isolate, WebContents::WebContents(v8::Isolate* isolate,
@ -538,8 +541,9 @@ void WebContents::WebContentsCreated(content::WebContents* source_contents,
content::WebContents* new_contents) { content::WebContents* new_contents) {
v8::Locker locker(isolate()); v8::Locker locker(isolate());
v8::HandleScope handle_scope(isolate()); v8::HandleScope handle_scope(isolate());
auto api_web_contents = CreateFrom(isolate(), new_contents, BROWSER_WINDOW); // Create V8 wrapper for the |new_contents|.
Emit("-web-contents-created", api_web_contents, target_url, frame_name); auto wrapper = CreateAndTake(isolate(), new_contents, BROWSER_WINDOW);
Emit("-web-contents-created", wrapper, target_url, frame_name);
} }
void WebContents::AddNewContents( void WebContents::AddNewContents(
@ -552,7 +556,11 @@ void WebContents::AddNewContents(
new ChildWebContentsTracker(new_contents.get()); new ChildWebContentsTracker(new_contents.get());
v8::Locker locker(isolate()); v8::Locker locker(isolate());
v8::HandleScope handle_scope(isolate()); v8::HandleScope handle_scope(isolate());
auto api_web_contents = CreateFrom(isolate(), new_contents.release()); // Note that the ownership of |new_contents| has already been claimed by
// the WebContentsCreated method, the release call here completes
// the ownership transfer.
auto api_web_contents = From(isolate(), new_contents.release());
DCHECK(!api_web_contents.IsEmpty());
if (Emit("-add-new-contents", api_web_contents, disposition, user_gesture, if (Emit("-add-new-contents", api_web_contents, disposition, user_gesture,
initial_rect.x(), initial_rect.y(), initial_rect.width(), initial_rect.x(), initial_rect.y(), initial_rect.width(),
initial_rect.height())) { initial_rect.height())) {
@ -979,8 +987,8 @@ void WebContents::DevToolsFocused() {
void WebContents::DevToolsOpened() { void WebContents::DevToolsOpened() {
v8::Locker locker(isolate()); v8::Locker locker(isolate());
v8::HandleScope handle_scope(isolate()); v8::HandleScope handle_scope(isolate());
auto handle = WebContents::CreateFrom( auto handle =
isolate(), managed_web_contents()->GetDevToolsWebContents()); FromOrCreate(isolate(), managed_web_contents()->GetDevToolsWebContents());
devtools_web_contents_.Reset(isolate(), handle.ToV8()); devtools_web_contents_.Reset(isolate(), handle.ToV8());
// Set inspected tabID. // Set inspected tabID.
@ -2180,32 +2188,40 @@ void WebContents::OnRendererMessageTo(content::RenderFrameHost* frame_host,
} }
// static // static
mate::Handle<WebContents> WebContents::CreateFrom( mate::Handle<WebContents> WebContents::Create(v8::Isolate* isolate,
v8::Isolate* isolate, const mate::Dictionary& options) {
content::WebContents* web_contents) { return mate::CreateHandle(isolate, new WebContents(isolate, options));
// We have an existing WebContents object in JS.
auto* existing = TrackableObject::FromWrappedClass(isolate, web_contents);
if (existing)
return mate::CreateHandle(isolate, static_cast<WebContents*>(existing));
// Otherwise create a new WebContents wrapper object.
return mate::CreateHandle(isolate,
new WebContents(isolate, web_contents, REMOTE));
} }
mate::Handle<WebContents> WebContents::CreateFrom( // static
mate::Handle<WebContents> WebContents::CreateAndTake(
v8::Isolate* isolate, v8::Isolate* isolate,
content::WebContents* web_contents, content::WebContents* web_contents,
Type type) { Type type) {
// Otherwise create a new WebContents wrapper object.
return mate::CreateHandle(isolate, return mate::CreateHandle(isolate,
new WebContents(isolate, web_contents, type)); new WebContents(isolate, web_contents, type));
} }
// static // static
mate::Handle<WebContents> WebContents::Create(v8::Isolate* isolate, mate::Handle<WebContents> WebContents::From(
const mate::Dictionary& options) { v8::Isolate* isolate,
return mate::CreateHandle(isolate, new WebContents(isolate, options)); content::WebContents* web_contents) {
auto* existing = TrackableObject::FromWrappedClass(isolate, web_contents);
if (existing)
return mate::CreateHandle(isolate, static_cast<WebContents*>(existing));
else
return mate::Handle<WebContents>();
}
// static
mate::Handle<WebContents> WebContents::FromOrCreate(
v8::Isolate* isolate,
content::WebContents* web_contents) {
auto existing = From(isolate, web_contents);
if (!existing.IsEmpty())
return existing;
else
return mate::CreateHandle(isolate, new WebContents(isolate, web_contents));
} }
} // namespace api } // namespace api

View file

@ -82,18 +82,29 @@ class WebContents : public mate::TrackableObject<WebContents>,
using PrintToPDFCallback = using PrintToPDFCallback =
base::Callback<void(v8::Local<v8::Value>, v8::Local<v8::Value>)>; base::Callback<void(v8::Local<v8::Value>, v8::Local<v8::Value>)>;
// Create from an existing WebContents. // Create a new WebContents and return the V8 wrapper of it.
static mate::Handle<WebContents> CreateFrom( static mate::Handle<WebContents> Create(v8::Isolate* isolate,
v8::Isolate* isolate, const mate::Dictionary& options);
content::WebContents* web_contents);
static mate::Handle<WebContents> CreateFrom( // Create a new V8 wrapper for an existing |web_content|.
//
// The lifetime of |web_contents| will be managed by this class.
static mate::Handle<WebContents> CreateAndTake(
v8::Isolate* isolate, v8::Isolate* isolate,
content::WebContents* web_contents, content::WebContents* web_contents,
Type type); Type type);
// Create a new WebContents. // Get the V8 wrapper of |web_content|, return empty handle if not wrapped.
static mate::Handle<WebContents> Create(v8::Isolate* isolate, static mate::Handle<WebContents> From(v8::Isolate* isolate,
const mate::Dictionary& options); content::WebContents* web_content);
// 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
// of this wrapper is always REMOTE.
static mate::Handle<WebContents> FromOrCreate(
v8::Isolate* isolate,
content::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);
@ -281,9 +292,13 @@ class WebContents : public mate::TrackableObject<WebContents>,
content::NavigationHandle* navigation_handle); content::NavigationHandle* navigation_handle);
protected: protected:
// Does not manage lifetime of |web_contents|.
WebContents(v8::Isolate* isolate, content::WebContents* web_contents);
// Takes over ownership of |web_contents|.
WebContents(v8::Isolate* isolate, WebContents(v8::Isolate* isolate,
content::WebContents* web_contents, content::WebContents* web_contents,
Type type); Type type);
// Creates a new content::WebContents.
WebContents(v8::Isolate* isolate, const mate::Dictionary& options); WebContents(v8::Isolate* isolate, const mate::Dictionary& options);
~WebContents() override; ~WebContents() override;

View file

@ -29,9 +29,9 @@ AtomNavigationThrottle::WillRedirectRequest() {
} }
auto api_contents = auto api_contents =
atom::api::WebContents::CreateFrom(v8::Isolate::GetCurrent(), contents); atom::api::WebContents::From(v8::Isolate::GetCurrent(), contents);
if (api_contents.IsEmpty()) { if (api_contents.IsEmpty()) {
NOTREACHED(); // No need to emit any event if the WebContents is not available in JS.
return PROCEED; return PROCEED;
} }

View file

@ -206,7 +206,7 @@ v8::Local<v8::Value> Converter<content::WebContents*>::ToV8(
content::WebContents* val) { content::WebContents* val) {
if (!val) if (!val)
return v8::Null(isolate); return v8::Null(isolate);
return atom::api::WebContents::CreateFrom(isolate, val).ToV8(); return atom::api::WebContents::FromOrCreate(isolate, val).ToV8();
} }
// static // static