ClickHouse/base/poco/Foundation/include/Poco/File.h
2023-02-14 22:13:11 +00:00

307 lines
8.1 KiB
C++

//
// File.h
//
// Library: Foundation
// Package: Filesystem
// Module: File
//
// Definition of the File class.
//
// Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH.
// and Contributors.
//
// SPDX-License-Identifier: BSL-1.0
//
#ifndef Foundation_File_INCLUDED
#define Foundation_File_INCLUDED
#include <vector>
#include "Poco/Foundation.h"
#include "Poco/Timestamp.h"
#if defined(POCO_OS_FAMILY_UNIX)
# include "Poco/File_UNIX.h"
#endif
namespace Poco
{
class Path;
class Foundation_API File : private FileImpl
/// The File class provides methods for working with a file.
///
/// Regarding paths passed to the various methods, note that
/// platform-specific limitations regarding maximum length
/// of the entire path and its components apply.
///
/// On Windows, if compiled with UTF-8 support (POCO_WIN32_UTF8)
/// the implementation tries to work around the rather low
/// 260 characters MAX_PATH limit by adding the "\\?\" prefix if
/// a path is absolute and exceeds MAX_PATH characters in length.
/// Note that various limitations regarding usage of the "\\?\"
/// prefix apply in that case, e.g. the path must
/// not contain relative components ("." and "..") and must not
/// use the forward slash ("/") as directory separator.
{
public:
typedef FileSizeImpl FileSize;
enum LinkType
/// Type of link for linkTo().
{
LINK_HARD = 0, /// hard link
LINK_SYMBOLIC = 1 /// symbolic link
};
File();
/// Creates the file.
File(const std::string & path);
/// Creates the file.
File(const char * path);
/// Creates the file.
File(const Path & path);
/// Creates the file.
File(const File & file);
/// Copy constructor.
virtual ~File();
/// Destroys the file.
File & operator=(const File & file);
/// Assignment operator.
File & operator=(const std::string & path);
/// Assignment operator.
File & operator=(const char * path);
/// Assignment operator.
File & operator=(const Path & path);
/// Assignment operator.
void swap(File & file);
/// Swaps the file with another one.
const std::string & path() const;
/// Returns the path.
bool exists() const;
/// Returns true iff the file exists.
bool canRead() const;
/// Returns true iff the file is readable.
bool canWrite() const;
/// Returns true iff the file is writeable.
bool canExecute() const;
/// Returns true iff the file is executable.
///
/// On Windows, the file must have
/// the extension ".EXE" to be executable.
/// On Unix platforms, the executable permission
/// bit must be set.
bool isFile() const;
/// Returns true iff the file is a regular file.
bool isLink() const;
/// Returns true iff the file is a symbolic link.
bool isDirectory() const;
/// Returns true iff the file is a directory.
bool isDevice() const;
/// Returns true iff the file is a device.
bool isHidden() const;
/// Returns true if the file is hidden.
///
/// On Windows platforms, the file's hidden
/// attribute is set for this to be true.
///
/// On Unix platforms, the file name must
/// begin with a period for this to be true.
Timestamp created() const;
/// Returns the creation date of the file.
///
/// Not all platforms or filesystems (e.g. Linux and most Unix
/// platforms with the exception of FreeBSD and Mac OS X)
/// maintain the creation date of a file.
/// On such platforms, created() returns
/// the time of the last inode modification.
Timestamp getLastModified() const;
/// Returns the modification date of the file.
File & setLastModified(const Timestamp & ts);
/// Sets the modification date of the file.
FileSize getSize() const;
/// Returns the size of the file in bytes.
File & setSize(FileSize size);
/// Sets the size of the file in bytes. Can be used
/// to truncate a file.
File & setWriteable(bool flag = true);
/// Makes the file writeable (if flag is true), or
/// non-writeable (if flag is false) by setting the
/// file's flags in the filesystem accordingly.
File & setReadOnly(bool flag = true);
/// Makes the file non-writeable (if flag is true), or
/// writeable (if flag is false) by setting the
/// file's flags in the filesystem accordingly.
File & setExecutable(bool flag = true);
/// Makes the file executable (if flag is true), or
/// non-executable (if flag is false) by setting
/// the file's permission bits accordingly.
///
/// Does nothing on Windows.
void copyTo(const std::string & path) const;
/// Copies the file (or directory) to the given path.
/// The target path can be a directory.
///
/// A directory is copied recursively.
void moveTo(const std::string & path);
/// Copies the file (or directory) to the given path and
/// removes the original file. The target path can be a directory.
void renameTo(const std::string & path);
/// Renames the file to the new name.
void linkTo(const std::string & path, LinkType type = LINK_SYMBOLIC) const;
/// Creates a link (symbolic or hard, depending on type argument)
/// at the given path to the file or directory.
///
/// May not be supported on all platforms.
/// Furthermore, some operating systems do not allow creating
/// hard links to directories.
void remove(bool recursive = false);
/// Deletes the file. If recursive is true and the
/// file is a directory, recursively deletes all
/// files in the directory.
bool createFile();
/// Creates a new, empty file in an atomic operation.
/// Returns true if the file has been created and false
/// if the file already exists. Throws an exception if
/// an error occurs.
bool createDirectory();
/// Creates a directory. Returns true if the directory
/// has been created and false if it already exists.
/// Throws an exception if an error occurs.
void createDirectories();
/// Creates a directory (and all parent directories
/// if necessary).
void list(std::vector<std::string> & files) const;
/// Fills the vector with the names of all
/// files in the directory.
void list(std::vector<File> & files) const;
/// Fills the vector with the names of all
/// files in the directory.
FileSize totalSpace() const;
/// Returns the total size in bytes of the partition containing this path.
FileSize usableSpace() const;
/// Returns the number of usable free bytes on the partition containing this path.
FileSize freeSpace() const;
/// Returns the number of free bytes on the partition containing this path.
bool operator==(const File & file) const;
bool operator!=(const File & file) const;
bool operator<(const File & file) const;
bool operator<=(const File & file) const;
bool operator>(const File & file) const;
bool operator>=(const File & file) const;
static void handleLastError(const std::string & path);
/// For internal use only. Throws an appropriate
/// exception for the last file-related error.
protected:
void copyDirectory(const std::string & path) const;
/// Copies a directory. Used internally by copyTo().
};
//
// inlines
//
inline const std::string & File::path() const
{
return getPathImpl();
}
inline bool File::operator==(const File & file) const
{
return getPathImpl() == file.getPathImpl();
}
inline bool File::operator!=(const File & file) const
{
return getPathImpl() != file.getPathImpl();
}
inline bool File::operator<(const File & file) const
{
return getPathImpl() < file.getPathImpl();
}
inline bool File::operator<=(const File & file) const
{
return getPathImpl() <= file.getPathImpl();
}
inline bool File::operator>(const File & file) const
{
return getPathImpl() > file.getPathImpl();
}
inline bool File::operator>=(const File & file) const
{
return getPathImpl() >= file.getPathImpl();
}
inline void swap(File & f1, File & f2)
{
f1.swap(f2);
}
} // namespace Poco
#endif // Foundation_File_INCLUDED