AlexVinS пре 9 година
родитељ
комит
a3f0d1a94e
2 измењених фајлова са 40 додато и 44 уклоњено
  1. 30 34
      lib/filesystem/MinizipExtensions.cpp
  2. 10 10
      lib/filesystem/MinizipExtensions.h

+ 30 - 34
lib/filesystem/MinizipExtensions.cpp

@@ -11,28 +11,28 @@
 #include "MinizipExtensions.h"
 #include "MinizipExtensions.h"
 
 
 #include "CMemoryBuffer.h"
 #include "CMemoryBuffer.h"
-
+#include "FileStream.h"
 
 
 ///CIOApi
 ///CIOApi
 voidpf ZCALLBACK CIOApi::openFileProxy(voidpf opaque, const void * filename, int mode)
 voidpf ZCALLBACK CIOApi::openFileProxy(voidpf opaque, const void * filename, int mode)
 {
 {
 	assert(opaque != nullptr);
 	assert(opaque != nullptr);
-	
-	std::string filename_s;
-	
+
+	boost::filesystem::path path;
+
 	if(filename != nullptr)
 	if(filename != nullptr)
-		filename_s = (const char *)filename;
-	
-	return ((CIOApi *)opaque)->openFile(filename_s, mode);
+		path =  static_cast<const boost::filesystem::path::value_type *>(filename);
+
+	return ((CIOApi *)opaque)->openFile(path, mode);
 }
 }
 
 
 uLong ZCALLBACK CIOApi::readFileProxy(voidpf opaque, voidpf stream, void * buf, uLong size)
 uLong ZCALLBACK CIOApi::readFileProxy(voidpf opaque, voidpf stream, void * buf, uLong size)
 {
 {
 	assert(opaque != nullptr);
 	assert(opaque != nullptr);
 	assert(stream != nullptr);
 	assert(stream != nullptr);
-	
+
 	CInputOutputStream * actualStream = static_cast<CInputOutputStream *>(stream);
 	CInputOutputStream * actualStream = static_cast<CInputOutputStream *>(stream);
-	
+
 	return actualStream->read((ui8 *)buf, size);
 	return actualStream->read((ui8 *)buf, size);
 }
 }
 
 
@@ -49,8 +49,8 @@ ZPOS64_T ZCALLBACK CIOApi::tellFileProxy(voidpf opaque, voidpf stream)
 {
 {
 	assert(opaque != nullptr);
 	assert(opaque != nullptr);
 	assert(stream != nullptr);
 	assert(stream != nullptr);
-	
-	CInputOutputStream * actualStream = static_cast<CInputOutputStream *>(stream);	
+
+	CInputOutputStream * actualStream = static_cast<CInputOutputStream *>(stream);
     return actualStream->tell();
     return actualStream->tell();
 }
 }
 
 
@@ -58,8 +58,8 @@ long ZCALLBACK CIOApi::seekFileProxy(voidpf  opaque, voidpf stream, ZPOS64_T off
 {
 {
 	assert(opaque != nullptr);
 	assert(opaque != nullptr);
 	assert(stream != nullptr);
 	assert(stream != nullptr);
-		
-	CInputOutputStream * actualStream = static_cast<CInputOutputStream *>(stream);	
+
+	CInputOutputStream * actualStream = static_cast<CInputOutputStream *>(stream);
 
 
     long ret = 0;
     long ret = 0;
     switch (origin)
     switch (origin)
@@ -73,7 +73,7 @@ long ZCALLBACK CIOApi::seekFileProxy(voidpf  opaque, voidpf stream, ZPOS64_T off
     		const si64 pos = actualStream->getSize() - offset;
     		const si64 pos = actualStream->getSize() - offset;
     		if(actualStream->seek(pos) != pos)
     		if(actualStream->seek(pos) != pos)
 				ret = -1;
 				ret = -1;
-    	}    	
+    	}
         break;
         break;
     case ZLIB_FILEFUNC_SEEK_SET :
     case ZLIB_FILEFUNC_SEEK_SET :
 		if(actualStream->seek(offset) != offset)
 		if(actualStream->seek(offset) != offset)
@@ -82,7 +82,7 @@ long ZCALLBACK CIOApi::seekFileProxy(voidpf  opaque, voidpf stream, ZPOS64_T off
     default: ret = -1;
     default: ret = -1;
     }
     }
     if(ret == -1)
     if(ret == -1)
-		logGlobal->error("CIOApi::seekFileProxy: seek failed");			
+		logGlobal->error("CIOApi::seekFileProxy: seek failed");
     return ret;
     return ret;
 }
 }
 
 
