source: src/Jobs/JobMarket/SystemCommandJob.hpp@ 365a44

Last change on this file since 365a44 was 365a44, checked in by Frederik Heber <heber@…>, 11 years ago

Added loop to SystemCommandJob to attempt execution three times.

  • Property mode set to 100644
File size: 2.4 KB
Line 
1/*
2 * SystemCommandJob.hpp
3 *
4 * Originally taken from my JobMarket project at 1.1.4.
5 *
6 * Created on: Feb 5, 2011
7 * Author: heber
8 */
9
10#ifndef SYSTEMCOMMANDJOB_HPP_
11#define SYSTEMCOMMANDJOB_HPP_
12
13// include config.h
14#ifdef HAVE_CONFIG_H
15#include <config.h>
16#endif
17
18#include <boost/serialization/export.hpp>
19
20#include <string>
21
22#ifdef HAVE_JOBMARKET
23#include "JobMarket/Jobs/FragmentJob.hpp"
24#else
25#include "Jobs/JobMarket/FragmentJob.hpp"
26#endif
27
28class SystemCommandJobTest;
29
30/** SystemCommandJob is an extension of FragmentJob that executes a system
31 * command operating onto a specific outputfile.
32 *
33 * Implement extractResult() to get the desired result from the captured
34 * output of the system command.
35 *
36 * Important is that this class is fully serializable such that it can be
37 * transfered to a scheduler (server) and be deserialized by the Worker.
38 */
39class SystemCommandJob : public FragmentJob
40{
41 //!> grant unit test access
42 friend class SystemCommandJobTest;
43public:
44 SystemCommandJob(const std::string &_command, const std::string &_outputfile, const JobId_t _JobId, const std::string &_suffix = std::string(""));
45 virtual ~SystemCommandJob();
46
47 FragmentResult::ptr Work();
48
49 bool operator==(const SystemCommandJob &other) const;
50
51 bool operator!=(const SystemCommandJob &other) const {
52 return !(*this == other);
53 }
54
55 const std::string& getOutputfile() const {
56 return outputfile;
57 }
58
59 const std::string& getCommand() const {
60 return command;
61 }
62
63protected:
64 virtual FragmentResult::ptr extractResult(const std::string &resultstring);
65
66 //!> string containing the command to launch the solver
67 std::string command;
68
69 //!> suffix to be appended to output file name
70 std::string suffix;
71
72 //!> string containing the configuration file for the solver
73 std::string outputfile;
74
75protected:
76 //!> private default cstor for serialization only
77 SystemCommandJob();
78
79private:
80 //!> number of maximum attempts to run fragment job
81 static const unsigned int MAX_ATTEMPTS;
82
83private:
84 friend class boost::serialization::access;
85 // serialization
86 template <typename Archive>
87 void serialize(Archive& ar, const unsigned int version)
88 {
89 ar & boost::serialization::base_object<FragmentJob>(*this);
90 ar & command;
91 ar & outputfile;
92 }
93};
94
95// we need to give this class a unique key for serialization
96// its is only serialized through its base class FragmentJob
97BOOST_CLASS_EXPORT_KEY(SystemCommandJob)
98
99#endif /* SYSTEMCOMMANDJOB_HPP_ */
Note: See TracBrowser for help on using the repository browser.