/****************************************************************************** * rawverse.cpp - code for class 'RawVerse'- a module that reads raw text * files: ot and nt using indexs ??.bks ??.cps ??.vss * and provides lookup and parsing functions based on * class VerseKey */ #include #include #include #include #ifndef __GNUC__ #include #include #else #include #endif #include #include #include #include #ifdef BIGENDIAN #include #endif #ifndef O_BINARY // O_BINARY is needed in Borland C++ 4.53 #define O_BINARY 0 // If it hasn't been defined than we probably #endif // don't need it. /****************************************************************************** * RawVerse Statics */ int RawVerse::instance = 0; /****************************************************************************** * RawVerse Constructor - Initializes data for instance of RawVerse * * ENT: ipath - path of the directory where data and index files are located. * be sure to include the trailing separator (e.g. '/' or '\') * (e.g. 'modules/texts/rawtext/webster/') */ RawVerse::RawVerse(const char *ipath, int fileMode) { char buf[127]; nl = '\n'; path = 0; stdstr(&path, ipath); sprintf(buf, "%sot.vss", path); idxfp[0] = FileMgr::systemFileMgr.open(buf, fileMode|O_BINARY); sprintf(buf, "%snt.vss", path); idxfp[1] = FileMgr::systemFileMgr.open(buf, fileMode|O_BINARY); sprintf(buf, "%sot", path); textfp[0] = FileMgr::systemFileMgr.open(buf, fileMode|O_BINARY); sprintf(buf, "%snt", path); textfp[1] = FileMgr::systemFileMgr.open(buf, fileMode|O_BINARY); instance++; } /****************************************************************************** * RawVerse Destructor - Cleans up instance of RawVerse */ RawVerse::~RawVerse() { int loop1; if (path) delete [] path; --instance; for (loop1 = 0; loop1 < 2; loop1++) { FileMgr::systemFileMgr.close(idxfp[loop1]); FileMgr::systemFileMgr.close(textfp[loop1]); } } /****************************************************************************** * RawVerse::findoffset - Finds the offset of the key verse from the indexes * * ENT: testmt - testament to find (0 - Bible/module introduction) * idxoff - offset into .vss * start - address to store the starting offset * size - address to store the size of the entry */ void RawVerse::findoffset(char testmt, long idxoff, long *start, unsigned short *size) { idxoff *= 6; if (!testmt) testmt = ((idxfp[1]) ? 1:2); if (idxfp[testmt-1]->getFd() >= 0) { lseek(idxfp[testmt-1]->getFd(), idxoff, SEEK_SET); read(idxfp[testmt-1]->getFd(), start, 4); long len = read(idxfp[testmt-1]->getFd(), size, 2); // read size #ifdef BIGENDIAN *start = lelong(*start); *size = leshort(*size); #endif if (len < 2) { *size = (unsigned short)(lseek(textfp[testmt-1]->getFd(), 0, SEEK_END) - (long)start); // if for some reason we get an error reading size, make size to end of file } } else { *start = 0; *size = 0; } } /****************************************************************************** * RawVerse::preptext - Prepares the text before returning it to external * objects * * ENT: buf - buffer where text is stored and where to store the prep'd * text. */ void RawVerse::preptext(char *buf) { char *to, *from, space = 0, cr = 0, realdata = 0, nlcnt = 0; for (to = from = buf; *from; from++) { switch (*from) { case 10: if (!realdata) continue; space = (cr) ? 0 : 1; cr = 0; nlcnt++; if (nlcnt > 1) { // *to++ = nl; *to++ = nl; // nlcnt = 0; } continue; case 13: if (!realdata) continue; *to++ = nl; space = 0; cr = 1; continue; } realdata = 1; nlcnt = 0; if (space) { space = 0; if (*from != ' ') { *to++ = ' '; from--; continue; } } *to++ = *from; } *to = 0; while (to > (buf+1)) { // remove trailing excess to--; if ((*to == 10) || (*to == ' ')) *to = 0; else break; } } /****************************************************************************** * RawVerse::gettext - gets text at a given offset * * ENT: testmt - testament file to search in (0 - Old; 1 - New) * start - starting offset where the text is located in the file * size - size of text entry + 1 (null) * buf - buffer to store text * */ void RawVerse::gettext(char testmt, long start, unsigned short size, char *buf) { memset(buf, 0, size); if (textfp[testmt-1]->getFd() >= 0) { lseek(textfp[testmt-1]->getFd(), start, SEEK_SET); read(textfp[testmt-1]->getFd(), buf, (int)size - 1); } } /****************************************************************************** * RawVerse::settext - Sets text for current offset * * ENT: testmt - testament to find (0 - Bible/module introduction) * idxoff - offset into .vss * buf - buffer to store */ void RawVerse::settext(char testmt, long idxoff, const char *buf) { long start; unsigned short size; unsigned short outsize; idxoff *= 6; if (!testmt) testmt = ((idxfp[1]) ? 1:2); size = outsize = strlen(buf); lseek(idxfp[testmt-1]->getFd(), idxoff, SEEK_SET); read(idxfp[testmt-1]->getFd(), &start, 4); #ifdef BIGENDIAN start = lelong(start); outsize = leshort(size); #endif write(idxfp[testmt-1]->getFd(), &outsize, 2); lseek(textfp[testmt-1]->getFd(), start, SEEK_SET); write(textfp[testmt-1]->getFd(), buf, (int)size); } /****************************************************************************** * RawVerse::CreateModule - Creates new module files * * ENT: path - directory to store module files * RET: error status */ char RawVerse::CreateModule(char *path) { char buf[127]; FileDesc *fd; sprintf(buf, "%sot.vss", path); unlink(buf); fd = FileMgr::systemFileMgr.open(buf, O_CREAT|O_WRONLY|O_BINARY, S_IREAD|S_IWRITE); FileMgr::systemFileMgr.close(fd); sprintf(buf, "%snt.vss", path); unlink(buf); fd = FileMgr::systemFileMgr.open(buf, O_CREAT|O_WRONLY|O_BINARY, S_IREAD|S_IWRITE); FileMgr::systemFileMgr.close(fd); sprintf(buf, "%sot", path); unlink(buf); fd = FileMgr::systemFileMgr.open(buf, O_CREAT|O_WRONLY|O_BINARY, S_IREAD|S_IWRITE); FileMgr::systemFileMgr.close(fd); sprintf(buf, "%snt", path); unlink(buf); fd = FileMgr::systemFileMgr.open(buf, O_CREAT|O_WRONLY|O_BINARY, S_IREAD|S_IWRITE); FileMgr::systemFileMgr.close(fd); RawVerse rv(path); VerseKey mykey("Rev 22:21"); return 0; }