diff options
author | danglassey <danglassey> | 2002-08-14 09:57:17 +0000 |
---|---|---|
committer | danglassey <danglassey> | 2002-08-14 09:57:17 +0000 |
commit | daa67ff1f728c07f2a116ee9a9f4505479ca6808 (patch) | |
tree | c224a537d30480002ae0560cc9104b543b4d1b5e /utilities/mod2zmod.cpp | |
parent | 6d6973e035aac5ec1676efccd5b8ada70c40b639 (diff) | |
download | sword-sf-cvs-import-1.1.1.tar.gz |
Initial import from crosswire CVS for syncingimport-1.1.1
Diffstat (limited to 'utilities/mod2zmod.cpp')
-rw-r--r-- | utilities/mod2zmod.cpp | 145 |
1 files changed, 145 insertions, 0 deletions
diff --git a/utilities/mod2zmod.cpp b/utilities/mod2zmod.cpp new file mode 100644 index 0000000..bfa7305 --- /dev/null +++ b/utilities/mod2zmod.cpp @@ -0,0 +1,145 @@ +// Compression on variable granularity + +#include <fcntl.h> +#include <iostream> +#include <fstream> +#include <string> + +#ifndef __GNUC__ +#include <io.h> +#else +#include <unistd.h> +#endif + +#include <ztext.h> +#include <zld.h> +#include <zcom.h> +#include <swmgr.h> +#include <lzsscomprs.h> +#include <zipcomprs.h> +#include <versekey.h> +#include <stdio.h> + +void errorOutHelp(char *appName) { + cerr << appName << " - a tool to create compressed Sword modules\n"; + cerr << "version 0.1\n\n"; + cerr << "usage: "<< appName << " <modname> <datapath> [blockType [compressType]]\n\n"; + cerr << "datapath: the directory in which to write the zModule\n"; + cerr << "blockType : (default 4)\n\t2 - verses\n\t3 - chapters\n\t4 - books\n"; + cerr << "compressType: (default 1):\n\t1 - LZSS\n\t2 - Zip\n"; + cerr << "\n\n"; + exit(-1); +} + + +int main(int argc, char **argv) +{ + int iType = 4; + int compType = 1; + SWCompress *compressor = 0; + SWModule *inModule = 0; + SWModule *outModule = 0; + + + if ((argc < 3) || (argc > 5)) { + errorOutHelp(argv[0]); + } + + if (argc > 3) { + iType = atoi(argv[3]); + if (argc > 4) { + compType = atoi(argv[4]); + } + } + + if ((iType < 2) || (compType < 1) || (compType > 2) || (!strcmp(argv[1], "-h")) || (!strcmp(argv[1], "--help")) || (!strcmp(argv[1], "/?")) || (!strcmp(argv[1], "-?")) || (!strcmp(argv[1], "-help"))) { + errorOutHelp(argv[0]); + } + + SWMgr mgr; + + ModMap::iterator it = mgr.Modules.find(argv[1]); + if (it == mgr.Modules.end()) { + fprintf(stderr, "error: %s: couldn't find module: %s \n", argv[0], argv[1]); + exit(-2); + } + + inModule = it->second; + + // Try to initialize a default set of datafiles and indicies at our + // datapath location passed to us from the user. + +#define BIBLE 1 +#define LEX 2 +#define COM 3 + + int modType = 0; + if (!strcmp(inModule->Type(), "Biblical Texts")) modType = BIBLE; + if (!strcmp(inModule->Type(), "Lexicons / Dictionaries")) modType = LEX; + if (!strcmp(inModule->Type(), "Commentaries")) modType = COM; + + switch (compType) { // these are deleted by zText + case 1: compressor = new LZSSCompress(); break; + case 2: compressor = new ZipCompress(); break; + } + + int result = 0; + switch (modType) { + case BIBLE: + result = zText::createModule(argv[2], iType); + break; + case LEX: + result = zLD::createModule(argv[2]); + break; + case COM: + result = zCom::createModule(argv[2], iType); + break; + } + + if (result) { + fprintf(stderr, "error: %s: couldn't create module at path: %s \n", argv[0], argv[2]); + exit(-3); + } + + switch (modType) { + case BIBLE: + outModule = new zText(argv[2], 0, 0, iType, compressor); // open our datapath with our RawText driver. + ((VerseKey *)(SWKey *)(*inModule))->Headings(1); + break; + case LEX: + outModule = new zLD(argv[2], 0, 0, iType, compressor); // open our datapath with our RawText driver. + break; + case COM: + outModule = new zCom(argv[2], 0, 0, iType, compressor); // open our datapath with our RawText driver. + ((VerseKey *)(SWKey *)(*inModule))->Headings(1); + break; + } + + string lastBuffer = "Something that would never be first module entry"; + SWKey bufferKey; + + inModule->setSkipConsecutiveLinks(false); + (*inModule) = TOP; + while (!inModule->Error()) { + bufferKey = *(SWKey *)(*inModule); + // pseudo-check for link. Will get most common links. + if ((lastBuffer == inModule->getRawEntry()) &&(lastBuffer.length() > 0)) { + (*outModule) << &bufferKey; // link to last key + cout << "Adding [" << bufferKey << "] link to: \n"; + } + else { + lastBuffer = inModule->getRawEntry(); + if (lastBuffer.length() > 0) { + cout << "Adding [" << bufferKey << "] new text. \n"; + outModule->SetKey(bufferKey); + (*outModule) << lastBuffer.c_str(); // save new text; + } + else { + cout << "Skipping [" << bufferKey << "] no entry in inModule. \n"; + } + } + (*inModule)++; + } + delete outModule; +} + |