summaryrefslogblamecommitdiffstats
path: root/misc/olb/Mainfrm.cpp
blob: 0a542db04648522ab44d1fd6bfd9b15c3018da28 (plain) (tree)






































































































































































































































































































































                                                                                                                                                                                 
/*

 * Copyright 2009 CrossWire Bible Society (http://www.crosswire.org)

 *	CrossWire Bible Society

 *	P. O. Box 2528

 *	Tempe, AZ  85280-2528

 *

 * This program is free software; you can redistribute it and/or modify it

 * under the terms of the GNU General Public License as published by the

 * Free Software Foundation version 2.

 *

 * This program is distributed in the hope that it will be useful, but

 * WITHOUT ANY WARRANTY; without even the implied warranty of

 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU

 * General Public License for more details.

 *

 */

//---------------------------------------------------------------------------

#include <vcl.h>

#pragma hdrstop


#include "Mainfrm.h"

//---------------------------------------------------------------------------

#pragma package(smart_init)

#pragma resource "*.dfm"



 extern "C" {
#include "online.h"

}

#include <stdio.h>

#include <stdlib.h>

#include <string.h>

#include <ctype.h>


#ifndef __GNUC__

#include <io.h>

#include <sys/stat.h>

#else

#include <unistd.h>

#endif


#include <fcntl.h>

#include <versekey.h>






TForm1 *Form1;
//---------------------------------------------------------------------------

__fastcall TForm1::TForm1(TComponent* Owner)
	: TForm(Owner)
{
	
}
//---------------------------------------------------------------------------


int TForm1::ProcessOLB(char *filepath)
{
	long pos, offset;
	int num1, num2, rangemax, curbook = 0, curchap = 0, curverse = 0;
	char buf[127];
	short size, tmp;
	extern struct zonline online;

//	checkparams(argc, argv);

	startflag = 0;

	inckey = key1 = key2 = key3 = "Genesis 1:1";
	olbvnum = 0;

	openfiles();

	num1    = key1.Chapter();
	num2    = key1.Verse();

	DOINIT(filepath);   /* initialize OLB system */

	while(!findbreak(fp, &offset, &num1, &num2, &rangemax, &size)) {
		if (!startflag) {
			startflag = 1;
		}
		else {
			if (num2 < key2.Verse()) {            // new chapter

				if (num1 <= key2.Chapter()) { // new book

					key2.Verse(1);
					key2.Chapter(1);
					key2.Book(key2.Book()+1);
				}
				printf("Found Chapter Break: %d ('%s')\n", num1, (const char *)key2);
				chapoffset = offset;
				chapsize = size;
//				continue;

			}
		}
		key2.Verse(1);
		key2.Chapter(num1);
		key2.Verse(num2);

		key3 = key2;
//		key3 += (rangemax - key3.Verse());


		writeidx(key1, key2, key3, offset, size);
	}
	close(vfp);
	close(cfp);
	close(bfp);
	close(fp);
	DOEND();		// close OLB system

}


/**************************************************************************

 * ENT:	key1	- current location of index

 * 	key2	- minimum keyval for which this offset is valid

 * 	key3	- maximum keyval for which this offset is valid

 */

void TForm1::writeidx(VerseKey &key1, VerseKey &key2, VerseKey &key3, long offset, short size)
{
	long pos;
	short tmp;

		if (key1.Verse() == 1) {	// new chapter

			if (key1.Chapter() == 1) {	// new book

				pos = lseek(cfp, 0, SEEK_CUR);
				write(bfp, &pos, 4);
				pos = lseek(vfp, 0, SEEK_CUR); /* Book intro (cps) */
				write(cfp, &pos, 4);
				write(vfp, &chapoffset, 4);  /* Book intro (vss)  set to same as chap for now(it should be chap 1 which usually contains the book into anyway)*/
				write(vfp, &chapsize, 2);
			}
			pos = lseek(vfp, 0, SEEK_CUR);
			write(cfp, &pos, 4);
			write(vfp, &chapoffset, 4);  /* Chapter intro */
			write(vfp, &chapsize, 2);
		}
		if (key1 >= key2) {
			write(vfp, &offset, 4);
			write(vfp, &size, 2);
		}
		else	{
			pos = 0;
			tmp = 0;
			write(vfp, &pos, 4);
			write(vfp, &tmp, 2);
		}
		key1++;
}



