-/*
- * interface.cpp
- *
- *
- * Created by Pat Schloss on 8/14/08.
- * Copyright 2008 Patrick D. Schloss. All rights reserved.
- *
- */
-
-#include "mothur.h"
-#include "engine.hpp"
-#include "globaldata.hpp"
-
-using namespace std;
-
-/**************************************************************************************************/
-
-GlobalData* GlobalData::_uniqueInstance = 0;
-
-int main(int argc, char *argv[]){
- try {
- //srand(54321);
- srand( (unsigned)time( NULL ) );
-
- Engine* mothur;
- bool bail = 0;
-
- if(argc>1){
- mothur = new BatchEngine(argv[0], argv[1]);
- }
- else{
- mothur = new InteractEngine(argv[0]);
- }
-
- while(bail == 0) { bail = mothur->getInput(); }
-
- delete mothur;
-
- return 0;
- }
- catch(exception& e) {
- cout << "Standard Error: " << e.what() << " has occurred in the dotur class Function main. Please contact Pat Schloss at pschloss@microbio.umass.edu." << "\n";
- exit(1);
- }
- catch(...) {
- cout << "An unknown error has occurred in the dotur class function main. Please contact Pat Schloss at pschloss@microbio.umass.edu." << "\n";
- exit(1);
- }
-}
-
-/**************************************************************************************************/
-
+/*\r
+ * interface.cpp\r
+ * \r
+ *\r
+ * Created by Pat Schloss on 8/14/08.\r
+ * Copyright 2008 Patrick D. Schloss. All rights reserved.\r
+ *\r
+ */\r
+ \r
+#include "mothur.h"\r
+#include "engine.hpp"\r
+#include "globaldata.hpp"\r
+#include "mothurout.h"\r
+\r
+\r
+/**************************************************************************************************/\r
+\r
+GlobalData* GlobalData::_uniqueInstance = 0;\r
+CommandFactory* CommandFactory::_uniqueInstance = 0;\r
+MothurOut* MothurOut::_uniqueInstance = 0;\r
+\r
+/***********************************************************************/\r
+volatile int ctrlc_pressed = 0;\r
+void ctrlc_handler ( int sig ) {\r
+ MothurOut* m = MothurOut::getInstance();\r
+ ctrlc_pressed = 1;\r
+ m->control_pressed = ctrlc_pressed;\r
+ \r
+ if (m->executing) { //if mid command quit execution, else quit mothur\r
+ m->mothurOutEndLine(); m->mothurOut("quitting command..."); m->mothurOutEndLine();\r
+ }else{\r
+ m->mothurOut("quitting mothur"); m->mothurOutEndLine();\r
+ exit(1);\r
+ }\r
+}\r
+/***********************************************************************/\r
+int main(int argc, char *argv[]){\r
+ MothurOut* m = MothurOut::getInstance();\r
+ try {\r
+ \r
+ signal(SIGINT, ctrlc_handler );\r
+ \r
+ time_t ltime = time(NULL); /* calendar time */ \r
+ string logFileName = "mothur." + toString(ltime) + ".logfile";\r
+ \r
+ #ifdef USE_MPI\r
+ MPI_Init(&argc, &argv); \r
+ #endif\r
+\r
+ m->setFileName(logFileName);\r
+ \r
+ \r
+ //version\r
+ #if defined (__APPLE__) || (__MACH__) || (linux) || (__linux)\r
+ system("clear");\r
+ #if defined (__APPLE__) || (__MACH__)\r
+ m->mothurOutJustToLog("Mac version");\r
+ m->mothurOutEndLine(); m->mothurOutEndLine();\r
+ #else\r
+ m->mothurOutJustToLog("Linux version");\r
+ m->mothurOutEndLine(); m->mothurOutEndLine();\r
+ #endif\r
+\r
+ #else\r
+ system("CLS");\r
+ m->mothurOutJustToLog("Windows version");\r
+ m->mothurOutEndLine(); m->mothurOutEndLine();\r
+ #endif \r
+ \r
+ #ifdef USE_READLINE\r
+ m->mothurOutJustToLog("Using ReadLine");\r
+ m->mothurOutEndLine(); m->mothurOutEndLine();\r
+ #endif\r
+ \r
+ //header\r
+ m->mothurOut("mothur v.1.10.2");\r
+ m->mothurOutEndLine(); \r
+ m->mothurOut("Last updated: 5/26/2010");\r
+ m->mothurOutEndLine(); \r
+ m->mothurOutEndLine(); \r
+ m->mothurOut("by");\r
+ m->mothurOutEndLine(); \r
+ m->mothurOut("Patrick D. Schloss");\r
+ m->mothurOutEndLine();\r
+ m->mothurOutEndLine(); \r
+ m->mothurOut("Department of Microbiology & Immunology");\r
+ m->mothurOutEndLine(); \r
+ m->mothurOut("University of Michigan");\r
+ m->mothurOutEndLine(); \r
+ m->mothurOut("pschloss@umich.edu");\r
+ m->mothurOutEndLine(); \r
+ m->mothurOut("http://www.mothur.org");\r
+ m->mothurOutEndLine();\r
+ m->mothurOutEndLine();\r
+ m->mothurOut("When using, please cite:");\r
+ m->mothurOutEndLine();\r
+ m->mothurOut("Schloss, P.D., et al., Introducing mothur: Open-source, platform-independent, community-supported software for describing and comparing microbial communities. Appl Environ Microbiol, 2009. 75(23):7537-41.");\r
+ m->mothurOutEndLine(); \r
+ m->mothurOutEndLine(); \r
+ m->mothurOut("Distributed under the GNU General Public License");\r
+ m->mothurOutEndLine();\r
+ m->mothurOutEndLine(); \r
+ m->mothurOut("Type 'help()' for information on the commands that are available");\r
+ m->mothurOutEndLine();\r
+ m->mothurOutEndLine(); \r
+ m->mothurOut("Type 'quit()' to exit program");\r
+ m->mothurOutEndLine(); \r
+ \r
+ #ifdef USE_MPI\r
+ m->mothurOutJustToLog("Using MPI\tversion ");\r
+ int version, subversion;\r
+ MPI_Get_version(&version, &subversion);\r
+ m->mothurOutJustToLog(toString(version) + "." + toString(subversion) + "\n");\r
+ #endif\r
+ \r
+ //srand(54321);\r
+ srand( (unsigned)time( NULL ) );\r
+ \r
+ Engine* mothur;\r
+ bool bail = 0;\r
+ string input;\r
+\r
+ if(argc>1){\r
+ input = argv[1];\r
+\r
+ if (input[0] == '#') {\r
+ m->mothurOutJustToLog("Script Mode");\r
+ m->mothurOutEndLine(); m->mothurOutEndLine();\r
+\r
+ mothur = new ScriptEngine(argv[0], argv[1]);\r
+ }else{\r
+ m->mothurOutJustToLog("Batch Mode");\r
+ m->mothurOutEndLine(); m->mothurOutEndLine();\r
+ \r
+ mothur = new BatchEngine(argv[0], argv[1]);\r
+ }\r
+ }\r
+ else{\r
+ m->mothurOutJustToLog("Interactive Mode");\r
+ m->mothurOutEndLine(); m->mothurOutEndLine();\r
+ \r
+ mothur = new InteractEngine(argv[0]); \r
+ }\r
+ \r
+ while(bail == 0) { bail = mothur->getInput(); }\r
+ \r
+ //closes logfile so we can rename\r
+ m->closeLog();\r
+ \r
+ string outputDir = mothur->getOutputDir();\r
+ string tempLog = mothur->getLogFileName();\r
+ bool append = mothur->getAppend();\r
+ \r
+ string newlogFileName;\r
+ if (tempLog != "") {\r
+ newlogFileName = outputDir + tempLog;\r
+ \r
+ if (!append) { \r
+ //need this because m->mothurOut makes the logfile, but doesn't know where to put it\r
+ rename(logFileName.c_str(), newlogFileName.c_str()); //logfile with timestamp\r
+\r
+ }else {\r
+ ofstream outNewLog;\r
+ openOutputFileAppend(newlogFileName, outNewLog);\r
+ outNewLog << endl << endl << "*********************************************************************************" << endl << endl;\r
+ outNewLog.close();\r
+ \r
+ appendFiles(logFileName, newlogFileName);\r
+ remove(logFileName.c_str());\r
+ }\r
+ }else{ \r
+ newlogFileName = outputDir + logFileName;\r
+ //need this because m->mothurOut makes the logfile, but doesn't know where to put it\r
+ rename(logFileName.c_str(), newlogFileName.c_str()); //logfile with timestamp\r
+ }\r
+ \r
+ \r
+ delete mothur;\r
+ \r
+ #ifdef USE_MPI\r
+ MPI_Finalize();\r
+ #endif\r
+ \r
+ return 0;\r
+ }\r
+ catch(exception& e) {\r
+ m->errorOut(e, "mothur", "main");\r
+ exit(1);\r
+ }\r
+}\r
+\r
+/**************************************************************************************************/\r
+\r