xref: /aosp_15_r20/external/cronet/base/files/scoped_temp_file.h (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
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