libtasks Documentation
1.6
|
#include <event_task.h>
Classes | |
struct | error_func_t |
Public Types | |
typedef std::function< void(worker *worker, const tasks_exception &e)> | error_func_worker_t |
typedef std::function< void(const tasks_exception &e)> | error_func_void_t |
![]() | |
typedef std::function< void(worker *worker)> | finish_func_worker_t |
typedef std::function< void()> | finish_func_void_t |
Public Member Functions | |
virtual | ~event_task () |
virtual bool | handle_event (worker *worker, int events)=0 |
virtual void | init_watcher ()=0 |
Initialize the underlying watcher object. More... | |
virtual void | stop_watcher (worker *worker)=0 |
Deactivate the underlying watcher. More... | |
virtual void | start_watcher (worker *worker)=0 |
Activate the underlying watcher to listen for I/O or timer events. More... | |
worker * | assigned_worker () const |
Returns a pointer to the assigned worker. More... | |
void | assign_worker (worker *worker) |
void | notify_error (worker *worker=nullptr) |
void | on_error (error_func_worker_t f) |
void | on_error (error_func_void_t f) |
Install an error callback. More... | |
![]() | |
virtual | ~task () |
bool | auto_delete () const |
Returns true if auto deletion is active. More... | |
void | disable_auto_delete () |
Call this to deactivate auto deletion. More... | |
void | finish (worker *worker=nullptr) |
Called by a worker when a task has auto_deletion enabled. More... | |
void | on_finish (finish_func_worker_t f) |
void | on_finish (finish_func_void_t f) |
![]() | |
error_base () | |
virtual | ~error_base () |
bool | error () const |
Return true if an error occured. More... | |
tasks_error | error_code () const |
Return the error code. More... | |
const std::string & | error_message () const |
Return the error message. More... | |
int | sys_errno () const |
Return the errno if available. More... | |
std::string | sys_errno_str () const |
Return the errno description if available. More... | |
const tasks_exception & | exception () const |
Return the underlying exception object. More... | |
void | set_exception (tasks_exception &e) |
Set an exception to report an error. More... | |
void | reset_error () |
Reset the error state. More... | |
Private Attributes | |
worker * | m_worker = nullptr |
std::vector< error_func_t > | m_error_funcs |
Definition at line 21 of file event_task.h.
typedef std::function<void(const tasks_exception& e)> tasks::event_task::error_func_void_t |
Definition at line 24 of file event_task.h.
typedef std::function<void(worker* worker, const tasks_exception& e)> tasks::event_task::error_func_worker_t |
Definition at line 23 of file event_task.h.
|
inlinevirtual |
Definition at line 45 of file event_task.h.
void tasks::event_task::assign_worker | ( | worker * | worker | ) |
Assigns a worker to the task in multi loop mode.
For multi loop mode a task does not leave the context of a worker thread, as each thread runs its own event loop. That also means this worker has to execute a dispose action. As dispose allows to be called from outside of the task system (a non worker thread context), a handle to the worker the task belongs to is needed. The method does nothing in single loop mode.
worker | The worker to assign. |
Definition at line 13 of file event_task.cpp.
|
inline |
Returns a pointer to the assigned worker.
Definition at line 68 of file event_task.h.
|
pure virtual |
Will be called for each I/O or timer event.
Each task needs to implement the handle_event method. Returns true if the task stays active and false otherwise. The task will be deleted if false is returned and auto_delete() returns true.
worker | The worker thread executing the task. |
events | The events bitmask. |
Implemented in tasks::net::acceptor< T >, echo_handler, tasks::net::http_sender< handler_type >, tasks::net::uwsgi_task, tasks::disk_io_task, test_http_close_handler, stats, tasks::cleanup_task, stats, stats, and echo_handler.
|
pure virtual |
Initialize the underlying watcher object.
Implemented in tasks::io_task_base, tasks::timer_task, and tasks::disk_io_task.
void tasks::event_task::notify_error | ( | worker * | worker = nullptr | ) |
Called by a worker when a task reports an error. All error callbacks will be executed. A worker calls this method after handle_event.
Definition at line 22 of file event_task.cpp.
|
inline |
If a task failed it can execute callback functions. Note that no locks will be used at this level.
Definition at line 86 of file event_task.h.
|
inline |
Install an error callback.
Definition at line 91 of file event_task.h.
|
pure virtual |
Activate the underlying watcher to listen for I/O or timer events.
Implemented in tasks::io_task_base, tasks::timer_task, and tasks::disk_io_task.
|
pure virtual |
Deactivate the underlying watcher.
Implemented in tasks::io_task_base, tasks::timer_task, and tasks::disk_io_task.
|
private |
Definition at line 97 of file event_task.h.
|
private |
Definition at line 96 of file event_task.h.