salsa
0.3.0
|
#include <Worker.hh>
Public Member Functions | |
Worker (std::string uuid, std::shared_ptr< Socket > pPipe, NodeManager *pNM) | |
virtual | ~Worker () |
uint32_t | numCores () const |
virtual void | onEnter (Message *pInMsg, std::vector< std::string > &out, std::string type) |
TODO Three horsemen of apocalypse. More... | |
virtual void | onExit (Message *pInMsg, std::vector< std::string > &out) |
virtual void | onWhisper (Message *pInMsg, std::vector< std::string > &out) |
std::string | uuid () const |
Returns distributor's UUID. More... | |
std::shared_ptr< Socket > | pipe () const |
TODO Returns distributor's pipe? More... | |
void | print () const |
TODO Prints distributor's state. More... | |
void | addClient (std::string uuid, std::string type) |
void | removeClient (std::string uuid) |
void | addOther (std::string uuid, std::string type) |
void | removeOther (std::string uuid) |
NodeInfo * | nodeInfo () const |
Static Public Member Functions | |
static std::shared_ptr< spdlog::logger > | getConsoleOutput () |
Get console output. | |
static void | setConsoleLevel (spdlog::level::level_enum level) |
Sets console log level. | |
Protected Attributes | |
std::string | mUUID {} |
Self UUID. | |
std::shared_ptr< Socket > | mpPipe = nullptr |
Pipe for messages (net connector) | |
std::map< std::string, std::string > | mClients {} |
List of clients. | |
std::map< std::string, std::string > | mOthers {} |
List of others. | |
NodeManager * | mpNodeManager = nullptr |
Node Manager. | |
NodeInfo * | mpNodeInfo {new NodeInfo()} |
Node Info. | |
Private Attributes | |
uint32_t | mNumCores = -1 |
Number of cores. | |
Salsa::Worker::Worker | ( | std::string | uuid, |
std::shared_ptr< Socket > | pPipe, | ||
NodeManager * | pNM | ||
) |
Constructor
Definition at line 6 of file Worker.cc.
References Salsa::NodeManager::addTaskSlot(), mNumCores, Salsa::Distributor::mpNodeInfo, Salsa::Distributor::mpNodeManager, and Salsa::Distributor::mUUID.
|
inherited |
Adds client
Definition at line 18 of file Distributor.cc.
References Salsa::Distributor::mClients, and Salsa::Distributor::uuid().
|
inherited |
Adds other
Definition at line 34 of file Distributor.cc.
References Salsa::Distributor::mOthers, and Salsa::Distributor::uuid().
|
inherited |
Returns node info
Definition at line 92 of file Distributor.cc.
References Salsa::Distributor::mpNodeInfo.
Referenced by Salsa::Feeder::onWhisper().
uint32_t Salsa::Worker::numCores | ( | ) | const |
|
virtual |
TODO Three horsemen of apocalypse.
onEnter
onEnter
Reimplemented from Salsa::Distributor.
Definition at line 80 of file Worker.cc.
References Salsa::Distributor::mpNodeInfo.
|
virtual |
|
virtual |
onWhisper
Reimplemented from Salsa::Distributor.
Definition at line 100 of file Worker.cc.
References Salsa::NodeManager::addTask(), Salsa::TaskPool::changeState(), Salsa::Message::content(), Salsa::TaskPool::findById(), Salsa::TaskPool::findFreeTask(), Salsa::TaskState::id(), Salsa::Distributor::mpNodeManager, Salsa::Distributor::mUUID, Salsa::TaskPool::print(), Salsa::NodeManager::runTask(), Salsa::TaskState::state(), Salsa::TaskState::task(), Salsa::NodeManager::taskPool(), Salsa::NodeManager::terminateJob(), and Salsa::Message::uuid().
|
inherited |
TODO Returns distributor's pipe?
Returns pipe socket
Definition at line 77 of file Distributor.cc.
References Salsa::Distributor::mpPipe.
Referenced by Salsa::Feeder::subscribe(), and Salsa::Feeder::terminateJob().
|
inherited |
TODO Prints distributor's state.
Prints info
Definition at line 50 of file Distributor.cc.
References Salsa::Distributor::mClients, Salsa::Distributor::mOthers, and Salsa::Distributor::mpPipe.
|
inherited |
Remove client
Definition at line 26 of file Distributor.cc.
References Salsa::Distributor::mClients, and Salsa::Distributor::uuid().
|
inherited |
Remove other
Definition at line 42 of file Distributor.cc.
References Salsa::Distributor::mOthers, and Salsa::Distributor::uuid().
|
inherited |
Returns distributor's UUID.
Returns uuid
Definition at line 84 of file Distributor.cc.
References Salsa::Distributor::mUUID.
Referenced by Salsa::Distributor::addClient(), Salsa::Distributor::addOther(), Salsa::Distributor::removeClient(), Salsa::Distributor::removeOther(), Salsa::Feeder::removeWorkerTask(), Salsa::Feeder::subscribe(), and Salsa::Feeder::terminateJob().