Asio Extensions
Additional functionality built on top of (Boost.)Asio
|
A thin and lightweight wrapper around a native file handle. More...
#include <asioext/file_handle.hpp>
Public Types | |
typedef implementation_defined | native_handle_type |
The operating system's native file handle type. More... | |
typedef file_handle | lowest_layer_type |
A file_handle is always the lowest layer. More... | |
Public Member Functions | |
file_handle () noexcept | |
Construct an empy file_handle. More... | |
~file_handle () | |
file_handle (const native_handle_type &handle) noexcept | |
Construct a file_handle using a native handle. More... | |
lowest_layer_type & | lowest_layer () noexcept |
Get a reference to the lowest layer. More... | |
const lowest_layer_type & | lowest_layer () const noexcept |
Get a const reference to the lowest layer. More... | |
native_handle_type | native_handle () const noexcept |
Get the native handle representation. More... | |
Handle-management functions | |
bool | is_open () const noexcept |
Determine whether the handle is open. More... | |
void | close () |
Close the handle. More... | |
void | close (error_code &ec) noexcept |
Close the handle. More... | |
void | clear () noexcept |
Clear the handle. More... | |
Positioning functions | |
uint64_t | position () |
Get the current file position. More... | |
uint64_t | position (error_code &ec) noexcept |
Get the current file position. More... | |
uint64_t | seek (seek_origin origin, int64_t offset) |
Change the read/write position. More... | |
uint64_t | seek (seek_origin origin, int64_t offset, error_code &ec) noexcept |
Change the read/write position. More... | |
Metadata functions | |
uint64_t | size () |
Get the size of a file. More... | |
uint64_t | size (error_code &ec) noexcept |
Get the size of a file. More... | |
void | size (uint64_t new_size) |
Set the size of a file. More... | |
void | size (uint64_t new_size, error_code &ec) noexcept |
Set the size of a file. More... | |
file_perms | permissions () |
Get the file's current access permissions. More... | |
file_perms | permissions (error_code &ec) noexcept |
Get the file's current access permissions. More... | |
void | permissions (file_perms perms, file_perm_options opts=file_perm_options::replace) |
Change file access permissions. More... | |
void | permissions (file_perms perms, error_code &ec) noexcept |
Change file access permissions. More... | |
void | permissions (file_perms perms, file_perm_options opts, error_code &ec) noexcept |
Change file access permissions. More... | |
file_attrs | attributes () |
Get the file's attributes. More... | |
file_attrs | attributes (error_code &ec) noexcept |
Get the file's attributes. More... | |
void | attributes (file_attrs attrs, file_attr_options opts=file_attr_options::replace) |
Change the file's attributes. More... | |
void | attributes (file_attrs attrs, error_code &ec) noexcept |
Change the file's attributes. More... | |
void | attributes (file_attrs attrs, file_attr_options opts, error_code &ec) noexcept |
Change the file's attributes. More... | |
file_times | times () |
Get the file's time data. More... | |
file_times | times (error_code &ec) noexcept |
Get the file's time data. More... | |
void | times (const file_times &new_times) |
Change a file's time data. More... | |
void | times (const file_times &new_times, error_code &ec) noexcept |
Change a file's time data. More... | |
SyncReadStream functions | |
template<typename MutableBufferSequence > | |
std::size_t | read_some (const MutableBufferSequence &buffers) |
Read some data from the file. More... | |
template<typename MutableBufferSequence > | |
std::size_t | read_some (const MutableBufferSequence &buffers, error_code &ec) noexcept |
Read some data from the file. More... | |
SyncWriteStream functions | |
template<typename ConstBufferSequence > | |
std::size_t | write_some (const ConstBufferSequence &buffers) |
Write some data to the file. More... | |
template<typename ConstBufferSequence > | |
std::size_t | write_some (const ConstBufferSequence &buffers, error_code &ec) noexcept |
Write some data to the file. More... | |
SyncRandomAccessReadDevice functions | |
template<typename MutableBufferSequence > | |
std::size_t | read_some_at (uint64_t offset, const MutableBufferSequence &buffers) |
Read some data from the file at the specified offset. More... | |
template<typename MutableBufferSequence > | |
std::size_t | read_some_at (uint64_t offset, const MutableBufferSequence &buffers, error_code &ec) noexcept |
Read some data from the file at the specified offset. More... | |
SyncRandomAccessWriteDevice functions | |
template<typename ConstBufferSequence > | |
std::size_t | write_some_at (uint64_t offset, const ConstBufferSequence &buffers) |
Write some data to the file at the specified offset. More... | |
template<typename ConstBufferSequence > | |
std::size_t | write_some_at (uint64_t offset, const ConstBufferSequence &buffers, error_code &ec) noexcept |
Write some data to the file at the specified offset. More... | |
A thin and lightweight wrapper around a native file handle.
The file_handle class provides uniform access to native OS file handles, wrapping the relevant OS APIs in portable methods.
file_handle doesn't assume ownership of the contained handle. If handle management is desired as well, take a look at the unique_file_handle
class.
file_handle models the following asio concepts:
A file_handle is always the lowest layer.
typedef implementation_defined asioext::file_handle::native_handle_type |
The operating system's native file handle type.
|
noexcept |
Construct an empy file_handle.
This constructor initializes the file_handle to an empty state.
asioext::file_handle::~file_handle | ( | ) |
Destroy a file_handle.
This destructor does nothing. Any contained handle will not be closed.
|
noexcept |
Construct a file_handle using a native handle.
This constructor doesn't take ownership of the given native file handle.
handle | The native file handle which shall be assigned to this file_handle object. |
file_attrs asioext::file_handle::attributes | ( | ) |
Get the file's attributes.
This function returns the file's attributes as a file_attrs
bitmask.
asio::system_error | Thrown on failure. |
|
noexcept |
Get the file's attributes.
This function returns the file's attributes as a file_attrs
bitmask.
ec | Set to indicate what error occurred. If no error occurred, the object is reset. |
void asioext::file_handle::attributes | ( | file_attrs | attrs, |
file_attr_options | opts = file_attr_options::replace |
||
) |
Change the file's attributes.
This function changes the file's attributes. Depending on whether file_attr_options::add_attrs
, file_attr_options::remove_attrs
are set, attributes are either added, removed or replaced.
attrs | Attributes to set, add or remove. |
opts | Options controlling this function's behavior. |
asio::system_error | Thrown on failure. |
|
noexcept |
Change the file's attributes.
This function changes the file's attributes. Depending on whether file_attr_options::add_attrs
, file_attr_options::remove_attrs
are set, attributes are either added, removed or replaced.
attrs | Attributes to set, add or remove. |
ec | Set to indicate what error occurred. If no error occurred, the object is reset. |
|
noexcept |
Change the file's attributes.
This function changes the file's attributes. Depending on whether file_attr_options::add_attrs
, file_attr_options::remove_attrs
are set, attributes are either added, removed or replaced.
attrs | Attributes to set, add or remove. |
opts | Options controlling this function's behavior. |
ec | Set to indicate what error occurred. If no error occurred, the object is reset. |
|
noexcept |
Clear the handle.
This function resets the contained handle to an empty state. The previous handle is not closed.
void asioext::file_handle::close | ( | ) |
Close the handle.
This function closes the contained handle. Does nothing if the object contains no handle.
asio::system_error | Thrown on failure. |
|
noexcept |
Close the handle.
This function closes the contained handle. Does nothing if the object contains no handle.
ec | Set to indicate what error occurred. If no error occurred, the object is reset. |
|
noexcept |
Determine whether the handle is open.
|
inlinenoexcept |
Get a reference to the lowest layer.
This function returns a reference to the lowest layer in a stack of layers. Since a file_handle cannot contain any further layers, it simply returns a reference to itself.
|
inlinenoexcept |
Get a const reference to the lowest layer.
This function returns a const reference to the lowest layer in a stack of layers. Since a file_handle cannot contain any further layers, it simply returns a reference to itself.
|
inlinenoexcept |
Get the native handle representation.
This function may be used to obtain the underlying representation of the handle. This is intended to allow access to native handle functionality that is not otherwise provided.
file_perms asioext::file_handle::permissions | ( | ) |
Get the file's current access permissions.
This function returns the file's current access permissions as a file_perms
bitmask.
asio::system_error | Thrown on failure. |
|
noexcept |
Get the file's current access permissions.
This function returns the file's current access permissions as a file_perms
bitmask.
ec | Set to indicate what error occurred. If no error occurred, the object is reset. |
void asioext::file_handle::permissions | ( | file_perms | perms, |
file_perm_options | opts = file_perm_options::replace |
||
) |
Change file access permissions.
This function changes the file's access permissions. Depending on whether file_perm_options::add_perms
, file_perm_options::remove_perms
are set, permissions are either added, removed or replaced.
perms | Permissions to set, add or remove. |
opts | Options controlling this function's behavior. |
asio::system_error | Thrown on failure. |
|
noexcept |
Change file access permissions.
This function changes the file's access permissions. Depending on whether file_perm_options::add_perms
, file_perm_options::remove_perms
are set, permissions are either added, removed or replaced.
perms | Permissions to set, add or remove. |
ec | Set to indicate what error occurred. If no error occurred, the object is reset. |
|
noexcept |
Change file access permissions.
This function changes the file's access permissions. Depending on whether file_perm_options::add_perms
, file_perm_options::remove_perms
are set, permissions are either added, removed or replaced.
perms | Permissions to set, add or remove. |
opts | Options controlling this function's behavior. |
ec | Set to indicate what error occurred. If no error occurred, the object is reset. |
uint64_t asioext::file_handle::position | ( | ) |
Get the current file position.
This function retrieves the current read/write position of this file handle, relative to the file's beginning.
asio::system_error | Thrown on failure. |
|
noexcept |
Get the current file position.
This function retrieves the current read/write position of this file handle, relative to the file's beginning.
ec | Set to indicate what error occurred. If no error occurred, the object is reset. |
std::size_t asioext::file_handle::read_some | ( | const MutableBufferSequence & | buffers | ) |
Read some data from the file.
This function is used to read data from the file, starting at the file_handle's current file position. The function call will block until one or more bytes of data has been read successfully, or until an error occurs.
buffers | One or more buffers into which the data will be read. |
asio::system_error | Thrown on failure. An error code of asio::error::eof indicates that the end of file was reached. |
asio::read
function if you need to ensure that the requested amount of data is read before the blocking operation completes.asio::buffer
function as follows: asio::buffer
documentation for information on reading into multiple buffers in one go, and how to use it with arrays, boost::array or std::vector.
|
noexcept |
Read some data from the file.
This function is used to read data from the file, starting at the file_handle's current file position. The function call will block until one or more bytes of data has been read successfully, or until an error occurs.
buffers | One or more buffers into which the data will be read. |
ec | Set to indicate what error occurred. If no error occurred, the object is reset. |
asio::read
function if you need to ensure that the requested amount of data is read before the blocking operation completes. std::size_t asioext::file_handle::read_some_at | ( | uint64_t | offset, |
const MutableBufferSequence & | buffers | ||
) |
Read some data from the file at the specified offset.
This function is used to read data from the file. The function call will block until one or more bytes of data has been read successfully, or until an error occurs.
offset | The offset at which the data will be read, relative to the file's beginning. |
buffers | One or more buffers into which the data will be read. |
asio::system_error | Thrown on failure. An error code of asio::error::eof indicates that the end of the file was reached. |
asio::read_at
function if you need to ensure that the requested amount of data is read before the blocking operation completes.asio::buffer
function as follows: asio::buffer
documentation for information on reading into multiple buffers in one go, and how to use it with arrays, boost::array or std::vector.
|
noexcept |
Read some data from the file at the specified offset.
This function is used to read data from the file. The function call will block until one or more bytes of data has been read successfully, or until an error occurs.
offset | The offset at which the data will be read, relative to the file's beginning. |
buffers | One or more buffers into which the data will be read. |
ec | Set to indicate what error occurred. If no error occurred, the object is reset. |
asio::read_at
function if you need to ensure that the requested amount of data is read before the blocking operation completes. uint64_t asioext::file_handle::seek | ( | seek_origin | origin, |
int64_t | offset | ||
) |
Change the read/write position.
This function repositions the current read/write position of this file_handle by offset
, relative to the origin specified by origin
.
origin | The origin of offset . |
offset | The offset by which the current position's modified. |
asio::system_error | Thrown on failure. |
|
noexcept |
Change the read/write position.
This function repositions the current read/write position of this file_handle by offset
, relative to the origin specified by origin
.
origin | The origin of offset . |
offset | The offset by which the current position's modified. |
ec | Set to indicate what error occurred. If no error occurred, the object is reset. |
uint64_t asioext::file_handle::size | ( | ) |
Get the size of a file.
This function retrieves the size of a file, in bytes.
asio::system_error | Thrown on failure. |
|
noexcept |
Get the size of a file.
This function retrieves the size of a file, in bytes.
ec | Set to indicate what error occurred. If no error occurred, the object is reset. |
void asioext::file_handle::size | ( | uint64_t | new_size | ) |
Set the size of a file.
This function resizes the file so its new size matches new_size
.
new_size | The new total size of the file (in bytes). |
asio::system_error | Thrown on failure. |
|
noexcept |
Set the size of a file.
This function resizes the file so its new size matches new_size
.
new_size | The new total size of the file (in bytes). |
ec | Set to indicate what error occurred. If no error occurred, the object is reset. |
file_times asioext::file_handle::times | ( | ) |
Get the file's time data.
This function retrieves the various times associated with a file and copies them into a file_times
structure.
Times in the file_times struct that are not available for this file are zero-initialized.
asio::system_error | Thrown on failure. |
|
noexcept |
Get the file's time data.
This function retrieves the various times associated with a file and copies them into a file_times
structure.
Times in the file_times struct that are not available for this file are zero-initialized.
ec | Set to indicate what error occurred. If no error occurred, the object is reset. |
void asioext::file_handle::times | ( | const file_times & | new_times | ) |
Change a file's time data.
This function replaces a file's time data with the given values. File times that are set to zero inside the file_times
structure remain unchanged.
new_times | The new file times. Zero values are ignored. |
asio::system_error | Thrown on failure. |
|
noexcept |
Change a file's time data.
This function replaces a file's time data with the given values. File times that are set to zero inside the file_times
structure remain unchanged.
new_times | The new file times. Zero values are ignored. |
ec | Set to indicate what error occurred. If no error occurred, the object is reset. |
std::size_t asioext::file_handle::write_some | ( | const ConstBufferSequence & | buffers | ) |
Write some data to the file.
This function is used to write data to the file, starting at the file_handle's current file position. The function call will block until one or more bytes of the data has been written successfully, or until an error occurs.
buffers | One or more data buffers to be written to the file. |
asio::system_error | Thrown on failure. |
asio::write
function if you need to ensure that all data is written before the blocking operation completes.asio::buffer
function as follows: asio::buffer
documentation for information on writing multiple buffers in one go, and how to use it with arrays, boost::array or std::vector.
|
noexcept |
Write some data to the file.
This function is used to write data to the file, starting at the file_handle's current file position. The function call will block until one or more bytes of the data has been written successfully, or until an error occurs.
buffers | One or more data buffers to be written to the file. |
ec | Set to indicate what error occurred. If no error occurred, the object is reset. |
asio::write
function if you need to ensure that all data is written before the blocking operation completes. std::size_t asioext::file_handle::write_some_at | ( | uint64_t | offset, |
const ConstBufferSequence & | buffers | ||
) |
Write some data to the file at the specified offset.
This function is used to write data to the file. The function call will block until one or more bytes of the data has been written successfully, or until an error occurs.
offset | The offset at which the data will be written, relative to the file's beginning. |
buffers | One or more data buffers to be written. |
asio::system_error | Thrown on failure. |
asio::write_at
function if you need to ensure that all data is written before the blocking operation completes.asio::buffer
function as follows: asio::buffer
documentation for information on writing multiple buffers in one go, and how to use it with arrays, boost::array or std::vector.
|
noexcept |
Write some data to the file at the specified offset.
This function is used to write data to the file. The function call will block until one or more bytes of the data has been written successfully, or until an error occurs.
offset | The offset at which the data will be written, relative to the file's beginning. |
buffers | One or more data buffers to be written to the handle. |
ec | Set to indicate what error occurred. If no error occurred, the object is reset. |
asio::write_at
function if you need to ensure that all data is written before the blocking operation completes.