diff options
Diffstat (limited to 'courgette/memory_allocator.cc')
-rw-r--r-- | courgette/memory_allocator.cc | 62 |
1 files changed, 18 insertions, 44 deletions
diff --git a/courgette/memory_allocator.cc b/courgette/memory_allocator.cc index f089163..07daf43 100644 --- a/courgette/memory_allocator.cc +++ b/courgette/memory_allocator.cc @@ -11,54 +11,25 @@ #if defined(OS_WIN) -namespace courgette { - -// TempFile - -TempFile::TempFile() : file_(base::kInvalidPlatformFileValue) { -} +namespace { -TempFile::~TempFile() { - Close(); -} - -void TempFile::Close() { - if (valid()) { - base::ClosePlatformFile(file_); - file_ = base::kInvalidPlatformFileValue; - } -} - -bool TempFile::Create() { - DCHECK(file_ == base::kInvalidPlatformFileValue); +// The file is created in the %TEMP% folder. +// NOTE: Since the file will be used as backing for a memory allocation, +// it will never be so big that size_t cannot represent its size. +base::File CreateTempFile() { base::FilePath path; if (!base::CreateTemporaryFile(&path)) - return false; + return base::File(); - bool created = false; - base::PlatformFileError error_code = base::PLATFORM_FILE_OK; - int flags = base::PLATFORM_FILE_OPEN_ALWAYS | base::PLATFORM_FILE_READ | - base::PLATFORM_FILE_WRITE | - base::PLATFORM_FILE_DELETE_ON_CLOSE | - base::PLATFORM_FILE_TEMPORARY; - file_ = base::CreatePlatformFile(path, flags, &created, &error_code); - if (file_ == base::kInvalidPlatformFileValue) - return false; - - return true; -} - -bool TempFile::valid() const { - return file_ != base::kInvalidPlatformFileValue; + int flags = base::File::FLAG_OPEN_ALWAYS | base::File::FLAG_READ | + base::File::FLAG_WRITE | base::File::FLAG_DELETE_ON_CLOSE | + base::File::FLAG_TEMPORARY; + return base::File(path, flags); } -base::PlatformFile TempFile::handle() const { - return file_; -} +} // namespace -bool TempFile::SetSize(size_t size) { - return base::TruncatePlatformFile(file_, size); -} +namespace courgette { // FileMapping @@ -116,13 +87,16 @@ TempMapping::~TempMapping() { } bool TempMapping::Initialize(size_t size) { + file_ = CreateTempFile(); + if (!file_.IsValid()) + return false; + // TODO(tommi): The assumption here is that the alignment of pointers (this) // is as strict or stricter than the alignment of the element type. This is // not always true, e.g. __m128 has 16-byte alignment. size += sizeof(this); - if (!file_.Create() || - !file_.SetSize(size) || - !mapping_.Create(file_.handle(), size)) { + if (!file_.SetLength(size) || + !mapping_.Create(file_.GetPlatformFile(), size)) { file_.Close(); return false; } |