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

Unified Diff: net/base/filename_util.h

Issue 869233006: [net] Cleanup filename_util and make it portable. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@clang-format-filename-tests
Patch Set: Created 5 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 | « content/child/web_url_loader_impl.cc ('k') | net/base/filename_util.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: net/base/filename_util.h
diff --git a/net/base/filename_util.h b/net/base/filename_util.h
index 6b151bad9b0bb93f859d7ee06a78695360b7569b..e1051b09898ff487ee6206df0ff4dbe28ec27204 100644
--- a/net/base/filename_util.h
+++ b/net/base/filename_util.h
@@ -39,31 +39,20 @@ NET_EXPORT bool FileURLToFilePath(const GURL& url, base::FilePath* file_path);
// interpret the URL if there are non-ascii characters.
// 4) |default_name|. If non-empty, |default_name| is assumed to be a filename
// and shouldn't contain a path. |default_name| is not subject to validation
-// or sanitization, and therefore shouldn't be a user supplied string.
-// 5) The hostname portion from the |url|
+// or sanitization, and therefore shouldn't be a user supplied string. It is
+// assumed to be in UTF-8.
+// 5) The hostname portion from the |url|.
+// 6) The string "download".
//
-// Then, leading and trailing '.'s will be removed. On Windows, trailing spaces
-// are also removed. The string "download" is the final fallback if no filename
-// is found or the filename is empty.
-//
-// Any illegal characters in the filename will be replaced by '-'. If the
-// filename doesn't contain an extension, and a |mime_type| is specified, the
-// preferred extension for the |mime_type| will be appended to the filename.
-// The resulting filename is then checked against a list of reserved names on
-// Windows. If the name is reserved, an underscore will be prepended to the
-// filename.
+// Any illegal characters in the filename will be replaced by '_'. This includes
+// Ileading and trailing whitespace and periods. If the filename doesn't contain
+// an extension, and a |mime_type| is specified, the preferred extension for the
+// |mime_type| will be appended to the filename. The resulting filename is then
+// checked against a list of reserved names on Windows. If the name is
+// reserved, an underscore will be prepended to the filename.
//
// Note: |mime_type| should only be specified if this function is called from a
// thread that allows IO.
-NET_EXPORT base::string16 GetSuggestedFilename(
- const GURL& url,
- const std::string& content_disposition,
- const std::string& referrer_charset,
- const std::string& suggested_name,
- const std::string& mime_type,
- const std::string& default_name);
-
-// Similar to GetSuggestedFilename(), but returns a FilePath.
NET_EXPORT base::FilePath GenerateFileName(
const GURL& url,
const std::string& content_disposition,
@@ -90,26 +79,45 @@ NET_EXPORT bool IsSafePortablePathComponent(const base::FilePath& component);
// absolute paths.
NET_EXPORT bool IsSafePortableRelativePath(const base::FilePath& path);
+// Options controlling how filename extensions are handled in
+// EnsureSafePortableFileName().
+enum ExtensionGenerationOption {
+ EXTENSION_OPTION_KEEP_EXISTING, // Don't generate a new extension.
+ EXTENSION_OPTION_GENERATE_IF_MISSING, // Generate one if the filename doesn't
+ // already have an extension.
+ EXTENSION_OPTION_GENERATE, // Always generate a new extension and replace the
+ // existing extension.
+ EXTENSION_OPTION_GENERATE_AND_APPEND // Generate a new extension and append
+ // it to the filename.
+};
+
// Ensures that the filename and extension is safe to use in the filesystem.
//
-// Assumes that |file_path| already contains a valid path or file name. On
-// Windows if the extension causes the file to have an unsafe interaction with
-// the shell (see net_util::IsShellIntegratedExtension()), then it will be
-// replaced by the string 'download'. If |file_path| doesn't contain an
-// extension or |ignore_extension| is true then the preferred extension, if one
-// exists, for |mime_type| will be used as the extension.
+// Note that this function only sanitizes the basename of |file_path|. I.e. it
+// assumes that the path leading up to the parent directory of |file_path| is
+// valid.
+//
+// This function:
//
-// On Windows, the filename will be checked against a set of reserved names, and
-// if so, an underscore will be prepended to the name.
+// - Updates |file_path| with a valid filename extension if |mime_type| is known
+// and |extension_option| specifies that an extension should be generated.
//
-// |file_name| can either be just the file name or it can be a full path to a
-// file.
+// - Replaces the extension with the string 'download' if the filename extension
+// is considered to be one which interacts with the Windows shell in an unsafe
+// manner.
+//
+// - Prepends an underscore to the filename if the filename will be considered a
+// device name or is otherwise reserved on Windows.
+//
+// - Replaces any illegal characters in the filename with underscores. This
+// includes leading and trailing whitespace and periods.
//
// Note: |mime_type| should only be non-empty if this function is called from a
// thread that allows IO.
-NET_EXPORT void GenerateSafeFileName(const std::string& mime_type,
- bool ignore_extension,
- base::FilePath* file_path);
+NET_EXPORT void EnsureSafePortableFileName(
+ const std::string& mime_type,
+ ExtensionGenerationOption extension_option,
+ base::FilePath* file_path);
} // namespace net
« no previous file with comments | « content/child/web_url_loader_impl.cc ('k') | net/base/filename_util.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698