diff options
author | Thales1330 <thaleslima.ufu@gmail.com> | 2016-12-15 17:24:24 -0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-12-15 17:24:24 -0200 |
commit | 28e9cc4d9df63cb12c01d49017172c5f39ca9c22 (patch) | |
tree | 7896e1bb7cc5f42751c5d31ec99ba2bdf19d6f6c /Project/FileHanding.h | |
parent | cff8d90d61be4d34f5e84e8dd0933f678e6214be (diff) | |
parent | 5cdfee44e75b9a3635350aa261818e0a3bb44c5f (diff) | |
download | PSP.git-28e9cc4d9df63cb12c01d49017172c5f39ca9c22.tar.gz PSP.git-28e9cc4d9df63cb12c01d49017172c5f39ca9c22.tar.xz PSP.git-28e9cc4d9df63cb12c01d49017172c5f39ca9c22.zip |
Merge pull request #3 from Thales1330/wip/save-load-xml
Wip/save load xml
Diffstat (limited to 'Project/FileHanding.h')
-rw-r--r-- | Project/FileHanding.h | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/Project/FileHanding.h b/Project/FileHanding.h new file mode 100644 index 0000000..ba95177 --- /dev/null +++ b/Project/FileHanding.h @@ -0,0 +1,47 @@ +#ifndef FILEHANDING_H +#define FILEHANDING_H + +#include <wx/string.h> +#include <fstream> +#include <sstream> + +#include "Workspace.h" +#include "ElectricCalculation.h" +#include "Text.h" + +#include "rapidXML/rapidxml.hpp" +// Modified: http://stackoverflow.com/questions/14113923/rapidxml-print-header-has-undefined-methods +#include "rapidXML/rapidxml_print.hpp" +#include "rapidXML/rapidxml_utils.hpp" + +class FileHanding +{ +public: + FileHanding(); + FileHanding(Workspace* workspace); + ~FileHanding(); + + void SetWorkspace(Workspace* workspace) { m_workspace = workspace; } + + void SaveProject(wxFileName path); + bool OpenProject(wxFileName path); + +protected: + Workspace* m_workspace; + + rapidxml::xml_node<>* AppendNode(rapidxml::xml_document<>& doc, + rapidxml::xml_node<>* parentNode, + const char* name, + rapidxml::node_type nodeType = rapidxml::node_element); + void SetNodeValue(rapidxml::xml_document<>& doc, rapidxml::xml_node<>* node, wxString value); + void SetNodeValue(rapidxml::xml_document<>& doc, rapidxml::xml_node<>* node, int value); + void SetNodeValue(rapidxml::xml_document<>& doc, rapidxml::xml_node<>* node, double value); + void SetNodeAttribute(rapidxml::xml_document<>& doc, rapidxml::xml_node<>* node, const char* atrName, wxString value); + void SetNodeAttribute(rapidxml::xml_document<>& doc, rapidxml::xml_node<>* node, const char* atrName, int value); + void SetNodeAttribute(rapidxml::xml_document<>& doc, rapidxml::xml_node<>* node, const char* atrName, double value); + double GetNodeValueDouble(rapidxml::xml_node<>* parent, const char* nodeName); + int GetNodeValueInt(rapidxml::xml_node<>* parent, const char* nodeName); + int GetAttributeValueInt(rapidxml::xml_node<>* parent, const char* nodeName, const char* atrName); +}; + +#endif // FILEHANDING_H |