diff options
7 files changed, 25 insertions, 15 deletions
diff --git a/chrome/browser/resources/chromeos/wallpaper_manager/manifest.json b/chrome/browser/resources/chromeos/wallpaper_manager/manifest.json index 68fc559..a1e037c 100644 --- a/chrome/browser/resources/chromeos/wallpaper_manager/manifest.json +++ b/chrome/browser/resources/chromeos/wallpaper_manager/manifest.json @@ -25,5 +25,6 @@ } }, "content_security_policy": - "default-src:none; object-src 'none'; script-src 'self'" + "default-src:none; object-src 'none'; script-src 'self'", + "display_in_launcher": false } diff --git a/chrome/browser/resources/cloud_print_app/manifest.json b/chrome/browser/resources/cloud_print_app/manifest.json index e891f59..d8e74f6 100644 --- a/chrome/browser/resources/cloud_print_app/manifest.json +++ b/chrome/browser/resources/cloud_print_app/manifest.json @@ -16,5 +16,6 @@ }, "permissions": [ "cloudPrintPrivate" - ] + ], + "display_in_launcher": false } diff --git a/chrome/common/extensions/api/_manifest_features.json b/chrome/common/extensions/api/_manifest_features.json index e42a088..a8c73be 100644 --- a/chrome/common/extensions/api/_manifest_features.json +++ b/chrome/common/extensions/api/_manifest_features.json @@ -93,6 +93,11 @@ "channel": "stable", "extension_types": ["extension", "packaged_app"] }, + "display_in_launcher": { + "channel": "stable", + "extension_types": ["packaged_app", "platform_app"], + "location": "component" + }, "file_browser_handlers": { "channel": "stable", "extension_types": ["extension", "packaged_app"] diff --git a/chrome/common/extensions/extension.cc b/chrome/common/extensions/extension.cc index eefbabe..ecdbcf3 100644 --- a/chrome/common/extensions/extension.cc +++ b/chrome/common/extensions/extension.cc @@ -1061,7 +1061,11 @@ bool Extension::LoadAppFeatures(string16* error) { !LoadLaunchContainer(error)) { return false; } - + if (manifest_->HasKey(keys::kDisplayInLauncher) && + !manifest_->GetBoolean(keys::kDisplayInLauncher, &display_in_launcher_)) { + *error = ASCIIToUTF16(errors::kInvalidDisplayInLauncher); + return false; + } return true; } @@ -2959,6 +2963,7 @@ Extension::Extension(const FilePath& path, launch_container_(extension_misc::LAUNCH_TAB), launch_width_(0), launch_height_(0), + display_in_launcher_(true), wants_file_access_(false), creation_flags_(0) { DCHECK(path.empty() || path.IsAbsolute()); @@ -3821,18 +3826,8 @@ bool Extension::IsSyncable() const { } bool Extension::ShouldDisplayInLauncher() const { - // All apps should be displayed on the NTP except for the Cloud Print App. - bool should_display_in_launcher = is_app() && - id() != extension_misc::kCloudPrintAppId; -#if defined(OS_CHROMEOS) - // Wallpaper manager is a component app which can only be launched via context - // menu or set wallpaper button in chrome settings page. We want to hide it - // from launcher. - return should_display_in_launcher && - id() != extension_misc::kWallpaperManagerId; -#else - return should_display_in_launcher; -#endif + // Only apps should be displayed on the NTP. + return is_app() && display_in_launcher_; } bool Extension::InstallWarning::operator==(const InstallWarning& other) const { diff --git a/chrome/common/extensions/extension.h b/chrome/common/extensions/extension.h index d0aef2a..ec4b54d 100644 --- a/chrome/common/extensions/extension.h +++ b/chrome/common/extensions/extension.h @@ -1143,6 +1143,9 @@ class Extension : public base::RefCountedThreadSafe<Extension> { int launch_width_; int launch_height_; + // Should this app be shown in a launcher. + bool display_in_launcher_; + // The Omnibox keyword for this extension, or empty if there is none. std::string omnibox_keyword_; diff --git a/chrome/common/extensions/extension_manifest_constants.cc b/chrome/common/extensions/extension_manifest_constants.cc index 802f0e7..f2e3588 100644 --- a/chrome/common/extensions/extension_manifest_constants.cc +++ b/chrome/common/extensions/extension_manifest_constants.cc @@ -26,6 +26,7 @@ const char kCurrentLocale[] = "current_locale"; const char kDefaultLocale[] = "default_locale"; const char kDescription[] = "description"; const char kDevToolsPage[] = "devtools_page"; +const char kDisplayInLauncher[] = "display_in_launcher"; const char kEventName[] = "event_name"; const char kExcludeGlobs[] = "exclude_globs"; const char kExcludeMatches[] = "exclude_matches"; @@ -226,6 +227,8 @@ const char kInvalidDescription[] = "Invalid value for 'description'."; const char kInvalidDevToolsPage[] = "Invalid value for 'devtools_page'."; +const char kInvalidDisplayInLauncher[] = + "Invalid value for 'display_in_launcher'."; const char kInvalidExcludeMatch[] = "Invalid value for 'content_scripts[*].exclude_matches[*]': *"; const char kInvalidExcludeMatches[] = diff --git a/chrome/common/extensions/extension_manifest_constants.h b/chrome/common/extensions/extension_manifest_constants.h index 26b51d6..edd61c5 100644 --- a/chrome/common/extensions/extension_manifest_constants.h +++ b/chrome/common/extensions/extension_manifest_constants.h @@ -33,6 +33,7 @@ namespace extension_manifest_keys { extern const char kDefaultLocale[]; extern const char kDescription[]; extern const char kDevToolsPage[]; + extern const char kDisplayInLauncher[]; extern const char kEventName[]; extern const char kExcludeGlobs[]; extern const char kExcludeMatches[]; @@ -197,6 +198,7 @@ namespace extension_manifest_errors { extern const char kInvalidDefaultLocale[]; extern const char kInvalidDescription[]; extern const char kInvalidDevToolsPage[]; + extern const char kInvalidDisplayInLauncher[]; extern const char kInvalidExcludeMatch[]; extern const char kInvalidExcludeMatches[]; extern const char kInvalidFileAccessList[]; |