// Copyright (c) 2008 Ole Weidner (oweidner@cct.lsu.edu) // // Distributed under the Boost Software License, Version 1.0. (See accompanying // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) #ifndef ADAPTORS_LSF_JOB_HPP #define ADAPTORS_LSF_JOB_HPP // stl includes #include // saga includes #include #include // saga engine includes #include // saga adaptor includes #include #include #include // job package includes #include // adaptor includes #include "lsf_job_adaptor.hpp" //////////////////////////////////////////////////////////////////////// namespace saga { namespace adaptors { namespace lsf { class job_cpi_impl : public saga::adaptors::v1_0::job_cpi { private: typedef saga::adaptors::v1_0::job_cpi base_cpi; // adaptor data typedef saga::adaptors::adaptor_data adaptor_data; // some private helper functions void set_job_attributes(std::string job_id); void update_state(saga::job::state newstate); saga::job::state get_rm_job_state(std::string job_id); std::vector jd_to_arg_list(const saga::job::description &jd); public: // constructor of the job adaptor job_cpi_impl (proxy * p, cpi_info const & info, saga::ini::ini const & glob_ini, saga::ini::ini const & adap_ini, TR1::shared_ptr adaptor); // destructor of the job adaptor ~job_cpi_impl (void); // job functions void sync_get_state (saga::job::state & ret); void sync_get_description (saga::job::description & ret); void sync_get_job_id (std::string & ret); void sync_get_stdin (saga::job::ostream & ret); void sync_get_stdout (saga::job::istream & ret); void sync_get_stderr (saga::job::istream & ret); void sync_checkpoint (saga::impl::void_t & ret); void sync_migrate (saga::impl::void_t & ret, saga::job::description jd); void sync_signal (saga::impl::void_t & ret, int signal); // inherited from saga::task void sync_run (saga::impl::void_t & ret); void sync_cancel (saga::impl::void_t & ret, double timeout); void sync_suspend (saga::impl::void_t & ret); void sync_resume (saga::impl::void_t & ret); void sync_wait (bool & ret, double timeout); // This adaptor implements the async functions // based on its own synchronous functions. saga::task async_get_state (void); saga::task async_get_description (void); saga::task async_get_job_id (void); saga::task async_get_stdin (void); saga::task async_get_stdout (void); saga::task async_get_stderr (void); saga::task async_checkpoint (void); saga::task async_migrate (saga::job::description jd); saga::task async_signal (int signal); // inherited from the task interface saga::task async_run (void); saga::task async_cancel (double timeout); saga::task async_suspend (void); saga::task async_resume (void); saga::task async_wait (double timeout); }; // class job_cpi_impl }}} // namespace lsf_job //////////////////////////////////////////////////////////////////////// #endif // ADAPTORS_LSF_JOB_HPP