Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/Actions/WorldAction/InputAction.cpp

    rbd2390 r1fd675  
    3030#include <string>
    3131
    32 #include <boost/filesystem/fstream.hpp>
    33 
    3432using namespace std;
    3533
     
    4139/** =========== define the function ====================== */
    4240Action::state_ptr WorldInputAction::performCall() {
    43 //  MoleculeListClass *molecules = World::getInstance().getMolecules();
    44 //  molecule *mol = NULL;
    45   boost::filesystem::ifstream test;
     41  MoleculeListClass *molecules = World::getInstance().getMolecules();
     42  molecule *mol = NULL;
     43  std::ifstream test;
    4644
    4745  // obtain information
    4846  getParametersfromValueStorage();
    4947
    50   DoLog(0) && (Log() << Verbose(0) << "Config file given " << params.filename << "." << endl);
    51   // using the filename as prefix for all parsers
    52   std::string FilenameSuffix;
    53   std::string FilenamePrefix;
    54   if (params.filename.has_filename()) {
    55     // get suffix
    56     FilenameSuffix = params.filename.extension().substr(1); // remove the prefixed "."
    57     FilenamePrefix = params.filename.stem();
     48  DoLog(0) && (Log() << Verbose(0) << "Config file given." << endl);
     49  if (params.filename.find('.') != string::npos) {
     50    std::string FilenamePrefix = params.filename.substr(0,params.filename.find_last_of('.'));
     51    std::string FilenameSuffix = params.filename.substr(params.filename.find_last_of('.')+1, params.filename.length());
    5852    DoLog(1) && (Log() << Verbose(1) << "Setting config file name prefix to " << FilenamePrefix << "." << endl);
     53    test.open(params.filename.c_str());
     54    if (test == NULL) {
     55      DoLog(1) && (Log() << Verbose(1) << "Specified config file " << params.filename << " not found." << endl);
     56    } else {
     57      DoLog(1) && (Log() << Verbose(1) << "Specified config file found, parsing ... ");
     58      FormatParserStorage::getInstance().get((std::istream &)test, FilenameSuffix);
     59      test.close();
     60    }
    5961    FormatParserStorage::getInstance().SetOutputPrefixForAll(FilenamePrefix);
     62    // set mol to first active molecule
     63    if (molecules->ListOfMolecules.size() != 0) {
     64      for (MoleculeList::iterator ListRunner = molecules->ListOfMolecules.begin(); ListRunner != molecules->ListOfMolecules.end(); ListRunner++)
     65        if ((*ListRunner)->ActiveFlag) {
     66          mol = *ListRunner;
     67          break;
     68        }
     69    }
     70    if (mol == NULL) {
     71      mol = World::getInstance().createMolecule();
     72      mol->ActiveFlag = true;
     73      molecules->insert(mol);
     74    }
     75    mol->SetNameFromFilename(params.filename.substr(0,params.filename.find('.')).c_str());
    6076  } else {
    6177    DoeLog(1) && (eLog() << Verbose(1) << "Input file does not have a suffix, cannot recognize format." << endl);
    62     return Action::failure;
    63   }
    64 
    65   // parsing file if present
    66   if (!boost::filesystem::exists(params.filename)) {
    67     DoLog(1) && (Log() << Verbose(1) << "Specified config file " << params.filename << " not found." << endl);
    68     // DONT FAIL: it's just empty and we use the name. // return Action::failure;
    69   } else {
    70     DoLog(1) && (Log() << Verbose(1) << "Specified config file found, parsing ... ");
    71 
    72     // parse the file
    73     test.open(params.filename);
    74     FormatParserStorage::getInstance().get(test, FilenameSuffix);
    75     test.close();
    76 
    77     // set file name of last molecule
    78     MoleculeList::const_iterator iter = World::getInstance().getMolecules()->ListOfMolecules.end();
    79     iter--;
    80     (*iter)->SetNameFromFilename(FilenamePrefix.c_str());
    8178  }
    8279  return Action::success;
Note: See TracChangeset for help on using the changeset viewer.