1 #ifndef LIBFILEZILLA_FILE_HEADER
2 #define LIBFILEZILLA_FILE_HEADER
4 #include "fsresult.hpp"
8 #include "glue/windows.hpp"
28 class FZ_PUBLIC_SYMBOL
file final
32 typedef HANDLE file_t;
63 current_user_only = 0x4,
75 current_user_and_admins_only = 0x8
86 explicit file(file_t fd);
91 file& operator=(
file const&) =
delete;
94 file& operator=(
file && op) noexcept;
97 explicit operator
bool()
const {
return opened(); }
99 result open(
native_string const& f, mode m, creation_flags d = existing);
125 int64_t size()
const;
139 int64_t seek(int64_t offset, seek_mode m);
164 int64_t
read(
void *buf, int64_t count);
176 int64_t
write(
void const* buf, int64_t count);
189 bool set_modification_time(
datetime const& t);
193 HANDLE fd_{INVALID_HANDLE_VALUE};
Data has become available.
mode
Files can be opened for reading, writing, or both.
Definition: file.hpp:38
Represents a point of time in wallclock, tracking the timestamps accuracy/precision.
Definition: time.hpp:40
Seek from current position in the file.
Definition: file.hpp:116
int64_t position()
Get Current position in file.
Definition: file.hpp:142
std::wstring native_string
A string in the system's native character type and encoding. Note: This typedef changes depending on...
Definition: string.hpp:33
Seek from beginning of file.
Definition: file.hpp:113
bool remove_file(native_string const &name)
remove the specified file.
The namespace used by libfilezilla.
Definition: apply.hpp:17
seek_mode
Used by seek.
Definition: file.hpp:111
creation_flags
Creation flags when opening file for writing.
Definition: file.hpp:50
Lean class for file access.
Definition: file.hpp:28
Sets some global macros and further includes string.hpp.
file_t fd()
Returns the raw file descriptor, but retains ownership.
Definition: file.hpp:104