+bool modelCDMProject::SetBuildPath(const std::string& path, std::string*& result)
+{
+ if(path == "")
+ {
+ result = new std::string("The path cannot be empty");
+ return false;
+ }
+ if(path == this->path)
+ {
+ result = new std::string("The path cannot be same as the project sources");
+ return false;
+ }
+ this->buildPath = path;
+ return true;
+}
+
+modelCDMIProjectTreeNode* modelCDMProject::CreatePackage(
+ const std::string& name,
+ std::string*& result,
+ const std::string& authors,
+ const std::string& authorsEmail,
+ const std::string& description,
+ const std::string& version
+)
+{
+ //fixing input parameters
+ std::vector<std::string> words;
+
+ CDMUtilities::splitter::split(words,name," ",CDMUtilities::splitter::no_empties);
+ std::string nameFixed = "";
+ for (int i = 0; i < words.size(); i++)
+ {
+ nameFixed += words[i];
+ }
+
+ words.clear();
+ CDMUtilities::splitter::split(words,authors," ",CDMUtilities::splitter::no_empties);
+ std::string authorFixed;
+ for (int i = 0; i < words.size(); i++)
+ {
+ authorFixed += words[i];
+ }
+
+ words.clear();
+ std::string descriptionFixed;
+ CDMUtilities::splitter::split(words,authorsEmail," ",CDMUtilities::splitter::no_empties);
+ for (int i = 0; i < words.size(); i++)
+ {
+ descriptionFixed += words[i];
+ }
+ words.clear();
+ CDMUtilities::splitter::split(words,description," ",CDMUtilities::splitter::no_empties);
+ for (int i = 0; i < words.size(); i++)
+ {
+ descriptionFixed += "_" + words[i];
+ }
+
+ //call project to create package : use bbCreatePackage <path> <name> [author] [description]
+ std::string creationCommand = "bbCreatePackage \"" + this->path + "\" \"" + nameFixed + "\" \"" + authorFixed + "\" \"" + descriptionFixed + "\"";
+ //TODO: bbCreatePackage script always returning 0. It should return 1 or greater if any error
+ if(system(creationCommand.c_str()))
+ {
+ result = new std::string("An error occurred while running '" + creationCommand + "'.");
+ return NULL;
+ }
+
+ //add library to model
+ modelCDMPackage* package = new modelCDMPackage(this->path + CDMUtilities::SLASH + "bbtk_" + nameFixed + "_PKG", "bbtk_" + nameFixed + "_PKG", this->level + 1);
+ this->packages.push_back(package);
+ this->children.push_back(package);
+
+ //TODO: set package version
+
+ this->SortChildren();
+
+ result = new std::string(this->path + CDMUtilities::SLASH + name);
+ return package;
+}
+
+modelCDMIProjectTreeNode* modelCDMProject::CreateLibrary(
+ const std::string& name,
+ std::string*& result,
+ const std::string& path
+)
+{
+ if(this->lib != NULL)
+ {
+ return this->lib->CreateLibrary(name, result);
+ }
+ result = new std::string("there is no lib folder in this project.");
+ return NULL;
+}
+
+modelCDMIProjectTreeNode* modelCDMProject::CreateApplication(
+ const std::string& name,
+ std::string*& result,
+ const std::string& path
+)
+{
+ if(this->appli != NULL)
+ {
+ return this->appli->CreateApplication(name, result);
+ }
+ result = new std::string("there is no appli folder in this project.");
+ return NULL;
+}
+
+modelCDMIProjectTreeNode* modelCDMProject::CreateBlackBox(
+ const std::string& name,
+ const std::string& package,
+ const std::string& authors,
+ const std::string& authorsEmail,
+ const std::string& categories,
+ const std::string& description
+)
+{
+ //TODO: implement method
+ return NULL;
+}
+
+bool modelCDMProject::OpenCMakeListsFile(std::string*& result)
+{
+ if (!CDMUtilities::openTextEditor(this->CMakeLists->GetPath()))
+ return true;
+ else
+ {
+ result = new std::string("Couldn't open CMakeLists file.");
+ return false;
+ }
+}
+
+const bool modelCDMProject::Refresh(std::string*& result)
+{
+ std::cout << "refreshing project" << std::endl;
+ //open makelists file
+ std::string pathMakeLists = this->path + CDMUtilities::SLASH + "CMakeLists.txt";
+
+ std::ifstream confFile;
+ confFile.open((pathMakeLists).c_str());
+
+ std::string word;
+ while(confFile.is_open() && !confFile.eof())
+ {
+ //std::cout << "leyendo " << word << std::endl;
+ //get project name
+ std::getline(confFile,word,'(');
+ std::vector<std::string> wordBits;
+ CDMUtilities::splitter::split(wordBits,word," (\n",CDMUtilities::splitter::no_empties);
+
+ if(wordBits[wordBits.size()-1] == "PROJECT")
+ {
+ std::getline(confFile,word,')');
+ std::vector<std::string> nameBits;
+ CDMUtilities::splitter::split(nameBits, word, " ", CDMUtilities::splitter::no_empties);
+
+ this->name = this->nameProject = "";
+ for (int i = 0; i < nameBits.size(); i++)
+ {
+ if(i != 0)
+ this->name += " ";
+ this->name += nameBits[i];
+ }
+ this->nameProject = this->name;
+
+ }
+
+
+ if(wordBits[wordBits.size()-1] == "SET")
+ {
+ //get project version
+ std::getline(confFile,word,')');
+ CDMUtilities::splitter::split(wordBits, word, " ", CDMUtilities::splitter::no_empties);
+ if(wordBits[0] == "PROJECT_MAJOR_VERSION")
+ {
+ version = wordBits[1];
+ }
+ if(wordBits[0] == "PROJECT_MINOR_VERSION")
+ {
+ version += "." + wordBits[1];
+ }
+ if(wordBits[0] == "PROJECT_BUILD_VERSION")
+ {
+ version += "." + wordBits[1];
+ }
+
+ //get project versionDate
+ if(wordBits[0] == "PROJECT_VERSION_DATE")
+ {
+ std::vector<std::string> versionBits;
+ CDMUtilities::splitter::split(versionBits, wordBits[1], "\"", CDMUtilities::splitter::no_empties);
+ versionDate = versionBits[0];
+ }
+ }
+ }
+ confFile.close();
+
+ this->type = wxDIR_DIRS;
+ this->level = 0;
+
+ std::vector<bool> checked(this->children.size(), false);
+ std::vector<bool> checkedPackages(this->packages.size(), false);
+
+ //check all folders
+ wxDir dir(crea::std2wx((this->path).c_str()));
+ if (dir.IsOpened())
+ {
+ wxString fileName;
+ bool cont = dir.GetFirst(&fileName, wxEmptyString, wxDIR_DIRS);
+ while (cont)
+ {
+ std::string stdfileName = crea::wx2std(fileName);
+
+ //if appli, create appli
+ if(stdfileName == "appli")
+ {
+ if (this->appli == NULL)
+ {
+ this->appli = new modelCDMAppli(this->path + CDMUtilities::SLASH + stdfileName, stdfileName, this->level + 1);
+ this->children.push_back(this->appli);
+ }
+ else
+ {
+ int pos = std::find(this->children.begin(), this->children.end(), this->appli) - this->children.begin();
+ checked[pos] = true;
+ if(!this->appli->Refresh(result))
+ return false;
+ }
+ }
+ //if lib, create lib
+ else if(stdfileName == "lib")
+ {
+ if (this->lib == NULL)
+ {
+ this->lib = new modelCDMLib(this->path + CDMUtilities::SLASH + stdfileName, stdfileName, this->level + 1);
+ this->children.push_back(this->lib);
+ }
+ else
+ {
+ int pos = std::find(this->children.begin(), this->children.end(), this->lib) - this->children.begin();
+ checked[pos] = true;
+ if(!this->lib->Refresh(result))
+ return false;
+ }
+
+ }
+ //if package , create package
+ else if(stdfileName.size() > 9 && stdfileName.substr(0,5) == "bbtk_" && stdfileName.substr(stdfileName.size()-4,4) == "_PKG")
+ {
+ bool found = false;
+ for (int i = 0; !found && i < this->packages.size(); i++)
+ {
+ if (this->packages[i]->GetName() == stdfileName)
+ {
+ found = true;
+ int pos = std::find(this->children.begin(), this->children.end(), this->packages[i]) - this->children.begin();
+ checked[pos] = true;
+ checkedPackages[i] = true;
+ if(!this->packages[i]->Refresh(result))
+ return false;
+ }
+ }
+ if(!found)
+ {
+ modelCDMPackage* package = new modelCDMPackage(this->path + CDMUtilities::SLASH + stdfileName, stdfileName, this->level + 1);
+ this->packages.push_back(package);
+ this->children.push_back(package);
+ }
+
+ }
+ //if is an unknown folder, create folder
+ else
+ {
+ bool found = false;
+ for (int i = 0; !found && i < this->children.size(); i++)
+ {
+ if (this->children[i]->GetName() == stdfileName)
+ {
+ found = true;
+ checked[i] = true;
+ if(!this->children[i]->Refresh(result))
+ return false;
+ }
+ }
+
+ if(!found)
+ {
+ modelCDMFolder* folder = new modelCDMFolder(this->path + CDMUtilities::SLASH + stdfileName, stdfileName, this->level + 1);
+ this->children.push_back(folder);
+ }
+ }
+
+ cont = dir.GetNext(&fileName);
+ }
+
+ cont = dir.GetFirst(&fileName, wxEmptyString, wxDIR_FILES);
+ while (cont)
+ {
+ std::string stdfileName = crea::wx2std(fileName);
+
+ //if CMakeLists, create CMakeLists
+ if(stdfileName == "CMakeLists.txt")
+ {
+ if (this->CMakeLists == NULL)
+ {
+ this->CMakeLists = new modelCDMCMakeListsFile(this->path + CDMUtilities::SLASH + stdfileName, stdfileName, this->level + 1);
+ this->children.push_back(this->CMakeLists);
+ }
+ else
+ {
+ int pos = std::find(this->children.begin(), this->children.end(), this->CMakeLists) - this->children.begin();
+ checked[pos] = true;
+ if(!this->CMakeLists->Refresh(result))
+ return false;
+ }
+ }
+ //if is an unknown file, create file
+ else
+ {
+ bool found = false;
+ for (int i = 0; !found && i < this->children.size(); i++)
+ {
+ if (this->children[i]->GetName() == stdfileName)
+ {
+ found = true;
+ checked[i] = true;
+ if(!this->children[i]->Refresh(result))
+ return false;
+ }
+ }
+
+ if(!found)
+ {
+ modelCDMFile* file = new modelCDMFile(this->path + CDMUtilities::SLASH + stdfileName, stdfileName, this->level + 1);
+ this->children.push_back(file);
+ }
+ }
+
+ cont = dir.GetNext(&fileName);
+ }
+ }
+
+ for (int i = 0; i < checkedPackages.size(); i++)
+ {
+ if(!checkedPackages[i])
+ {
+ this->packages.erase(this->packages.begin()+i);
+ checkedPackages.erase(checkedPackages.begin()+i);
+ i--;
+ }
+ }
+ for (int i = 0; i < checked.size(); i++)
+ {
+ if(!checked[i])
+ {
+ delete this->children[i];
+ this->children.erase(this->children.begin()+i);
+ checked.erase(checked.begin()+i);
+ i--;
+ }
+ }
+
+ this->SortChildren();
+ std::sort(this->packages.begin(), this->packages.end(), CompareNodeItem);
+ return true;
+}
+
+bool modelCDMProject::ConfigureBuild(std::string*& result)
+{
+ //TODO: implement method
+ return true;
+}
+
+bool modelCDMProject::Build(std::string*& result)
+{
+ //TODO: implement method
+ return true;
+}
+
+bool modelCDMProject::Connect(std::string*& result)
+{
+ //TODO: implement method
+ return true;
+}