Thrill
0.1
|
Request that is aware of threads waiting for it to complete.
Definition at line 29 of file request_with_waiters.hpp.
#include <request_with_waiters.hpp>
Public Member Functions | |
request_with_waiters (const completion_handler &on_complete, file *file, void *buffer, offset_type offset, size_type bytes, read_or_write op) | |
Public Member Functions inherited from request | |
request (const completion_handler &on_complete, file *file, void *buffer, offset_type offset, size_type bytes, read_or_write op) | |
request (const request &)=delete | |
non-copyable: delete copy-constructor More... | |
request (request &&)=default | |
move-constructor: default More... | |
virtual | ~request () |
request & | operator= (const request &)=delete |
non-copyable: delete assignment operator More... | |
request & | operator= (request &&)=default |
move-assignment operator: default More... | |
file * | get_file () const |
void * | buffer () const |
offset_type | offset () const |
size_type | bytes () const |
read_or_write | op () const |
void | check_alignment () const |
std::ostream & | print (std::ostream &out) const final |
Dumps properties of a request. More... | |
void | error_occured (const char *msg) |
void | error_occured (const std::string &msg) |
void | check_errors () |
Rises an exception if there were error with the I/O. More... | |
const char * | io_type () const override |
Identifies the type of I/O implementation. More... | |
void | release_file_reference () |
Public Member Functions inherited from request_interface | |
request_interface ()=default | |
request_interface (const request_interface &)=delete | |
non-copyable: delete copy-constructor More... | |
virtual | ~request_interface () |
virtual bool | cancel ()=0 |
Cancel a request. More... | |
request_interface & | operator= (const request_interface &)=delete |
non-copyable: delete assignment operator More... | |
virtual bool | poll ()=0 |
virtual void | wait (bool measure_time=true)=0 |
Suspends calling thread until completion of the request. More... | |
Public Member Functions inherited from ReferenceCounter | |
ReferenceCounter () noexcept | |
new objects have zero reference count More... | |
ReferenceCounter (const ReferenceCounter &) noexcept | |
coping still creates a new object with zero reference count More... | |
~ReferenceCounter () | |
bool | dec_reference () const noexcept |
Call whenever resetting (i.e. More... | |
void | inc_reference () const noexcept |
Call whenever setting a pointer to the object. More... | |
ReferenceCounter & | operator= (const ReferenceCounter &) noexcept |
assignment operator, leaves pointers unchanged More... | |
size_t | reference_count () const noexcept |
Return the number of references to this object (for debugging) More... | |
bool | unique () const noexcept |
Test if the ReferenceCounter is referenced by only one CountingPtr. More... | |
Protected Member Functions | |
bool | add_waiter (onoff_switch *sw) final |
void | delete_waiter (onoff_switch *sw) final |
void | notify_waiters () final |
size_t | num_waiters () |
returns number of waiters More... | |
Protected Member Functions inherited from request | |
void | check_nref (bool after=false) |
Protected Member Functions inherited from request_interface | |
virtual void | completed (bool canceled)=0 |
Private Attributes | |
std::set< onoff_switch * > | waiters_ |
std::mutex | waiters_mutex_ |
Additional Inherited Members | |
Public Types inherited from request_interface | |
using | offset_type = uint64_t |
type for offsets within a file More... | |
enum | read_or_write { READ, WRITE } |
using | size_type = size_t |
type for block transfer sizes More... | |
Protected Attributes inherited from request | |
std::unique_ptr< io_error > | error_ |
completion_handler | on_complete_ |
file * | file_ |
file implementation to perform I/O with More... | |
void * | buffer_ |
data buffer to transfer More... | |
offset_type | offset_ |
offset within file More... | |
size_type | bytes_ |
number of bytes at buffer_ to transfer More... | |
read_or_write | op_ |
READ or WRITE. More... | |
|
inline |
Definition at line 43 of file request_with_waiters.hpp.
|
finalprotectedvirtual |
Implements request_interface.
Definition at line 23 of file request_with_waiters.cpp.
References request_interface::poll(), request_with_waiters::waiters_, and request_with_waiters::waiters_mutex_.
|
finalprotectedvirtual |
Implements request_interface.
Definition at line 41 of file request_with_waiters.cpp.
References request_with_waiters::waiters_, and request_with_waiters::waiters_mutex_.
|
finalprotectedvirtual |
Implements request_interface.
Definition at line 47 of file request_with_waiters.cpp.
References onoff_switch::on(), request_with_waiters::waiters_, and request_with_waiters::waiters_mutex_.
Referenced by request_with_state::cancel(), and request_with_state::completed().
|
protected |
returns number of waiters
Definition at line 56 of file request_with_waiters.cpp.
References request_with_waiters::waiters_, and request_with_waiters::waiters_mutex_.
|
private |
Definition at line 32 of file request_with_waiters.hpp.
Referenced by request_with_waiters::add_waiter(), request_with_waiters::delete_waiter(), request_with_waiters::notify_waiters(), and request_with_waiters::num_waiters().
|
private |
Definition at line 31 of file request_with_waiters.hpp.
Referenced by request_with_waiters::add_waiter(), request_with_waiters::delete_waiter(), request_with_waiters::notify_waiters(), and request_with_waiters::num_waiters().