@@ -90,11 +90,11 @@ int ZCALLBACK CIOApi::closeFileProxy(voidpf opaque, voidpf stream)
 {
 {
 	assert(opaque != nullptr);
 	assert(opaque != nullptr);
 	assert(stream != nullptr);
 	assert(stream != nullptr);
-		
+
 	CInputOutputStream * actualStream = static_cast<CInputOutputStream *>(stream);
 	CInputOutputStream * actualStream = static_cast<CInputOutputStream *>(stream);
-	
+
 	((CIOApi *)opaque)->closeFile(actualStream);
 	((CIOApi *)opaque)->closeFile(actualStream);
-	
+
     return 0;
     return 0;
 }
 }
 
 
@@ -113,8 +113,8 @@ zlib_filefunc64_def CIOApi::getApiStructure() const
 	api.ztell64_file = &tellFileProxy;
 	api.ztell64_file = &tellFileProxy;
 	api.zseek64_file = &seekFileProxy;
 	api.zseek64_file = &seekFileProxy;
 	api.zclose_file = &closeFileProxy;
 	api.zclose_file = &closeFileProxy;
-	api.zerror_file = &errorFileProxy;	
-	
+	api.zerror_file = &errorFileProxy;
+
 	return api;
 	return api;
 }
 }
 
 
@@ -126,44 +126,40 @@ void CIOApi::closeFile(CInputOutputStream * stream) const
 ///CDefaultIOApi
 ///CDefaultIOApi
 CDefaultIOApi::CDefaultIOApi()
 CDefaultIOApi::CDefaultIOApi()
 {
 {
-	
+
 }
 }
 
 
 CDefaultIOApi::~CDefaultIOApi()
 CDefaultIOApi::~CDefaultIOApi()
 {
 {
-	
+
 }
 }
 
 
 zlib_filefunc64_def CDefaultIOApi::getApiStructure() const
 zlib_filefunc64_def CDefaultIOApi::getApiStructure() const
 {
 {
-	zlib_filefunc64_def api;
-	
-	fill_fopen64_filefunc(&api);
-	
-	return api;	
+	return * FileStream::GetMinizipFilefunc();
 }
 }
 
 
-CInputOutputStream * CDefaultIOApi::openFile(const std::string& filename, int mode) const
+CInputOutputStream * CDefaultIOApi::openFile(const boost::filesystem::path & filename, int mode) const
 {
 {
-	throw new std::runtime_error("CDefaultIOApi::openFile call not expected.");	
+	throw new std::runtime_error("CDefaultIOApi::openFile call not expected.");
 }
 }
 
 
 ///CProxyIOApi
 ///CProxyIOApi
 CProxyIOApi::CProxyIOApi(CInputOutputStream * buffer):
 CProxyIOApi::CProxyIOApi(CInputOutputStream * buffer):
 	data(buffer)
 	data(buffer)
 {
 {
-	
+
 }
 }
 
 
 CProxyIOApi::~CProxyIOApi()
 CProxyIOApi::~CProxyIOApi()
 {
 {
-	
+
 }
 }
 
 
-CInputOutputStream * CProxyIOApi::openFile(const std::string& filename, int mode) const
+CInputOutputStream * CProxyIOApi::openFile(const boost::filesystem::path & filename, int mode) const
 {
 {
-	logGlobal->traceStream() << "CProxyIOApi: stream opened for " <<filename<<" with mode "<<mode; 
-	
+	logGlobal->traceStream() << "CProxyIOApi: stream opened for " <<filename.string() <<" with mode "<<mode;
+
 	data->seek(0);
 	data->seek(0);
 	return data;
 	return data;
 }
 }

