2012-04-29 18:52:25 +00:00
|
|
|
//
|
|
|
|
// File.h
|
|
|
|
//
|
|
|
|
// Library: Foundation
|
|
|
|
// Package: Filesystem
|
|
|
|
// Module: File
|
|
|
|
//
|
|
|
|
// Definition of the File class.
|
|
|
|
//
|
|
|
|
// Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH.
|
|
|
|
// and Contributors.
|
|
|
|
//
|
2014-05-04 21:02:42 +02:00
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
2012-04-29 18:52:25 +00:00
|
|
|
//
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef Foundation_File_INCLUDED
|
|
|
|
#define Foundation_File_INCLUDED
|
|
|
|
|
|
|
|
|
|
|
|
#include "Poco/Foundation.h"
|
|
|
|
#include "Poco/Timestamp.h"
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
|
2022-07-07 17:18:20 +08:00
|
|
|
#if defined(POCO_OS_FAMILY_WINDOWS)
|
2012-04-29 18:52:25 +00:00
|
|
|
#include "Poco/File_WIN32U.h"
|
|
|
|
#elif defined(POCO_VXWORKS)
|
|
|
|
#include "Poco/File_VX.h"
|
|
|
|
#elif 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.
|
2017-02-02 20:54:59 +01:00
|
|
|
///
|
2017-11-09 11:15:18 +01:00
|
|
|
/// Regarding paths passed to the various methods, note that
|
2017-02-02 20:54:59 +01:00
|
|
|
/// platform-specific limitations regarding maximum length
|
|
|
|
/// of the entire path and its components apply.
|
|
|
|
///
|
2020-01-09 10:08:09 +01:00
|
|
|
/// On Windows, the implementation tries to work around the rather low
|
2017-02-02 20:54:59 +01:00
|
|
|
/// 260 characters MAX_PATH limit by adding the "\\?\" prefix if
|
|
|
|
/// a path is absolute and exceeds MAX_PATH characters in length.
|
2017-11-09 11:15:18 +01:00
|
|
|
/// Note that various limitations regarding usage of the "\\?\"
|
2017-02-02 20:54:59 +01:00
|
|
|
/// prefix apply in that case, e.g. the path must
|
2017-11-09 11:15:18 +01:00
|
|
|
/// not contain relative components ("." and "..") and must not
|
2017-02-02 20:54:59 +01:00
|
|
|
/// use the forward slash ("/") as directory separator.
|
2012-04-29 18:52:25 +00:00
|
|
|
{
|
|
|
|
public:
|
2024-07-29 13:16:18 -05:00
|
|
|
using FileSize = FileSizeImpl;
|
2012-04-29 18:52:25 +00:00
|
|
|
|
2017-12-14 10:35:07 +01:00
|
|
|
enum LinkType
|
|
|
|
/// Type of link for linkTo().
|
|
|
|
{
|
|
|
|
LINK_HARD = 0, /// hard link
|
|
|
|
LINK_SYMBOLIC = 1 /// symbolic link
|
|
|
|
};
|
|
|
|
|
2019-11-26 13:03:43 +01:00
|
|
|
enum Options
|
|
|
|
/// Options for File Copy/Movement
|
|
|
|
{
|
2019-11-27 14:44:55 +01:00
|
|
|
OPT_FAIL_ON_OVERWRITE = OPT_FAIL_ON_OVERWRITE_IMPL
|
2019-11-26 13:03:43 +01:00
|
|
|
};
|
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
File();
|
|
|
|
/// Creates the file.
|
|
|
|
|
|
|
|
File(const std::string& path);
|
|
|
|
/// Creates the file.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
File(const char* path);
|
|
|
|
/// Creates the file.
|
|
|
|
|
|
|
|
File(const Path& path);
|
|
|
|
/// Creates the file.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
File(const File& file);
|
|
|
|
/// Copy constructor.
|
|
|
|
|
2024-07-29 13:16:18 -05:00
|
|
|
~File() override;
|
2012-04-29 18:52:25 +00:00
|
|
|
/// Destroys the file.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
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.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2022-06-28 19:14:36 +02:00
|
|
|
void swap(File& file) noexcept;
|
2012-04-29 18:52:25 +00:00
|
|
|
/// Swaps the file with another one.
|
|
|
|
|
|
|
|
const std::string& path() const;
|
|
|
|
/// Returns the path.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2024-07-29 13:16:18 -05:00
|
|
|
std::string absolutePath() const;
|
|
|
|
/// Returns absolute path.
|
|
|
|
/// Attempts to find the existing file
|
|
|
|
/// using curent work directory and the PATH
|
|
|
|
/// environment variable.
|
|
|
|
/// If the file doesn't exist, returns empty string.
|
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
bool exists() const;
|
|
|
|
/// Returns true iff the file exists.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2024-07-29 13:16:18 -05:00
|
|
|
bool existsAnywhere() const;
|
|
|
|
/// If the file path is relative, searches
|
|
|
|
/// for the file in the current working directory
|
|
|
|
/// and the environment paths.
|
|
|
|
/// If the file path is absolute, the
|
|
|
|
/// functionality is identical to the
|
|
|
|
/// exists() call.
|
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
bool canRead() const;
|
|
|
|
/// Returns true iff the file is readable.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
bool canWrite() const;
|
|
|
|
/// Returns true iff the file is writeable.
|
|
|
|
|
|
|
|
bool canExecute() const;
|
|
|
|
/// Returns true iff the file is executable.
|
|
|
|
///
|
2017-11-09 11:15:18 +01:00
|
|
|
/// On Windows, the file must have
|
2012-04-29 18:52:25 +00:00
|
|
|
/// 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.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
bool isLink() const;
|
|
|
|
/// Returns true iff the file is a symbolic link.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
bool isDirectory() const;
|
|
|
|
/// Returns true iff the file is a directory.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
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.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
File& setLastModified(const Timestamp& ts);
|
|
|
|
/// Sets the modification date of the file.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
FileSize getSize() const;
|
|
|
|
/// Returns the size of the file in bytes.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
File& setSize(FileSize size);
|
|
|
|
/// Sets the size of the file in bytes. Can be used
|
|
|
|
/// to truncate a file.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
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.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
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.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
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.
|
|
|
|
///
|
2017-11-09 11:15:18 +01:00
|
|
|
/// Does nothing on Windows.
|
|
|
|
|
2019-11-26 13:03:43 +01:00
|
|
|
void copyTo(const std::string& path, int options = 0) const;
|
2017-11-09 11:15:18 +01:00
|
|
|
/// Copies the file (or directory) to the given path.
|
2012-04-29 18:52:25 +00:00
|
|
|
/// The target path can be a directory.
|
|
|
|
///
|
|
|
|
/// A directory is copied recursively.
|
2019-11-26 14:10:32 +01:00
|
|
|
/// If options is set to OPT_FAIL_ON_OVERWRITE the Method throws an FileExists Exception
|
2019-11-18 13:06:43 +01:00
|
|
|
/// if the File already exists.
|
2012-04-29 18:52:25 +00:00
|
|
|
|
2019-11-26 13:03:43 +01:00
|
|
|
void moveTo(const std::string& path, int options = 0);
|
2017-11-09 11:15:18 +01:00
|
|
|
/// Copies the file (or directory) to the given path and
|
2012-04-29 18:52:25 +00:00
|
|
|
/// removes the original file. The target path can be a directory.
|
2019-11-26 14:10:32 +01:00
|
|
|
/// If options is set to OPT_FAIL_ON_OVERWRITE the Method throws an FileExists Exception
|
2019-11-18 13:06:43 +01:00
|
|
|
/// if the File already exists.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2019-11-26 13:03:43 +01:00
|
|
|
void renameTo(const std::string& path, int options = 0);
|
2012-04-29 18:52:25 +00:00
|
|
|
/// Renames the file to the new name.
|
2019-11-26 14:10:32 +01:00
|
|
|
/// If options is set to OPT_FAIL_ON_OVERWRITE the Method throws an FileExists Exception
|
2019-11-18 13:06:43 +01:00
|
|
|
/// if the File already exists.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2017-12-14 10:35:07 +01:00
|
|
|
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.
|
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
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.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
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.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
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.
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
void createDirectories();
|
|
|
|
/// Creates a directory (and all parent directories
|
|
|
|
/// if necessary).
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
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.
|
|
|
|
|
2018-03-06 18:46:48 +01:00
|
|
|
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.
|
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
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;
|
2017-11-09 11:15:18 +01:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
static void handleLastError(const std::string& path);
|
|
|
|
/// For internal use only. Throws an appropriate
|
|
|
|
/// exception for the last file-related error.
|
|
|
|
|
|
|
|
protected:
|
2019-11-26 13:03:43 +01:00
|
|
|
void copyDirectory(const std::string& path, int options = 0) const;
|
2012-04-29 18:52:25 +00:00
|
|
|
/// 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();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-06-28 19:14:36 +02:00
|
|
|
inline void swap(File& f1, File& f2) noexcept
|
2012-04-29 18:52:25 +00:00
|
|
|
{
|
|
|
|
f1.swap(f2);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
} // namespace Poco
|
|
|
|
|
|
|
|
|
|
|
|
#endif // Foundation_File_INCLUDED
|