blob: 9b4477431ab72dbc4c58e37f1b267216763caabf [file] [log] [blame] [edit]
// Copyright 2016 The Fuchsia Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef SRC_LIB_FILES_SCOPED_TEMP_DIR_H_
#define SRC_LIB_FILES_SCOPED_TEMP_DIR_H_
#include <string>
#include <string_view>
namespace files {
// An object representing a temporary / scratch directory that should be cleaned
// up (recursively) 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.
//
// The temporary directory is created in |parent_path| relative to |root_fd|. If
// |root_fd| is AT_FDCWD, |parent_path| is relative to the current working
// directory. If |parent_path| is not given, the temporary directory is directly
// created in |root_fd|.
class ScopedTempDirAt {
public:
explicit ScopedTempDirAt(int root_fd);
explicit ScopedTempDirAt(int root_fd, std::string_view parent_path);
ScopedTempDirAt(ScopedTempDirAt&&) = delete;
ScopedTempDirAt& operator=(ScopedTempDirAt&&) = delete;
~ScopedTempDirAt();
const std::string& path();
int root_fd();
bool NewTempFile(std::string* output);
bool NewTempFileWithData(const std::string& data, std::string* output);
bool NewTempDir(std::string* output);
private:
int root_fd_;
std::string directory_path_;
};
// As |ScopedTempDirAt|, but instead of creating the temporary directory
// relative to a file descriptor, it is created either in |parent_path|, or in
// the global temporary directory.
class ScopedTempDir {
public:
ScopedTempDir();
explicit ScopedTempDir(std::string_view parent_path);
ScopedTempDir(ScopedTempDir&&) = delete;
ScopedTempDir& operator=(ScopedTempDir&&) = delete;
~ScopedTempDir();
const std::string& path();
bool NewTempFile(std::string* output);
bool NewTempFileWithData(const std::string& data, std::string* output);
bool NewTempDir(std::string* output);
private:
ScopedTempDirAt base_;
};
} // namespace files
#endif // SRC_LIB_FILES_SCOPED_TEMP_DIR_H_