it = parameters.find("template");
//user has given a template file
if(it != parameters.end()){
- path = hasPath(it->second);
+ path = m->hasPath(it->second);
//if the user has not given a path then, add inputdir. else leave path alone.
if (path == "") { parameters["template"] = inputDir + it->second; }
}
fastafile = validParameter.validFile(parameters, "fasta", false);
if (fastafile == "not found") { fastafile = ""; m->mothurOut("fasta is a required parameter for the chimera.ccode command."); m->mothurOutEndLine(); abort = true; }
else {
- splitAtDash(fastafile, fastaFileNames);
+ m->splitAtDash(fastafile, fastaFileNames);
//go through files and make sure they are good, if not, then disregard them
for (int i = 0; i < fastaFileNames.size(); i++) {
if (inputDir != "") {
- string path = hasPath(fastaFileNames[i]);
+ string path = m->hasPath(fastaFileNames[i]);
//if the user has not given a path then, add inputdir. else leave path alone.
if (path == "") { fastaFileNames[i] = inputDir + fastaFileNames[i]; }
}
int ableToOpen;
ifstream in;
- ableToOpen = openInputFile(fastaFileNames[i], in, "noerror");
+ ableToOpen = m->openInputFile(fastaFileNames[i], in, "noerror");
//if you can't open it, try default location
if (ableToOpen == 1) {
if (m->getDefaultPath() != "") { //default path is set
- string tryPath = m->getDefaultPath() + getSimpleName(fastaFileNames[i]);
+ string tryPath = m->getDefaultPath() + m->getSimpleName(fastaFileNames[i]);
m->mothurOut("Unable to open " + fastaFileNames[i] + ". Trying default " + tryPath); m->mothurOutEndLine();
- ableToOpen = openInputFile(tryPath, in, "noerror");
+ ableToOpen = m->openInputFile(tryPath, in, "noerror");
fastaFileNames[i] = tryPath;
}
}
//if the user changes the output directory command factory will send this info to us in the output parameter
outputDir = validParameter.validFile(parameters, "outputdir", false); if (outputDir == "not found"){
outputDir = "";
- outputDir += hasPath(fastafile); //if user entered a file with a path then preserve it
+ outputDir += m->hasPath(fastafile); //if user entered a file with a path then preserve it
}
templatefile = validParameter.validFile(parameters, "template", true);
if (maskfile == "not found") { maskfile = ""; }
else if (maskfile != "default") {
if (inputDir != "") {
- string path = hasPath(maskfile);
+ string path = m->hasPath(maskfile);
//if the user has not given a path then, add inputdir. else leave path alone.
if (path == "") { maskfile = inputDir + maskfile; }
}
ifstream in;
- int ableToOpen = openInputFile(maskfile, in);
+ int ableToOpen = m->openInputFile(maskfile, in);
if (ableToOpen == 1) { abort = true; }
in.close();
}
string temp;
temp = validParameter.validFile(parameters, "filter", false); if (temp == "not found") { temp = "F"; }
- filter = isTrue(temp);
+ filter = m->isTrue(temp);
temp = validParameter.validFile(parameters, "processors", false); if (temp == "not found") { temp = "1"; }
convert(temp, processors);
string outputFileName, accnosFileName;
if (maskfile != "") {
- outputFileName = outputDir + getRootName(getSimpleName(fastaFileNames[s])) + maskfile + ".ccode.chimeras";
- accnosFileName = outputDir + getRootName(getSimpleName(fastaFileNames[s])) + maskfile + ".ccode.accnos";
+ outputFileName = outputDir + m->getRootName(m->getSimpleName(fastaFileNames[s])) + maskfile + ".ccode.chimeras";
+ accnosFileName = outputDir + m->getRootName(m->getSimpleName(fastaFileNames[s])) + maskfile + ".ccode.accnos";
}else {
- outputFileName = outputDir + getRootName(getSimpleName(fastaFileNames[s])) + "ccode.chimeras";
- accnosFileName = outputDir + getRootName(getSimpleName(fastaFileNames[s])) + "ccode.accnos";
+ outputFileName = outputDir + m->getRootName(m->getSimpleName(fastaFileNames[s])) + "ccode.chimeras";
+ accnosFileName = outputDir + m->getRootName(m->getSimpleName(fastaFileNames[s])) + "ccode.accnos";
}
- string mapInfo = outputDir + getRootName(getSimpleName(fastaFileNames[s])) + "mapinfo";
+ string mapInfo = outputDir + m->getRootName(m->getSimpleName(fastaFileNames[s])) + "mapinfo";
if (m->control_pressed) { delete chimera; for (int j = 0; j < outputNames.size(); j++) { remove(outputNames[j].c_str()); } return 0; }
MPI_File_write_shared(outMPI, buf2, length, MPI_CHAR, &status);
delete buf2;
- MPIPos = setFilePosFasta(fastaFileNames[s], numSeqs); //fills MPIPos, returns numSeqs
+ MPIPos = m->setFilePosFasta(fastaFileNames[s], numSeqs); //fills MPIPos, returns numSeqs
//send file positions to all processes
for(int i = 1; i < processors; i++) {
#else
ofstream outHeader;
- string tempHeader = outputDir + getRootName(getSimpleName(fastaFileNames[s])) + maskfile + "ccode.chimeras.tempHeader";
- openOutputFile(tempHeader, outHeader);
+ string tempHeader = outputDir + m->getRootName(m->getSimpleName(fastaFileNames[s])) + maskfile + "ccode.chimeras.tempHeader";
+ m->openOutputFile(tempHeader, outHeader);
outHeader << "For full window mapping info refer to " << mapInfo << endl << endl;
outHeader.close();
- vector<unsigned long int> positions = divideFile(fastaFileNames[s], processors);
+ vector<unsigned long int> positions = m->divideFile(fastaFileNames[s], processors);
for (int i = 0; i < (positions.size()-1); i++) {
lines.push_back(new linePair(positions[i], positions[(i+1)]));
//append output files
for(int i=1;i<processors;i++){
- appendFiles((outputFileName + toString(processIDS[i]) + ".temp"), outputFileName);
+ m->appendFiles((outputFileName + toString(processIDS[i]) + ".temp"), outputFileName);
remove((outputFileName + toString(processIDS[i]) + ".temp").c_str());
}
//append output files
for(int i=1;i<processors;i++){
- appendFiles((accnosFileName + toString(processIDS[i]) + ".temp"), accnosFileName);
+ m->appendFiles((accnosFileName + toString(processIDS[i]) + ".temp"), accnosFileName);
remove((accnosFileName + toString(processIDS[i]) + ".temp").c_str());
}
#endif
- appendFiles(outputFileName, tempHeader);
+ m->appendFiles(outputFileName, tempHeader);
remove(outputFileName.c_str());
rename(tempHeader.c_str(), outputFileName.c_str());
int ChimeraCcodeCommand::driver(linePair* filePos, string outputFName, string filename, string accnos){
try {
ofstream out;
- openOutputFile(outputFName, out);
+ m->openOutputFile(outputFName, out);
ofstream out2;
- openOutputFile(accnos, out2);
+ m->openOutputFile(accnos, out2);
ifstream inFASTA;
- openInputFile(filename, inFASTA);
+ m->openInputFile(filename, inFASTA);
inFASTA.seekg(filePos->start);
if (m->control_pressed) { return 1; }
- Sequence* candidateSeq = new Sequence(inFASTA); gobble(inFASTA);
+ Sequence* candidateSeq = new Sequence(inFASTA); m->gobble(inFASTA);
if (candidateSeq->getName() != "") { //incase there is a commented sequence at the end of a file
}
delete candidateSeq;
- unsigned long int pos = inFASTA.tellg();
- if ((pos == -1) || (pos >= filePos->end)) { break; }
+ #if defined (__APPLE__) || (__MACH__) || (linux) || (__linux)
+ unsigned long int pos = inFASTA.tellg();
+ if ((pos == -1) || (pos >= filePos->end)) { break; }
+ #else
+ if (inFASTA.eof()) { break; }
+ #endif
//report progress
if((count) % 100 == 0){ m->mothurOut("Processing sequence: " + toString(count)); m->mothurOutEndLine(); }
istringstream iss (tempBuf,istringstream::in);
delete buf4;
- Sequence* candidateSeq = new Sequence(iss); gobble(iss);
+ Sequence* candidateSeq = new Sequence(iss); m->gobble(iss);
if (candidateSeq->getName() != "") { //incase there is a commented sequence at the end of a file
//pass numSeqs to parent
ofstream out;
- string tempFile = toString(getpid()) + ".temp";
- openOutputFile(tempFile, out);
+ string tempFile = outputFileName + toString(getpid()) + ".num.temp";
+ m->openOutputFile(tempFile, out);
out << num << endl;
out.close();
for (int i = 0; i < processIDS.size(); i++) {
ifstream in;
- string tempFile = toString(processIDS[i]) + ".temp";
- openInputFile(tempFile, in);
+ string tempFile = outputFileName + toString(processIDS[i]) + ".num.temp";
+ m->openInputFile(tempFile, in);
if (!in.eof()) { int tempNum = 0; in >> tempNum; num += tempNum; }
in.close(); remove(tempFile.c_str());
}