#include "document.h"
+#include <cstdio>
+
using namespace IPDF;
using namespace std;
+void Document::Save(const string & filename)
+{
+ Debug("Saving document to file \"%s\"...", filename.c_str());
+ FILE * file = fopen(filename.c_str(), "w");
+ if (file == NULL)
+ Fatal("Couldn't open file \"%s\" - %s", filename.c_str(), strerror(errno));
+
+ size_t written;
+ Debug("Number of objects (%u)...", ObjectCount());
+ written = fwrite(&m_count, sizeof(m_count), 1, file);
+ if (written != 1)
+ Fatal("Failed to write number of objects!");
+
+ Debug("Object bounds...");
+ written = fwrite(m_objects.bounds.data(), sizeof(Rect), m_objects.bounds.size(), file);
+ if (written != ObjectCount())
+ Fatal("Only wrote %u objects!", written);
+
+ int err = fclose(file);
+ if (err != 0)
+ Fatal("Failed to close file \"%s\" - %s", filename.c_str(), strerror(err));
+
+ Debug("Successfully saved %u objects to \"%s\"", ObjectCount(), filename.c_str());
+}
+
void Document::Load(const string & filename)
{
m_objects.bounds.clear();
m_count = 0;
if (filename == "")
+ {
+ Debug("Loaded empty document.");
return;
+ }
+ Debug("Loading document from file \"%s\"", filename.c_str());
+ FILE * file = fopen(filename.c_str(), "r");
+ if (file == NULL)
+ Fatal("Couldn't open file \"%s\"", filename.c_str(), strerror(errno));
+
+ size_t read;
+ read = fread(&m_count, sizeof(m_count), 1, file);
+ if (read != 1)
+ Fatal("Failed to read number of objects!");
+ Debug("Number of objects: %u", ObjectCount());
+
+ m_objects.bounds.resize(ObjectCount());
+
+ Debug("Object bounds...");
+ read = fread(m_objects.bounds.data(), sizeof(Rect), m_objects.bounds.size(), file);
+ if (read != ObjectCount())
+ Fatal("Only read %u objects!", read);
+
+ Debug("Successfully loaded %u objects from \"%s\"", ObjectCount(), filename.c_str());
}
void Document::Add(Real x, Real y, Real w, Real h)
m_objects.bounds.push_back(Rect(x, y, w, h));
m_count++;
}
+
+void Document::DebugDumpObjects()
+{
+ Debug("Objects for Document %p are:", this);
+ for (unsigned id = 0; id < ObjectCount(); ++id)
+ {
+ Debug("%u.\t%s", id, m_objects.bounds[id].Str().c_str());
+ }
+}
+
+bool Document::operator==(const Document & equ) const
+{
+ return (ObjectCount() == equ.ObjectCount() && memcmp(m_objects.bounds.data(), equ.m_objects.bounds.data(), ObjectCount() * sizeof(Rect)) == 0);
+}
class Document
{
public:
- Document() : m_objects(), m_count(0) {Load();}
+ Document(const std::string & filename = "") : m_objects(), m_count(0) {Load(filename);}
virtual ~Document() {}
void Load(const std::string & filename = "");
+ void Save(const std::string & filename);
void Add(Real x, Real y, Real w, Real h);
+ void DebugDumpObjects();
- unsigned ObjectCount() {return m_count;}
+ unsigned ObjectCount() const {return m_count;}
+
+ bool operator==(const Document & equ) const;
+ bool operator!=(const Document & equ) const {return !(this->operator==(equ));}
private:
friend class View;
typedef float Real;
inline float RealToFloat(Real r) {return r;}
+ inline Real Random(Real max=1, Real min=0)
+ {
+ return min + (max-min) * ((Real)(rand() % (int)1e6) / 1e6);
+ }
typedef unsigned ObjectID;
struct Rect
{
Real x; Real y; Real w; Real h;
+ Rect() = default; // Needed so we can fread/fwrite this struct
Rect(Real _x, Real _y, Real _w, Real _h) : x(_x), y(_y), w(_w), h(_h) {}
std::string Str()
{
--- /dev/null
+#include "../common.h"
+
+#include "../document.h"
+#include "../view.h"
+
+using namespace std;
+using namespace IPDF;
+
+unsigned test_objects = 4;
+
+int main(int argc, char ** argv)
+{
+ srand(time(NULL));
+ Document doc;
+ for (unsigned id = 0; id < test_objects; ++id)
+ {
+ doc.Add(Random(), Random(), Random(), Random());
+ }
+ doc.Save("test.ipdf");
+
+ Document equ("test.ipdf");
+ //doc.Add(Random(), Random(), Random(), Random());
+ if (doc != equ || equ != doc)
+ {
+ Error("Loaded document is not equivelant to saved document!");
+ doc.DebugDumpObjects();
+ equ.DebugDumpObjects();
+ }
+
+
+ return 0;
+}