1*6777b538SAndroid Build Coastguard Worker // Copyright 2023 The Chromium Authors 2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be 3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file. 4*6777b538SAndroid Build Coastguard Worker 5*6777b538SAndroid Build Coastguard Worker #ifndef BASE_FILES_SCOPED_TEMP_FILE_H_ 6*6777b538SAndroid Build Coastguard Worker #define BASE_FILES_SCOPED_TEMP_FILE_H_ 7*6777b538SAndroid Build Coastguard Worker 8*6777b538SAndroid Build Coastguard Worker #include "base/base_export.h" 9*6777b538SAndroid Build Coastguard Worker #include "base/files/file_path.h" 10*6777b538SAndroid Build Coastguard Worker 11*6777b538SAndroid Build Coastguard Worker namespace base { 12*6777b538SAndroid Build Coastguard Worker 13*6777b538SAndroid Build Coastguard Worker // An owned FilePath that's deleted when this object goes out of scope. 14*6777b538SAndroid Build Coastguard Worker // Deletion is attempted on destruction, but is not guaranteed. 15*6777b538SAndroid Build Coastguard Worker class BASE_EXPORT ScopedTempFile { 16*6777b538SAndroid Build Coastguard Worker public: 17*6777b538SAndroid Build Coastguard Worker // No file is owned/created initially. 18*6777b538SAndroid Build Coastguard Worker ScopedTempFile(); 19*6777b538SAndroid Build Coastguard Worker 20*6777b538SAndroid Build Coastguard Worker ScopedTempFile(ScopedTempFile&&) noexcept; 21*6777b538SAndroid Build Coastguard Worker ScopedTempFile& operator=(ScopedTempFile&&) noexcept; 22*6777b538SAndroid Build Coastguard Worker 23*6777b538SAndroid Build Coastguard Worker ~ScopedTempFile(); 24*6777b538SAndroid Build Coastguard Worker 25*6777b538SAndroid Build Coastguard Worker // The owned path must be empty before calling Create(). 26*6777b538SAndroid Build Coastguard Worker // Returns true on success. 27*6777b538SAndroid Build Coastguard Worker [[nodiscard]] bool Create(); 28*6777b538SAndroid Build Coastguard Worker 29*6777b538SAndroid Build Coastguard Worker // Returns true on success or if the file was never created. 30*6777b538SAndroid Build Coastguard Worker [[nodiscard]] bool Delete(); 31*6777b538SAndroid Build Coastguard Worker 32*6777b538SAndroid Build Coastguard Worker // Attempts to delete the file. The managed path is reset regardless of 33*6777b538SAndroid Build Coastguard Worker // if the deletion was successful. 34*6777b538SAndroid Build Coastguard Worker void Reset(); 35*6777b538SAndroid Build Coastguard Worker path()36*6777b538SAndroid Build Coastguard Worker [[nodiscard]] const base::FilePath& path() const { return path_; } 37*6777b538SAndroid Build Coastguard Worker 38*6777b538SAndroid Build Coastguard Worker // NOLINTNEXTLINE(google-explicit-constructor) 39*6777b538SAndroid Build Coastguard Worker operator bool() const { return !path_.empty(); } 40*6777b538SAndroid Build Coastguard Worker 41*6777b538SAndroid Build Coastguard Worker private: 42*6777b538SAndroid Build Coastguard Worker FilePath path_; 43*6777b538SAndroid Build Coastguard Worker }; 44*6777b538SAndroid Build Coastguard Worker 45*6777b538SAndroid Build Coastguard Worker } // namespace base 46*6777b538SAndroid Build Coastguard Worker 47*6777b538SAndroid Build Coastguard Worker #endif // BASE_FILES_SCOPED_TEMP_FILE_H_ 48