diff options
author | tony@chromium.org <tony@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-10-13 20:22:37 +0000 |
---|---|---|
committer | tony@chromium.org <tony@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-10-13 20:22:37 +0000 |
commit | ebcb20c7ead50898319724aa42efb0e31acf1877 (patch) | |
tree | fc1b9f066fc9ac3aa2faa32ae56e765f9133423a | |
parent | 55a75d99c6609ed4f6dc7052fcf3d907efaf7137 (diff) | |
download | chromium_src-ebcb20c7ead50898319724aa42efb0e31acf1877.zip chromium_src-ebcb20c7ead50898319724aa42efb0e31acf1877.tar.gz chromium_src-ebcb20c7ead50898319724aa42efb0e31acf1877.tar.bz2 |
Convert BlockFiles to use FilePath instead of wstring.
BUG=24444
Review URL: http://codereview.chromium.org/274012
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@28873 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | net/disk_cache/backend_impl.h | 4 | ||||
-rw-r--r-- | net/disk_cache/block_files.cc | 27 | ||||
-rw-r--r-- | net/disk_cache/block_files.h | 7 | ||||
-rw-r--r-- | net/disk_cache/block_files_unittest.cc | 31 | ||||
-rw-r--r-- | net/disk_cache/cache_util.h | 2 | ||||
-rw-r--r-- | net/disk_cache/cache_util_posix.cc | 4 | ||||
-rw-r--r-- | net/disk_cache/cache_util_win.cc | 4 | ||||
-rw-r--r-- | net/disk_cache/disk_cache_perftest.cc | 2 | ||||
-rw-r--r-- | net/disk_cache/disk_cache_test_util.cc | 6 | ||||
-rw-r--r-- | net/disk_cache/disk_cache_test_util.h | 4 | ||||
-rw-r--r-- | net/tools/dump_cache/dump_files.cc | 4 |
11 files changed, 46 insertions, 49 deletions
diff --git a/net/disk_cache/backend_impl.h b/net/disk_cache/backend_impl.h index 00711a9..85075db 100644 --- a/net/disk_cache/backend_impl.h +++ b/net/disk_cache/backend_impl.h @@ -36,14 +36,14 @@ class BackendImpl : public Backend { friend class Eviction; public: explicit BackendImpl(const FilePath& path) - : path_(path), block_files_(path.ToWStringHack()), mask_(0), max_size_(0), + : path_(path), block_files_(path), mask_(0), max_size_(0), cache_type_(net::DISK_CACHE), uma_report_(0), user_flags_(0), init_(false), restarted_(false), unit_test_(false), read_only_(false), new_eviction_(false), first_timer_(true), ALLOW_THIS_IN_INITIALIZER_LIST(factory_(this)) {} // mask can be used to limit the usable size of the hash table, for testing. BackendImpl(const FilePath& path, uint32 mask) - : path_(path), block_files_(path.ToWStringHack()), mask_(mask), max_size_(0), + : path_(path), block_files_(path), mask_(mask), max_size_(0), cache_type_(net::DISK_CACHE), uma_report_(0), user_flags_(kMask), init_(false), restarted_(false), unit_test_(false), read_only_(false), new_eviction_(false), first_timer_(true), diff --git a/net/disk_cache/block_files.cc b/net/disk_cache/block_files.cc index ffb74db..9cdb2e0 100644 --- a/net/disk_cache/block_files.cc +++ b/net/disk_cache/block_files.cc @@ -15,7 +15,7 @@ using base::Time; namespace { -const wchar_t* kBlockName = L"data_"; +const char* kBlockName = "data_"; // This array is used to perform a fast lookup of the nibble bit pattern to the // type of entry that can be stored there (number of consecutive blocks). @@ -200,24 +200,21 @@ void BlockFiles::CloseFiles() { block_files_.clear(); } -std::wstring BlockFiles::Name(int index) { +FilePath BlockFiles::Name(int index) { // The file format allows for 256 files. DCHECK(index < 256 || index >= 0); - std::wstring name(path_); - std::wstring tmp = StringPrintf(L"%ls%d", kBlockName, index); - file_util::AppendToPath(&name, tmp); - - return name; + std::string tmp = StringPrintf("%s%d", kBlockName, index); + return path_.AppendASCII(tmp); } bool BlockFiles::CreateBlockFile(int index, FileType file_type, bool force) { - std::wstring name = Name(index); + FilePath name = Name(index); int flags = force ? base::PLATFORM_FILE_CREATE_ALWAYS : base::PLATFORM_FILE_CREATE; flags |= base::PLATFORM_FILE_WRITE | base::PLATFORM_FILE_EXCLUSIVE_WRITE; scoped_refptr<File> file(new File( - base::CreatePlatformFile(name.c_str(), flags, NULL))); + base::CreatePlatformFile(name, flags, NULL))); if (!file->IsValid()) return false; @@ -236,16 +233,16 @@ bool BlockFiles::OpenBlockFile(int index) { block_files_.resize(block_files_.size() + to_add); } - std::wstring name = Name(index); + FilePath name = Name(index); scoped_refptr<MappedFile> file(new MappedFile()); - if (!file->Init(name, kBlockHeaderSize)) { - LOG(ERROR) << "Failed to open " << name; + if (!file->Init(name.ToWStringHack(), kBlockHeaderSize)) { + LOG(ERROR) << "Failed to open " << name.value(); return false; } if (file->GetLength() < static_cast<size_t>(kBlockHeaderSize)) { - LOG(ERROR) << "File too small " << name; + LOG(ERROR) << "File too small " << name.value(); return false; } @@ -390,11 +387,11 @@ void BlockFiles::RemoveEmptyFile(FileType block_type) { block_files_[file_index]->Release(); block_files_[file_index] = NULL; - std::wstring name = Name(file_index); + FilePath name = Name(file_index); int failure = DeleteCacheFile(name) ? 0 : 1; UMA_HISTOGRAM_COUNTS("DiskCache.DeleteFailed2", failure); if (failure) - LOG(ERROR) << "Failed to delete " << name << " from the cache."; + LOG(ERROR) << "Failed to delete " << name.value() << " from the cache."; continue; } diff --git a/net/disk_cache/block_files.h b/net/disk_cache/block_files.h index faf38ef..8503062 100644 --- a/net/disk_cache/block_files.h +++ b/net/disk_cache/block_files.h @@ -9,6 +9,7 @@ #include <vector> +#include "base/file_path.h" #include "net/disk_cache/addr.h" #include "net/disk_cache/mapped_file.h" #include "testing/gtest/include/gtest/gtest_prod.h" @@ -20,7 +21,7 @@ class EntryImpl; // This class handles the set of block-files open by the disk cache. class BlockFiles { public: - explicit BlockFiles(const std::wstring& path) + explicit BlockFiles(const FilePath& path) : init_(false), zero_buffer_(NULL), path_(path) {} ~BlockFiles(); @@ -69,11 +70,11 @@ class BlockFiles { bool FixBlockFileHeader(MappedFile* file); // Returns the filename for a given file index. - std::wstring Name(int index); + FilePath Name(int index); bool init_; char* zero_buffer_; // Buffer to speed-up cleaning deleted entries. - std::wstring path_; // Path to the backing folder. + FilePath path_; // Path to the backing folder. std::vector<MappedFile*> block_files_; // The actual files. FRIEND_TEST(DiskCacheTest, BlockFiles_ZeroSizeFile); diff --git a/net/disk_cache/block_files_unittest.cc b/net/disk_cache/block_files_unittest.cc index 2ea930e..322c10c 100644 --- a/net/disk_cache/block_files_unittest.cc +++ b/net/disk_cache/block_files_unittest.cc @@ -14,9 +14,8 @@ using base::Time; namespace { // Returns the number of files in this folder. -int NumberOfFiles(const std::wstring& path) { - file_util::FileEnumerator iter(FilePath::FromWStringHack(path), false, - file_util::FileEnumerator::FILES); +int NumberOfFiles(const FilePath& path) { + file_util::FileEnumerator iter(path, false, file_util::FileEnumerator::FILES); int count = 0; for (FilePath file = iter.Next(); !file.value().empty(); file = iter.Next()) { count++; @@ -29,8 +28,8 @@ int NumberOfFiles(const std::wstring& path) { namespace disk_cache { TEST_F(DiskCacheTest, BlockFiles_Grow) { - std::wstring path = GetCachePath(); - ASSERT_TRUE(DeleteCache(path.c_str())); + FilePath path = FilePath::FromWStringHack(GetCachePath()); + ASSERT_TRUE(DeleteCache(path)); ASSERT_TRUE(file_util::CreateDirectory(path)); BlockFiles files(path); @@ -56,8 +55,8 @@ TEST_F(DiskCacheTest, BlockFiles_Grow) { // We should be able to delete empty block files. TEST_F(DiskCacheTest, BlockFiles_Shrink) { - std::wstring path = GetCachePath(); - ASSERT_TRUE(DeleteCache(path.c_str())); + FilePath path = FilePath::FromWStringHack(GetCachePath()); + ASSERT_TRUE(DeleteCache(path)); ASSERT_TRUE(file_util::CreateDirectory(path)); BlockFiles files(path); @@ -80,8 +79,8 @@ TEST_F(DiskCacheTest, BlockFiles_Shrink) { // Handling of block files not properly closed. TEST_F(DiskCacheTest, BlockFiles_Recover) { - std::wstring path = GetCachePath(); - ASSERT_TRUE(DeleteCache(path.c_str())); + FilePath path = FilePath::FromWStringHack(GetCachePath()); + ASSERT_TRUE(DeleteCache(path)); ASSERT_TRUE(file_util::CreateDirectory(path)); BlockFiles files(path); @@ -158,19 +157,19 @@ TEST_F(DiskCacheTest, BlockFiles_Recover) { // Handling of truncated files. TEST_F(DiskCacheTest, BlockFiles_ZeroSizeFile) { - std::wstring path = GetCachePath(); - ASSERT_TRUE(DeleteCache(path.c_str())); + FilePath path = FilePath::FromWStringHack(GetCachePath()); + ASSERT_TRUE(DeleteCache(path)); ASSERT_TRUE(file_util::CreateDirectory(path)); BlockFiles files(path); ASSERT_TRUE(files.Init(true)); - std::wstring filename = files.Name(0); + FilePath filename = files.Name(0); files.CloseFiles(); // Truncate one of the files. { scoped_refptr<File> file(new File); - ASSERT_TRUE(file->Init(FilePath::FromWStringHack(filename))); + ASSERT_TRUE(file->Init(filename)); EXPECT_TRUE(file->SetLength(0)); } @@ -180,8 +179,8 @@ TEST_F(DiskCacheTest, BlockFiles_ZeroSizeFile) { // An invalid file can be detected after init. TEST_F(DiskCacheTest, BlockFiles_InvalidFile) { - std::wstring path = GetCachePath(); - ASSERT_TRUE(DeleteCache(path.c_str())); + FilePath path = FilePath::FromWStringHack(GetCachePath()); + ASSERT_TRUE(DeleteCache(path)); ASSERT_TRUE(file_util::CreateDirectory(path)); BlockFiles files(path); @@ -192,7 +191,7 @@ TEST_F(DiskCacheTest, BlockFiles_InvalidFile) { EXPECT_TRUE(NULL == files.GetFile(addr)); // Let's create an invalid file. - FilePath filename(FilePath::FromWStringHack(files.Name(5))); + FilePath filename(files.Name(5)); char header[kBlockHeaderSize]; memset(header, 'a', kBlockHeaderSize); EXPECT_EQ(kBlockHeaderSize, diff --git a/net/disk_cache/cache_util.h b/net/disk_cache/cache_util.h index 7c91574..1caac8c 100644 --- a/net/disk_cache/cache_util.h +++ b/net/disk_cache/cache_util.h @@ -25,8 +25,6 @@ void DeleteCache(const std::wstring& path, bool remove_folder); // Deletes a cache file. bool DeleteCacheFile(const FilePath& name); -// Deprecated. -bool DeleteCacheFile(const std::wstring& name); } // namespace disk_cache diff --git a/net/disk_cache/cache_util_posix.cc b/net/disk_cache/cache_util_posix.cc index 180e521..97d3a4e 100644 --- a/net/disk_cache/cache_util_posix.cc +++ b/net/disk_cache/cache_util_posix.cc @@ -38,8 +38,4 @@ void DeleteCache(const std::wstring& path, bool remove_folder) { DeleteCache(FilePath::FromWStringHack(path), remove_folder); } -bool DeleteCacheFile(const std::wstring& name) { - return DeleteCacheFile(FilePath::FromWStringHack(name)); -} - } // namespace disk_cache diff --git a/net/disk_cache/cache_util_win.cc b/net/disk_cache/cache_util_win.cc index 46bffe8..182e818 100644 --- a/net/disk_cache/cache_util_win.cc +++ b/net/disk_cache/cache_util_win.cc @@ -65,8 +65,4 @@ void DeleteCache(const std::wstring& path, bool remove_folder) { DeleteCache(FilePath::FromWStringHack(path), remove_folder); } -bool DeleteCacheFile(const std::wstring& name) { - return DeleteCacheFile(FilePath::FromWStringHack(name)); -} - } // namespace disk_cache diff --git a/net/disk_cache/disk_cache_perftest.cc b/net/disk_cache/disk_cache_perftest.cc index 4eab41d..e216d69 100644 --- a/net/disk_cache/disk_cache_perftest.cc +++ b/net/disk_cache/disk_cache_perftest.cc @@ -207,7 +207,7 @@ TEST_F(DiskCacheTest, BlockFilesPerformance) { ScopedTestCache test_cache; - disk_cache::BlockFiles files(test_cache.path_wstring()); + disk_cache::BlockFiles files(test_cache.path()); ASSERT_TRUE(files.Init(true)); int seed = static_cast<int>(Time::Now().ToInternalValue()); diff --git a/net/disk_cache/disk_cache_test_util.cc b/net/disk_cache/disk_cache_test_util.cc index 77d731f..ddc9799 100644 --- a/net/disk_cache/disk_cache_test_util.cc +++ b/net/disk_cache/disk_cache_test_util.cc @@ -72,11 +72,15 @@ bool CreateCacheTestFile(const wchar_t* name) { return true; } -bool DeleteCache(const wchar_t* path) { +bool DeleteCache(const FilePath& path) { disk_cache::DeleteCache(path, false); return true; } +bool DeleteCache(const wchar_t* path) { + return DeleteCache(FilePath::FromWStringHack(path)); +} + bool CheckCacheIntegrity(const std::wstring& path, bool new_eviction) { scoped_ptr<disk_cache::BackendImpl> cache(new disk_cache::BackendImpl( FilePath::FromWStringHack(path))); diff --git a/net/disk_cache/disk_cache_test_util.h b/net/disk_cache/disk_cache_test_util.h index 9e17512..24c5567 100644 --- a/net/disk_cache/disk_cache_test_util.h +++ b/net/disk_cache/disk_cache_test_util.h @@ -13,10 +13,14 @@ #include "base/timer.h" #include "net/base/test_completion_callback.h" +class FilePath; + // Re-creates a given test file inside the cache test folder. bool CreateCacheTestFile(const wchar_t* name); // Deletes all file son the cache. +bool DeleteCache(const FilePath& path); +// Deprecated. bool DeleteCache(const wchar_t* path); // Gets the path to the cache test folder. diff --git a/net/tools/dump_cache/dump_files.cc b/net/tools/dump_cache/dump_files.cc index 2fcf7a4..45b647c 100644 --- a/net/tools/dump_cache/dump_files.cc +++ b/net/tools/dump_cache/dump_files.cc @@ -106,7 +106,9 @@ void DumpBlockHeader(const std::wstring& name) { class CacheDumper { public: explicit CacheDumper(const std::wstring& path) - : path_(path), block_files_(path), index_(NULL) {} + : path_(path), + block_files_(FilePath::FromWStringHack(path)), + index_(NULL) {} bool Init(); |