diff options
-rw-r--r-- | base/file_util.cc | 23 | ||||
-rw-r--r-- | base/file_util.h | 14 | ||||
-rw-r--r-- | base/file_util_posix.cc | 40 | ||||
-rw-r--r-- | base/file_util_win.cc | 22 | ||||
-rw-r--r-- | chrome/browser/spellchecker.cc | 2 |
5 files changed, 28 insertions, 73 deletions
diff --git a/base/file_util.cc b/base/file_util.cc index 1cf22b7..10e08d5 100644 --- a/base/file_util.cc +++ b/base/file_util.cc @@ -275,29 +275,6 @@ bool CloseFile(FILE* file) { return fclose(file) == 0; } -/////////////////////////////////////////////// -// MemoryMappedFile - -MemoryMappedFile::~MemoryMappedFile() { - CloseHandles(); -} - -bool MemoryMappedFile::Initialize(const FilePath& file_name) { - if (IsValid()) - return false; - - if (!MapFileToMemory(file_name)) { - CloseHandles(); - return false; - } - - return true; -} - -bool MemoryMappedFile::IsValid() { - return data_ != NULL; -} - // Deprecated functions ---------------------------------------------------- bool AbsolutePath(std::wstring* path_str) { diff --git a/base/file_util.h b/base/file_util.h index d1cfb05..854703f 100644 --- a/base/file_util.h +++ b/base/file_util.h @@ -414,6 +414,8 @@ class FileEnumerator { DISALLOW_EVIL_CONSTRUCTORS(FileEnumerator); }; +// TODO(port): port this class to posix. +#if defined(OS_WIN) class MemoryMappedFile { public: // The default constructor sets all members to invalid/null values. @@ -427,8 +429,8 @@ class MemoryMappedFile { // Later we may want to allow the user to specify access. bool Initialize(const FilePath& file_name); - const uint8* data() const { return data_; } - size_t length() const { return length_; } + const uint8* Data() const { return data_; } + size_t Length() const { return length_; } // Is file_ a valid file handle that points to an open, memory mapped file? bool IsValid(); @@ -441,18 +443,14 @@ class MemoryMappedFile { // Closes all open handles. Later we may want to make this public. void CloseHandles(); -#if defined(OS_WIN) HANDLE file_; HANDLE file_mapping_; -#elif defined(OS_POSIX) - // The file descriptor. - int file_; -#endif - uint8* data_; + const uint8* data_; size_t length_; DISALLOW_COPY_AND_ASSIGN(MemoryMappedFile); }; +#endif // defined(OS_WIN) // Renames a file using the SHFileOperation API to ensure that the target file // gets the correct default security descriptor in the new path. diff --git a/base/file_util_posix.cc b/base/file_util_posix.cc index 7448ed8..153f70a 100644 --- a/base/file_util_posix.cc +++ b/base/file_util_posix.cc @@ -12,7 +12,6 @@ #include <stdio.h> #include <string.h> #include <sys/errno.h> -#include <sys/mman.h> #include <sys/stat.h> #include <time.h> @@ -379,9 +378,6 @@ bool SetCurrentDirectory(const FilePath& path) { return !ret; } -/////////////////////////////////////////////// -// FileEnumerator - FileEnumerator::FileEnumerator(const FilePath& root_path, bool recursive, FileEnumerator::FILE_TYPE file_type) @@ -483,41 +479,5 @@ FilePath FileEnumerator::Next() { return Next(); } -/////////////////////////////////////////////// -// MemoryMappedFile - -MemoryMappedFile::MemoryMappedFile() - : file_(-1), - data_(NULL), - length_(0) { -} - -bool MemoryMappedFile::MapFileToMemory(const FilePath& file_name) { - file_ = open(file_name.value().c_str(), O_RDONLY); - if (file_ == -1) - return false; - - struct stat file_stat; - if (fstat(file_, &file_stat) == -1) - return false; - length_ = file_stat.st_size; - - data_ = static_cast<uint8*>( - mmap(NULL, length_, PROT_READ, MAP_SHARED, file_, 0)); - if (data_ == MAP_FAILED) - data_ = NULL; - return data_ != NULL; -} - -void MemoryMappedFile::CloseHandles() { - if (data_ != NULL) - munmap(data_, length_); - if (file_ != -1) - close(file_); - - data_ = NULL; - length_ = 0; - file_ = -1; -} } // namespace file_util diff --git a/base/file_util_win.cc b/base/file_util_win.cc index b674910..c287129 100644 --- a/base/file_util_win.cc +++ b/base/file_util_win.cc @@ -704,6 +704,22 @@ MemoryMappedFile::MemoryMappedFile() length_(INVALID_FILE_SIZE) { } +MemoryMappedFile::~MemoryMappedFile() { + CloseHandles(); +} + +bool MemoryMappedFile::Initialize(const FilePath& file_name) { + if (IsValid()) + return false; + + if (!MapFileToMemory(file_name)) { + CloseHandles(); + return false; + } + + return true; +} + bool MemoryMappedFile::MapFileToMemory(const FilePath& file_name) { file_ = ::CreateFile(file_name.value().c_str(), GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, @@ -720,11 +736,15 @@ bool MemoryMappedFile::MapFileToMemory(const FilePath& file_name) { if (file_mapping_ == INVALID_HANDLE_VALUE) return false; - data_ = static_cast<const uint8*>( + data_ = reinterpret_cast<const uint8*>( ::MapViewOfFile(file_mapping_, FILE_MAP_READ, 0, 0, length_)); return data_ != NULL; } +bool MemoryMappedFile::IsValid() { + return data_ != NULL; +} + void MemoryMappedFile::CloseHandles() { if (data_) ::UnmapViewOfFile(data_); diff --git a/chrome/browser/spellchecker.cc b/chrome/browser/spellchecker.cc index 6fc9d4c..004c39b 100644 --- a/chrome/browser/spellchecker.cc +++ b/chrome/browser/spellchecker.cc @@ -430,7 +430,7 @@ bool SpellChecker::Initialize() { TimeTicks begin_time = TimeTicks::Now(); bdict_file_.reset(new file_util::MemoryMappedFile()); if (bdict_file_->Initialize(FilePath::FromWStringHack(bdict_file_name_))) { - hunspell_.reset(new Hunspell(bdict_file_->data(), bdict_file_->length())); + hunspell_.reset(new Hunspell(bdict_file_->Data(), bdict_file_->Length())); AddCustomWordsToHunspell(); } DHISTOGRAM_TIMES(L"Spellcheck.InitTime", TimeTicks::Now() - begin_time); |