BatchEngine::BatchEngine(string path, string batchFileName){
try {
globaldata = GlobalData::getInstance();
+
openedBatch = openInputFile(batchFileName, inputBatchFile);
globaldata->argv = path;
string input = "";
string commandName = "";
string options = "";
+ //int count = 1;
//CommandFactory cFactory;
int quitCommandCalled = 0;
if (inputBatchFile.eof()) { input = "quit()"; }
else { getline(inputBatchFile, input); }
+ //cout << "command number" << count << endl; count++;
+
if (input[0] != '#') {
cout << endl << "mothur > " << input << endl;
/***********************************************************************/
+/***********************************************************************/
+//This function opens the batchfile to be used by BatchEngine::getInput.
+ScriptEngine::ScriptEngine(string path, string commandString){
+ try {
+ globaldata = GlobalData::getInstance();
+
+ //remove quotes
+ listOfCommands = commandString.substr(1, (commandString.length()-1));
+
+ globaldata->argv = path;
+ system("clear");
+
+ }
+ catch(exception& e) {
+ cout << "Standard Error: " << e.what() << " has occurred in the ScriptEngine class Function ScriptEngine. Please contact Pat Schloss at pschloss@microbio.umass.edu." << "\n";
+ exit(1);
+ }
+ catch(...) {
+ cout << "An unknown error has occurred in the ScriptEngine class function ScriptEngine. Please contact Pat Schloss at pschloss@microbio.umass.edu." << "\n";
+ exit(1);
+ }
+}
+
+/***********************************************************************/
+
+ScriptEngine::~ScriptEngine(){
+ }
+
+/***********************************************************************/
+//This Function allows the user to run a batchfile containing several commands on Dotur
+bool ScriptEngine::getInput(){
+ try {
+
+ string input = "";
+ string commandName = "";
+ string options = "";
+ //int count = 1;
+
+ //CommandFactory cFactory;
+ int quitCommandCalled = 0;
+
+ while(quitCommandCalled == 0){
+
+ input = getNextCommand(listOfCommands);
+
+ if (input == "") { input = "quit()"; }
+ //cout << "command number" << count << endl; count++;
+
+ cout << endl << "mothur > " << input << endl;
+
+ //allow user to omit the () on the quit command
+ if (input == "quit") { input = "quit()"; }
+
+ CommandOptionParser parser(input);
+ commandName = parser.getCommandString();
+ options = parser.getOptionString();
+
+ if (commandName != "") {
+
+ //executes valid command
+ CommandFactory cFactory;
+ Command* command = cFactory.getCommand(commandName, options);
+ quitCommandCalled = command->execute();
+ }else { cout << "Invalid." << endl; }
+
+ }
+
+ return 1;
+ }
+ catch(exception& e) {
+ cout << "Standard Error: " << e.what() << " has occurred in the ScriptEngine class Function getInput. Please contact Pat Schloss at pschloss@microbio.umass.edu." << "\n";
+ exit(1);
+ }
+ catch(...) {
+ cout << "An unknown error has occurred in the ScriptEngine class function getInput. Please contact Pat Schloss at pschloss@microbio.umass.edu." << "\n";
+ exit(1);
+ }
+}
+/***********************************************************************/
+string ScriptEngine::getNextCommand(string& commandString) {
+ try {
+ string nextcommand = "";
+
+ nextcommand = commandString.substr(0,commandString.find_first_of(';'));
+
+
+ if ((commandString.find_first_of(';')+1) <= commandString.length()) {
+ commandString = commandString.substr(commandString.find_first_of(';')+1, commandString.length());
+ }else { commandString = ""; } //you have reached the last command.
+
+ //get rid of any extra spaces in between commands
+ //string space = " ";
+
+ //while(commandString.at(0) == ' ')
+ //commandString = commandString.substr(1, commandString.length());
+
+ return nextcommand;
+ }
+ catch(exception& e) {
+ cout << "Standard Error: " << e.what() << " has occurred in the ScriptEngine class Function getNextCommand. Please contact Pat Schloss at pschloss@microbio.umass.edu." << "\n";
+ exit(1);
+ }
+ catch(...) {
+ cout << "An unknown error has occurred in the ScriptEngine class function getNextCommand. Please contact Pat Schloss at pschloss@microbio.umass.edu." << "\n";
+ exit(1);
+ }
+}
+/***********************************************************************/
\ No newline at end of file
else if (namefile == "not found") { namefile = ""; }
else { globaldata->setNameFile(namefile); }
-// format = globaldata->getFormat();
+ format = globaldata->getFormat();
//error checking on files
if ((globaldata->getSharedFile() == "") && ((phylipfile == "") && (columnfile == ""))) { cout << "You must run the read.otu command or provide a distance file before running the tree.shared command." << endl; abort = true; }
if (lookup.size() < 2) { cout << "You have not provided enough valid groups. I cannot run the command." << endl; return 0; }
+ globaldata->runParse = false;
+
//create tree file
makeSimsShared();
}else{
//fills globaldatas tree names
globaldata->Treenames = globaldata->Groups;
-
+
+ globaldata->runParse = false;
+
makeSimsDist();
//create a new filename
}
}
}
-
+
//creates tree from similarity matrix and write out file
createTree();
}