| [73d6fc] | 1 | /*
 | 
|---|
| [f98c8e] | 2 |  * AsyncOperation.hpp
 | 
|---|
| [73d6fc] | 3 |  *
 | 
|---|
 | 4 |  *  Created on: Nov 11, 2011
 | 
|---|
 | 5 |  *      Author: heber
 | 
|---|
 | 6 |  */
 | 
|---|
 | 7 | 
 | 
|---|
| [f98c8e] | 8 | #ifndef FRAGMENTCONTROLLER_ASYNCOPERATION_HPP_
 | 
|---|
 | 9 | #define FRAGMENTCONTROLLER_ASYNCOPERATION_HPP_
 | 
|---|
| [73d6fc] | 10 | 
 | 
|---|
 | 11 | // include config.h
 | 
|---|
 | 12 | #ifdef HAVE_CONFIG_H
 | 
|---|
 | 13 | #include <config.h>
 | 
|---|
 | 14 | #endif
 | 
|---|
 | 15 | 
 | 
|---|
 | 16 | #include <boost/asio.hpp>
 | 
|---|
| [2e661a] | 17 | #include <boost/function.hpp>
 | 
|---|
 | 18 | #include <functional>
 | 
|---|
| [73d6fc] | 19 | #include <string>
 | 
|---|
 | 20 | #include <vector>
 | 
|---|
 | 21 | 
 | 
|---|
| [2e661a] | 22 | #include "CodePatterns/Observer/Observable.hpp"
 | 
|---|
 | 23 | 
 | 
|---|
| [701bbc] | 24 | #include "Operation.hpp"
 | 
|---|
| [73d6fc] | 25 | 
 | 
|---|
| [2e661a] | 26 | /** This class represents an asynchronous operation that is initiated by
 | 
|---|
 | 27 |  * calling AsyncOperation::operator() and gives an update with the Observer
 | 
|---|
 | 28 |  * construct when the operation has finished.
 | 
|---|
 | 29 |  *
 | 
|---|
 | 30 |  * \note Make sure that deriving classes still end the asynchronous operation
 | 
|---|
 | 31 |  * chain by calling AsyncOperation::handle_FinishOperation(). Otherwise the
 | 
|---|
 | 32 |  * update signal at operation's end is not triggered.
 | 
|---|
 | 33 |  */
 | 
|---|
| [9db22d] | 34 | class AsyncOperation : public Operation, public Observable
 | 
|---|
 | 35 | {
 | 
|---|
 | 36 | public:
 | 
|---|
 | 37 |   //!> static function as default callback on success/failure of operation that does nothing
 | 
|---|
 | 38 |   static const boost::function<void ()> NoOpCallback;
 | 
|---|
| [73d6fc] | 39 | public:
 | 
|---|
| [701bbc] | 40 |   /** Constructor for class AsyncOperation.
 | 
|---|
 | 41 |    *
 | 
|---|
 | 42 |    * \param _name name for this AsyncOperation for retrieval from a registry
 | 
|---|
 | 43 |    * \param _connection connection to operate on
 | 
|---|
| [9db22d] | 44 |    * \param callback_on_success function to call when operation ends successfully
 | 
|---|
 | 45 |    * \param callback_on_failure function to call when operation fails
 | 
|---|
| [701bbc] | 46 |    */
 | 
|---|
| [2e661a] | 47 |   AsyncOperation(
 | 
|---|
 | 48 |       const std::string &_name,
 | 
|---|
| [9db22d] | 49 |       Connection &_connection,
 | 
|---|
 | 50 |       const boost::function<void ()> &_callback_on_success = NoOpCallback,
 | 
|---|
 | 51 |       const boost::function<void ()> &_callback_on_failure = NoOpCallback) :
 | 
|---|
| [2e661a] | 52 |     Operation(_name, _connection),
 | 
|---|
| [9db22d] | 53 |     Observable(_name),
 | 
|---|
 | 54 |     callback_on_success(_callback_on_success),
 | 
|---|
 | 55 |     callback_on_failure(_callback_on_failure)
 | 
|---|
| [701bbc] | 56 |   {}
 | 
|---|
 | 57 | 
 | 
|---|
 | 58 |   /** Destructor for class AsyncOperation.
 | 
|---|
 | 59 |    *
 | 
|---|
 | 60 |    */
 | 
|---|
 | 61 |   virtual ~AsyncOperation()
 | 
|---|
 | 62 |   {}
 | 
|---|
| [73d6fc] | 63 | 
 | 
|---|
| [701bbc] | 64 | public:
 | 
|---|
| [73d6fc] | 65 |   // virtual function pointer to the operation to do
 | 
|---|
| [9948a7] | 66 |   void operator()(const std::string& _host, const std::string& _service);
 | 
|---|
| [73d6fc] | 67 | 
 | 
|---|
| [701bbc] | 68 | protected:
 | 
|---|
| [d6fe76] | 69 |   // virtual function pointer to the connection handler
 | 
|---|
 | 70 |   virtual void handle_connect(const boost::system::error_code& e,
 | 
|---|
 | 71 |       boost::asio::ip::tcp::resolver::iterator endpoint_iterator) = 0;
 | 
|---|
 | 72 | 
 | 
|---|
| [73d6fc] | 73 |   /// Handle completion of an operation.
 | 
|---|
 | 74 |   void handle_FinishOperation(const boost::system::error_code& e);
 | 
|---|
 | 75 | 
 | 
|---|
 | 76 | protected:
 | 
|---|
 | 77 |   /// internal function to disconnect from server
 | 
|---|
 | 78 |   void disconnect();
 | 
|---|
| [9db22d] | 79 | 
 | 
|---|
 | 80 | private:
 | 
|---|
 | 81 |   //!> Callback function on successful end of operation
 | 
|---|
 | 82 |   boost::function<void ()> callback_on_success;
 | 
|---|
 | 83 |   //!> Callback function on end of operation with failure
 | 
|---|
 | 84 |   boost::function<void ()> callback_on_failure;
 | 
|---|
| [73d6fc] | 85 | };
 | 
|---|
 | 86 | 
 | 
|---|
| [f98c8e] | 87 | #endif /* FRAGMENTCONTROLLER_ASYNCOPERATION_HPP_ */
 | 
|---|