//**********************************************************************************************************************
vector<string> SetDirectoryCommand::setParameters(){
try {
- CommandParameter ptempdefault("tempdefault", "String", "", "", "", "", "",false,false); parameters.push_back(ptempdefault);
- CommandParameter pinput("input", "String", "", "", "", "", "",false,false); parameters.push_back(pinput);
- CommandParameter poutput("output", "String", "", "", "", "", "",false,false); parameters.push_back(poutput);
- CommandParameter pinputdir("inputdir", "String", "", "", "", "", "",false,false); parameters.push_back(pinputdir);
- CommandParameter poutputdir("outputdir", "String", "", "", "", "", "",false,false); parameters.push_back(poutputdir);
+ CommandParameter ptempdefault("tempdefault", "String", "", "", "", "", "","",false,false); parameters.push_back(ptempdefault);
+ CommandParameter pdebug("debug", "Boolean", "", "F", "", "", "","",false,false); parameters.push_back(pdebug);
+ CommandParameter pinput("input", "String", "", "", "", "", "","",false,false,true); parameters.push_back(pinput);
+ CommandParameter poutput("output", "String", "", "", "", "", "","",false,false,true); parameters.push_back(poutput);
+ CommandParameter pinputdir("inputdir", "String", "", "", "", "", "","",false,false); parameters.push_back(pinputdir);
+ CommandParameter poutputdir("outputdir", "String", "", "", "", "", "","",false,false); parameters.push_back(poutputdir);
vector<string> myArray;
for (int i = 0; i < parameters.size(); i++) { myArray.push_back(parameters[i].name); }
helpString += "The set.dir command can be used to direct the output files generated by mothur to a specific place, the directory must exist.\n";
helpString += "The set.dir command can also be used to specify the directory where your input files are located, the directory must exist.\n";
helpString += "The set.dir command can also be used to override or set the default location mothur will look for files if it is unable to find them, the directory must exist.\n";
- helpString += "The set.dir command parameters are input, output and tempdefault and one is required.\n";
+ helpString += "The set.dir command can also be used to run mothur in debug mode.\n";
+ helpString += "The set.dir command parameters are input, output, tempdefault and debug and one is required.\n";
+ helpString += "To run mothur in debug mode set debug=true. Default debug=false.\n";
helpString += "To return the output to the same directory as the input files you may enter: output=clear.\n";
helpString += "To return the input to the current working directory you may enter: input=clear.\n";
helpString += "To set the output to the directory where mothur.exe is located you may enter: output=default.\n";
tempdefault = validParameter.validFile(parameters, "tempdefault", false);
if (tempdefault == "not found") { tempdefault = ""; }
+
+ bool debug = false;
+ bool nodebug = false;
+ debugOnly = false;
+ string temp = validParameter.validFile(parameters, "debug", false);
+ if (temp == "not found") { debug = false; nodebug=true; }
+ else { debug = m->isTrue(temp); }
+ m->debug = debug;
+
+ if (debug) { m->mothurOut("Setting [DEBUG] flag.\n"); }
- if ((input == "") && (output == "") && (tempdefault == "")) {
- m->mothurOut("You must provide either an input, output or tempdefault for the set.outdir command."); m->mothurOutEndLine(); abort = true;
- }
+ if ((input == "") && (output == "") && (tempdefault == "") && nodebug) {
+ m->mothurOut("You must provide either an input, output, tempdefault or debug for the set.outdir command."); m->mothurOutEndLine(); abort = true;
+ }else if((input == "") && (output == "") && (tempdefault == "")) { debugOnly = true; }
}
}
catch(exception& e) {
if (abort == true) { if (calledHelp) { return 0; } return 2; }
+ if (debugOnly) { return 0; }
+
commandFactory = CommandFactory::getInstance();
m->mothurOut("Mothur's directories:"); m->mothurOutEndLine();