X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=engine.hpp;h=d5846ba65fc287a6b7de3e7f5f6cfaa57a7f5951;hb=5334a314651228c55fd0f206dec0209bc3148b24;hp=a35b616e6cce63d541684e057a76248481af29ca;hpb=c5c7502f435e1413c19e373dab1dfebcaa67588d;p=mothur.git diff --git a/engine.hpp b/engine.hpp index a35b616..d5846ba 100644 --- a/engine.hpp +++ b/engine.hpp @@ -17,35 +17,40 @@ #include "commandoptionparser.hpp" #include "command.hpp" #include "commandfactory.hpp" -#include "errorchecking.h" - - -using namespace std; +#include "mothurout.h" class GlobalData; class Engine { public: - virtual ~Engine(){}; + Engine(); + virtual ~Engine(){} virtual bool getInput() = 0; -// string getCommand() { return command; } - vector getOptions() { return options; } + virtual string getCommand(); + virtual string getOutputDir() { return cFactory->getOutputDir(); } + virtual string getLogFileName() { return cFactory->getLogfileName(); } + virtual bool getAppend() { return cFactory->getAppend(); } + + vector getOptions() { return options; } protected: -// string command; vector options; + CommandFactory* cFactory; + MothurOut* mout; + string findMothursPath(); }; class BatchEngine : public Engine { public: - BatchEngine(string); + BatchEngine(string, string); ~BatchEngine(); virtual bool getInput(); int openedBatch; private: GlobalData* globaldata; ifstream inputBatchFile; + string getNextCommand(ifstream&); }; @@ -53,7 +58,7 @@ private: class InteractEngine : public Engine { public: - InteractEngine(); + InteractEngine(string); ~InteractEngine(); virtual bool getInput(); private: @@ -61,4 +66,18 @@ private: }; +class ScriptEngine : public Engine { +public: + ScriptEngine(string, string); + ~ScriptEngine(); + virtual bool getInput(); + int openedBatch; +private: + GlobalData* globaldata; + string listOfCommands; + string getNextCommand(string&); + +}; + + #endif