#include #include #include #include #ifndef __GNUC__ #include #else #include #endif #include class FileCompress: public LZSSCompress { int ifd; int ofd; int ufd; int zfd; public: FileCompress(char *); ~FileCompress(); int GetChars(char *, int len); int SendChars(char *, int 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.zzz", fname); zfd = open(buf, O_RDWR|O_CREAT|O_BINARY, 00644); } FileCompress::~FileCompress() { close(ufd); close(zfd); } int FileCompress::GetChars(char *buf, int len) { return read(ifd, buf, len); } int FileCompress::SendChars(char *buf, int len) { return write(ofd, buf, len); } void FileCompress::Encode() { ifd = ufd; ofd = zfd; LZSSCompress::Encode(); } void FileCompress::Decode() { ifd = zfd; ofd = ufd; LZSSCompress::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], ".zzz")) { argv[1][strlen(argv[1])-4] = 0; decomp = 1; } } fobj = new FileCompress(argv[1]); if (decomp) fobj->Decode(); else fobj->Encode(); delete fobj; }