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

Unified Diff: extensions/common/features/simple_feature.h

Issue 241673002: Support a "policy" extension location in extension features files. At the same (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: different approach (yoz) Created 6 years, 8 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: extensions/common/features/simple_feature.h
diff --git a/extensions/common/features/simple_feature.h b/extensions/common/features/simple_feature.h
index e3884e014c73da53a6c994a45be303c964c50ddd..32892ed44ac8158e4f25f705672ec35f533378c8 100644
--- a/extensions/common/features/simple_feature.h
+++ b/extensions/common/features/simple_feature.h
@@ -10,6 +10,7 @@
#include <vector>
#include "base/gtest_prod_util.h"
+#include "base/lazy_instance.h"
#include "base/memory/linked_ptr.h"
#include "base/memory/scoped_ptr.h"
#include "base/values.h"
@@ -39,21 +40,8 @@ class SimpleFeature : public Feature {
// the error found, or an empty string on success.
virtual std::string Parse(const base::DictionaryValue* value);
- Location location() const { return location_; }
- void set_location(Location location) { location_ = location; }
-
std::set<Platform>* platforms() { return &platforms_; }
- int min_manifest_version() const { return min_manifest_version_; }
- void set_min_manifest_version(int min_manifest_version) {
- min_manifest_version_ = min_manifest_version;
- }
-
- int max_manifest_version() const { return max_manifest_version_; }
- void set_max_manifest_version(int max_manifest_version) {
- max_manifest_version_ = max_manifest_version;
- }
-
Availability IsAvailableToContext(const Extension* extension,
Context context) const {
return IsAvailableToContext(extension, context, GURL());
@@ -72,7 +60,7 @@ class SimpleFeature : public Feature {
// extension::Feature:
virtual Availability IsAvailableToManifest(const std::string& extension_id,
Manifest::Type type,
- Location location,
+ Manifest::Location location,
int manifest_version,
Platform platform) const OVERRIDE;
@@ -105,6 +93,29 @@ class SimpleFeature : public Feature {
Context context) const;
private:
+ // Similar to Manifest::Location, these are the classes of locations
+ // supported in feature files; "component" implies
+ // COMPONENT/EXTERNAL_COMPONENT manifest location types, etc.
+ enum Location {
+ UNSPECIFIED_LOCATION,
+ COMPONENT_LOCATION,
+ POLICY_LOCATION,
+ };
+
+ bool MatchesManifestLocation(Manifest::Location manifest_location) const;
+
+ // Accessors defined for testing.
+ Location location() const { return location_; }
+ void set_location(Location location) { location_ = location; }
+ int min_manifest_version() const { return min_manifest_version_; }
+ void set_min_manifest_version(int min_manifest_version) {
+ min_manifest_version_ = min_manifest_version;
+ }
+ int max_manifest_version() const { return max_manifest_version_; }
+ void set_max_manifest_version(int max_manifest_version) {
+ max_manifest_version_ = max_manifest_version;
+ }
+
// For clarity and consistency, we handle the default value of each of these
// members the same way: it matches everything. It is up to the higher level
// code that reads Features out of static data to validate that data and set
@@ -113,7 +124,7 @@ class SimpleFeature : public Feature {
std::set<Manifest::Type> extension_types_;
std::set<Context> contexts_;
URLPatternSet matches_;
- Location location_; // we only care about component/not-component now
+ Location location_;
std::set<Platform> platforms_;
int min_manifest_version_;
int max_manifest_version_;
@@ -122,7 +133,19 @@ class SimpleFeature : public Feature {
typedef std::vector<linked_ptr<SimpleFeatureFilter> > FilterList;
FilterList filters_;
+ struct Mappings;
+ static base::LazyInstance<Mappings> g_mappings;
+
+ FRIEND_TEST_ALL_PREFIXES(ExtensionAPITest, DefaultConfigurationFeatures);
FRIEND_TEST_ALL_PREFIXES(ExtensionSimpleFeatureTest, Context);
+ FRIEND_TEST_ALL_PREFIXES(ExtensionSimpleFeatureTest, Inheritance);
+ FRIEND_TEST_ALL_PREFIXES(ExtensionSimpleFeatureTest, Location);
+ FRIEND_TEST_ALL_PREFIXES(ExtensionSimpleFeatureTest, ManifestVersion);
+ FRIEND_TEST_ALL_PREFIXES(ExtensionSimpleFeatureTest, ParseLocation);
+ FRIEND_TEST_ALL_PREFIXES(ExtensionSimpleFeatureTest, ParseNull);
+ FRIEND_TEST_ALL_PREFIXES(ExtensionSimpleFeatureTest, Version);
+ FRIEND_TEST_ALL_PREFIXES(ManifestTest, Extension);
+
DISALLOW_COPY_AND_ASSIGN(SimpleFeature);
};

Powered by Google App Engine
This is Rietveld 408576698