X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=lib%2FcreaDevManagerLib%2FmodelCDMApplication.cpp;h=0ee18a913fa037ed71e1065488b54f6cb5785d57;hb=ef630179c0efdb37f43994958b727f585cf2c3ec;hp=c39b48d769677ca311727fe391180d14aa109244;hpb=2b6788596bc21c7942df4b0d6917eaf5b5d72277;p=crea.git diff --git a/lib/creaDevManagerLib/modelCDMApplication.cpp b/lib/creaDevManagerLib/modelCDMApplication.cpp index c39b48d..0ee18a9 100644 --- a/lib/creaDevManagerLib/modelCDMApplication.cpp +++ b/lib/creaDevManagerLib/modelCDMApplication.cpp @@ -35,6 +35,7 @@ #include "modelCDMApplication.h" #include +#include #include #include "CDMUtilities.h" @@ -43,27 +44,24 @@ modelCDMApplication::modelCDMApplication() { + mainFile = NULL; } -modelCDMApplication::modelCDMApplication(const std::string& path, const int& level) +modelCDMApplication::modelCDMApplication(modelCDMIProjectTreeNode* parent, const std::string& path, const std::string& name, const int& level) { + std::cout << "creating application: " + path + "\n"; + this->parent = parent; + this->mainFile = NULL; //folder name - std::vector words; - std::string delimiters; - //TODO::fix for windows - delimiters = "/"; - CDMUtilities::splitter::split(words, path, delimiters, CDMUtilities::splitter::no_empties); - this->name = words[words.size()-1]; - + this->name = name; //path this->path = CDMUtilities::fixPath(path); //type this->type = wxDIR_DIRS; //level this->level = level; - //open CMakeList - std::string pathMakeLists = path + "/CMakeLists.txt"; + std::string pathMakeLists = path + CDMUtilities::SLASH + "CMakeLists.txt"; std::ifstream confFile; confFile.open((pathMakeLists).c_str()); @@ -84,12 +82,12 @@ modelCDMApplication::modelCDMApplication(const std::string& path, const int& lev if(wordBits[0] == "EXE_NAME") { word = wordBits[1]; - for (int i = 2; i < wordBits.size(); i++) + for (int i = 2; i < (int)(wordBits.size()); i++) { word += " " + wordBits[i]; } - this->nameApplication = this->executableName = word; + this->executableName = word; } } } @@ -108,7 +106,7 @@ modelCDMApplication::modelCDMApplication(const std::string& path, const int& lev { std::string stdfileName = crea::wx2std(fileName); - modelCDMFolder* folder = new modelCDMFolder(this->path + "/" + stdfileName, this->level + 1); + modelCDMFolder* folder = new modelCDMFolder(this, this->path + CDMUtilities::SLASH + stdfileName, stdfileName, this->level + 1); this->folders.push_back(folder); this->children.push_back(folder); @@ -123,33 +121,54 @@ modelCDMApplication::modelCDMApplication(const std::string& path, const int& lev //if CMakeLists, create CMakeLists if(stdfileName == "CMakeLists.txt") { - this->CMakeLists = new modelCDMCMakeListsFile(this->path + "/" + stdfileName, this->level + 1); + this->CMakeLists = new modelCDMCMakeListsFile(this, this->path + CDMUtilities::SLASH + stdfileName, stdfileName, this->level + 1); this->children.push_back(this->CMakeLists); } //if is an unknown file, create file else { - this->children.push_back(new modelCDMFile(this->path + "/" + stdfileName, this->level + 1)); + modelCDMFile* file = new modelCDMFile(this, this->path + CDMUtilities::SLASH + stdfileName, stdfileName, this->level + 1); + std::string extension = stdfileName.substr(stdfileName.size()-4); + if (mainFile == NULL && (extension == ".cxx" || extension == ".cpp")) + { + std::ifstream fileStream; + std::string word; + fileStream.open((this->path + CDMUtilities::SLASH + stdfileName).c_str()); + while (fileStream.is_open() && !fileStream.eof()) + { + //get sets + std::getline(fileStream,word,'('); + std::vector wordBits; + CDMUtilities::splitter::split(wordBits,word," \n",CDMUtilities::splitter::no_empties); + if (wordBits[wordBits.size() - 1] == "main" || wordBits[wordBits.size() - 1] == "IMPLEMENT_APP") + { + this->mainFile = file; + } + } + fileStream.close(); + } + this->children.push_back(file); } cont = dir.GetNext(&fileName); } } this->SortChildren(); + std::sort(this->folders.begin(), this->folders.end(), CompareNodeItem); } modelCDMApplication::~modelCDMApplication() { } -const std::string& modelCDMApplication::GetNameApplication() const +const std::string& modelCDMApplication::GetExecutableName() const { - return this->nameApplication; + return this->executableName; } -const std::string& modelCDMApplication::GetExecutableName() const +modelCDMFile* modelCDMApplication::GetMainFile() const { - return this->executableName; + return this->mainFile; } bool modelCDMApplication::SetExecutableName(const std::string& fileName, std::string*& result) @@ -157,21 +176,21 @@ bool modelCDMApplication::SetExecutableName(const std::string& fileName, std::st std::vector words; CDMUtilities::splitter::split(words, fileName, ", /\\\"", CDMUtilities::splitter::no_empties); std::string fileNameReal = words[0]; - for (int i = 1; i < words.size(); i++) + for (int i = 1; i < (int)(words.size()); i++) { fileNameReal += "-" + words[i]; } std::string line; //opening original cmakelists - std::ifstream in((this->path + "/CMakeLists.txt").c_str()); + std::ifstream in((this->path + CDMUtilities::SLASH + "CMakeLists.txt").c_str()); if( !in.is_open()) { result = new std::string("CMakeLists.txt file failed to open."); return false; } //opening temporal cmakelists - std::ofstream out((this->path + "/CMakeLists.txt.tmp").c_str()); + std::ofstream out((this->path + CDMUtilities::SLASH + "CMakeLists.txt.tmp").c_str()); if( !out.is_open()) { result = new std::string("CMakeLists.txt.tmp file failed to open."); @@ -187,27 +206,32 @@ bool modelCDMApplication::SetExecutableName(const std::string& fileName, std::st in.close(); out.close(); //delete old file and rename new file - std::string renameCommand = "mv " + this->path + "/CMakeLists.txt.tmp " + this->path + "/CMakeLists.txt"; +#ifdef _WIN32 + std::string renameCommand = "move /Y \"" + this->path + CDMUtilities::SLASH + "CMakeLists.txt.tmp\" \"" + this->path + CDMUtilities::SLASH + "CMakeLists.txt\""; +#else + std::string renameCommand = "mv \"" + this->path + CDMUtilities::SLASH + "CMakeLists.txt.tmp\" \"" + this->path + CDMUtilities::SLASH + "CMakeLists.txt\""; +#endif + if(system(renameCommand.c_str())) { result = new std::string("An error occurred while running '" + renameCommand + "'."); return false; } - this->executableName = this->nameApplication = fileNameReal; + this->executableName = fileNameReal; return true; } modelCDMFolder* modelCDMApplication::CreateFolder(const std::string& name, std::string*& result) { //TODO:: mkdir depending on OS - std::string command = "mkdir " + path + "/" + name; + std::string command = "mkdir " + path + CDMUtilities::SLASH + name; if(system(command.c_str())) { result = new std::string("Error executing: " + command + "."); return NULL; } - modelCDMFolder* folder = new modelCDMFolder(path + "/" + name, level + 1); + modelCDMFolder* folder = new modelCDMFolder(this, path + CDMUtilities::SLASH + name, name, level + 1); this->folders.push_back(folder); this->children.push_back(folder); @@ -216,11 +240,13 @@ modelCDMFolder* modelCDMApplication::CreateFolder(const std::string& name, std:: const bool modelCDMApplication::Refresh(std::string*& result) { + this->mainFile = NULL; + std::cout << "refreshing application: " << this->executableName << std::endl; //set attributes this->type = wxDIR_DIRS; //open CMakeList - std::string pathMakeLists = path + "/CMakeLists.txt"; + std::string pathMakeLists = path + CDMUtilities::SLASH + "CMakeLists.txt"; std::ifstream confFile; confFile.open((pathMakeLists).c_str()); @@ -235,18 +261,18 @@ const bool modelCDMApplication::Refresh(std::string*& result) if(wordBits[wordBits.size()-1] == "SET") { - //get library name + //get app name std::getline(confFile,word,')'); CDMUtilities::splitter::split(wordBits, word, " ", CDMUtilities::splitter::no_empties); - if(wordBits[0] == "LIBRARY_NAME") + if(wordBits[0] == "EXE_NAME") { word = wordBits[1]; - for (int i = 2; i < wordBits.size(); i++) + for (int i = 2; i < (int)(wordBits.size()); i++) { word += " " + wordBits[i]; } - this->nameApplication = this->executableName = word; + this->executableName = word; } } } @@ -269,7 +295,7 @@ const bool modelCDMApplication::Refresh(std::string*& result) std::string applicationName = stdfileName; //check if they already exist bool found = false; - for (int i = 0;!found && i < this->folders.size(); i++) + for (int i = 0; !found && i < (int)(this->folders.size()); i++) { if (this->folders[i]->GetName() == applicationName) { @@ -283,7 +309,7 @@ const bool modelCDMApplication::Refresh(std::string*& result) } if(!found) { - modelCDMFolder* folder = new modelCDMFolder(this->path + "/" + stdfileName, this->level + 1); + modelCDMFolder* folder = new modelCDMFolder(this, this->path + CDMUtilities::SLASH + stdfileName, stdfileName, this->level + 1); this->folders.push_back(folder); this->children.push_back(folder); } @@ -300,7 +326,7 @@ const bool modelCDMApplication::Refresh(std::string*& result) { if (this->CMakeLists == NULL) { - this->CMakeLists = new modelCDMCMakeListsFile(this->path + "/" + stdfileName, this->level + 1); + this->CMakeLists = new modelCDMCMakeListsFile(this, this->path + CDMUtilities::SLASH + stdfileName, stdfileName, this->level + 1); this->children.push_back(this->CMakeLists); } else @@ -315,20 +341,62 @@ const bool modelCDMApplication::Refresh(std::string*& result) else { bool found = false; - for (int i = 0; i children.size(); i++) + for (int i = 0; !found && i < (int)(this->children.size()); i++) { if (this->children[i]->GetName() == stdfileName) { found = true; checked[i] = true; + if(!this->children[i]->Refresh(result)) return false; + + std::string extension = stdfileName.substr(stdfileName.size()-4); + if (mainFile == NULL && (extension == ".cxx" || extension == ".cpp")) + { + std::ifstream fileStream; + std::string word; + fileStream.open((this->path + CDMUtilities::SLASH + stdfileName).c_str()); + while (fileStream.is_open() && !fileStream.eof()) + { + //get sets + std::getline(fileStream,word,'('); + std::vector wordBits; + CDMUtilities::splitter::split(wordBits,word," \n",CDMUtilities::splitter::no_empties); + if (wordBits[wordBits.size() - 1] == "main" || wordBits[wordBits.size() - 1] == "IMPLEMENT_APP") + { + this->mainFile = dynamic_cast(children[i]); + } + } + fileStream.close(); + } } } if(!found) { - modelCDMFile* file = new modelCDMFile(this->path + "/" + stdfileName, this->level + 1); + modelCDMFile* file = new modelCDMFile(this, this->path + CDMUtilities::SLASH + stdfileName, stdfileName, this->level + 1); + + std::string extension = stdfileName.substr(stdfileName.size()-4); + if (mainFile == NULL && (extension == ".cxx" || extension == ".cpp")) + { + std::ifstream fileStream; + std::string word; + fileStream.open((this->path + CDMUtilities::SLASH + stdfileName).c_str()); + while (fileStream.is_open() && !fileStream.eof()) + { + //get sets + std::getline(fileStream,word,'('); + std::vector wordBits; + CDMUtilities::splitter::split(wordBits,word," \n",CDMUtilities::splitter::no_empties); + if (wordBits[wordBits.size() - 1] == "main" || wordBits[wordBits.size() - 1] == "IMPLEMENT_APP") + { + this->mainFile = file; + } + } + fileStream.close(); + } + this->children.push_back(file); } } @@ -337,7 +405,7 @@ const bool modelCDMApplication::Refresh(std::string*& result) } } - for (int i = 0; i < checkedFolders.size(); i++) + for (int i = 0; i < (int)(checkedFolders.size()); i++) { if(!checkedFolders[i]) { @@ -346,7 +414,7 @@ const bool modelCDMApplication::Refresh(std::string*& result) i--; } } - for (int i = 0; i < checked.size(); i++) + for (int i = 0; i < (int)(checked.size()); i++) { if(!checked[i]) { @@ -359,3 +427,264 @@ const bool modelCDMApplication::Refresh(std::string*& result) this->SortChildren(); return true; } + +void modelCDMApplication::CheckStructure(std::map& properties) +{ + //check cmake exist + if(this->CMakeLists != NULL) + { + //set default properties + properties["application " + this->name + " lib ${crea_LIBRARIES}"] = false; + properties["application " + this->name + " lib ${WXWIDGETS_LIBRARIES}"] = false; + properties["application " + this->name + " lib ${KWWidgets_LIBRARIES}"] = false; + properties["application " + this->name + " lib ${VTK_LIBRARIES}"] = false; + properties["application " + this->name + " lib ${ITK_LIBRARIES}"] = false; + properties["application " + this->name + " lib ${GDCM_LIBRARIES}"] = false; + properties["application " + this->name + " lib ${BOOST_LIBRARIES}"] = false; + + //open cmakelists + std::ifstream confFile; + confFile.open((this->CMakeLists->GetPath()).c_str()); + + //take everything that is not commented + std::string fileContent; + + std::string word; + std::vector words; + while(confFile.is_open() && !confFile.eof()) + { + std::getline(confFile,word, '\n'); + if(word[0] != '#') + { + CDMUtilities::splitter::split(words, word, "#", CDMUtilities::splitter::empties_ok); + if (words.size() > 0) + { + word = words[0]; + CDMUtilities::splitter::split(words, word, " ", CDMUtilities::splitter::empties_ok); + for (int i = 0; i < (int)(words.size()); i++) + { + if(words[i].substr(0,2) == "//") + break; + fileContent += words[i] + " "; + } + } + } + } + + //check every instruction + std::stringstream ss(fileContent); + while(!ss.eof()) + { + std::getline(ss,word, '('); + + //check instruction name + CDMUtilities::splitter::split(words, word, " ", CDMUtilities::splitter::no_empties); + + //set instructions + if (words.size() > 0 && words[words.size()-1] == "SET") + { + std::getline(ss,word, ')'); + + CDMUtilities::splitter::split(words, word, " \t", CDMUtilities::splitter::no_empties); + if (words.size() > 1) + { + if (words[0] == "${EXE_NAME}_LINK_LIBRARIES") + { + for (int i = 1; i < (int)(words.size()); i++) + { + properties["application " + this->name + " lib " + words[i]] = true; + } + } + } + } + else if (words.size() > 0 && words[words.size()-1] == "INCLUDE_DIRECTORIES") + { + std::getline(ss,word, ')'); + + CDMUtilities::splitter::split(words, word, " \t", CDMUtilities::splitter::no_empties); + + for (int i = 0; i < (int)(words.size()); i++) + { + properties["application " + this->name + " dir " + words[i]] = true; + } + + + } + } + + } +} + +std::map modelCDMApplication::Get3rdPartyLibraries() +{ + std::map correspondence; + correspondence["${crea_LIBRARIES}"] = "Crea"; + correspondence["${WXWIDGETS_LIBRARIES}"] = "WxWidgets"; + correspondence["${KWWidgets_LIBRARIES}"] = "KWWidgets"; + correspondence["${VTK_LIBRARIES}"] = "VTK"; + correspondence["${ITK_LIBRARIES}"] = "ITK"; + correspondence["${GDCM_LIBRARIES}"] = "GDCM"; + correspondence["${BOOST_LIBRARIES}"] = "Boost"; + std::map res; + res["Crea"] = false; + res["WxWidgets"] = false; + res["KWWidgets"] = false; + res["VTK"] = false; + res["ITK"] = false; + res["GDCM"] = false; + res["Boost"] = false; + + if (this->HasCMakeLists()) + { + CDMUtilities::CMLFile cmlFile = CDMUtilities::readCMLFile(this->CMakeLists->GetPath().c_str()); + // look at every syntax element + for (int i = 0; i < cmlFile.size(); ++i) + { + // if the element is a command and is a SET command + if (cmlFile[i].first == "command" && cmlFile[i].second[0] == "SET") + { + // search first parameter + int pos = 1; + while (pos < cmlFile[i].second.size()) + { + // see if it is ${LIBRARY_NAME}_LINK_LIBRARIES + if (cmlFile[i].second[pos] == "${EXE_NAME}_LINK_LIBRARIES") + { + pos++; + // look for all the third party libraries included + while (pos < cmlFile[i].second.size()) + { + if (cmlFile[i].second[pos][0] == '$' && correspondence.find(cmlFile[i].second[pos]) != correspondence.end()) + { + res[correspondence[cmlFile[i].second[pos]]] = true; + } + pos++; + } + } + // if it is the first parameter but is not ${LIBRARY_NAME}_LINK_LIBRARIES then finish with this command + else if (!isspace(cmlFile[i].second[pos][0]) && cmlFile[i].second[pos][0] != '#' && cmlFile[i].second[pos][0] != '(' && cmlFile[i].second[pos][0] != ')') + { + break; + } + pos++; + } + } + } + } + return res; +} + +bool modelCDMApplication::Set3rdPartyLibrary(const std::string& library_name, const bool& toInclude) +{ + std::map correspondence; + + correspondence["Crea"] = "${crea_LIBRARIES}"; + correspondence["WxWidgets"] = "${WXWIDGETS_LIBRARIES}"; + correspondence["KWWidgets"] = "${KWWidgets_LIBRARIES}"; + correspondence["VTK"] = "${VTK_LIBRARIES}"; + correspondence["ITK"] = "${ITK_LIBRARIES}"; + correspondence["GDCM"] = "${GDCM_LIBRARIES}"; + correspondence["Boost"] = "${BOOST_LIBRARIES}"; + + if (correspondence.find(library_name) != correspondence.end()) + { + std::string library_command = correspondence[library_name]; + if (this->HasCMakeLists()) + { + CDMUtilities::CMLFile cmlFile = CDMUtilities::readCMLFile(this->CMakeLists->GetPath()); + + // look at every syntax element + for (int i = 0; i < cmlFile.size(); ++i) + { + // if the element is a command and is a SET command + if (cmlFile[i].first == "command" && cmlFile[i].second[0] == "SET") + { + // search first parameter + int pos = 1; + while (pos < cmlFile[i].second.size()) + { + // see if it is ${LIBRARY_NAME}_LINK_LIBRARIES + if (cmlFile[i].second[pos] == "${EXE_NAME}_LINK_LIBRARIES") + { + bool found = false; + pos++; + // look for all the third party libraries included + while (pos < cmlFile[i].second.size() && cmlFile[i].second[pos] != ")") + { + // if is library_command then found + if (cmlFile[i].second[pos] == library_command) + { + found = true; + //if toInclude is false the make it a comment + if (!toInclude) + { + cmlFile[i].second[pos] = "#" + cmlFile[i].second[pos]; + std::cout << "library commented: " << library_name << std::endl; + } + break; + } + else if (toInclude && cmlFile[i].second[pos][0] == '#') + { + std::vector segments; + CDMUtilities::splitter::split(segments, cmlFile[i].second[pos], "#", CDMUtilities::splitter::no_empties); + if(segments.size()) + { + for (int j = 0; j < segments[0].size(); ++j) + { + if(isspace(segments[0][j])) + { + segments[0].erase(j,1); + j--; + } + } + + if(segments[0].size() && segments[0] == library_command) + { + found = true; + while(cmlFile[i].second[pos][0] == '#') + { + cmlFile[i].second[pos].erase(0,1); + } + std::cout << "library uncommented: " << library_name << std::endl; + break; + } + } + } + pos++; + } + + //if the library was not found and is an inclusion then include it + if (!found && toInclude && pos < cmlFile[i].second.size() && cmlFile[i].second[pos] == ")") + { + cmlFile[i].second.insert(cmlFile[i].second.begin()+pos, library_command); + cmlFile[i].second.insert(cmlFile[i].second.begin()+pos+1, "\n"); + std::cout << "library included: " << library_name << std::endl; + } + } + // if it is the first parameter but is not ${LIBRARY_NAME}_LINK_LIBRARIES then finish with this command + else if (!isspace(cmlFile[i].second[pos][0]) && cmlFile[i].second[pos][0] != '#' && cmlFile[i].second[pos][0] != '(' && cmlFile[i].second[pos][0] != ')') + { + break; + } + pos++; + } + } + } + + return CDMUtilities::writeCMLFile(this->CMakeLists->GetPath(), cmlFile); + } + } + return false; +} + +std::map modelCDMApplication::GetCustomLibraries() +{ + std::map res; + res["Test"] = false; + return res; +} + +bool modelCDMApplication::SetCustomLibrary(const std::string& library_name, const bool& toInclude) +{ + return false; +}