Chromium Code Reviews| Index: chrome/browser/shell_integration.cc |
| diff --git a/chrome/browser/shell_integration.cc b/chrome/browser/shell_integration.cc |
| index 43b6dbc0f7b12996f3932b5154e54771661f3e3d..6ffe3be19a323d2d4e7fa08841894bea494f6f20 100644 |
| --- a/chrome/browser/shell_integration.cc |
| +++ b/chrome/browser/shell_integration.cc |
| @@ -45,6 +45,12 @@ bool SetAsDefaultBrowserInteractive() { |
| return false; |
| } |
| +void SetAsDefaultBrowserUsingSystemSettings( |
| + const base::Closure& on_finished_callback) { |
| + NOTREACHED(); |
|
Alexei Svitkine (slow)
2016/04/06 20:13:06
Why is this NOTREACHED()? Should have a comment.
Patrick Monette
2016/04/06 21:54:34
Done.
|
| + on_finished_callback.Run(); |
| +} |
| + |
| bool SetAsDefaultProtocolClientInteractive(const std::string& protocol) { |
| return false; |
| } |
| @@ -187,8 +193,10 @@ void DefaultWebClientWorker::CheckIsDefault(bool is_following_set_as_default) { |
| void DefaultWebClientWorker::SetAsDefault() { |
| DCHECK_CURRENTLY_ON(BrowserThread::FILE); |
| - SetAsDefaultImpl(); |
| - CheckIsDefault(true); |
| + |
| + // SetAsDefaultImpl will make sure the callback is executed exactly once. |
| + SetAsDefaultImpl( |
| + base::Bind(&DefaultWebClientWorker::CheckIsDefault, this, true)); |
| } |
| void DefaultWebClientWorker::ReportSetDefaultResult( |
| @@ -237,7 +245,8 @@ DefaultWebClientState DefaultBrowserWorker::CheckIsDefaultImpl() { |
| return GetDefaultBrowser(); |
| } |
| -void DefaultBrowserWorker::SetAsDefaultImpl() { |
| +void DefaultBrowserWorker::SetAsDefaultImpl( |
| + const base::Closure& on_finished_callback) { |
| switch (CanSetAsDefaultBrowser()) { |
| case SET_DEFAULT_NOT_ALLOWED: |
| NOTREACHED(); |
| @@ -249,7 +258,13 @@ void DefaultBrowserWorker::SetAsDefaultImpl() { |
| if (interactive_permitted_) |
| SetAsDefaultBrowserInteractive(); |
| break; |
| + case SET_DEFAULT_OPEN_SETTINGS: |
| + if (interactive_permitted_) { |
| + SetAsDefaultBrowserUsingSystemSettings(on_finished_callback); |
| + return; |
| + } |
|
Alexei Svitkine (slow)
2016/04/06 20:13:06
Nit: Add a break outside the if so that if a new c
Patrick Monette
2016/04/06 21:54:34
Done.
|
| } |
| + on_finished_callback.Run(); |
| } |
| /////////////////////////////////////////////////////////////////////////////// |
| @@ -274,7 +289,8 @@ DefaultWebClientState DefaultProtocolClientWorker::CheckIsDefaultImpl() { |
| return IsDefaultProtocolClient(protocol_); |
| } |
| -void DefaultProtocolClientWorker::SetAsDefaultImpl() { |
| +void DefaultProtocolClientWorker::SetAsDefaultImpl( |
| + const base::Closure& on_finished_callback) { |
| switch (CanSetAsDefaultProtocolClient()) { |
| case SET_DEFAULT_NOT_ALLOWED: |
| // Not allowed, do nothing. |
| @@ -283,11 +299,13 @@ void DefaultProtocolClientWorker::SetAsDefaultImpl() { |
| SetAsDefaultProtocolClient(protocol_); |
| break; |
| case SET_DEFAULT_INTERACTIVE: |
| - if (interactive_permitted_) { |
| + // TODO(pmonette): Implement SET_DEFAULT_OPEN_SETTINGS for Windows 10. |
| + case SET_DEFAULT_OPEN_SETTINGS: |
| + if (interactive_permitted_) |
| SetAsDefaultProtocolClientInteractive(protocol_); |
| - } |
| break; |
| } |
| + on_finished_callback.Run(); |
| } |
| } // namespace shell_integration |