summaryrefslogtreecommitdiffstats
path: root/Project/FileHanding.h
diff options
context:
space:
mode:
authorThales1330 <thaleslima.ufu@gmail.com>2016-12-15 17:24:24 -0200
committerGitHub <noreply@github.com>2016-12-15 17:24:24 -0200
commit28e9cc4d9df63cb12c01d49017172c5f39ca9c22 (patch)
tree7896e1bb7cc5f42751c5d31ec99ba2bdf19d6f6c /Project/FileHanding.h
parentcff8d90d61be4d34f5e84e8dd0933f678e6214be (diff)
parent5cdfee44e75b9a3635350aa261818e0a3bb44c5f (diff)
downloadPSP.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.h47
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