OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/ui/intents/web_intent_picker_controller.h" | 5 #include "chrome/browser/ui/intents/web_intent_picker_controller.h" |
6 | 6 |
7 #include <vector> | 7 #include <vector> |
8 | 8 |
9 #include "base/bind.h" | 9 #include "base/bind.h" |
10 #include "base/bind_helpers.h" | 10 #include "base/bind_helpers.h" |
11 #include "base/memory/scoped_ptr.h" | 11 #include "base/memory/scoped_ptr.h" |
12 #include "base/utf_string_conversions.h" | 12 #include "base/utf_string_conversions.h" |
13 #include "chrome/browser/extensions/webstore_installer.h" | 13 #include "chrome/browser/extensions/webstore_installer.h" |
14 #include "chrome/browser/favicon/favicon_service.h" | 14 #include "chrome/browser/favicon/favicon_service.h" |
| 15 #include "chrome/browser/intents/cws_intents_registry_factory.h" |
15 #include "chrome/browser/intents/default_web_intent_service.h" | 16 #include "chrome/browser/intents/default_web_intent_service.h" |
16 #include "chrome/browser/intents/web_intents_registry_factory.h" | 17 #include "chrome/browser/intents/web_intents_registry_factory.h" |
17 #include "chrome/browser/intents/cws_intents_registry_factory.h" | |
18 #include "chrome/browser/profiles/profile.h" | 18 #include "chrome/browser/profiles/profile.h" |
19 #include "chrome/browser/tab_contents/tab_util.h" | 19 #include "chrome/browser/tab_contents/tab_util.h" |
20 #include "chrome/browser/tabs/tab_strip_model.h" | 20 #include "chrome/browser/tabs/tab_strip_model.h" |
21 #include "chrome/browser/ui/browser.h" | 21 #include "chrome/browser/ui/browser.h" |
22 #include "chrome/browser/ui/browser_list.h" | 22 #include "chrome/browser/ui/browser_list.h" |
23 #include "chrome/browser/ui/browser_navigator.h" | 23 #include "chrome/browser/ui/browser_navigator.h" |
24 #include "chrome/browser/ui/intents/web_intent_picker.h" | 24 #include "chrome/browser/ui/intents/web_intent_picker.h" |
25 #include "chrome/browser/ui/intents/web_intent_picker_model.h" | 25 #include "chrome/browser/ui/intents/web_intent_picker_model.h" |
26 #include "chrome/browser/ui/tab_contents/tab_contents_wrapper.h" | 26 #include "chrome/browser/ui/tab_contents/tab_contents_wrapper.h" |
27 #include "chrome/browser/webdata/web_data_service.h" | 27 #include "chrome/browser/webdata/web_data_service.h" |
(...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
94 return l10n_util::GetStringUTF16(IDS_WEB_INTENTS_ACTION_SUBSCRIBE); | 94 return l10n_util::GetStringUTF16(IDS_WEB_INTENTS_ACTION_SUBSCRIBE); |
95 else if (!action.compare(kSaveActionURL)) | 95 else if (!action.compare(kSaveActionURL)) |
96 return l10n_util::GetStringUTF16(IDS_WEB_INTENTS_ACTION_SAVE); | 96 return l10n_util::GetStringUTF16(IDS_WEB_INTENTS_ACTION_SAVE); |
97 else | 97 else |
98 return l10n_util::GetStringUTF16(IDS_INTENT_PICKER_CHOOSE_SERVICE); | 98 return l10n_util::GetStringUTF16(IDS_INTENT_PICKER_CHOOSE_SERVICE); |
99 } | 99 } |
100 | 100 |
101 // Self-deleting trampoline that forwards A URLFetcher response to a callback. | 101 // Self-deleting trampoline that forwards A URLFetcher response to a callback. |
102 class URLFetcherTrampoline : public content::URLFetcherDelegate { | 102 class URLFetcherTrampoline : public content::URLFetcherDelegate { |
103 public: | 103 public: |
104 typedef base::Callback<void(const content::URLFetcher* source)> | 104 typedef base::Callback<void(const net::URLFetcher* source)> |
105 ForwardingCallback; | 105 ForwardingCallback; |
106 | 106 |
107 explicit URLFetcherTrampoline(const ForwardingCallback& callback); | 107 explicit URLFetcherTrampoline(const ForwardingCallback& callback); |
108 ~URLFetcherTrampoline(); | 108 ~URLFetcherTrampoline(); |
109 | 109 |
110 // content::URLFetcherDelegate implementation. | 110 // content::URLFetcherDelegate implementation. |
111 virtual void OnURLFetchComplete(const content::URLFetcher* source) OVERRIDE; | 111 virtual void OnURLFetchComplete(const net::URLFetcher* source) OVERRIDE; |
112 | 112 |
113 private: | 113 private: |
114 // Fowarding callback from |OnURLFetchComplete|. | 114 // Fowarding callback from |OnURLFetchComplete|. |
115 ForwardingCallback callback_; | 115 ForwardingCallback callback_; |
116 }; | 116 }; |
117 | 117 |
118 URLFetcherTrampoline::URLFetcherTrampoline(const ForwardingCallback& callback) | 118 URLFetcherTrampoline::URLFetcherTrampoline(const ForwardingCallback& callback) |
119 : callback_(callback) { | 119 : callback_(callback) { |
120 } | 120 } |
121 | 121 |
122 URLFetcherTrampoline::~URLFetcherTrampoline() { | 122 URLFetcherTrampoline::~URLFetcherTrampoline() { |
123 } | 123 } |
124 | 124 |
125 void URLFetcherTrampoline::OnURLFetchComplete( | 125 void URLFetcherTrampoline::OnURLFetchComplete( |
126 const content::URLFetcher* source) { | 126 const net::URLFetcher* source) { |
127 DCHECK(!callback_.is_null()); | 127 DCHECK(!callback_.is_null()); |
128 callback_.Run(source); | 128 callback_.Run(source); |
129 delete source; | 129 delete source; |
130 delete this; | 130 delete this; |
131 } | 131 } |
132 | 132 |
133 } // namespace | 133 } // namespace |
134 | 134 |
135 WebIntentPickerController::WebIntentPickerController( | 135 WebIntentPickerController::WebIntentPickerController( |
136 TabContentsWrapper* wrapper) | 136 TabContentsWrapper* wrapper) |
(...skipping 431 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
568 net::LOAD_DO_NOT_SEND_COOKIES | net::LOAD_DO_NOT_SAVE_COOKIES); | 568 net::LOAD_DO_NOT_SEND_COOKIES | net::LOAD_DO_NOT_SAVE_COOKIES); |
569 icon_url_fetcher->SetRequestContext( | 569 icon_url_fetcher->SetRequestContext( |
570 wrapper_->profile()->GetRequestContext()); | 570 wrapper_->profile()->GetRequestContext()); |
571 icon_url_fetcher->Start(); | 571 icon_url_fetcher->Start(); |
572 } | 572 } |
573 | 573 |
574 AsyncOperationFinished(); | 574 AsyncOperationFinished(); |
575 } | 575 } |
576 | 576 |
577 void WebIntentPickerController::OnExtensionIconURLFetchComplete( | 577 void WebIntentPickerController::OnExtensionIconURLFetchComplete( |
578 const string16& extension_id, const content::URLFetcher* source) { | 578 const string16& extension_id, const net::URLFetcher* source) { |
579 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); | 579 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); |
580 if (source->GetResponseCode() != 200) { | 580 if (source->GetResponseCode() != 200) { |
581 AsyncOperationFinished(); | 581 AsyncOperationFinished(); |
582 return; | 582 return; |
583 } | 583 } |
584 | 584 |
585 scoped_ptr<std::string> response(new std::string); | 585 scoped_ptr<std::string> response(new std::string); |
586 if (!source->GetResponseAsString(response.get())) { | 586 if (!source->GetResponseAsString(response.get())) { |
587 AsyncOperationFinished(); | 587 AsyncOperationFinished(); |
588 return; | 588 return; |
(...skipping 95 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
684 // If picker is non-NULL, it was set by a test. | 684 // If picker is non-NULL, it was set by a test. |
685 if (picker_ == NULL) | 685 if (picker_ == NULL) |
686 picker_ = WebIntentPicker::Create(wrapper_, this, picker_model_.get()); | 686 picker_ = WebIntentPicker::Create(wrapper_, this, picker_model_.get()); |
687 picker_shown_ = true; | 687 picker_shown_ = true; |
688 } | 688 } |
689 | 689 |
690 void WebIntentPickerController::ClosePicker() { | 690 void WebIntentPickerController::ClosePicker() { |
691 if (picker_) | 691 if (picker_) |
692 picker_->Close(); | 692 picker_->Close(); |
693 } | 693 } |
OLD | NEW |