aboutsummaryrefslogtreecommitdiffstats
path: root/tests/libsample/simplefile.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tests/libsample/simplefile.cpp')
-rw-r--r--tests/libsample/simplefile.cpp57
1 files changed, 49 insertions, 8 deletions
diff --git a/tests/libsample/simplefile.cpp b/tests/libsample/simplefile.cpp
index c79152bac..1dc378acd 100644
--- a/tests/libsample/simplefile.cpp
+++ b/tests/libsample/simplefile.cpp
@@ -32,18 +32,59 @@
* 02110-1301 USA
*/
+#include <stdlib.h>
+#include <string.h>
#include <fstream>
#include "simplefile.h"
+class SimpleFile_p
+{
+public:
+ SimpleFile_p(const char* filename) : m_descriptor(0), m_size(0)
+ {
+ m_filename = strdup(filename);
+ }
+
+ ~SimpleFile_p()
+ {
+ free(m_filename);
+ }
+
+ char* m_filename;
+ FILE* m_descriptor;
+ long m_size;
+};
+
+SimpleFile::SimpleFile(const char* filename)
+{
+ p = new SimpleFile_p(filename);
+}
+
+SimpleFile::~SimpleFile()
+{
+ close();
+ delete p;
+}
+
+const char* SimpleFile::filename()
+{
+ return p->m_filename;
+}
+
+long SimpleFile::size()
+{
+ return p->m_size;
+}
+
bool
SimpleFile::open()
{
- if ((m_descriptor = fopen(m_filename, "rb")) == 0)
+ if ((p->m_descriptor = fopen(p->m_filename, "rb")) == 0)
return false;
- fseek(m_descriptor, 0, SEEK_END);
- m_size = ftell(m_descriptor);
- rewind(m_descriptor);
+ fseek(p->m_descriptor, 0, SEEK_END);
+ p->m_size = ftell(p->m_descriptor);
+ rewind(p->m_descriptor);
return true;
}
@@ -51,16 +92,16 @@ SimpleFile::open()
void
SimpleFile::close()
{
- if (m_descriptor) {
- fclose(m_descriptor);
- m_descriptor = 0;
+ if (p->m_descriptor) {
+ fclose(p->m_descriptor);
+ p->m_descriptor = 0;
}
}
bool
SimpleFile::exists() const
{
- std::ifstream ifile(m_filename);
+ std::ifstream ifile(p->m_filename);
return ifile;
}