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

Unified Diff: chrome/browser/download/download_manager.cc

Issue 1276003: Append a number to make app shortcut name unique. (Closed)
Patch Set: Created 10 years, 9 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 | « no previous file | chrome/browser/download/download_util.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/download/download_manager.cc
diff --git a/chrome/browser/download/download_manager.cc b/chrome/browser/download/download_manager.cc
index 00753522fefb1f0bee6d5628374722fff12e7243..7e4740eb56766776de380c2c44d35b2393581fd1 100644
--- a/chrome/browser/download/download_manager.cc
+++ b/chrome/browser/download/download_manager.cc
@@ -79,34 +79,6 @@ const int kUpdateTimeMs = 1000;
// more negative.
const int kUninitializedHandle = 0;
-// Appends the passed the number between parenthesis the path before the
-// extension.
-void AppendNumberToPath(FilePath* path, int number) {
- file_util::InsertBeforeExtension(path,
- StringPrintf(FILE_PATH_LITERAL(" (%d)"), number));
-}
-
-// Attempts to find a number that can be appended to that path to make it
-// unique. If |path| does not exist, 0 is returned. If it fails to find such
-// a number, -1 is returned.
-int GetUniquePathNumber(const FilePath& path) {
- const int kMaxAttempts = 100;
-
- if (!file_util::PathExists(path))
- return 0;
-
- FilePath new_path;
- for (int count = 1; count <= kMaxAttempts; ++count) {
- new_path = FilePath(path);
- AppendNumberToPath(&new_path, count);
-
- if (!file_util::PathExists(new_path))
- return count;
- }
-
- return -1;
-}
-
// Used to sort download items based on descending start time.
bool CompareStartTime(DownloadItem* first, DownloadItem* second) {
return first->start_time() > second->start_time();
@@ -324,7 +296,7 @@ FilePath DownloadItem::GetFileName() const {
return file_name_;
if (path_uniquifier_ > 0) {
FilePath name(original_name_);
- AppendNumberToPath(&name, path_uniquifier_);
+ download_util::AppendNumberToPath(&name, path_uniquifier_);
return name;
}
return original_name_;
@@ -699,8 +671,10 @@ void DownloadManager::CheckIfSuggestedPathExists(DownloadCreateInfo* info) {
// Do not add the path uniquifier if we are saving to a specific path as in
// the drag-out case.
- if (info->save_info.file_path.empty())
- info->path_uniquifier = GetUniquePathNumber(info->suggested_path);
+ if (info->save_info.file_path.empty()) {
+ info->path_uniquifier = download_util::GetUniquePathNumber(
+ info->suggested_path);
+ }
// If the download is deemed dangerous, we'll use a temporary name for it.
if (info->is_dangerous) {
@@ -720,7 +694,8 @@ void DownloadManager::CheckIfSuggestedPathExists(DownloadCreateInfo* info) {
} else {
// We know the final path, build it if necessary.
if (info->path_uniquifier > 0) {
- AppendNumberToPath(&(info->suggested_path), info->path_uniquifier);
+ download_util::AppendNumberToPath(&(info->suggested_path),
+ info->path_uniquifier);
// Setting path_uniquifier to 0 to make sure we don't try to unique it
// later on.
info->path_uniquifier = 0;
@@ -1016,9 +991,9 @@ void DownloadManager::ProceedWithFinishedDangerousDownload(
// have the same path. This is because we uniquify the name on download
// start, and at that time the first file does not exists yet, so the second
// file gets the same name.
- uniquifier = GetUniquePathNumber(new_path);
+ uniquifier = download_util::GetUniquePathNumber(new_path);
if (uniquifier > 0)
- AppendNumberToPath(&new_path, uniquifier);
+ download_util::AppendNumberToPath(&new_path, uniquifier);
success = file_util::Move(path, new_path);
} else {
NOTREACHED();
« no previous file with comments | « no previous file | chrome/browser/download/download_util.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698