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

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

Issue 125573002: Move ExtensionService::GetExtensionById() to ExtensionRegistry (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase, add test, get_extension_by_id Created 6 years, 11 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
« no previous file with comments | « chrome/browser/extensions/extension_service.h ('k') | chrome/browser/extensions/extension_util.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/extensions/extension_service.cc
diff --git a/chrome/browser/extensions/extension_service.cc b/chrome/browser/extensions/extension_service.cc
index 99881fd4e7b548c013ac35291fd0af5d0045041d..d2c1085c22266fd8dc25f74743df75736fae042c 100644
--- a/chrome/browser/extensions/extension_service.cc
+++ b/chrome/browser/extensions/extension_service.cc
@@ -115,6 +115,7 @@ using extensions::CrxInstaller;
using extensions::Extension;
using extensions::ExtensionIdSet;
using extensions::ExtensionInfo;
+using extensions::ExtensionRegistry;
using extensions::ExtensionSet;
using extensions::FeatureSwitch;
using extensions::InstallVerifier;
@@ -456,14 +457,15 @@ void ExtensionService::Shutdown() {
const Extension* ExtensionService::GetExtensionById(
const std::string& id, bool include_disabled) const {
- int include_mask = INCLUDE_ENABLED;
+ int include_mask = ExtensionRegistry::ENABLED;
if (include_disabled) {
// Include blacklisted extensions here because there are hundreds of
// callers of this function, and many might assume that this includes those
// that have been disabled due to blacklisting.
- include_mask |= INCLUDE_DISABLED | INCLUDE_BLACKLISTED;
+ include_mask |= ExtensionRegistry::DISABLED |
+ ExtensionRegistry::BLACKLISTED;
}
- return GetExtensionById(id, include_mask);
+ return registry_->GetExtensionById(id, include_mask);
}
GURL ExtensionService::GetSiteForExtensionId(const std::string& extension_id) {
@@ -472,36 +474,6 @@ GURL ExtensionService::GetSiteForExtensionId(const std::string& extension_id) {
Extension::GetBaseURLFromExtensionId(extension_id));
}
-const Extension* ExtensionService::GetExtensionById(
- const std::string& id, int include_mask) const {
- std::string lowercase_id = StringToLowerASCII(id);
- if (include_mask & INCLUDE_ENABLED) {
- const Extension* extension =
- registry_->enabled_extensions().GetByID(lowercase_id);
- if (extension)
- return extension;
- }
- if (include_mask & INCLUDE_DISABLED) {
- const Extension* extension =
- registry_->disabled_extensions().GetByID(lowercase_id);
- if (extension)
- return extension;
- }
- if (include_mask & INCLUDE_TERMINATED) {
- const Extension* extension =
- registry_->terminated_extensions().GetByID(lowercase_id);
- if (extension)
- return extension;
- }
- if (include_mask & INCLUDE_BLACKLISTED) {
- const Extension* extension =
- registry_->blacklisted_extensions().GetByID(lowercase_id);
- if (extension)
- return extension;
- }
- return NULL;
-}
-
void ExtensionService::Init() {
CHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
@@ -1017,8 +989,9 @@ void ExtensionService::DisableExtension(
extension_prefs_->SetExtensionState(extension_id, Extension::DISABLED);
extension_prefs_->AddDisableReason(extension_id, disable_reason);
- int include_mask = INCLUDE_EVERYTHING & ~INCLUDE_DISABLED;
- extension = GetExtensionById(extension_id, include_mask);
+ int include_mask =
+ ExtensionRegistry::EVERYTHING & ~ExtensionRegistry::DISABLED;
+ extension = registry_->GetExtensionById(extension_id, include_mask);
if (!extension)
return;
@@ -1229,6 +1202,12 @@ Profile* ExtensionService::profile() {
return profile_;
}
+content::BrowserContext* ExtensionService::GetBrowserContext() const {
+ // Implemented in the .cc file to avoid adding a profile.h dependency to
+ // extension_service.h.
+ return profile_;
+}
+
extensions::ExtensionPrefs* ExtensionService::extension_prefs() {
return extension_prefs_;
}
@@ -1606,9 +1585,10 @@ void ExtensionService::UnloadExtension(
const std::string& extension_id,
UnloadedExtensionInfo::Reason reason) {
// Make sure the extension gets deleted after we return from this function.
- int include_mask = INCLUDE_EVERYTHING & ~INCLUDE_TERMINATED;
+ int include_mask =
+ ExtensionRegistry::EVERYTHING & ~ExtensionRegistry::TERMINATED;
scoped_refptr<const Extension> extension(
- GetExtensionById(extension_id, include_mask));
+ registry_->GetExtensionById(extension_id, include_mask));
// This method can be called via PostTask, so the extension may have been
// unloaded by the time this runs.
@@ -2363,16 +2343,12 @@ void ExtensionService::UntrackTerminatedExtension(const std::string& id) {
const Extension* ExtensionService::GetTerminatedExtension(
const std::string& id) const {
- return GetExtensionById(id, INCLUDE_TERMINATED);
+ return registry_->GetExtensionById(id, ExtensionRegistry::TERMINATED);
}
const Extension* ExtensionService::GetInstalledExtension(
const std::string& id) const {
- int include_mask = INCLUDE_ENABLED |
- INCLUDE_DISABLED |
- INCLUDE_TERMINATED |
- INCLUDE_BLACKLISTED;
- return GetExtensionById(id, include_mask);
+ return registry_->GetExtensionById(id, ExtensionRegistry::EVERYTHING);
}
bool ExtensionService::ExtensionBindingsAllowed(const GURL& url) {
« no previous file with comments | « chrome/browser/extensions/extension_service.h ('k') | chrome/browser/extensions/extension_util.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698