xref: /aosp_15_r20/external/sandboxed-api/sandboxed_api/util/temp_file.h (revision ec63e07ab9515d95e79c211197c445ef84cefa6a)
1*ec63e07aSXin Li // Copyright 2019 Google LLC
2*ec63e07aSXin Li //
3*ec63e07aSXin Li // Licensed under the Apache License, Version 2.0 (the "License");
4*ec63e07aSXin Li // you may not use this file except in compliance with the License.
5*ec63e07aSXin Li // You may obtain a copy of the License at
6*ec63e07aSXin Li //
7*ec63e07aSXin Li //     https://www.apache.org/licenses/LICENSE-2.0
8*ec63e07aSXin Li //
9*ec63e07aSXin Li // Unless required by applicable law or agreed to in writing, software
10*ec63e07aSXin Li // distributed under the License is distributed on an "AS IS" BASIS,
11*ec63e07aSXin Li // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*ec63e07aSXin Li // See the License for the specific language governing permissions and
13*ec63e07aSXin Li // limitations under the License.
14*ec63e07aSXin Li 
15*ec63e07aSXin Li #ifndef SANDBOXED_API_UTIL_TEMP_FILE_H_
16*ec63e07aSXin Li #define SANDBOXED_API_UTIL_TEMP_FILE_H_
17*ec63e07aSXin Li 
18*ec63e07aSXin Li #include <string>
19*ec63e07aSXin Li #include <utility>
20*ec63e07aSXin Li 
21*ec63e07aSXin Li #include "absl/status/statusor.h"
22*ec63e07aSXin Li #include "absl/strings/string_view.h"
23*ec63e07aSXin Li 
24*ec63e07aSXin Li namespace sapi {
25*ec63e07aSXin Li 
26*ec63e07aSXin Li // Creates a temporary file under a path starting with prefix. File is not
27*ec63e07aSXin Li // unlinked and its path is returned together with an open fd.
28*ec63e07aSXin Li absl::StatusOr<std::pair<std::string, int>> CreateNamedTempFile(
29*ec63e07aSXin Li     absl::string_view prefix);
30*ec63e07aSXin Li 
31*ec63e07aSXin Li // Creates a temporary file under a path starting with prefix. File is not
32*ec63e07aSXin Li // unlinked and its path is returned. FD of the created file is closed just
33*ec63e07aSXin Li // after creation.
34*ec63e07aSXin Li absl::StatusOr<std::string> CreateNamedTempFileAndClose(
35*ec63e07aSXin Li     absl::string_view prefix);
36*ec63e07aSXin Li 
37*ec63e07aSXin Li // Creates a temporary directory under a path starting with prefix.
38*ec63e07aSXin Li // Returns the path of the created directory.
39*ec63e07aSXin Li absl::StatusOr<std::string> CreateTempDir(absl::string_view prefix);
40*ec63e07aSXin Li 
41*ec63e07aSXin Li }  // namespace sapi
42*ec63e07aSXin Li 
43*ec63e07aSXin Li #endif  // SANDBOXED_API_UTIL_TEMP_FILE_H_
44