#include <errno.h>
#include <unistd.h>
-#include <boost/filesystem.hpp>
+#ifndef MPI_DISABLED
+#include <mpi.h>
+#endif
using namespace std;
-string writeout::tstamp(const long& timestamp)
+string writeout::longToStr (long arg)
{
- stringstream sstr;
- if(!timestamp) sstr << time (NULL);
- else sstr << timestamp;
- return sstr.str();
+ stringstream ss;
+ ss << arg;
+ return ss.str();
}
void writeout::newsub(string subname) {
of[subname] = new ofstream;
if ( fulldir != "" ) {
- if(rank>0) of[subname]->open( (fulldir + "/rank" + cRank + "-" + subname + ".tmp").c_str() );
- else of[subname]->open( (fulldir + "/" + signature + "-" + subname + ".dat").c_str() );
+ if(rank>0) of[subname]->open( (fulldir + "/rank" + cRank + "_" + subname + ".tmp").c_str() );
+ else of[subname]->open( (fulldir + "/" + signature + "_" + subname + ".dat").c_str() );
if ( !of[subname]->is_open() ) {
logf << "WRITEOUT: Could not open output-file!" << endl << flush;
}
writeout::writeout(const string& wdir, const string& _signature,
- const int& _rank, const int& procs, const long& timestamp)
+ const int& _rank, const int& procs)
{
+ long timestamp;
+ int iseq=0;
+
fulldir = "";
signature = _signature;
rank = _rank;
if(wdir != ""){
numprocs = procs;
sprintf(cRank, "%d", rank);
- fulldir = wdir + "/" + tstamp(timestamp) + "_" + signature + ".tmp";
-
- if (rank==0)
- mkdir(fulldir.c_str(), 0775);
- else {
- while ( ! ( boost::filesystem::exists(fulldir) && boost::filesystem::is_directory(fulldir) ) ) {
- cerr << "WRITOUT: Waiting for rank 0 to create out directory." << endl << flush;
- sleep(1);
+
+ if (rank == 0) {
+ timestamp = time(NULL);
+
+ while (true) {
+ fulldir = wdir + "/" + longToStr(timestamp) + "." + longToStr(iseq) + "_" + signature + ".tmp";
+ if ( mkdir(fulldir.c_str(), 0775) == 0 )
+ break;
+ else if ( errno != EEXIST ) {
+ cerr << "WRITEOUT: Could not create outdir!" << endl << flush;
+ break;
+ }
+ iseq++;
}
+
+#ifndef MPI_DISABLED
+ for(int idest=1; idest<numprocs; idest++) {
+ MPI_Send(×tamp, 1, MPI_LONG, idest, 123, MPI_COMM_WORLD);
+ MPI_Send(&iseq, 1, MPI_LONG, idest, 124, MPI_COMM_WORLD);
+ }
+#endif
+
}
+#ifndef MPI_DISABLED
+ else if(rank>0) {
+ MPI_Recv(×tamp, 1, MPI_LONG, 0, 123, MPI_COMM_WORLD, MPI_STATUS_IGNORE);
+ MPI_Recv(&iseq, 1, MPI_LONG, 0, 124, MPI_COMM_WORLD, MPI_STATUS_IGNORE);
+ fulldir = wdir + "/" + longToStr(timestamp) + "." + longToStr(iseq) + "_" + signature + ".tmp";
+ }
+#endif
+
logf.open( (fulldir + "/rank" + cRank + ".log").c_str() );
if ( !logf.is_open() ) {
}
else {
ofit->second->close();
- rename((fulldir + "/rank" + cRank + "-" + ofit->first + ".tmp").c_str(),
- (fulldir + "/rank" + cRank + "-" + ofit->first + ".part").c_str());
+ rename((fulldir + "/rank" + cRank + "_" + ofit->first + ".tmp").c_str(),
+ (fulldir + "/rank" + cRank + "_" + ofit->first + ".part").c_str());
}
}
if( cRank[0] == '0' )
myfile = string(dirp->d_name);
if(myfile.length() > 3 && myfile.substr(myfile.length()-4) == "part" &&
- subname == myfile.substr( myfile.find("-")+1, myfile.rfind(".")-myfile.find("-")-1 ) ) {
+ subname == myfile.substr( myfile.find("_")+1, myfile.rfind(".")-myfile.find("_")-1 ) ) {
closedir(dp);
return myfile;
}