Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(4728)

Unified Diff: chrome/browser/extensions/extension_install_prompt.cc

Issue 1534123002: [Extensions] Migrate ExtensionInstallPrompt::Delegate to be a callback (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/extensions/extension_install_prompt.cc
diff --git a/chrome/browser/extensions/extension_install_prompt.cc b/chrome/browser/extensions/extension_install_prompt.cc
index 6345f4f65b39c0c21d2a39bf15d0bcbeac5cfad8..cd27d50b8f7332c5d6b2488bdac7f8097c7fd8de 100644
--- a/chrome/browser/extensions/extension_install_prompt.cc
+++ b/chrome/browser/extensions/extension_install_prompt.cc
@@ -6,6 +6,7 @@
#include <utility>
+#include "base/callback_helpers.h"
#include "base/location.h"
#include "base/strings/string_number_conversions.h"
#include "base/strings/string_util.h"
@@ -146,25 +147,22 @@ SkBitmap GetDefaultIconBitmapForMaxScaleFactor(bool is_app) {
// If auto confirm is enabled then posts a task to proceed with or cancel the
// install and returns true. Otherwise returns false.
-bool AutoConfirmPrompt(ExtensionInstallPrompt::Delegate* delegate) {
+bool AutoConfirmPrompt(ExtensionInstallPrompt::DoneCallback* callback) {
switch (extensions::ScopedTestDialogAutoConfirm::GetAutoConfirmValue()) {
case extensions::ScopedTestDialogAutoConfirm::NONE:
return false;
- // We use PostTask instead of calling the delegate directly here, because in
+ // We use PostTask instead of calling the callback directly here, because in
// the real implementations it's highly likely the message loop will be
// pumping a few times before the user clicks accept or cancel.
case extensions::ScopedTestDialogAutoConfirm::ACCEPT:
base::MessageLoop::current()->PostTask(
- FROM_HERE,
- base::Bind(&ExtensionInstallPrompt::Delegate::InstallUIProceed,
- base::Unretained(delegate)));
+ FROM_HERE, base::Bind(base::ResetAndReturn(callback),
asargent_no_longer_on_chrome 2015/12/31 00:45:56 I'm probably missing something subtle here - can y
Devlin 2016/01/04 22:59:23 If the callback is run, then we have to reset the
+ ExtensionInstallPrompt::Result::ACCEPTED));
return true;
case extensions::ScopedTestDialogAutoConfirm::CANCEL:
base::ThreadTaskRunnerHandle::Get()->PostTask(
- FROM_HERE,
- base::Bind(&ExtensionInstallPrompt::Delegate::InstallUIAbort,
- base::Unretained(delegate),
- true));
+ FROM_HERE, base::Bind(base::ResetAndReturn(callback),
+ ExtensionInstallPrompt::Result::USER_CANCELED));
return true;
}
@@ -624,7 +622,6 @@ ExtensionInstallPrompt::ExtensionInstallPrompt(content::WebContents* contents)
install_ui_(extensions::CreateExtensionInstallUI(
ProfileForWebContents(contents))),
show_params_(new ExtensionInstallPromptShowParams(contents)),
- delegate_(NULL),
did_call_show_dialog_(false) {
}
@@ -636,7 +633,6 @@ ExtensionInstallPrompt::ExtensionInstallPrompt(Profile* profile,
install_ui_(extensions::CreateExtensionInstallUI(profile)),
show_params_(
new ExtensionInstallPromptShowParams(profile, native_window)),
- delegate_(NULL),
did_call_show_dialog_(false) {
}
@@ -644,26 +640,26 @@ ExtensionInstallPrompt::~ExtensionInstallPrompt() {
}
void ExtensionInstallPrompt::ShowDialog(
- Delegate* delegate,
+ const DoneCallback& done_callback,
const Extension* extension,
const SkBitmap* icon,
const ShowDialogCallback& show_dialog_callback) {
- ShowDialog(delegate, extension, icon,
+ ShowDialog(done_callback, extension, icon,
make_scoped_ptr(new Prompt(INSTALL_PROMPT)), show_dialog_callback);
}
void ExtensionInstallPrompt::ShowDialog(
- Delegate* delegate,
+ const DoneCallback& done_callback,
const Extension* extension,
const SkBitmap* icon,
scoped_ptr<Prompt> prompt,
const ShowDialogCallback& show_dialog_callback) {
- ShowDialog(delegate, extension, icon, std::move(prompt), nullptr,
+ ShowDialog(done_callback, extension, icon, std::move(prompt), nullptr,
show_dialog_callback);
}
void ExtensionInstallPrompt::ShowDialog(
- Delegate* delegate,
+ const DoneCallback& done_callback,
const Extension* extension,
const SkBitmap* icon,
scoped_ptr<Prompt> prompt,
@@ -672,7 +668,7 @@ void ExtensionInstallPrompt::ShowDialog(
DCHECK(ui_loop_ == base::MessageLoop::current());
DCHECK(prompt);
extension_ = extension;
- delegate_ = delegate;
+ done_callback_ = done_callback;
if (icon && !icon->empty())
SetIcon(icon);
prompt_ = std::move(prompt);
@@ -689,7 +685,7 @@ void ExtensionInstallPrompt::ShowDialog(
if (extension->is_theme()) {
if (extension->from_webstore() ||
extensions::FeatureSwitch::easy_off_store_install()->IsEnabled()) {
- delegate->InstallUIProceed();
+ done_callback.Run(Result::ACCEPTED);
return;
}
}
@@ -833,20 +829,19 @@ void ExtensionInstallPrompt::ShowConfirmation() {
prompt_->set_icon(gfx::Image::CreateFrom1xBitmap(icon_));
if (show_params_->WasParentDestroyed()) {
- delegate_->InstallUIAbort(false);
+ base::ResetAndReturn(&done_callback_).Run(Result::ABORTED);
return;
}
g_last_prompt_type_for_tests = prompt_->type();
did_call_show_dialog_ = true;
- if (AutoConfirmPrompt(delegate_))
+ if (AutoConfirmPrompt(&done_callback_))
return;
if (show_dialog_callback_.is_null())
- GetDefaultShowDialogCallback().Run(show_params_.get(), delegate_,
- std::move(prompt_));
- else
- show_dialog_callback_.Run(show_params_.get(), delegate_,
- std::move(prompt_));
+ show_dialog_callback_ = GetDefaultShowDialogCallback();
+ base::ResetAndReturn(&show_dialog_callback_)
+ .Run(show_params_.get(), base::ResetAndReturn(&done_callback_),
+ std::move(prompt_));
asargent_no_longer_on_chrome 2015/12/31 00:45:56 Similar to my above question, I don't quite get wh
Devlin 2016/01/04 22:59:23 Doing it directly on line 688 was a mistake. Even
asargent_no_longer_on_chrome 2016/01/05 18:58:54 Ok. I am slightly worried about an overall design
Devlin 2016/01/05 21:30:16 I agree - I'd like to not have to do this. But th
}

Powered by Google App Engine
This is Rietveld 408576698