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

Unified Diff: chrome/browser/chooser_controller/chooser_controller.cc

Issue 2746313002: Remove RenderFrameHost pointer from ChooserController. (Closed)
Patch Set: Fix Android build and juncai@ comment. Created 3 years, 9 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/chooser_controller/chooser_controller.cc
diff --git a/chrome/browser/chooser_controller/chooser_controller.cc b/chrome/browser/chooser_controller/chooser_controller.cc
index 44340322c027e82fb39bceaf2db6263e8deff5ca..45390379754de4b1aebe2da556905c6ee7f93b03 100644
--- a/chrome/browser/chooser_controller/chooser_controller.cc
+++ b/chrome/browser/chooser_controller/chooser_controller.cc
@@ -14,24 +14,16 @@
#include "ui/base/l10n/l10n_util.h"
#include "url/origin.h"
-ChooserController::ChooserController(content::RenderFrameHost* owner,
- int title_string_id_origin,
- int title_string_id_extension)
- : owning_frame_(owner),
- title_string_id_origin_(title_string_id_origin),
- title_string_id_extension_(title_string_id_extension) {}
+namespace {
-ChooserController::~ChooserController() {}
-
-base::string16 ChooserController::GetTitle() const {
- if (!owning_frame_)
- return base::string16();
-
- url::Origin origin = owning_frame_->GetLastCommittedOrigin();
+base::string16 CreateTitle(content::RenderFrameHost* render_frame_host,
+ int title_string_id_origin,
+ int title_string_id_extension) {
+ url::Origin origin = render_frame_host->GetLastCommittedOrigin();
if (origin.scheme() == extensions::kExtensionScheme) {
content::WebContents* web_contents =
- content::WebContents::FromRenderFrameHost(owning_frame_);
+ content::WebContents::FromRenderFrameHost(render_frame_host);
content::BrowserContext* browser_context =
web_contents->GetBrowserContext();
extensions::ExtensionRegistry* extension_registry =
@@ -40,18 +32,35 @@ base::string16 ChooserController::GetTitle() const {
const extensions::Extension* extension =
extension_registry->enabled_extensions().GetByID(origin.host());
if (extension) {
- return l10n_util::GetStringFUTF16(title_string_id_extension_,
+ return l10n_util::GetStringFUTF16(title_string_id_extension,
base::UTF8ToUTF16(extension->name()));
}
}
}
return l10n_util::GetStringFUTF16(
- title_string_id_origin_,
+ title_string_id_origin,
url_formatter::FormatOriginForSecurityDisplay(
origin, url_formatter::SchemeDisplay::OMIT_CRYPTOGRAPHIC));
}
+} // namespace
+
+ChooserController::ChooserController(content::RenderFrameHost* owner,
+ int title_string_id_origin,
+ int title_string_id_extension) {
+ if (owner) {
+ title_ =
+ CreateTitle(owner, title_string_id_origin, title_string_id_extension);
+ }
+}
+
+ChooserController::~ChooserController() {}
+
+base::string16 ChooserController::GetTitle() const {
+ return title_;
+}
+
bool ChooserController::ShouldShowIconBeforeText() const {
return false;
}
« no previous file with comments | « chrome/browser/chooser_controller/chooser_controller.h ('k') | chrome/browser/chooser_controller/mock_chooser_controller.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698