// Copyright (c) 2014 GitHub, Inc. All rights reserved. // Use of this source code is governed by the MIT license that can be // found in the LICENSE file. #ifndef ATOM_COMMON_ASAR_SCOPED_TEMPORARY_FILE_H_ #define ATOM_COMMON_ASAR_SCOPED_TEMPORARY_FILE_H_ #include "base/files/file_path.h" #include "base/memory/ref_counted.h" namespace asar { // An object representing a temporary file that should be cleaned up when this // object goes out of scope. Note that since deletion occurs during the // destructor, no further error handling is possible if the directory fails to // be deleted. As a result, deletion is not guaranteed by this class. class ScopedTemporaryFile : public base::RefCounted { public: ScopedTemporaryFile(); // Init an empty temporary file. bool Init(); // Init an temporary file and fill it with content of |path|. bool InitFromFile(const base::FilePath& path, uint64 offset, uint64 size); base::FilePath path() const { return path_; } private: friend class base::RefCounted; virtual ~ScopedTemporaryFile(); base::FilePath path_; DISALLOW_COPY_AND_ASSIGN(ScopedTemporaryFile); }; } // namespace asar #endif // ATOM_COMMON_ASAR_SCOPED_TEMPORARY_FILE_H_