+ 10 - 10
lib/filesystem/MinizipExtensions.h

@@ -27,20 +27,20 @@ class DLL_LINKAGE CIOApi
 {
 {
 public:
 public:
 	virtual ~CIOApi(){};
 	virtual ~CIOApi(){};
-	
+
 	virtual zlib_filefunc64_def getApiStructure() const;
 	virtual zlib_filefunc64_def getApiStructure() const;
 
 
-protected:	
-	virtual CInputOutputStream * openFile(const std::string & filename, int mode) const = 0;
-	
+protected:
+	virtual CInputOutputStream * openFile(const boost::filesystem::path & filename, int mode) const = 0;
+
 	///default implementation deletes stream object
 	///default implementation deletes stream object
 	virtual void closeFile(CInputOutputStream * stream) const;
 	virtual void closeFile(CInputOutputStream * stream) const;
-	
+
 private:
 private:
 	static voidpf ZCALLBACK openFileProxy(voidpf opaque, const void * filename, int mode);
 	static voidpf ZCALLBACK openFileProxy(voidpf opaque, const void * filename, int mode);
 	static uLong ZCALLBACK readFileProxy(voidpf opaque, voidpf stream, void * buf, uLong size);
 	static uLong ZCALLBACK readFileProxy(voidpf opaque, voidpf stream, void * buf, uLong size);
 	static uLong ZCALLBACK writeFileProxy(voidpf opaque, voidpf stream, const void * buf, uLong size);
 	static uLong ZCALLBACK writeFileProxy(voidpf opaque, voidpf stream, const void * buf, uLong size);
-	static ZPOS64_T ZCALLBACK tellFileProxy(voidpf opaque, voidpf stream);	
+	static ZPOS64_T ZCALLBACK tellFileProxy(voidpf opaque, voidpf stream);
 	static long ZCALLBACK seekFileProxy(voidpf  opaque, voidpf stream, ZPOS64_T offset, int origin);
 	static long ZCALLBACK seekFileProxy(voidpf  opaque, voidpf stream, ZPOS64_T offset, int origin);
 	static int ZCALLBACK closeFileProxy(voidpf opaque, voidpf stream);
 	static int ZCALLBACK closeFileProxy(voidpf opaque, voidpf stream);
 	static int ZCALLBACK errorFileProxy(voidpf opaque, voidpf stream);
 	static int ZCALLBACK errorFileProxy(voidpf opaque, voidpf stream);
@@ -53,11 +53,11 @@ class DLL_LINKAGE CDefaultIOApi: public CIOApi
 public:
 public:
 	CDefaultIOApi();
 	CDefaultIOApi();
 	~CDefaultIOApi();
 	~CDefaultIOApi();
-	
+
 	zlib_filefunc64_def getApiStructure() const override;
 	zlib_filefunc64_def getApiStructure() const override;
-	
+
 protected:
 protected:
-	CInputOutputStream * openFile(const std::string & filename, int mode) const override;
+	CInputOutputStream * openFile(const boost::filesystem::path & filename, int mode) const override;
 };
 };
 
 
 ///redirects all file IO to single stream
 ///redirects all file IO to single stream
@@ -67,7 +67,7 @@ public:
 	CProxyIOApi(CInputOutputStream * buffer);
 	CProxyIOApi(CInputOutputStream * buffer);
 	~CProxyIOApi();
 	~CProxyIOApi();
 protected:
 protected:
-	CInputOutputStream * openFile(const std::string & filename, int mode) const override;
+	CInputOutputStream * openFile(const boost::filesystem::path & filename, int mode) const override;
 	void closeFile(CInputOutputStream * stream) const override;
 	void closeFile(CInputOutputStream * stream) const override;
 private:
 private:
 	CInputOutputStream * data;
 	CInputOutputStream * data;