Index: base/file_util.cc |
diff --git a/base/file_util.cc b/base/file_util.cc |
deleted file mode 100644 |
index d11cd15a2e0032d587329ab0399682c25b2195f4..0000000000000000000000000000000000000000 |
--- a/base/file_util.cc |
+++ /dev/null |
@@ -1,260 +0,0 @@ |
-// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
-// Use of this source code is governed by a BSD-style license that can be |
-// found in the LICENSE file. |
- |
-#include "base/file_util.h" |
- |
-#if defined(OS_WIN) |
-#include <io.h> |
-#endif |
-#include <stdio.h> |
- |
-#include <fstream> |
-#include <limits> |
- |
-#include "base/files/file_enumerator.h" |
-#include "base/files/file_path.h" |
-#include "base/logging.h" |
-#include "base/strings/string_piece.h" |
-#include "base/strings/string_util.h" |
-#include "base/strings/stringprintf.h" |
-#include "base/strings/utf_string_conversions.h" |
- |
-namespace base { |
- |
-namespace { |
- |
-// The maximum number of 'uniquified' files we will try to create. |
-// This is used when the filename we're trying to download is already in use, |
-// so we create a new unique filename by appending " (nnn)" before the |
-// extension, where 1 <= nnn <= kMaxUniqueFiles. |
-// Also used by code that cleans up said files. |
-static const int kMaxUniqueFiles = 100; |
- |
-} // namespace |
- |
-int64 ComputeDirectorySize(const FilePath& root_path) { |
- int64 running_size = 0; |
- FileEnumerator file_iter(root_path, true, FileEnumerator::FILES); |
- while (!file_iter.Next().empty()) |
- running_size += file_iter.GetInfo().GetSize(); |
- return running_size; |
-} |
- |
-bool Move(const FilePath& from_path, const FilePath& to_path) { |
- if (from_path.ReferencesParent() || to_path.ReferencesParent()) |
- return false; |
- return internal::MoveUnsafe(from_path, to_path); |
-} |
- |
-bool CopyFile(const FilePath& from_path, const FilePath& to_path) { |
- if (from_path.ReferencesParent() || to_path.ReferencesParent()) |
- return false; |
- return internal::CopyFileUnsafe(from_path, to_path); |
-} |
- |
-bool ContentsEqual(const FilePath& filename1, const FilePath& filename2) { |
- // We open the file in binary format even if they are text files because |
- // we are just comparing that bytes are exactly same in both files and not |
- // doing anything smart with text formatting. |
- std::ifstream file1(filename1.value().c_str(), |
- std::ios::in | std::ios::binary); |
- std::ifstream file2(filename2.value().c_str(), |
- std::ios::in | std::ios::binary); |
- |
- // Even if both files aren't openable (and thus, in some sense, "equal"), |
- // any unusable file yields a result of "false". |
- if (!file1.is_open() || !file2.is_open()) |
- return false; |
- |
- const int BUFFER_SIZE = 2056; |
- char buffer1[BUFFER_SIZE], buffer2[BUFFER_SIZE]; |
- do { |
- file1.read(buffer1, BUFFER_SIZE); |
- file2.read(buffer2, BUFFER_SIZE); |
- |
- if ((file1.eof() != file2.eof()) || |
- (file1.gcount() != file2.gcount()) || |
- (memcmp(buffer1, buffer2, file1.gcount()))) { |
- file1.close(); |
- file2.close(); |
- return false; |
- } |
- } while (!file1.eof() || !file2.eof()); |
- |
- file1.close(); |
- file2.close(); |
- return true; |
-} |
- |
-bool TextContentsEqual(const FilePath& filename1, const FilePath& filename2) { |
- std::ifstream file1(filename1.value().c_str(), std::ios::in); |
- std::ifstream file2(filename2.value().c_str(), std::ios::in); |
- |
- // Even if both files aren't openable (and thus, in some sense, "equal"), |
- // any unusable file yields a result of "false". |
- if (!file1.is_open() || !file2.is_open()) |
- return false; |
- |
- do { |
- std::string line1, line2; |
- getline(file1, line1); |
- getline(file2, line2); |
- |
- // Check for mismatched EOF states, or any error state. |
- if ((file1.eof() != file2.eof()) || |
- file1.bad() || file2.bad()) { |
- return false; |
- } |
- |
- // Trim all '\r' and '\n' characters from the end of the line. |
- std::string::size_type end1 = line1.find_last_not_of("\r\n"); |
- if (end1 == std::string::npos) |
- line1.clear(); |
- else if (end1 + 1 < line1.length()) |
- line1.erase(end1 + 1); |
- |
- std::string::size_type end2 = line2.find_last_not_of("\r\n"); |
- if (end2 == std::string::npos) |
- line2.clear(); |
- else if (end2 + 1 < line2.length()) |
- line2.erase(end2 + 1); |
- |
- if (line1 != line2) |
- return false; |
- } while (!file1.eof() || !file2.eof()); |
- |
- return true; |
-} |
- |
-bool ReadFileToString(const FilePath& path, |
- std::string* contents, |
- size_t max_size) { |
- if (contents) |
- contents->clear(); |
- if (path.ReferencesParent()) |
- return false; |
- FILE* file = OpenFile(path, "rb"); |
- if (!file) { |
- return false; |
- } |
- |
- char buf[1 << 16]; |
- size_t len; |
- size_t size = 0; |
- bool read_status = true; |
- |
- // Many files supplied in |path| have incorrect size (proc files etc). |
- // Hence, the file is read sequentially as opposed to a one-shot read. |
- while ((len = fread(buf, 1, sizeof(buf), file)) > 0) { |
- if (contents) |
- contents->append(buf, std::min(len, max_size - size)); |
- |
- if ((max_size - size) < len) { |
- read_status = false; |
- break; |
- } |
- |
- size += len; |
- } |
- read_status = read_status && !ferror(file); |
- CloseFile(file); |
- |
- return read_status; |
-} |
- |
-bool ReadFileToString(const FilePath& path, std::string* contents) { |
- return ReadFileToString(path, contents, std::numeric_limits<size_t>::max()); |
-} |
- |
-bool IsDirectoryEmpty(const FilePath& dir_path) { |
- FileEnumerator files(dir_path, false, |
- FileEnumerator::FILES | FileEnumerator::DIRECTORIES); |
- if (files.Next().empty()) |
- return true; |
- return false; |
-} |
- |
-FILE* CreateAndOpenTemporaryFile(FilePath* path) { |
- FilePath directory; |
- if (!GetTempDir(&directory)) |
- return NULL; |
- |
- return CreateAndOpenTemporaryFileInDir(directory, path); |
-} |
- |
-bool CreateDirectory(const FilePath& full_path) { |
- return CreateDirectoryAndGetError(full_path, NULL); |
-} |
- |
-bool GetFileSize(const FilePath& file_path, int64* file_size) { |
- File::Info info; |
- if (!GetFileInfo(file_path, &info)) |
- return false; |
- *file_size = info.size; |
- return true; |
-} |
- |
-bool TouchFile(const FilePath& path, |
- const Time& last_accessed, |
- const Time& last_modified) { |
- int flags = File::FLAG_OPEN | File::FLAG_WRITE_ATTRIBUTES; |
- |
-#if defined(OS_WIN) |
- // On Windows, FILE_FLAG_BACKUP_SEMANTICS is needed to open a directory. |
- if (DirectoryExists(path)) |
- flags |= File::FLAG_BACKUP_SEMANTICS; |
-#endif // OS_WIN |
- |
- File file(path, flags); |
- if (!file.IsValid()) |
- return false; |
- |
- return file.SetTimes(last_accessed, last_modified); |
-} |
- |
-bool CloseFile(FILE* file) { |
- if (file == NULL) |
- return true; |
- return fclose(file) == 0; |
-} |
- |
-bool TruncateFile(FILE* file) { |
- if (file == NULL) |
- return false; |
- long current_offset = ftell(file); |
- if (current_offset == -1) |
- return false; |
-#if defined(OS_WIN) |
- int fd = _fileno(file); |
- if (_chsize(fd, current_offset) != 0) |
- return false; |
-#else |
- int fd = fileno(file); |
- if (ftruncate(fd, current_offset) != 0) |
- return false; |
-#endif |
- return true; |
-} |
- |
-int GetUniquePathNumber(const FilePath& path, |
- const FilePath::StringType& suffix) { |
- bool have_suffix = !suffix.empty(); |
- if (!PathExists(path) && |
- (!have_suffix || !PathExists(FilePath(path.value() + suffix)))) { |
- return 0; |
- } |
- |
- FilePath new_path; |
- for (int count = 1; count <= kMaxUniqueFiles; ++count) { |
- new_path = path.InsertBeforeExtensionASCII(StringPrintf(" (%d)", count)); |
- if (!PathExists(new_path) && |
- (!have_suffix || !PathExists(FilePath(new_path.value() + suffix)))) { |
- return count; |
- } |
- } |
- |
- return -1; |
-} |
- |
-} // namespace base |