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

Side by Side Diff: chrome/browser/infobars/infobar_responder.cc

Issue 1143343005: chrome/browser: Remove use of MessageLoopProxy and deprecated MessageLoop APIs (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebased. Created 5 years, 6 months 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 unified diff | Download patch
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/infobars/infobar_responder.h" 5 #include "chrome/browser/infobars/infobar_responder.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/message_loop/message_loop.h" 8 #include "base/location.h"
9 #include "base/single_thread_task_runner.h"
10 #include "base/thread_task_runner_handle.h"
9 #include "chrome/browser/infobars/infobar_service.h" 11 #include "chrome/browser/infobars/infobar_service.h"
10 #include "components/infobars/core/confirm_infobar_delegate.h" 12 #include "components/infobars/core/confirm_infobar_delegate.h"
11 #include "components/infobars/core/infobar.h" 13 #include "components/infobars/core/infobar.h"
12 14
13 InfoBarResponder::InfoBarResponder(InfoBarService* infobar_service, 15 InfoBarResponder::InfoBarResponder(InfoBarService* infobar_service,
14 AutoResponseType response) 16 AutoResponseType response)
15 : infobar_service_(infobar_service), response_(response) { 17 : infobar_service_(infobar_service), response_(response) {
16 infobar_service_->AddObserver(this); 18 infobar_service_->AddObserver(this);
17 } 19 }
18 20
19 InfoBarResponder::~InfoBarResponder() { 21 InfoBarResponder::~InfoBarResponder() {
20 // This is safe even if we were already removed as an observer in 22 // This is safe even if we were already removed as an observer in
21 // OnInfoBarAdded(). 23 // OnInfoBarAdded().
22 infobar_service_->RemoveObserver(this); 24 infobar_service_->RemoveObserver(this);
23 } 25 }
24 26
25 void InfoBarResponder::OnInfoBarAdded(infobars::InfoBar* infobar) { 27 void InfoBarResponder::OnInfoBarAdded(infobars::InfoBar* infobar) {
26 infobar_service_->RemoveObserver(this); 28 infobar_service_->RemoveObserver(this);
27 ConfirmInfoBarDelegate* delegate = 29 ConfirmInfoBarDelegate* delegate =
28 infobar->delegate()->AsConfirmInfoBarDelegate(); 30 infobar->delegate()->AsConfirmInfoBarDelegate();
29 DCHECK(delegate); 31 DCHECK(delegate);
30 32
31 base::MessageLoop::current()->PostTask( 33 base::ThreadTaskRunnerHandle::Get()->PostTask(
32 FROM_HERE, 34 FROM_HERE,
33 base::Bind(&InfoBarResponder::Respond, base::Unretained(this), delegate)); 35 base::Bind(&InfoBarResponder::Respond, base::Unretained(this), delegate));
34 } 36 }
35 37
36 void InfoBarResponder::OnInfoBarReplaced(infobars::InfoBar* old_infobar, 38 void InfoBarResponder::OnInfoBarReplaced(infobars::InfoBar* old_infobar,
37 infobars::InfoBar* new_infobar) { 39 infobars::InfoBar* new_infobar) {
38 OnInfoBarAdded(new_infobar); 40 OnInfoBarAdded(new_infobar);
39 } 41 }
40 42
41 void InfoBarResponder::Respond(ConfirmInfoBarDelegate* delegate) { 43 void InfoBarResponder::Respond(ConfirmInfoBarDelegate* delegate) {
42 switch (response_) { 44 switch (response_) {
43 case ACCEPT: 45 case ACCEPT:
44 delegate->Accept(); 46 delegate->Accept();
45 break; 47 break;
46 case DENY: 48 case DENY:
47 delegate->Cancel(); 49 delegate->Cancel();
48 break; 50 break;
49 case DISMISS: 51 case DISMISS:
50 delegate->InfoBarDismissed(); 52 delegate->InfoBarDismissed();
51 break; 53 break;
52 } 54 }
53 } 55 }
OLDNEW
« no previous file with comments | « chrome/browser/history/web_history_service_unittest.cc ('k') | chrome/browser/intranet_redirect_detector.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698