X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=lib%2FcreaDevManagerLib%2FmodelCDMPackage.cpp;h=c6ea443d6d516e0e00b72c65cefe38f3c7f4ef79;hb=ef630179c0efdb37f43994958b727f585cf2c3ec;hp=81fb90610b5ac2b5e23877905ac06d17e61c51e6;hpb=5a17d994576296f2a5a85f3a01ad5631786a0c56;p=crea.git diff --git a/lib/creaDevManagerLib/modelCDMPackage.cpp b/lib/creaDevManagerLib/modelCDMPackage.cpp index 81fb906..c6ea443 100644 --- a/lib/creaDevManagerLib/modelCDMPackage.cpp +++ b/lib/creaDevManagerLib/modelCDMPackage.cpp @@ -693,13 +693,13 @@ void modelCDMPackage::CheckStructure(std::map& properties) std::map modelCDMPackage::Get3rdPartyLibraries() { std::map correspondence; - correspondence["${BBTK_PACKAGE_NAME}_USE_VTKON"] = "VTK"; - correspondence["${BBTK_PACKAGE_NAME}_USE_ITKON"] = "ITK"; - correspondence["${BBTK_PACKAGE_NAME}_USE_GDCMON"] = "GDCM"; - correspondence["${BBTK_PACKAGE_NAME}_USE_GDCM_VTKON"] = "GDCM_VTK"; - correspondence["${BBTK_PACKAGE_NAME}_USE_GSMISON"] = "GSMIS"; - correspondence["${BBTK_PACKAGE_NAME}_USE_WXWIDGETSON"] = "WxWidgets"; - correspondence["${BBTK_PACKAGE_NAME}_USE_KWWIDGETSON"] = "KWWidgets"; + correspondence["${BBTK_PACKAGE_NAME}_USE_VTK"] = "VTK"; + correspondence["${BBTK_PACKAGE_NAME}_USE_ITK"] = "ITK"; + correspondence["${BBTK_PACKAGE_NAME}_USE_GDCM"] = "GDCM"; + correspondence["${BBTK_PACKAGE_NAME}_USE_GDCM_VTK"] = "GDCM_VTK"; + correspondence["${BBTK_PACKAGE_NAME}_USE_GSMIS"] = "GSMIS"; + correspondence["${BBTK_PACKAGE_NAME}_USE_WXWIDGETS"] = "WxWidgets"; + correspondence["${BBTK_PACKAGE_NAME}_USE_KWWIDGETS"] = "KWWidgets"; std::map res; res["VTK"] = false; res["ITK"] = false; @@ -709,45 +709,46 @@ std::map modelCDMPackage::Get3rdPartyLibraries() res["WxWidgets"] = false; res["KWWidgets"] = false; - if(this->HasCMakeLists()) + if (this->HasCMakeLists()) { - std::ifstream CMFile(this->CMakeLists->GetPath().c_str()); - if (CMFile.is_open()) + CDMUtilities::CMLFile cmlFile = CDMUtilities::readCMLFile(this->CMakeLists->GetPath().c_str()); + // look at every syntax element + for (int i = 0; i < cmlFile.size(); ++i) { - std::string line; - while(!CMFile.eof()) + // if the element is a command and is a SET command + if (cmlFile[i].first == "command" && cmlFile[i].second[0] == "SET") { - std::getline(CMFile, line, '('); - - std::vector lineSeg; - CDMUtilities::splitter::split(lineSeg,line,"\n",CDMUtilities::splitter::no_empties); - for(int i = 0; lineSeg.size() > 0 && i < lineSeg[lineSeg.size()-1].size(); ++i) - if (lineSeg[lineSeg.size()-1][i] == ' ') - { - lineSeg[lineSeg.size()-1].erase(i,1); - --i; - } - if(lineSeg.size() > 0 && lineSeg[lineSeg.size()-1][0]!='#' && lineSeg[lineSeg.size()-1] == "SET") + // search first parameter + int pos = 1; + while (pos < cmlFile[i].second.size()) { - std::getline(CMFile, line, ')'); - CDMUtilities::splitter::split(lineSeg,line,"\t\n",CDMUtilities::splitter::no_empties); - if(lineSeg.size() > 0) + if (!isspace(cmlFile[i].second[pos][0]) && cmlFile[i].second[pos][0] != '#' && cmlFile[i].second[pos][0] != '(' && cmlFile[i].second[pos][0] != ')') { - for(int i = 0; i < lineSeg[0].size(); ++i) - if (lineSeg[0][i] == ' ') - { - lineSeg[0].erase(i,1); - --i; - } - - if(lineSeg[0].size() > 0 && lineSeg[0][0] == '$' && correspondence.find(lineSeg[0]) != correspondence.end()) + break; + } + pos++; + } + // if the first parameter is a third party statement + if (pos < cmlFile[i].second.size() && correspondence.find(cmlFile[i].second[pos]) != correspondence.end()) + { + std::string foundLibrary = cmlFile[i].second[pos]; + // search for second parameter + pos++; + while (pos < cmlFile[i].second.size()) + { + if (!isspace(cmlFile[i].second[pos][0]) && cmlFile[i].second[pos][0] != '#' && cmlFile[i].second[pos][0] != '(' && cmlFile[i].second[pos][0] != ')') { - res[correspondence[lineSeg[0]]] = true; + break; } + pos++; + } + // if the second parameter is ON + if (pos < cmlFile[i].second.size() && cmlFile[i].second[pos] == "ON") + { + res[correspondence[foundLibrary]] = true; } } } - CMFile.close(); } } return res; @@ -756,6 +757,89 @@ std::map modelCDMPackage::Get3rdPartyLibraries() bool modelCDMPackage::Set3rdPartyLibrary(const std::string& library_name, const bool& toInclude) { + std::map correspondence; + + correspondence["VTK"] = "${BBTK_PACKAGE_NAME}_USE_VTK"; + correspondence["ITK"] = "${BBTK_PACKAGE_NAME}_USE_ITK"; + correspondence["GDCM"] = "${BBTK_PACKAGE_NAME}_USE_GDCM"; + correspondence["GDCM_VTK"] = "${BBTK_PACKAGE_NAME}_USE_GDCM_VTK"; + correspondence["GSMIS"] = "${BBTK_PACKAGE_NAME}_USE_GSMIS"; + correspondence["WxWidgets"] = "${BBTK_PACKAGE_NAME}_USE_WXWIDGETS"; + correspondence["KWWidgets"] = "${BBTK_PACKAGE_NAME}_USE_KWWIDGETS"; +/* + 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().c_str()); + bool found = false; + // 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()) + { + if (!isspace(cmlFile[i].second[pos][0]) && cmlFile[i].second[pos][0] != '#' && cmlFile[i].second[pos][0] != '(' && cmlFile[i].second[pos][0] != ')') + { + break; + } + pos++; + } + // if the first parameter is a third party statement + if (pos < cmlFile[i].second.size() && cmlFile[i].second[pos] == library_command) + { + std::string foundLibrary = cmlFile[i].second[pos]; + // search for second parameter + pos++; + while (pos < cmlFile[i].second.size()) + { + if (!isspace(cmlFile[i].second[pos][0]) && cmlFile[i].second[pos][0] != '#' && cmlFile[i].second[pos][0] != '(' && cmlFile[i].second[pos][0] != ')') + { + break; + } + pos++; + } + // if the second parameter is ON + if (pos < cmlFile[i].second.size() && cmlFile[i].second[pos] == "ON") + { + found = true; + if (toInclude) + { + std::cout << "library already included: " << library_name << std::endl; + } + else + { + cmlFile[i].first = "comment"; + cmlFile[i].second[0] = "#" + cmlFile[i].second[0]; + std::cout << "library include commented: " << library_name << std::endl; + } + } + else if (pos < cmlFile[i].second.size() && cmlFile[i].second[pos] == "OFF") + { + found = true; + if (toInclude) + { + cmlFile[i].second[pos] = "ON"; + std::cout << "library include activated: " << library_name << std::endl; + } + else + { + std::cout << "library include already disabled: " << library_name << std::endl; + } + } + } + } else if (cmlFile[i].first == "comment") { + //TODO: check if it is commented + } + } + } + } +*/ return false; }