summaryrefslogtreecommitdiffstats
path: root/chrome
diff options
context:
space:
mode:
authoravi@chromium.org <avi@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-06-29 20:31:29 +0000
committeravi@chromium.org <avi@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-06-29 20:31:29 +0000
commitf1ce6e6c4d6bb08bd1534170b4647aabf8ff25ef (patch)
tree9166583bf968e8b0e780482823b2592fcade223f /chrome
parent401392455919b47e7a85a20a058754e4b05da488 (diff)
downloadchromium_src-f1ce6e6c4d6bb08bd1534170b4647aabf8ff25ef.zip
chromium_src-f1ce6e6c4d6bb08bd1534170b4647aabf8ff25ef.tar.gz
chromium_src-f1ce6e6c4d6bb08bd1534170b4647aabf8ff25ef.tar.bz2
Allow extension extensions to be case-insensitive.
BUG=none TEST=try to load an extension with a capital letter or two in the extension's extension. It should load. Review URL: http://codereview.chromium.org/147017 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@19520 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome')
-rw-r--r--chrome/browser/download/download_manager.cc27
-rw-r--r--chrome/common/extensions/extension.cc8
-rw-r--r--chrome/common/extensions/extension.h3
3 files changed, 16 insertions, 22 deletions
diff --git a/chrome/browser/download/download_manager.cc b/chrome/browser/download/download_manager.cc
index 7ed4ad0..bd74f91 100644
--- a/chrome/browser/download/download_manager.cc
+++ b/chrome/browser/download/download_manager.cc
@@ -26,7 +26,6 @@
#include "chrome/browser/renderer_host/resource_dispatcher_host.h"
#include "chrome/browser/tab_contents/tab_util.h"
#include "chrome/browser/tab_contents/tab_contents.h"
-#include "chrome/common/chrome_constants.h"
#include "chrome/common/chrome_paths.h"
#include "chrome/common/extensions/extension.h"
#include "chrome/common/platform_util.h"
@@ -826,14 +825,8 @@ void DownloadManager::DownloadFinished(int32 download_id, int64 size) {
void DownloadManager::DownloadRenamedToFinalName(int download_id,
const FilePath& full_path) {
- FilePath::StringType extension = full_path.Extension();
- // Drop the leading period.
- if (extension.size() > 0)
- extension = extension.substr(1);
-
- if (extension == chrome::kExtensionFileExtension) {
+ if (Extension::IsExtension(full_path))
OpenChromeExtension(full_path);
- }
}
void DownloadManager::ContinueDownloadFinished(DownloadItem* download) {
@@ -849,12 +842,9 @@ void DownloadManager::ContinueDownloadFinished(DownloadItem* download) {
// Open the download if the user or user prefs indicate it should be.
FilePath::StringType extension = download->full_path().Extension();
- // Drop the leading period.
- if (extension.size() > 0)
- extension = extension.substr(1);
// Handle chrome extensions explicitly and skip the shell execute.
- if (extension == chrome::kExtensionFileExtension) {
+ if (Extension::IsExtension(download->full_path())) {
// Skip the shell execute. This will be handled in
// DownloadRenamedToFinalName
return;
@@ -1218,14 +1208,9 @@ void DownloadManager::ShowDownloadInShell(const DownloadItem* download) {
void DownloadManager::OpenDownload(const DownloadItem* download,
gfx::NativeView parent_window) {
- FilePath::StringType extension = download->full_path().Extension();
- // Drop the leading period.
- if (extension.size() > 0)
- extension = extension.substr(1);
-
// Open Chrome extensions with ExtensionsService. For everything else do shell
// execute.
- if (extension == chrome::kExtensionFileExtension) {
+ if (Extension::IsExtension(download->full_path())) {
OpenChromeExtension(download->full_path());
} else {
OpenDownloadInShell(download, parent_window);
@@ -1260,7 +1245,7 @@ bool DownloadManager::ShouldOpenFileExtension(
// Special-case Chrome extensions as always-open.
if (!IsExecutable(extension) &&
(auto_open_.find(extension) != auto_open_.end() ||
- extension == chrome::kExtensionFileExtension))
+ Extension::IsExtension(FilePath(extension))))
return true;
return false;
}
@@ -1484,9 +1469,7 @@ void DownloadManager::ShowDownloadInBrowser(const DownloadCreateInfo& info,
// Extension downloading skips the shelf. This is a temporary fix until
// we can modularize the download system and develop specific extensiona
// install UI.
- FilePath::StringType extension = info.path.Extension();
- // Ignore the leading period.
- if (extension.find(chrome::kExtensionFileExtension) == 1)
+ if (Extension::IsExtension(info.path))
return;
// The 'contents' may no longer exist if the user closed the tab before we get
diff --git a/chrome/common/extensions/extension.cc b/chrome/common/extensions/extension.cc
index 9b74737..33baff8 100644
--- a/chrome/common/extensions/extension.cc
+++ b/chrome/common/extensions/extension.cc
@@ -12,6 +12,7 @@
#include "base/string_util.h"
#include "base/third_party/nss/blapi.h"
#include "base/third_party/nss/sha256.h"
+#include "chrome/common/chrome_constants.h"
#include "chrome/common/extensions/extension_error_reporter.h"
#include "chrome/common/extensions/extension_error_utils.h"
#include "chrome/common/extensions/user_script.h"
@@ -199,6 +200,13 @@ const std::string Extension::VersionString() const {
}
// static
+bool Extension::IsExtension(const FilePath& file_name) {
+ return file_name.MatchesExtension(
+ FilePath::StringType(FILE_PATH_LITERAL(".")) +
+ chrome::kExtensionFileExtension);
+}
+
+// static
bool Extension::IdIsValid(const std::string& id) {
// Verify that the id is legal.
if (id.size() != (kIdSize * 2))
diff --git a/chrome/common/extensions/extension.h b/chrome/common/extensions/extension.h
index 1b774ae..ec14b0b 100644
--- a/chrome/common/extensions/extension.h
+++ b/chrome/common/extensions/extension.h
@@ -142,6 +142,9 @@ class Extension {
explicit Extension(const FilePath& path);
virtual ~Extension();
+ // Returns true if the specified file is an extension.
+ static bool IsExtension(const FilePath& file_name);
+
// Resets the id counter. This is only useful for unit tests.
static void ResetGeneratedIdCounter() {
id_counter_ = 0;