From daa67ff1f728c07f2a116ee9a9f4505479ca6808 Mon Sep 17 00:00:00 2001 From: danglassey Date: Wed, 14 Aug 2002 09:57:17 +0000 Subject: Initial import from crosswire CVS for syncing --- tests/compzip.cpp | 107 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 107 insertions(+) create mode 100644 tests/compzip.cpp (limited to 'tests/compzip.cpp') diff --git a/tests/compzip.cpp b/tests/compzip.cpp new file mode 100644 index 0000000..cbc5c5c --- /dev/null +++ b/tests/compzip.cpp @@ -0,0 +1,107 @@ +#include +#include +#include +#include +#include +#include + +#ifndef __GNUC__ +#include +#else +#include +#endif + +#include + +class FileCompress: public ZipCompress { + int ifd; + int ofd; + int ufd; + int zfd; +public: + FileCompress(char *); + ~FileCompress(); + unsigned long GetChars(char *, unsigned long len); + unsigned long SendChars(char *, unsigned long len); + void Encode(); + void Decode(); +}; + + +FileCompress::FileCompress(char *fname) +{ + char buf[256]; + +#ifndef O_BINARY +#define O_BINARY 0 +#endif + + ufd = open(fname, O_RDWR|O_CREAT|O_BINARY, 00644); + + sprintf(buf, "%s.zip", fname); + zfd = open(buf, O_RDWR|O_CREAT|O_BINARY, 00644); +} + + +FileCompress::~FileCompress() +{ + close(ufd); + close(zfd); +} + + +unsigned long FileCompress::GetChars(char *buf, unsigned long len) +{ + return read(ifd, buf, len); +} + + +unsigned long FileCompress::SendChars(char *buf, unsigned long len) +{ + return write(ofd, buf, len); +} + + +void FileCompress::Encode() +{ + ifd = ufd; + ofd = zfd; + + ZipCompress::Encode(); +} + + +void FileCompress::Decode() +{ + ifd = zfd; + ofd = ufd; + + ZipCompress::Decode(); +} + + +main(int argc, char **argv) +{ + int decomp = 0; + SWCompress *fobj; + + if (argc != 2) { + fprintf(stderr, "usage: %s \n", argv[0]); + exit(1); + } + + if (strlen(argv[1]) > 4) { + if (!strcmp(&argv[1][strlen(argv[1])-4], ".zip")) { + argv[1][strlen(argv[1])-4] = 0; + decomp = 1; + } + } + + fobj = new FileCompress(argv[1]); + + if (decomp) + fobj->Decode(); + else fobj->Encode(); + + delete fobj; +} -- cgit