char TForm1::findbreak(int fp, long *offset, int *num1, int *num2, int *rangemax, short *size)
{
	char buf[7];
	char buf2[20];
	char ch;
	char loop;
	long offset2;
	int ch2, vs2, rm2;
	bool flag;
	long chapstart = 0; 
	short versedata[MAX_VERSE];
	char data[MAX_DATA];


	if (++olbvnum <= 31102) {

		if (olbvnum == 23146) {	// "Matthew 1:1"	

			close(vfp);
			close(cfp);
			close(bfp);
			close(fp);
			key1 = key2 = key3 = inckey = "Matthew 1:1";
			openfiles();
			startflag = 0;
		}


		*offset = lseek(fp, 0, SEEK_CUR);

		if ((olbvnum!=1) && (olbvnum != 23146))
			inckey++;
			
		*num1 = inckey.Chapter();
		*num2 = inckey.Verse();
	
	// output verse from olb

//		printf("%s\n", (const char *)inckey);

		GETEXT(olbvnum, versedata, 1, 1, 1, 1);
		BLDVERSE(versedata, data);
		charsetconvert(data);
		write(fp, data, strlen(data));

		*size = lseek(fp, 0, SEEK_CUR) - *offset;
		write(fp, "\n", 1);
		return 0;
	}
	return 1;
}

void TForm1::charsetconvert(char *data)
{
	for (;*data; data++) {
//		printf("%c %d", *data, *data);

		switch((unsigned char)*data) {
		case 129: *data = 252; break;
		case 130: *data = 233; break;
		case 131: *data = 226; break;
		case 133: *data = 224; break;
		case 135: *data = 231; break;
		case 136: *data = 234; break;
		case 137: *data = 235; break;
		case 138: *data = 232; break;
		case 139: *data = 239; break;
		case 140: *data = 238; break;
		case 144: *data = 201; break;
		case 147: *data = 244; break;
		case 150: *data = 251; break;
		case 151: *data = 249; break;
		case 160: *data = 225; break;
		case 161: *data = 237; break;
		case 162: *data = 243; break;
		case 163: *data = 250; break;
		case 164: *data = 241; break;
		case 168: *data = 191; break;
		case 173: *data = 161; break;
		default:
			if ((unsigned char)*data > 126)
				fprintf(stderr, "Suspicious character: %c (%d); %s\n", *data, (unsigned char )*data, (const char *)inckey);
			break;
		}
	}
}


void TForm1::openfiles()
{
	char buf[255];
	char fname[5];
	long pos;
	short size;
	
	testmnt = key1.Testament();

	strcpy(fname, (testmnt==2) ? "nt" : "ot");
	unlink(fname);
	if ((fp = open(fname, O_CREAT|O_RDWR|O_BINARY, S_IREAD|S_IWRITE)) == -1) {
		sprintf(buf, "Couldn't open file: %s\n", fname);
		MessageBox(this->Handle, buf, "openfiles()", MB_OK);
		exit(1);
	}

	sprintf(buf, "%s.vss", fname);
	unlink(buf);
	if ((vfp = open(buf, O_CREAT|O_WRONLY|O_BINARY, S_IREAD|S_IWRITE)) == -1) {
		fprintf(stderr, "Couldn't open file: %s\n", buf);
		exit(1);
	}

	sprintf(buf, "%s.cps", fname);
	unlink(buf);
	if ((cfp = open(buf, O_CREAT|O_WRONLY|O_BINARY, S_IREAD|S_IWRITE)) == -1) {
		fprintf(stderr, "Couldn't open file: %s\n", buf);
		exit(1);
	}

	sprintf(buf, "%s.bks", fname);
	unlink(buf);
	if ((bfp = open(buf, O_CREAT|O_WRONLY|O_BINARY, S_IREAD|S_IWRITE)) == -1) {
		fprintf(stderr, "Couldn't open file: %s\n", buf);
		exit(1);
	}

	pos  = 0;
	write(bfp, &pos, 4);  /* Book    offset for testament intros */
	pos = 4;
	write(cfp, &pos, 4);  /* Chapter offset for testament intro */


/*	Right now just zero out intros until parsing correctly */
	pos = 0;
	size = 0;
	write(vfp, &pos, 4);  /* Module intro */
	write(vfp, &size, 2);
	write(vfp, &pos, 4);  /* Testament intro */
	write(vfp, &size, 2);

}


void TForm1::checkparams(int argc, char **argv)
{
	if (argc < 2) {
		fprintf(stderr, "usage: %s <path to OLB module directory (e.g. \"G:\\BIBLE\\AV\")>\n", argv[0]);
		exit(1);
	}
}
void __fastcall TForm1::FSButtonClick(TObject *Sender)
{
	FSDialog->FileName = "Text.dat";
	char *fname;

	if (FSDialog->Execute()) {
		fname = new char [ strlen(FSDialog->FileName.c_str()) + 1 ];
		strcpy(fname, FSDialog->FileName.c_str());
		for (int i = strlen(fname) - 1; i; i--) {
			if ((fname[i] != '\\') && (fname[i] != '/'))
				fname[i] = 0;
			else break;
		}
		FilePathEdit->Text = fname;
		delete [] fname;
		try {
			RichEdit1->Lines->LoadFromFile(FilePathEdit->Text + "Copyrite.dat");
		}
		catch (...) {}
	}
}
//---------------------------------------------------------------------------

void __fastcall TForm1::Button1Click(TObject *Sender)
{
	ProcessOLB(FilePathEdit->Text.c_str());	
}
//---------------------------------------------------------------------------