ModList after tests, finished lower-level data objects

This commit is contained in:
Phitherek 2013-04-07 15:44:36 +02:00
parent 062f6feebd
commit 5aabfdc764
6 changed files with 252 additions and 21 deletions

View File

@ -354,7 +354,7 @@ void ModInfo::clear() {
_localPath = ""; _localPath = "";
} }
void ModInfo::setModInfoDescription(ModInfoDescripion mid) { void ModInfo::setModInfoDescription(ModInfoDescription mid) {
_desc = mid; _desc = mid;
} }

View File

@ -3,6 +3,9 @@
#include "3mExceptions.h" #include "3mExceptions.h"
#include <vector> #include <vector>
#include <fstream> #include <fstream>
#include <iostream>
#include <string>
#include <cstdlib>
using namespace mmm; using namespace mmm;
ModList::ModList() { ModList::ModList() {
@ -47,7 +50,7 @@ ModList::ModList(ModListDescription mld) {
if(line[0] != NULL && line[0] != ' ' && line[0] != '\n' && line[0] != '\r') { if(line[0] != NULL && line[0] != ' ' && line[0] != '\n' && line[0] != '\r') {
if(action == "detect") { if(action == "detect") {
if(line[0] == '{') { if(line[0] == '{') {
string name = ""; std::string name = "";
for(unsigned int i = 1; line[i] != '}' && i < line.length(); i++) { for(unsigned int i = 1; line[i] != '}' && i < line.length(); i++) {
name += line[i]; name += line[i];
} }
@ -79,8 +82,8 @@ ModList::ModList(ModListDescription mld) {
throw ParseException(_desc.getServer() + _desc.getPath(), msg); throw ParseException(_desc.getServer() + _desc.getPath(), msg);
} }
} else if(line[0] == '[') { } else if(line[0] == '[') {
string tmpact = ""; std::string tmpact = "";
for(int i = 1; line[i] != ']' && i < line.length(); i++) { for(unsigned int i = 1; line[i] != ']' && i < line.length(); i++) {
tmpact += line[i]; tmpact += line[i];
} }
if(tmpact == "server" || tmpact == "modinfo") { if(tmpact == "server" || tmpact == "modinfo") {
@ -126,18 +129,20 @@ ModList::ModList(ModListDescription mld) {
} }
} }
} }
cout << "Got all modinfo descriptions from " << _desc.getName() << ", downloading and parsing modinfos..." << endl; std::cout << "Got all modinfo descriptions from " << _desc.getName() << ", downloading and parsing modinfos..." << std::endl;
for(unsigned int i = 0; i < _modinfos.size(); i++) { for(unsigned int i = 0; i < _modinfos.size(); i++) {
try { try {
ModInfo mi(_modinfos[i].getModInfoDescription()); ModInfo mi(_modinfos[i].getModInfoDescription());
cout << "Successfully downloaded and parsed: " << mi.getName() << endl; std::cout << "Successfully downloaded and parsed: " << mi.getName() << std::endl;
_modinfos[i] = mi; _modinfos[i] = mi;
} catch(NetSocketPP::NetworkException &exc) { } catch(NetSocketPP::NetworkException &exc) {
cerr << "NetworkException occured in NetSocket++: " << exc.what() << endl; std::cerr << "NetworkException occured in NetSocket++: " << exc.what() << std::endl;
} catch(NetSocketPP::SocketException &exc) { } catch(NetSocketPP::SocketException &exc) {
cerr << "SocketException occured in NetSocket++: " << exc.what() << endl; std::cerr << "SocketException occured in NetSocket++: " << exc.what() << std::endl;
} catch(ParseException &exc) { } catch(ParseException &exc) {
cerr << "ParseException occured: " << exc.what() << endl; std::cerr << "ParseException occured: " << exc.what() << std::endl;
} catch(BadResponseException &exc) {
std::cerr << "BadResponseException occured: " << exc.what() << std::endl;
} }
} }
} }
@ -150,7 +155,7 @@ ModList::ModList(std::string path) {
_localPath = path; _localPath = path;
_modinfosIterator = -1; _modinfosIterator = -1;
_modinfosAtEnd = false; _modinfosAtEnd = false;
ifstream modlist(_localPath.c_str()); std::ifstream modlist(_localPath.c_str());
if(!modlist) { if(!modlist) {
throw FileException(_localPath, "reading", "Could not open file!"); throw FileException(_localPath, "reading", "Could not open file!");
} }
@ -169,7 +174,7 @@ ModList::ModList(std::string path) {
if(line[0] != NULL && line[0] != ' ' && line[0] != '\n' && line[0] != '\r') { if(line[0] != NULL && line[0] != ' ' && line[0] != '\n' && line[0] != '\r') {
if(action == "detect") { if(action == "detect") {
if(line[0] == '{') { if(line[0] == '{') {
string name = ""; std::string name = "";
for(unsigned int i = 1; line[i] != '}' && i < line.length(); i++) { for(unsigned int i = 1; line[i] != '}' && i < line.length(); i++) {
name += line[i]; name += line[i];
} }
@ -201,8 +206,8 @@ ModList::ModList(std::string path) {
throw ParseException(_localPath, msg); throw ParseException(_localPath, msg);
} }
} else if(line[0] == '[') { } else if(line[0] == '[') {
string tmpact = ""; std::string tmpact = "";
for(int i = 1; line[i] != ']' && i < line.length(); i++) { for(unsigned int i = 1; line[i] != ']' && i < line.length(); i++) {
tmpact += line[i]; tmpact += line[i];
} }
if(tmpact == "server" || tmpact == "modinfo") { if(tmpact == "server" || tmpact == "modinfo") {
@ -286,7 +291,7 @@ ModInfo ModList::getNextModInfo() {
ModInfo ModList::getModInfoByName(std::string name) { ModInfo ModList::getModInfoByName(std::string name) {
for(unsigned int i = 0; i < _modinfos.size(); i++) { for(unsigned int i = 0; i < _modinfos.size(); i++) {
if(_modinfos[i].getModInfoDescription().getName() == name) { if(_modinfos[i].getModInfoDescription().getName() == name) {
return modinfos[i]; return _modinfos[i];
} }
} }
static ModInfo emptymi; static ModInfo emptymi;
@ -303,9 +308,11 @@ void ModList::insertModInfoDescription(ModInfoDescription mid) {
} }
void ModList::deleteModInfo(std::string name) { void ModList::deleteModInfo(std::string name) {
for(std::vector<ModInfo>::iterator i = _modinfos.begin; i != _modinfos.end(); i++) { for(std::vector<ModInfo>::iterator i = _modinfos.begin(); i != _modinfos.end(); i++) {
if((i -> getModInfoDescription()).getName() == name) { mmm::ModInfoDescription mid = i -> getModInfoDescription();
if(mid.getName() == name) {
_modinfos.erase(i); _modinfos.erase(i);
return;
} }
} }
} }
@ -325,13 +332,22 @@ void ModList::write() {
if(!_edit) { if(!_edit) {
throw NonEditableException("Tried to write back remotely obtained modlist file!"); throw NonEditableException("Tried to write back remotely obtained modlist file!");
} }
ofstream modlist(_localPath.c_str()); std::ofstream modlist(_localPath.c_str());
if(!ofstream) { if(!modlist) {
throw FileException(_localPath, "writing", "Could not open file!"); throw FileException(_localPath, "writing", "Could not open file!");
} }
for(unsigned int i = 0; i < _modinfos.size(); i++) { for(unsigned int i = 0; i < _modinfos.size(); i++) {
ModInfoDescription mid = _modinfos[i].getModInfoDescription(); ModInfoDescription mid = _modinfos[i].getModInfoDescription();
modlist << "{" << mid.getName() << "}" << endl << "[server]" << endl << mid.getServer() << endl << "[modinfo]" << endl << mid.getPath() << endl << "{end}" << endl; modlist << "{" << mid.getName() << "}" << std::endl << "[server]" << std::endl << mid.getServer() << std::endl << "[modinfo]" << std::endl << mid.getPath() << std::endl << "{end}" << std::endl;
} }
modlist.close(); modlist.close();
} }
ModListDescription ModList::getModListDescription() {
return _desc;
}
void ModList::setPath(std::string path) {
_localPath = path;
_edit = true;
}

View File

@ -47,6 +47,10 @@ public:
///< \return True if modlist iterator reached its end, false otherwise. ///< \return True if modlist iterator reached its end, false otherwise.
void write(); ///< A function that writes modlist to local file. void write(); ///< A function that writes modlist to local file.
void clear(); ///< A function that clears the object. void clear(); ///< A function that clears the object.
ModListDescription getModListDescription(); ///< \brief A function that gets a ModListDescription object.
///< \return A ModListDescription object.
void setPath(std::string path); ///< \brief A function that sets path to local modlist file.
///< \param path A path to local modlist file.
}; };
} }
#endif #endif

View File

@ -1,5 +1,5 @@
ModDescription: name, description, release, deps, repotype, repoaddr x ModDescription: name, description, release, deps, repotype, repoaddr x
ModList: ModListDescription, vector<ModInfoDescription> t ModList: ModListDescription, vector<ModInfo> x
ModListList: vector<ModListDescription> x ModListList: vector<ModListDescription> x
LocalModDescription: ModDescription + remoteModlist (inheritance) x LocalModDescription: ModDescription + remoteModlist (inheritance) x
LocalModList: vector<LocalModDescription>, ConfigFile x LocalModList: vector<LocalModDescription>, ConfigFile x

View File

@ -7,6 +7,7 @@ all:
${CXX} ${CXXFLAGS} -o LocalModListTest LocalModListTest.cpp ../LocalModList.cpp ../LocalModDescription.cpp ../ModDescription.cpp ../3mExceptions.cpp ../ConfigFile.cpp ${CXX} ${CXXFLAGS} -o LocalModListTest LocalModListTest.cpp ../LocalModList.cpp ../LocalModDescription.cpp ../ModDescription.cpp ../3mExceptions.cpp ../ConfigFile.cpp
${CXX} ${CXXFLAGS} -o RepositoryInfoTest RepositoryInfoTest.cpp ../RepositoryModDescription.cpp ../ModDescription.cpp ../3mExceptions.cpp ../ConfigFile.cpp ../RepositoryInfo.cpp ${CXX} ${CXXFLAGS} -o RepositoryInfoTest RepositoryInfoTest.cpp ../RepositoryModDescription.cpp ../ModDescription.cpp ../3mExceptions.cpp ../ConfigFile.cpp ../RepositoryInfo.cpp
${CXX} ${CXXFLAGS} -o ModInfoTest ModInfoTest.cpp ../ModInfo.cpp ../ModInfoDescription.cpp ../ModDescription.cpp ../3mExceptions.cpp -lnetsocketpp ${CXX} ${CXXFLAGS} -o ModInfoTest ModInfoTest.cpp ../ModInfo.cpp ../ModInfoDescription.cpp ../ModDescription.cpp ../3mExceptions.cpp -lnetsocketpp
${CXX} ${CXXFLAGS} -o ModListTest ModListTest.cpp ../ModList.cpp ../ModListDescription.cpp ../ModInfo.cpp ../ModInfoDescription.cpp ../ModDescription.cpp ../3mExceptions.cpp -lnetsocketpp
debug: debug:
${CXX} ${CXXFLAGS} -o ConfigFileTest ConfigFileTest.cpp ../ConfigFile.cpp ../3mExceptions.cpp -g ${CXX} ${CXXFLAGS} -o ConfigFileTest ConfigFileTest.cpp ../ConfigFile.cpp ../3mExceptions.cpp -g
${CXX} ${CXXFLAGS} -o ModDescriptionTest ModDescriptionTest.cpp ../ModDescription.cpp -g ${CXX} ${CXXFLAGS} -o ModDescriptionTest ModDescriptionTest.cpp ../ModDescription.cpp -g
@ -15,5 +16,6 @@ debug:
${CXX} ${CXXFLAGS} -o LocalModListTest LocalModListTest.cpp ../LocalModList.cpp ../LocalModDescription.cpp ../ModDescription.cpp ../3mExceptions.cpp ../ConfigFile.cpp -g ${CXX} ${CXXFLAGS} -o LocalModListTest LocalModListTest.cpp ../LocalModList.cpp ../LocalModDescription.cpp ../ModDescription.cpp ../3mExceptions.cpp ../ConfigFile.cpp -g
${CXX} ${CXXFLAGS} -o RepositoryInfoTest RepositoryInfoTest.cpp ../RepositoryModDescription.cpp ../ModDescription.cpp ../3mExceptions.cpp ../ConfigFile.cpp ../RepositoryInfo.cpp -g ${CXX} ${CXXFLAGS} -o RepositoryInfoTest RepositoryInfoTest.cpp ../RepositoryModDescription.cpp ../ModDescription.cpp ../3mExceptions.cpp ../ConfigFile.cpp ../RepositoryInfo.cpp -g
${CXX} ${CXXFLAGS} -o ModInfoTest ModInfoTest.cpp ../ModInfo.cpp ../ModInfoDescription.cpp ../ModDescription.cpp ../3mExceptions.cpp -lnetsocketpp -g ${CXX} ${CXXFLAGS} -o ModInfoTest ModInfoTest.cpp ../ModInfo.cpp ../ModInfoDescription.cpp ../ModDescription.cpp ../3mExceptions.cpp -lnetsocketpp -g
${CXX} ${CXXFLAGS} -o ModListTest ModListTest.cpp ../ModList.cpp ../ModListDescription.cpp ../ModInfo.cpp ../ModInfoDescription.cpp ../ModDescription.cpp ../3mExceptions.cpp -lnetsocketpp -g
clean: clean:
rm -rf ConfigFileTest ModDescriptionTest LocalModDescriptionTest ModListListTest LocalModListTest RepositoryInfoTest ModInfoTest rm -rf ConfigFileTest ModDescriptionTest LocalModDescriptionTest ModListListTest LocalModListTest RepositoryInfoTest ModInfoTest ModListTest

209
tests/ModListTest.cpp Normal file
View File

@ -0,0 +1,209 @@
#include "../ModList.h"
#include "../ModInfo.h"
#include "NetSocket++/NetSocketPP.h"
#include "../ModListDescription.h"
#include "../ModInfoDescription.h"
#include "../ModDescription.h"
#include <iostream>
#include <cstdlib>
using namespace std;
int main() {
char mode;
cout << "Select mode: Download, parse and list (r)emote modlist file, Open and parse (l)ocal modlist file, Create (n)ew local modlist file: ";
cin >> mode;
if(mode == 'r') {
string server;
string path;
cout << "Enter server of remote modlist: ";
cin >> server;
cout << "Enter path to the remote modlist on the server: ";
cin >> path;
try {
mmm::ModListDescription mld("test", server, path);
mmm::ModList ml(mld);
mld = ml.getModListDescription();
cout << "Got modlist: " << mld.getName() << "!" << endl << "server: " << mld.getServer() << endl << "path: " << mld.getPath() << endl << "Content: " << endl;
ml.resetModInfoIterator();
while(!ml.modinfosEnd()) {
mmm::ModInfo mi = ml.getNextModInfo();
if(mi.getModInfoDescription().getName() != "" && mi.getModInfoDescription().getServer() != "" && mi.getModInfoDescription().getPath() != "") {
cout << "Modinfo: " << endl << "name: " << mi.getModInfoDescription().getName() << endl << "server: " << mi.getModInfoDescription().getServer() << endl << "path: " << mi.getModInfoDescription().getPath() << endl;
if(mi.getName() != "" && mi.getDescription() != "" && mi.getReleaseNr() > 0 && mi.getRepositoryType() != "" && mi.getRepositoryAddress() != "") {
cout << "Mod description: " << endl << "name: " << mi.getName() << endl << "description: " << mi.getDescription() << endl << "release: " << mi.getReleaseNr() << endl << "dependencies:" << endl;
mi.resetDependencyIterator();
while(!mi.dependenciesEnd()) {
string dep = mi.getNextDependency();
if(dep != "") {
cout << dep << endl;
}
}
cout << "repository type: " << mi.getRepositoryType() << endl << "repository address: " << mi.getRepositoryAddress() << endl;
} else {
cout << "No mod information!" << endl;
}
}
cout << endl;
}
} catch(NetSocketPP::NetworkException &exc) {
cerr << "NetworkException occured in NetSocket++: " << exc.what() << "! Exiting..." << endl;
return EXIT_FAILURE;
} catch(NetSocketPP::SocketException &exc) {
cerr << "SocketException occured in NetSocket++: " << exc.what() << "! Exiting..." << endl;
return EXIT_FAILURE;
} catch(mmm::ParseException &exc) {
cerr << "ParseException occured: " << exc.what() << "! That probably means you have badly formatted modlist file! Exiting..." << endl;
return EXIT_FAILURE;
} catch(mmm::BadResponseException &exc) {
cerr << "BadResponseException occured: " << exc.what() << "! That probably means you have given wrong path to the file on the server! Exiting..." << endl;
}
cout << "All OK!" << endl;
} else if(mode == 'l') {
string path;
cout << "Enter path: ";
cin >> path;
try {
mmm::ModList ml(path);
char action;
do {
cout << "Select action: (l)ist modlist, (f)ind by name and list, (a)dd modinfo description, (d)elete modinfo description, (s)ave and exit, (q)uit without saving: ";
cin >> action;
if(action == 'l') {
mmm::ModListDescription mld = ml.getModListDescription();
cout << "Modlist name: " << mld.getName() << endl << "server: " << mld.getServer() << endl << "path: " << mld.getPath() << endl << "Content: " << endl;
ml.resetModInfoIterator();
while(!ml.modinfosEnd()) {
mmm::ModInfo mi = ml.getNextModInfo();
if(mi.getModInfoDescription().getName() != "" && mi.getModInfoDescription().getServer() != "" && mi.getModInfoDescription().getPath() != "") {
cout << "Modinfo: " << endl << "name: " << mi.getModInfoDescription().getName() << endl << "server: " << mi.getModInfoDescription().getServer() << endl << "path: " << mi.getModInfoDescription().getPath() << endl;
}
}
} else if(action == 'f') {
string name;
cout << "Modinfo name: ";
cin >> name;
mmm::ModInfo mi = ml.getModInfoByName(name);
if(mi.getModInfoDescription().getName() != "" && mi.getModInfoDescription().getServer() != "" && mi.getModInfoDescription().getPath() != "") {
cout << "name: " << mi.getModInfoDescription().getName() << endl << "server: " << mi.getModInfoDescription().getServer() << endl << "path: " << mi.getModInfoDescription().getPath() << endl;
} else {
cout << name << " not found!" << endl;
}
} else if(action == 'a') {
string name, server, path;
cout << "name: ";
cin >> name;
cout << "server: ";
cin >> server;
cout << "path: ";
cin >> path;
if(name != "" && server != "" && path != "") {
mmm::ModInfoDescription mid(name, server, path);
ml.insertModInfoDescription(mid);
} else {
cerr << "Cannot insert empty field!" << endl;
}
} else if(action == 'd') {
string name;
cout << "Modinfo name: ";
cin >> name;
mmm::ModInfo mi = ml.getModInfoByName(name);
if(mi.getModInfoDescription().getName() != "" && mi.getModInfoDescription().getServer() != "" && mi.getModInfoDescription().getPath() != "") {
ml.deleteModInfo(name);
} else {
cout << name << " not found!" << endl;
}
} else if(action != 's' && action != 'q') {
cerr << "Unknown action!" << endl;
}
} while(action != 's' && action != 'q');
if(action == 's') {
ml.write();
}
cout << "All OK!" << endl;
} catch(mmm::FileException &exc) {
cerr << "FileException occured: " << exc.what() << "! That probably means you entered wrong path! Exiting..." << endl;
return EXIT_FAILURE;
} catch(mmm::ParseException &exc) {
cerr << "ParseException occured: " << exc.what() << "! That probably means your modinfo file is badly formatted! Exiting..." << endl;
return EXIT_FAILURE;
} catch(mmm::NonEditableException &exc) {
cerr << "NonEditableException occured: " << exc.what() << "! Exiting..." << endl;
}
} else if(mode == 'n') {
string path;
cout << "Enter path: ";
cin >> path;
try {
mmm::ModList ml;
ml.setPath(path);
char action;
do {
cout << "Select action: (l)ist modlist, (f)ind by name and list, (a)dd modinfo description, (d)elete modinfo description, (s)ave and exit, (q)uit without saving: ";
cin >> action;
if(action == 'l') {
mmm::ModListDescription mld = ml.getModListDescription();
cout << "Modlist name: " << mld.getName() << endl << "server: " << mld.getServer() << endl << "path: " << mld.getPath() << endl << "Content: " << endl;
ml.resetModInfoIterator();
while(!ml.modinfosEnd()) {
mmm::ModInfo mi = ml.getNextModInfo();
if(mi.getModInfoDescription().getName() != "" && mi.getModInfoDescription().getServer() != "" && mi.getModInfoDescription().getPath() != "") {
cout << "Modinfo: " << endl << "name: " << mi.getModInfoDescription().getName() << endl << "server: " << mi.getModInfoDescription().getServer() << endl << "path: " << mi.getModInfoDescription().getPath() << endl;
}
}
} else if(action == 'f') {
string name;
cout << "Modinfo name: ";
cin >> name;
mmm::ModInfo mi = ml.getModInfoByName(name);
if(mi.getModInfoDescription().getName() != "" && mi.getModInfoDescription().getServer() != "" && mi.getModInfoDescription().getPath() != "") {
cout << "name: " << mi.getModInfoDescription().getName() << endl << "server: " << mi.getModInfoDescription().getServer() << endl << "path: " << mi.getModInfoDescription().getPath() << endl;
} else {
cout << name << " not found!" << endl;
}
} else if(action == 'a') {
string name, server, path;
cout << "name: ";
cin >> name;
cout << "server: ";
cin >> server;
cout << "path: ";
cin >> path;
if(name != "" && server != "" && path != "") {
mmm::ModInfoDescription mid(name, server, path);
ml.insertModInfoDescription(mid);
} else {
cerr << "Cannot insert empty field!" << endl;
}
} else if(action == 'd') {
string name;
cout << "Modinfo name: ";
cin >> name;
mmm::ModInfo mi = ml.getModInfoByName(name);
if(mi.getModInfoDescription().getName() != "" && mi.getModInfoDescription().getServer() != "" && mi.getModInfoDescription().getPath() != "") {
ml.deleteModInfo(name);
} else {
cout << name << "not found!" << endl;
}
} else if(action != 's' && action != 'q') {
cerr << "Unknown action!" << endl;
}
} while(action != 's' && action != 'q');
if(action == 's') {
ml.write();
}
cout << "All OK!" << endl;
} catch(mmm::FileException &exc) {
cerr << "FileException occured: " << exc.what() << "! That probably means you entered wrong path! Exiting..." << endl;
return EXIT_FAILURE;
} catch(mmm::ParseException &exc) {
cerr << "ParseException occured: " << exc.what() << "! That probably means your modinfo file is badly formatted! Exiting..." << endl;
return EXIT_FAILURE;
} catch(mmm::NonEditableException &exc) {
cerr << "NonEditableException occured: " << exc.what() << "! Exiting..." << endl;
}
} else {
cerr << "Unknown mode: " << mode << "! Exiting..." << endl;
return EXIT_FAILURE;
}
return EXIT_SUCCESS;
}