diff options
-rw-r--r-- | chrome/common/extensions/api/_api_features.json | 28 | ||||
-rw-r--r-- | chrome/common/extensions/api/extension_api_unittest.cc | 2 | ||||
-rw-r--r-- | chrome/common/extensions/features/simple_feature.cc | 15 | ||||
-rw-r--r-- | chrome/common/extensions/features/simple_feature.h | 5 | ||||
-rw-r--r-- | chrome/common/extensions/features/simple_feature_unittest.cc | 41 | ||||
-rw-r--r-- | extensions/common/features/feature.cc | 6 | ||||
-rw-r--r-- | extensions/common/features/feature.h | 8 |
7 files changed, 70 insertions, 35 deletions
diff --git a/chrome/common/extensions/api/_api_features.json b/chrome/common/extensions/api/_api_features.json index cc6e8a4..8e58146 100644 --- a/chrome/common/extensions/api/_api_features.json +++ b/chrome/common/extensions/api/_api_features.json @@ -113,7 +113,7 @@ "contexts": ["blessed_extension"] }, "chromeosInfoPrivate": { - "platform": "chromeos", + "platforms": ["chromeos"], "dependencies": ["permission:chromeosInfoPrivate"], "contexts": ["blessed_extension"] }, @@ -196,12 +196,12 @@ "contexts": ["blessed_extension", "unblessed_extension", "content_script"] }, "echoPrivate": { - "platform": "chromeos", + "platforms": ["chromeos"], "dependencies": ["permission:echoPrivate"], "contexts": ["blessed_extension"] }, "enterprise.platformKeysPrivate": { - "platform": "chromeos", + "platforms": ["chromeos"], "dependencies": ["permission:enterprise.platformKeysPrivate"], "contexts": ["blessed_extension"] }, @@ -268,18 +268,18 @@ "contexts": ["blessed_extension"] }, "fileBrowserHandler": { - "platform": "chromeos", + "platforms": ["chromeos"], "dependencies": ["permission:fileBrowserHandler"], "contexts": ["blessed_extension"] }, "fileBrowserHandlerInternal": { "internal": true, - "platform": "chromeos", + "platforms": ["chromeos"], "channel": "stable", "contexts": ["blessed_extension", "unblessed_extension", "content_script"] }, "fileBrowserPrivate": { - "platform": "chromeos", + "platforms": ["chromeos"], "dependencies": ["permission:fileBrowserPrivate"], "contexts": ["blessed_extension"] }, @@ -326,12 +326,12 @@ "contexts": ["blessed_extension"] }, "input.ime": { - "platform": "chromeos", + "platforms": ["chromeos"], "dependencies": ["permission:input"], "contexts": ["blessed_extension"] }, "inputMethodPrivate": { - "platform": "chromeos", + "platforms": ["chromeos"], "dependencies": ["permission:inputMethodPrivate"], "contexts": ["blessed_extension"] }, @@ -374,7 +374,7 @@ "contexts": ["blessed_extension"] }, "mediaPlayerPrivate": { - "platform": "chromeos", + "platforms": ["chromeos"], "dependencies": ["permission:mediaPlayerPrivate"], "contexts": ["blessed_extension"] }, @@ -391,7 +391,7 @@ "contexts": ["blessed_extension"] }, "networkingPrivate": { - "platform": "chromeos", + "platforms": ["chromeos"], "dependencies": ["permission:networkingPrivate"], "contexts": ["blessed_extension"] }, @@ -576,7 +576,7 @@ "contexts": ["blessed_extension"] }, "terminalPrivate": { - "platform": "chromeos", + "platforms": ["chromeos"], "dependencies": ["permission:terminalPrivate"], "contexts": ["blessed_extension"] }, @@ -612,17 +612,17 @@ "contexts": ["blessed_extension"] }, "virtualKeyboardPrivate": { - "platform": "chromeos", + "platforms": ["chromeos"], "dependencies": ["permission:virtualKeyboardPrivate"], "contexts": ["blessed_extension"] }, "wallpaper": { - "platform": "chromeos", + "platforms": ["chromeos"], "dependencies": ["permission:wallpaper"], "contexts": ["blessed_extension"] }, "wallpaperPrivate": { - "platform": "chromeos", + "platforms": ["chromeos"], "dependencies": ["permission:wallpaperPrivate"], "contexts": ["blessed_extension"] }, diff --git a/chrome/common/extensions/api/extension_api_unittest.cc b/chrome/common/extensions/api/extension_api_unittest.cc index fba0a71..0e340ba 100644 --- a/chrome/common/extensions/api/extension_api_unittest.cc +++ b/chrome/common/extensions/api/extension_api_unittest.cc @@ -720,7 +720,7 @@ TEST(ExtensionAPITest, DefaultConfigurationFeatures) { Feature::BLESSED_EXTENSION_CONTEXT)); EXPECT_EQ(Feature::UNSPECIFIED_LOCATION, feature->location()); - EXPECT_EQ(Feature::UNSPECIFIED_PLATFORM, feature->platform()); + EXPECT_TRUE(feature->platforms()->empty()); EXPECT_EQ(0, feature->min_manifest_version()); EXPECT_EQ(0, feature->max_manifest_version()); } diff --git a/chrome/common/extensions/features/simple_feature.cc b/chrome/common/extensions/features/simple_feature.cc index c03b03e..4f71552 100644 --- a/chrome/common/extensions/features/simple_feature.cc +++ b/chrome/common/extensions/features/simple_feature.cc @@ -39,6 +39,9 @@ struct Mappings { locations["component"] = Feature::COMPONENT_LOCATION; platforms["chromeos"] = Feature::CHROMEOS_PLATFORM; + platforms["linux"] = Feature::LINUX_PLATFORM; + platforms["macosx"] = Feature::MACOSX_PLATFORM; + platforms["windows"] = Feature::WIN_PLATFORM; channels["trunk"] = VersionInfo::CHANNEL_UNKNOWN; channels["canary"] = VersionInfo::CHANNEL_CANARY; @@ -186,7 +189,6 @@ std::string HashExtensionId(const std::string& extension_id) { SimpleFeature::SimpleFeature() : location_(UNSPECIFIED_LOCATION), - platform_(UNSPECIFIED_PLATFORM), min_manifest_version_(0), max_manifest_version_(0), channel_(VersionInfo::CHANNEL_UNKNOWN), @@ -200,7 +202,7 @@ SimpleFeature::SimpleFeature(const SimpleFeature& other) contexts_(other.contexts_), matches_(other.matches_), location_(other.location_), - platform_(other.platform_), + platforms_(other.platforms_), min_manifest_version_(other.min_manifest_version_), max_manifest_version_(other.max_manifest_version_), channel_(other.channel_), @@ -217,7 +219,7 @@ bool SimpleFeature::Equals(const SimpleFeature& other) const { contexts_ == other.contexts_ && matches_ == other.matches_ && location_ == other.location_ && - platform_ == other.platform_ && + platforms_ == other.platforms_ && min_manifest_version_ == other.min_manifest_version_ && max_manifest_version_ == other.max_manifest_version_ && channel_ == other.channel_ && @@ -235,8 +237,8 @@ std::string SimpleFeature::Parse(const base::DictionaryValue* value) { g_mappings.Get().contexts); ParseEnum<Location>(value, "location", &location_, g_mappings.Get().locations); - ParseEnum<Platform>(value, "platform", &platform_, - g_mappings.Get().platforms); + ParseEnumSet<Platform>(value, "platforms", &platforms_, + g_mappings.Get().platforms); value->GetInteger("min_manifest_version", &min_manifest_version_); value->GetInteger("max_manifest_version", &max_manifest_version_); ParseEnum<VersionInfo::Channel>( @@ -298,7 +300,8 @@ Feature::Availability SimpleFeature::IsAvailableToManifest( if (location_ != UNSPECIFIED_LOCATION && location_ != location) return CreateAvailability(INVALID_LOCATION, type); - if (platform_ != UNSPECIFIED_PLATFORM && platform_ != platform) + if (!platforms_.empty() && + platforms_.find(platform) == platforms_.end()) return CreateAvailability(INVALID_PLATFORM, type); if (min_manifest_version_ != 0 && manifest_version < min_manifest_version_) diff --git a/chrome/common/extensions/features/simple_feature.h b/chrome/common/extensions/features/simple_feature.h index e955648..9013e18 100644 --- a/chrome/common/extensions/features/simple_feature.h +++ b/chrome/common/extensions/features/simple_feature.h @@ -40,8 +40,7 @@ class SimpleFeature : public Feature { Location location() const { return location_; } void set_location(Location location) { location_ = location; } - Platform platform() const { return platform_; } - void set_platform(Platform platform) { platform_ = platform; } + std::set<Platform>* platforms() { return &platforms_; } int min_manifest_version() const { return min_manifest_version_; } void set_min_manifest_version(int min_manifest_version) { @@ -109,7 +108,7 @@ class SimpleFeature : public Feature { std::set<Context> contexts_; URLPatternSet matches_; Location location_; // we only care about component/not-component now - Platform platform_; // we only care about chromeos/not-chromeos now + std::set<Platform> platforms_; int min_manifest_version_; int max_manifest_version_; chrome::VersionInfo::Channel channel_; diff --git a/chrome/common/extensions/features/simple_feature_unittest.cc b/chrome/common/extensions/features/simple_feature_unittest.cc index 4129d6f..03145a5 100644 --- a/chrome/common/extensions/features/simple_feature_unittest.cc +++ b/chrome/common/extensions/features/simple_feature_unittest.cc @@ -174,7 +174,7 @@ TEST_F(ExtensionSimpleFeatureTest, Context) { SimpleFeature feature; feature.GetContexts()->insert(Feature::BLESSED_EXTENSION_CONTEXT); feature.extension_types()->insert(Manifest::TYPE_LEGACY_PACKAGED_APP); - feature.set_platform(Feature::CHROMEOS_PLATFORM); + feature.platforms()->insert(Feature::CHROMEOS_PLATFORM); feature.set_min_manifest_version(21); feature.set_max_manifest_version(25); @@ -270,7 +270,7 @@ TEST_F(ExtensionSimpleFeatureTest, Location) { TEST_F(ExtensionSimpleFeatureTest, Platform) { SimpleFeature feature; - feature.set_platform(Feature::CHROMEOS_PLATFORM); + feature.platforms()->insert(Feature::CHROMEOS_PLATFORM); EXPECT_EQ(Feature::IS_AVAILABLE, feature.IsAvailableToManifest(std::string(), Manifest::TYPE_UNKNOWN, @@ -353,7 +353,7 @@ TEST_F(ExtensionSimpleFeatureTest, ParseNull) { EXPECT_TRUE(feature->extension_types()->empty()); EXPECT_TRUE(feature->GetContexts()->empty()); EXPECT_EQ(Feature::UNSPECIFIED_LOCATION, feature->location()); - EXPECT_EQ(Feature::UNSPECIFIED_PLATFORM, feature->platform()); + EXPECT_TRUE(feature->platforms()->empty()); EXPECT_EQ(0, feature->min_manifest_version()); EXPECT_EQ(0, feature->max_manifest_version()); } @@ -432,12 +432,35 @@ TEST_F(ExtensionSimpleFeatureTest, ParseLocation) { EXPECT_EQ(Feature::COMPONENT_LOCATION, feature->location()); } -TEST_F(ExtensionSimpleFeatureTest, ParsePlatform) { +TEST_F(ExtensionSimpleFeatureTest, ParsePlatforms) { scoped_ptr<base::DictionaryValue> value(new base::DictionaryValue()); - value->SetString("platform", "chromeos"); scoped_ptr<SimpleFeature> feature(new SimpleFeature()); + base::ListValue* platforms = new base::ListValue(); + value->Set("platforms", platforms); feature->Parse(value.get()); - EXPECT_EQ(Feature::CHROMEOS_PLATFORM, feature->platform()); + EXPECT_TRUE(feature->platforms()->empty()); + + platforms->AppendString("chromeos"); + feature->Parse(value.get()); + EXPECT_FALSE(feature->platforms()->empty()); + EXPECT_EQ(Feature::CHROMEOS_PLATFORM, *feature->platforms()->begin()); + + platforms->Clear(); + platforms->AppendString("windows"); + feature->Parse(value.get()); + EXPECT_FALSE(feature->platforms()->empty()); + EXPECT_EQ(Feature::WIN_PLATFORM, *feature->platforms()->begin()); + + platforms->Clear(); + platforms->AppendString("windows"); + platforms->AppendString("chromeos"); + feature->Parse(value.get()); + std::set<Feature::Platform> expected_platforms; + expected_platforms.insert(Feature::CHROMEOS_PLATFORM); + expected_platforms.insert(Feature::WIN_PLATFORM); + + EXPECT_FALSE(feature->platforms()->empty()); + EXPECT_EQ(expected_platforms, *feature->platforms()); } TEST_F(ExtensionSimpleFeatureTest, ManifestVersion) { @@ -456,7 +479,7 @@ TEST_F(ExtensionSimpleFeatureTest, Inheritance) { feature.extension_types()->insert(Manifest::TYPE_THEME); feature.GetContexts()->insert(Feature::BLESSED_EXTENSION_CONTEXT); feature.set_location(Feature::COMPONENT_LOCATION); - feature.set_platform(Feature::CHROMEOS_PLATFORM); + feature.platforms()->insert(Feature::CHROMEOS_PLATFORM); feature.set_min_manifest_version(1); feature.set_max_manifest_version(2); @@ -499,7 +522,7 @@ TEST_F(ExtensionSimpleFeatureTest, Equals) { feature.extension_types()->insert(Manifest::TYPE_THEME); feature.GetContexts()->insert(Feature::UNBLESSED_EXTENSION_CONTEXT); feature.set_location(Feature::COMPONENT_LOCATION); - feature.set_platform(Feature::CHROMEOS_PLATFORM); + feature.platforms()->insert(Feature::CHROMEOS_PLATFORM); feature.set_min_manifest_version(18); feature.set_max_manifest_version(25); @@ -522,7 +545,7 @@ TEST_F(ExtensionSimpleFeatureTest, Equals) { EXPECT_FALSE(feature2.Equals(feature)); feature2 = feature; - feature2.set_platform(Feature::UNSPECIFIED_PLATFORM); + feature.platforms()->insert(Feature::UNSPECIFIED_PLATFORM); EXPECT_FALSE(feature2.Equals(feature)); feature2 = feature; diff --git a/extensions/common/features/feature.cc b/extensions/common/features/feature.cc index 705f3e5..60f7f88 100644 --- a/extensions/common/features/feature.cc +++ b/extensions/common/features/feature.cc @@ -17,6 +17,12 @@ namespace extensions { Feature::Platform Feature::GetCurrentPlatform() { #if defined(OS_CHROMEOS) return CHROMEOS_PLATFORM; +#elif defined(OS_LINUX) + return LINUX_PLATFORM; +#elif defined(OS_MACOSX) + return MACOSX_PLATFORM; +#elif defined(OS_WIN) + return WIN_PLATFORM; #else return UNSPECIFIED_PLATFORM; #endif diff --git a/extensions/common/features/feature.h b/extensions/common/features/feature.h index 036fc72..0ffd91d 100644 --- a/extensions/common/features/feature.h +++ b/extensions/common/features/feature.h @@ -20,7 +20,8 @@ class Extension; // Represents a single feature accessible to an extension developer, such as a // top-level manifest key, a permission, or a programmatic API. A feature can // express requirements for where it can be accessed, and supports testing -// support for those requirements. +// support for those requirements. If platforms are not specified, then feature +// is available on all platforms. class Feature { public: // The JavaScript contexts the feature is supported in. @@ -49,7 +50,10 @@ class Feature { // The platforms the feature is supported in. enum Platform { UNSPECIFIED_PLATFORM, - CHROMEOS_PLATFORM + CHROMEOS_PLATFORM, + LINUX_PLATFORM, + MACOSX_PLATFORM, + WIN_PLATFORM }; // Whether a feature is available in a given situation or not, and if not, |