/* * Project: MoleCuilder * Description: creates and alters molecular systems * Copyright (C) 2012 University of Bonn. All rights reserved. * Please see the LICENSE file or "Copyright notice" in builder.cpp for details. */ /* * GetNextJobIdOperation.cpp * * Created on: Feb 16, 2012 * Author: heber */ // include config.h #ifdef HAVE_CONFIG_H #include #endif // boost asio needs specific operator new #include #include "CodePatterns/MemDebug.hpp" #include #include #include "Connection.hpp" // Must come before boost/serialization headers. #include #include "CodePatterns/Info.hpp" #include "CodePatterns/Log.hpp" #include "ControllerChoices.hpp" #include "types.hpp" #include "Controller/Commands/GetNextJobIdOperation.hpp" /** Handle connect operation to send number of done jobs. * * \param e error code if something went wrong * \param endpoint_iterator endpoint of the connection */ void GetNextJobIdOperation::handle_connect(const boost::system::error_code& e, boost::asio::ip::tcp::resolver::iterator endpoint_iterator) { Info info(__FUNCTION__); if (!e) { // Successfully established connection. Give choice. enum ControllerChoices choice = GetNextJobId; connection_.async_write(choice, boost::bind(&GetNextJobIdOperation::handle_ReceiveNextId, this, boost::asio::placeholders::error)); } else if (endpoint_iterator != boost::asio::ip::tcp::resolver::iterator()) { // Try the next endpoint. connection_.socket().close(); boost::asio::ip::tcp::endpoint endpoint = *endpoint_iterator; connection_.socket().async_connect(endpoint, boost::bind(&GetNextJobIdOperation::handle_connect, this, boost::asio::placeholders::error, ++endpoint_iterator)); } else { // An error occurred. Log it and return. Since we are not starting a new // operation the io_service will run out of work to do and the client will // exit. ELOG(1, e.message()); } } /** Callback function when doneJobs have been received. * * \param e error code if something went wrong */ void GetNextJobIdOperation::handle_ReceiveNextId(const boost::system::error_code& e) { Info info(__FUNCTION__); if (!e) { // The connection::async_read() function will automatically // decode the data that is written to the underlying socket. LOG(1, "INFO: Obtaining next available job id ..."); connection_.async_read(nextid, boost::bind(&GetNextJobIdOperation::handle_FinishOperation, this, boost::asio::placeholders::error)); } else { // An error occurred. ELOG(1, e.message()); } } /** Callback function when an operation has been completed. * * \param e error code if something went wrong */ void GetNextJobIdOperation::handle_FinishOperation(const boost::system::error_code& e) { Info info(__FUNCTION__); // place id into nextids nextids.push_back(nextid); nextid = JobId::IllegalJob; // and finish operation Operation::handle_FinishOperation(e); } /** Getter for nextid. * * \sa checkResults() * \param next available JobId_t */ size_t GetNextJobIdOperation::getNextId() { ASSERT( nextids.size() != (size_t)0, "GetNextJobIdOperation::getNextId() - no next id available."); const JobId_t availableid = nextids.front(); nextids.pop_front(); return availableid; }