#include "modelCDMApplication.h"
#include <fstream>
+#include <sstream>
#include <algorithm>
#include "CDMUtilities.h"
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<std::string> 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());
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;
}
}
}
{
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);
//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<std::string> 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)
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];
}
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.");
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);
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());
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;
}
}
}
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)
{
}
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);
}
{
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
else
{
bool found = false;
- for (int i = 0; i <!found && this->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<std::string> wordBits;
+ CDMUtilities::splitter::split(wordBits,word," \n",CDMUtilities::splitter::no_empties);
+ if (wordBits[wordBits.size() - 1] == "main")
+ {
+ this->mainFile = dynamic_cast<modelCDMFile*>(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<std::string> wordBits;
+ CDMUtilities::splitter::split(wordBits,word," \n",CDMUtilities::splitter::no_empties);
+ if (wordBits[wordBits.size() - 1] == "main")
+ {
+ this->mainFile = file;
+ }
+ }
+ fileStream.close();
+ }
+
this->children.push_back(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])
{
this->SortChildren();
return true;
}
+
+void modelCDMApplication::CheckStructure(std::map<std::string, bool>& 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<std::string> 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;
+ }
+
+
+ }
+ }
+
+ }
+}