#include <fstream>
#include <sstream>
#include <algorithm>
+#include <boost/regex.hpp>
#include "CDMUtilities.h"
#include "creaWx.h"
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];
}
while (cont)
{
std::string stdfileName = crea::wx2std(fileName);
-
//if CMakeLists, create CMakeLists
if(stdfileName == "CMakeLists.txt")
{
{
modelCDMFile* file = new modelCDMFile(this, this->path + CDMUtilities::SLASH + stdfileName, stdfileName, this->level + 1);
std::string extension = stdfileName.substr(stdfileName.size()-4);
+ //if is cxx or cpp check if is the main file.
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())
+ std::ifstream fileStream((this->path + CDMUtilities::SLASH + stdfileName).c_str());
+
+ if (fileStream.is_open())
{
- //get sets
- std::getline(fileStream,word,'(');
- std::vector<std::string> wordBits;
- CDMUtilities::splitter::split(wordBits,word," \n",CDMUtilities::splitter::no_empties);
- if (wordBits[wordBits.size() - 1] == "main")
+ std::string fileContent = "";
+ char ch = fileStream.get();
+ while(!fileStream.eof())
+ {
+ fileContent.push_back(ch);
+ ch = fileStream.get();
+ }
+ fileStream.close();
+
+ boost::regex expression("^\\h*IMPLEMENT_APP[#\\s\\(]");
+ std::string::const_iterator start, end;
+ start = fileContent.begin();
+ end = fileContent.end();
+ boost::match_results<std::string::const_iterator> what;
+ boost::match_flag_type flags = boost::match_default;
+ if(boost::regex_search(start, end, what, expression, flags))
{
+ std::cout << "found main wxwidgets file: " << stdfileName << std::endl;
this->mainFile = file;
}
+ else
+ {
+ expression = boost::regex("^\\h*int\\h+main[#\\s\\(]");
+ start = fileContent.begin();
+ end = fileContent.end();
+ if(boost::regex_search(start, end, what, expression, flags))
+ {
+ std::cout << "found main console file: " << stdfileName << std::endl;
+ this->mainFile = file;
+ }
+ }
}
- fileStream.close();
+
}
this->children.push_back(file);
}
std::vector<std::string> 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];
}
in.close();
out.close();
//delete old file and rename new file
+#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 + "'.");
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];
}
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)
{
else
{
bool found = false;
- for (int i = 0; !found && i < this->children.size(); i++)
+ for (int i = 0; !found && i < (int)(this->children.size()); i++)
{
if (this->children[i]->GetName() == stdfileName)
{
std::getline(fileStream,word,'(');
std::vector<std::string> wordBits;
CDMUtilities::splitter::split(wordBits,word," \n",CDMUtilities::splitter::no_empties);
- if (wordBits[wordBits.size() - 1] == "main")
+ if (wordBits[wordBits.size() - 1] == "main" || wordBits[wordBits.size() - 1] == "IMPLEMENT_APP")
{
this->mainFile = dynamic_cast<modelCDMFile*>(children[i]);
}
std::getline(fileStream,word,'(');
std::vector<std::string> wordBits;
CDMUtilities::splitter::split(wordBits,word," \n",CDMUtilities::splitter::no_empties);
- if (wordBits[wordBits.size() - 1] == "main")
+ if (wordBits[wordBits.size() - 1] == "main" || wordBits[wordBits.size() - 1] == "IMPLEMENT_APP")
{
this->mainFile = file;
}
}
}
- for (int i = 0; i < checkedFolders.size(); i++)
+ for (int i = 0; i < (int)(checkedFolders.size()); i++)
{
if(!checkedFolders[i])
{
i--;
}
}
- for (int i = 0; i < checked.size(); i++)
+ for (int i = 0; i < (int)(checked.size()); i++)
{
if(!checked[i])
{
{
word = words[0];
CDMUtilities::splitter::split(words, word, " ", CDMUtilities::splitter::empties_ok);
- for (int i = 0; i < words.size(); i++)
+ for (int i = 0; i < (int)(words.size()); i++)
{
if(words[i].substr(0,2) == "//")
break;
{
if (words[0] == "${EXE_NAME}_LINK_LIBRARIES")
{
- for (int i = 1; i < words.size(); i++)
+ for (int i = 1; i < (int)(words.size()); i++)
{
properties["application " + this->name + " lib " + words[i]] = true;
}
CDMUtilities::splitter::split(words, word, " \t", CDMUtilities::splitter::no_empties);
- for (int i = 0; i < words.size(); i++)
+ for (int i = 0; i < (int)(words.size()); i++)
{
properties["application " + this->name + " dir " + words[i]] = true;
}
}
}
+
+std::map<std::string, bool> modelCDMApplication::Get3rdPartyLibraries()
+{
+ std::map<std::string, std::string> 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<std::string, bool> 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())
+ {
+
+ std::string CMfile = CDMUtilities::readFile(this->CMakeLists->GetPath().c_str());
+
+ boost::regex expression("^\\h*SET([\\s]|#[^\\n]*\\n)*\\(([\\s]|#[^\\n]*\\n)*\\$\\{EXE_NAME\\}_LINK_LIBRARIES(([\\s]|#[^\\n]*\\n)+([\\$\\{\\}\\w\\d]+|\"(?:[^\"\\\\]|\\\\.)*\"))*([\\s]|#[^\\n]*\\n)*\\)");
+ std::string::const_iterator start, end;
+ start = CMfile.begin();
+ end = CMfile.end();
+ boost::match_results<std::string::const_iterator> what;
+ boost::match_flag_type flags = boost::match_default;
+ if(boost::regex_search(start, end, what, expression, flags))
+ {
+
+ expression = boost::regex("^\\h*SET([\\s]|#[^\\n]*\\n)*\\(([\\s]|#[^\\n]*\\n)*\\$\\{EXE_NAME\\}_LINK_LIBRARIES");
+ std::string::const_iterator start1, end1;
+ start1 = what[0].first;
+ end1 = what[0].second;
+ boost::match_results<std::string::const_iterator> what1;
+ if(boost::regex_search(start1, end1, what1, expression, flags))
+ {
+ expression = boost::regex("(#[^\\n]*\\n|\\s*\\$\\{\\w+\\})");
+ std::string::const_iterator start2, end2;
+ start2 = what1[0].second;
+ end2 = what[0].second;
+ boost::match_results<std::string::const_iterator> what2;
+ while(boost::regex_search(start2, end2, what2, expression, flags))
+ {
+ if(what2.str()[0] != '#')
+ {
+ std::string dete = what2.str();
+ CDMUtilities::normalizeStr(dete);
+ if(correspondence.find(dete) != correspondence.end())
+ res[correspondence[dete]] = true;
+ }
+ start2 = what2[0].second;
+ }
+ }
+ }
+ }
+ return res;
+}
+
+bool modelCDMApplication::Set3rdPartyLibrary(const std::string& library_name, const bool& toInclude)
+{
+ std::map<std::string, std::string> 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<std::string> 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<std::string, bool> modelCDMApplication::GetCustomLibraries()
+{
+ std::map<std::string, bool> res;
+ res["Test"] = false;
+ return res;
+}
+
+bool modelCDMApplication::SetCustomLibrary(const std::string& library_name, const bool& toInclude)
+{
+ return false;
+}