| [41c1b7] | 1 | /* | 
|---|
|  | 2 | * SendJobToWorkerOperation.hpp | 
|---|
|  | 3 | * | 
|---|
|  | 4 | *  Created on: Feb 22, 2012 | 
|---|
|  | 5 | *      Author: heber | 
|---|
|  | 6 | */ | 
|---|
|  | 7 |  | 
|---|
|  | 8 | #ifndef FRAGMENTCONTROLLER_SENDJOBTOWORKEROPERATION_HPP_ | 
|---|
|  | 9 | #define FRAGMENTCONTROLLER_SENDJOBTOWORKEROPERATION_HPP_ | 
|---|
|  | 10 |  | 
|---|
|  | 11 | // include config.h | 
|---|
|  | 12 | #ifdef HAVE_CONFIG_H | 
|---|
|  | 13 | #include <config.h> | 
|---|
|  | 14 | #endif | 
|---|
|  | 15 |  | 
|---|
|  | 16 | #include <boost/asio.hpp> | 
|---|
|  | 17 | #include <string> | 
|---|
|  | 18 | #include <vector> | 
|---|
|  | 19 |  | 
|---|
|  | 20 | #include "Connection.hpp" | 
|---|
|  | 21 |  | 
|---|
|  | 22 | #include "Jobs/FragmentJob.hpp" | 
|---|
|  | 23 | #include "Jobs/SystemCommandJob.hpp" | 
|---|
| [50d095] | 24 | #include "Operations/AsyncOperation.hpp" | 
|---|
| [41c1b7] | 25 | #include "WorkerAddress.hpp" | 
|---|
|  | 26 |  | 
|---|
| [f98c8e] | 27 | class SendJobToWorkerOperation : public AsyncOperation  { | 
|---|
| [41c1b7] | 28 | public: | 
|---|
| [86a1e8] | 29 | /** Constructor for class SendJobToWorkerOperation. | 
|---|
|  | 30 | * | 
|---|
|  | 31 | * @param _connection connection for operation | 
|---|
|  | 32 | */ | 
|---|
| [9db22d] | 33 | SendJobToWorkerOperation(Connection &_connection, | 
|---|
|  | 34 | const boost::function<void ()> &_callback_on_success = NoOpCallback, | 
|---|
|  | 35 | const boost::function<void ()> &_callback_on_failure = NoOpCallback) : | 
|---|
|  | 36 | AsyncOperation(std::string("sendjobtoworker"),_connection, _callback_on_success, _callback_on_failure), | 
|---|
| [41c1b7] | 37 | job( new SystemCommandJob(std::string("/bin/true"), std::string("donothing"), JobId::NoJob) ) | 
|---|
|  | 38 | {} | 
|---|
| [86a1e8] | 39 | /** Constructor for class SendJobToWorkerOperation. | 
|---|
|  | 40 | * | 
|---|
|  | 41 | * @param _connection connection for operation | 
|---|
|  | 42 | * @param _job job to send to worker | 
|---|
|  | 43 | */ | 
|---|
|  | 44 | SendJobToWorkerOperation(Connection &_connection, FragmentJob::ptr &_job) : | 
|---|
|  | 45 | AsyncOperation(std::string("sendjobtoworker"),_connection), | 
|---|
|  | 46 | job( _job ) | 
|---|
|  | 47 | {} | 
|---|
| [41c1b7] | 48 | /// Destructor for class SendJobToWorkerOperation | 
|---|
|  | 49 | ~SendJobToWorkerOperation() {} | 
|---|
|  | 50 |  | 
|---|
|  | 51 | /** Setter for job. | 
|---|
|  | 52 | * | 
|---|
|  | 53 | * @param _job job to take over internally | 
|---|
|  | 54 | */ | 
|---|
|  | 55 | void setJob(FragmentJob::ptr &_job) | 
|---|
|  | 56 | { | 
|---|
|  | 57 | job.reset(); | 
|---|
|  | 58 | job = _job; | 
|---|
|  | 59 | } | 
|---|
|  | 60 |  | 
|---|
|  | 61 | public: | 
|---|
|  | 62 | // virtual function pointer to the connection handler | 
|---|
|  | 63 | virtual void handle_connect(const boost::system::error_code& e, | 
|---|
|  | 64 | boost::asio::ip::tcp::resolver::iterator endpoint_iterator); | 
|---|
|  | 65 |  | 
|---|
|  | 66 | private: | 
|---|
|  | 67 | //!> job to send to | 
|---|
|  | 68 | FragmentJob::ptr job; | 
|---|
|  | 69 | }; | 
|---|
|  | 70 |  | 
|---|
|  | 71 | #endif /* FRAGMENTCONTROLLER_SENDJOBTOWORKEROPERATION_HPP_ */ | 
|---|