Commit 35ee485b authored by Olivier Bertrand's avatar Olivier Bertrand

- Implemented: not split indexes (all indexes in one file)

modified:
  storage/connect/tabdos.cpp
  storage/connect/xindex.cpp
  storage/connect/xindex.h
parent f4570a7b
...@@ -249,10 +249,8 @@ bool DOSDEF::DefineAM(PGLOBAL g, LPCSTR am, int poff) ...@@ -249,10 +249,8 @@ bool DOSDEF::DefineAM(PGLOBAL g, LPCSTR am, int poff)
Ending = Cat->GetIntCatInfo("Ending", CRLF); Ending = Cat->GetIntCatInfo("Ending", CRLF);
if (Recfm == RECFM_FIX || Recfm == RECFM_BIN) { if (Recfm == RECFM_FIX || Recfm == RECFM_BIN) {
int defhuge = (Cat->GetDefHuge()) ? 1 : 0; Huge = Cat->GetBoolCatInfo("Huge", Cat->GetDefHuge());
Padded = Cat->GetBoolCatInfo("Padded", false);
Huge = (Cat->GetIntCatInfo("Huge", defhuge) != 0);
Padded = (Cat->GetIntCatInfo("Padded", 0) != 0);
Blksize = Cat->GetIntCatInfo("Blksize", 0); Blksize = Cat->GetIntCatInfo("Blksize", 0);
Eof = (Cat->GetIntCatInfo("EOF", 0) != 0); Eof = (Cat->GetIntCatInfo("EOF", 0) != 0);
} else if (Recfm == RECFM_DBF) { } else if (Recfm == RECFM_DBF) {
...@@ -554,8 +552,8 @@ int TDBDOS::MakeIndex(PGLOBAL g, PIXDEF pxdf, bool add) ...@@ -554,8 +552,8 @@ int TDBDOS::MakeIndex(PGLOBAL g, PIXDEF pxdf, bool add)
if (!x->Make(g, sxp)) { if (!x->Make(g, sxp)) {
// Retreive define values from the index // Retreive define values from the index
xdp->SetMaxSame(x->GetMaxSame()); xdp->SetMaxSame(x->GetMaxSame());
xdp->SetOffset(x->GetDefoff()); // xdp->SetOffset(x->GetDefoff());
xdp->SetOffhigh(x->GetDefhigh()); // xdp->SetOffhigh(x->GetDefhigh());
xdp->SetSize(x->GetSize()); xdp->SetSize(x->GetSize());
// store KXYCOL Mxs in KPARTDEF Mxsame // store KXYCOL Mxs in KPARTDEF Mxsame
......
...@@ -17,6 +17,7 @@ ...@@ -17,6 +17,7 @@
//#include <windows.h> //#include <windows.h>
#else // !WIN32 #else // !WIN32
#if defined(UNIX) #if defined(UNIX)
#define _LARGEFILE64_SOURCE
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <errno.h> #include <errno.h>
...@@ -51,6 +52,7 @@ ...@@ -51,6 +52,7 @@
/***********************************************************************/ /***********************************************************************/
#define NZ 7 #define NZ 7
#define NW 5 #define NW 5
#define MAX_INDX 10
#ifndef INVALID_SET_FILE_POINTER #ifndef INVALID_SET_FILE_POINTER
#define INVALID_SET_FILE_POINTER 0xFFFFFFFF #define INVALID_SET_FILE_POINTER 0xFFFFFFFF
#endif #endif
...@@ -109,8 +111,8 @@ INDEXDEF::INDEXDEF(char *name, bool uniq, int n) ...@@ -109,8 +111,8 @@ INDEXDEF::INDEXDEF(char *name, bool uniq, int n)
AutoInc = false; AutoInc = false;
Nparts = 0; Nparts = 0;
ID = n; ID = n;
Offset = 0; //Offset = 0;
Offhigh = 0; //Offhigh = 0;
Size = 0; Size = 0;
MaxSame = 1; MaxSame = 1;
} // end of INDEXDEF constructor } // end of INDEXDEF constructor
...@@ -209,8 +211,8 @@ XINDEX::XINDEX(PTDBDOS tdbp, PIXDEF xdp, PXLOAD pxp, PCOL *cp, PXOB *xp, int k) ...@@ -209,8 +211,8 @@ XINDEX::XINDEX(PTDBDOS tdbp, PIXDEF xdp, PXLOAD pxp, PCOL *cp, PXOB *xp, int k)
Nk = xdp->GetNparts(); Nk = xdp->GetNparts();
Nval = (k) ? k : Nk; Nval = (k) ? k : Nk;
Incr = 0; Incr = 0;
Defoff = xdp->GetOffset(); //Defoff = xdp->GetOffset();
Defhigh = xdp->GetOffhigh(); //Defhigh = xdp->GetOffhigh();
Size = xdp->GetSize(); Size = xdp->GetSize();
MaxSame = xdp->GetMaxSame(); MaxSame = xdp->GetMaxSame();
} // end of XINDEX constructor } // end of XINDEX constructor
...@@ -703,7 +705,8 @@ bool XINDEX::SaveIndex(PGLOBAL g, PIXDEF sxp) ...@@ -703,7 +705,8 @@ bool XINDEX::SaveIndex(PGLOBAL g, PIXDEF sxp)
char *ftype; char *ftype;
char fn[_MAX_PATH]; char fn[_MAX_PATH];
int n[NZ], nof = (Mul) ? (Ndif + 1) : 0; int n[NZ], nof = (Mul) ? (Ndif + 1) : 0;
bool rc = false; int id = -1;
bool sep, rc = false;
PXCOL kcp = To_KeyCol; PXCOL kcp = To_KeyCol;
PDOSDEF defp = (PDOSDEF)Tdbp->To_Def; PDOSDEF defp = (PDOSDEF)Tdbp->To_Def;
PDBUSER dup = PlgGetUser(g); PDBUSER dup = PlgGetUser(g);
...@@ -723,7 +726,7 @@ bool XINDEX::SaveIndex(PGLOBAL g, PIXDEF sxp) ...@@ -723,7 +726,7 @@ bool XINDEX::SaveIndex(PGLOBAL g, PIXDEF sxp)
return true; return true;
} // endswitch Ftype } // endswitch Ftype
if (dup->Catalog->GetBoolCatInfo("SepIndex", false)) { if ((sep = dup->Catalog->GetBoolCatInfo("SepIndex", false))) {
// Index is saved in a separate file // Index is saved in a separate file
#if !defined(UNIX) #if !defined(UNIX)
char drive[_MAX_DRIVE]; char drive[_MAX_DRIVE];
...@@ -737,12 +740,14 @@ bool XINDEX::SaveIndex(PGLOBAL g, PIXDEF sxp) ...@@ -737,12 +740,14 @@ bool XINDEX::SaveIndex(PGLOBAL g, PIXDEF sxp)
strcat(strcat(fname, "_"), Xdp->GetName()); strcat(strcat(fname, "_"), Xdp->GetName());
_makepath(fn, drive, direc, fname, ftype); _makepath(fn, drive, direc, fname, ftype);
sxp = NULL; sxp = NULL;
} else } else {
id = ID;
strcat(PlugRemoveType(fn, strcpy(fn, defp->GetOfn())), ftype); strcat(PlugRemoveType(fn, strcpy(fn, defp->GetOfn())), ftype);
} // endif sep
PlugSetPath(fn, fn, Tdbp->GetPath()); PlugSetPath(fn, fn, Tdbp->GetPath());
if (X->Open(g, fn, (sxp) ? MODE_INSERT : MODE_WRITE)) { if (X->Open(g, fn, id, (sxp) ? MODE_INSERT : MODE_WRITE)) {
printf("%s\n", g->Message); printf("%s\n", g->Message);
return true; return true;
} // endif Open } // endif Open
...@@ -751,7 +756,7 @@ bool XINDEX::SaveIndex(PGLOBAL g, PIXDEF sxp) ...@@ -751,7 +756,7 @@ bool XINDEX::SaveIndex(PGLOBAL g, PIXDEF sxp)
goto end; // Void index goto end; // Void index
// Defoff is the start of the definition in the index file // Defoff is the start of the definition in the index file
X->GetOff(Defoff, Defhigh, sxp); //X->GetOff(Defoff, Defhigh, sxp);
#if defined(TRACE) #if defined(TRACE)
printf("Defoff=%d Defhigh=%d\n", Defoff, Defhigh); printf("Defoff=%d Defhigh=%d\n", Defoff, Defhigh);
...@@ -815,7 +820,7 @@ bool XINDEX::SaveIndex(PGLOBAL g, PIXDEF sxp) ...@@ -815,7 +820,7 @@ bool XINDEX::SaveIndex(PGLOBAL g, PIXDEF sxp)
#endif // TRACE #endif // TRACE
end: end:
X->Close(); X->Close(fn, id);
return rc; return rc;
} // end of SaveIndex } // end of SaveIndex
...@@ -831,7 +836,7 @@ bool XINDEX::Init(PGLOBAL g) ...@@ -831,7 +836,7 @@ bool XINDEX::Init(PGLOBAL g)
/*********************************************************************/ /*********************************************************************/
char *ftype; char *ftype;
char fn[_MAX_PATH]; char fn[_MAX_PATH];
int k, n, nv[NZ]; int k, n, nv[NZ], id = -1;
bool estim = false; bool estim = false;
PCOL colp; PCOL colp;
PXCOL prev = NULL, kcp = NULL; PXCOL prev = NULL, kcp = NULL;
...@@ -890,8 +895,10 @@ bool XINDEX::Init(PGLOBAL g) ...@@ -890,8 +895,10 @@ bool XINDEX::Init(PGLOBAL g)
_splitpath(defp->GetOfn(), drive, direc, fname, NULL); _splitpath(defp->GetOfn(), drive, direc, fname, NULL);
strcat(strcat(fname, "_"), Xdp->GetName()); strcat(strcat(fname, "_"), Xdp->GetName());
_makepath(fn, drive, direc, fname, ftype); _makepath(fn, drive, direc, fname, ftype);
} else } else {
id = ID;
strcat(PlugRemoveType(fn, strcpy(fn, defp->GetOfn())), ftype); strcat(PlugRemoveType(fn, strcpy(fn, defp->GetOfn())), ftype);
} // endif sep
PlugSetPath(fn, fn, Tdbp->GetPath()); PlugSetPath(fn, fn, Tdbp->GetPath());
...@@ -902,13 +909,9 @@ bool XINDEX::Init(PGLOBAL g) ...@@ -902,13 +909,9 @@ bool XINDEX::Init(PGLOBAL g)
/*********************************************************************/ /*********************************************************************/
/* Open the index file and check its validity. */ /* Open the index file and check its validity. */
/*********************************************************************/ /*********************************************************************/
if (X->Open(g, fn, MODE_READ)) if (X->Open(g, fn, id, MODE_READ))
goto err; // No saved values goto err; // No saved values
// Get offset from XDB file
if (X->Seek(g, Defoff, Defhigh, SEEK_SET))
goto err;
// Now start the reading process. // Now start the reading process.
if (X->Read(g, nv, NZ, sizeof(int))) if (X->Read(g, nv, NZ, sizeof(int)))
goto err; goto err;
...@@ -1269,7 +1272,7 @@ bool XINDEX::GetAllSizes(PGLOBAL g, int &ndif, int &numk) ...@@ -1269,7 +1272,7 @@ bool XINDEX::GetAllSizes(PGLOBAL g, int &ndif, int &numk)
{ {
char *ftype; char *ftype;
char fn[_MAX_PATH]; char fn[_MAX_PATH];
int n, nv[NZ]; int n, nv[NZ], id = -1;
bool estim = false; bool estim = false;
PDOSDEF defp = (PDOSDEF)Tdbp->To_Def; PDOSDEF defp = (PDOSDEF)Tdbp->To_Def;
...@@ -1327,8 +1330,10 @@ bool XINDEX::GetAllSizes(PGLOBAL g, int &ndif, int &numk) ...@@ -1327,8 +1330,10 @@ bool XINDEX::GetAllSizes(PGLOBAL g, int &ndif, int &numk)
_splitpath(defp->GetOfn(), drive, direc, fname, NULL); _splitpath(defp->GetOfn(), drive, direc, fname, NULL);
strcat(strcat(fname, "_"), Xdp->GetName()); strcat(strcat(fname, "_"), Xdp->GetName());
_makepath(fn, drive, direc, fname, ftype); _makepath(fn, drive, direc, fname, ftype);
} else } else {
id = ID;
strcat(PlugRemoveType(fn, strcpy(fn, defp->GetOfn())), ftype); strcat(PlugRemoveType(fn, strcpy(fn, defp->GetOfn())), ftype);
} // endif sep
PlugSetPath(fn, fn, Tdbp->GetPath()); PlugSetPath(fn, fn, Tdbp->GetPath());
...@@ -1339,12 +1344,12 @@ bool XINDEX::GetAllSizes(PGLOBAL g, int &ndif, int &numk) ...@@ -1339,12 +1344,12 @@ bool XINDEX::GetAllSizes(PGLOBAL g, int &ndif, int &numk)
/*********************************************************************/ /*********************************************************************/
/* Open the index file and check its validity. */ /* Open the index file and check its validity. */
/*********************************************************************/ /*********************************************************************/
if (X->Open(g, fn, MODE_READ)) if (X->Open(g, fn, id, MODE_READ))
goto err; // No saved values goto err; // No saved values
// Get offset from XDB file // Get offset from XDB file
if (X->Seek(g, Defoff, Defhigh, SEEK_SET)) //if (X->Seek(g, Defoff, Defhigh, SEEK_SET))
goto err; // goto err;
// Now start the reading process. // Now start the reading process.
if (X->Read(g, nv, NZ, sizeof(int))) if (X->Read(g, nv, NZ, sizeof(int)))
...@@ -2046,6 +2051,7 @@ XLOAD::XLOAD(void) ...@@ -2046,6 +2051,7 @@ XLOAD::XLOAD(void)
#if defined(WIN32) && defined(XMAP) #if defined(WIN32) && defined(XMAP)
ViewBase = NULL; ViewBase = NULL;
#endif // WIN32 && XMAP #endif // WIN32 && XMAP
NewOff.Val = 0LL;
} // end of XLOAD constructor } // end of XLOAD constructor
/***********************************************************************/ /***********************************************************************/
...@@ -2085,9 +2091,11 @@ XFILE::XFILE(void) : XLOAD() ...@@ -2085,9 +2091,11 @@ XFILE::XFILE(void) : XLOAD()
/***********************************************************************/ /***********************************************************************/
/* Xopen function: opens a file using native API's. */ /* Xopen function: opens a file using native API's. */
/***********************************************************************/ /***********************************************************************/
bool XFILE::Open(PGLOBAL g, char *filename, MODE mode) bool XFILE::Open(PGLOBAL g, char *filename, int id, MODE mode)
{ {
char *pmod; char *pmod;
bool rc;
IOFF noff[MAX_INDX];
/*********************************************************************/ /*********************************************************************/
/* Open the index file according to mode. */ /* Open the index file according to mode. */
...@@ -2108,7 +2116,7 @@ bool XFILE::Open(PGLOBAL g, char *filename, MODE mode) ...@@ -2108,7 +2116,7 @@ bool XFILE::Open(PGLOBAL g, char *filename, MODE mode)
return true; return true;
} // endif Xfile } // endif Xfile
if (mode == MODE_INSERT) if (mode == MODE_INSERT) {
/*******************************************************************/ /*******************************************************************/
/* Position the cursor at end of file so ftell returns file size. */ /* Position the cursor at end of file so ftell returns file size. */
/*******************************************************************/ /*******************************************************************/
...@@ -2117,9 +2125,35 @@ bool XFILE::Open(PGLOBAL g, char *filename, MODE mode) ...@@ -2117,9 +2125,35 @@ bool XFILE::Open(PGLOBAL g, char *filename, MODE mode)
return true; return true;
} // endif } // endif
NewOff.Low = (int)ftell(Xfile);
} else if (mode == MODE_WRITE) {
if (id >= 0) {
// New not sep index file. Write the header.
memset(noff, 0, sizeof(noff));
Write(g, noff, sizeof(IOFF), MAX_INDX, rc);
fseek(Xfile, 0, SEEK_END);
NewOff.Low = (int)ftell(Xfile);
} // endif id
} else if (mode == MODE_READ && id >= 0) {
// Get offset from the header
if (fread(noff, sizeof(IOFF), MAX_INDX, Xfile) != MAX_INDX) {
sprintf(g->Message, MSG(XFILE_READERR), errno);
return true;
} // endif MAX_INDX
// Position the cursor at the offset of this index
if (fseek(Xfile, noff[id].Low, SEEK_SET)) {
sprintf(g->Message, MSG(FUNC_ERRNO), errno, "Xseek");
return true;
} // endif
} // endif mode
return false; return false;
} // end of Open } // end of Open
#if 0
/***********************************************************************/ /***********************************************************************/
/* Tell were we are in the index file. */ /* Tell were we are in the index file. */
/***********************************************************************/ /***********************************************************************/
...@@ -2133,6 +2167,7 @@ bool XFILE::GetOff(int& low, int& high, PIXDEF sxp) ...@@ -2133,6 +2167,7 @@ bool XFILE::GetOff(int& low, int& high, PIXDEF sxp)
return false; return false;
} // end of GetOff } // end of GetOff
#endif // 0
/***********************************************************************/ /***********************************************************************/
/* Tell were we are in a huge file. */ /* Tell were we are in a huge file. */
...@@ -2181,7 +2216,24 @@ int XFILE::Write(PGLOBAL g, void *buf, int n, int size, bool& rc) ...@@ -2181,7 +2216,24 @@ int XFILE::Write(PGLOBAL g, void *buf, int n, int size, bool& rc)
} // end of Write } // end of Write
/***********************************************************************/ /***********************************************************************/
/* Close the index huge file. */ /* Update the file header and close the index file. */
/***********************************************************************/
void XFILE::Close(char *fn, int id)
{
if (id >= 0 && fn && Xfile) {
fclose(Xfile);
if ((Xfile = fopen(fn, "r+b")))
if (!fseek(Xfile, id * sizeof(IOFF), SEEK_SET))
fwrite(&NewOff, sizeof(int), 2, Xfile);
} // endif id
Close();
} // end of Close
/***********************************************************************/
/* Close the index file. */
/***********************************************************************/ /***********************************************************************/
void XFILE::Close(void) void XFILE::Close(void)
{ {
...@@ -2336,8 +2388,12 @@ void *XFILE::FileView(PGLOBAL g, char *fn, int loff, int hoff, int size) ...@@ -2336,8 +2388,12 @@ void *XFILE::FileView(PGLOBAL g, char *fn, int loff, int hoff, int size)
/***********************************************************************/ /***********************************************************************/
/* Xopen function: opens a file using native API's. */ /* Xopen function: opens a file using native API's. */
/***********************************************************************/ /***********************************************************************/
bool XHUGE::Open(PGLOBAL g, char *filename, MODE mode) bool XHUGE::Open(PGLOBAL g, char *filename, int id, MODE mode)
{ {
LONG high = 0;
DWORD drc, rc;
IOFF noff[MAX_INDX];
if (Hfile != INVALID_HANDLE_VALUE) { if (Hfile != INVALID_HANDLE_VALUE) {
sprintf(g->Message, MSG(FILE_OPEN_YET), filename); sprintf(g->Message, MSG(FILE_OPEN_YET), filename);
return true; return true;
...@@ -2348,7 +2404,7 @@ bool XHUGE::Open(PGLOBAL g, char *filename, MODE mode) ...@@ -2348,7 +2404,7 @@ bool XHUGE::Open(PGLOBAL g, char *filename, MODE mode)
#endif // TRACE #endif // TRACE
#if defined(WIN32) #if defined(WIN32)
DWORD rc, access, share, creation; DWORD access, share, creation;
/*********************************************************************/ /*********************************************************************/
/* Create the file object according to access mode */ /* Create the file object according to access mode */
...@@ -2397,8 +2453,7 @@ bool XHUGE::Open(PGLOBAL g, char *filename, MODE mode) ...@@ -2397,8 +2453,7 @@ bool XHUGE::Open(PGLOBAL g, char *filename, MODE mode)
/*******************************************************************/ /*******************************************************************/
/* In Insert mode we must position the cursor at end of file. */ /* In Insert mode we must position the cursor at end of file. */
/*******************************************************************/ /*******************************************************************/
LONG high = 0; rc = SetFilePointer(Hfile, 0, &high, FILE_END);
DWORD drc, rc = SetFilePointer(Hfile, 0, &high, FILE_END);
if (rc == INVALID_SET_FILE_POINTER && (drc = GetLastError()) != NO_ERROR) { if (rc == INVALID_SET_FILE_POINTER && (drc = GetLastError()) != NO_ERROR) {
sprintf(g->Message, MSG(ERROR_IN_SFP), drc); sprintf(g->Message, MSG(ERROR_IN_SFP), drc);
...@@ -2407,6 +2462,34 @@ bool XHUGE::Open(PGLOBAL g, char *filename, MODE mode) ...@@ -2407,6 +2462,34 @@ bool XHUGE::Open(PGLOBAL g, char *filename, MODE mode)
return true; return true;
} // endif } // endif
NewOff.Low = (int)rc;
NewOff.High = (int)high;
} else if (mode == MODE_WRITE) {
if (id >= 0) {
// New not sep index file. Write the header.
memset(noff, 0, sizeof(noff));
rc = WriteFile(Hfile, noff, sizeof(noff), &drc, NULL);
NewOff.Low = (int)drc;
} // endif id
} else if (mode == MODE_READ && id >= 0) {
// Get offset from the header
rc = ReadFile(Hfile, noff, sizeof(noff), &drc, NULL);
if (!rc) {
sprintf(g->Message, MSG(XFILE_READERR), GetLastError());
return true;
} // endif rc
// Position the cursor at the offset of this index
rc = SetFilePointer(Hfile, noff[id].Low,
(PLONG)&noff[id].High, FILE_BEGIN);
if (rc == INVALID_SET_FILE_POINTER) {
sprintf(g->Message, MSG(FUNC_ERRNO), GetLastError(), "SetFilePointer");
return true;
} // endif
} // endif Mode } // endif Mode
#else // UNIX #else // UNIX
...@@ -2422,7 +2505,7 @@ bool XHUGE::Open(PGLOBAL g, char *filename, MODE mode) ...@@ -2422,7 +2505,7 @@ bool XHUGE::Open(PGLOBAL g, char *filename, MODE mode)
oflag |= O_RDONLY; oflag |= O_RDONLY;
break; break;
case MODE_WRITE: case MODE_WRITE:
oflag |= O_WRONLY | O_CREAT; oflag |= O_WRONLY | O_CREAT | O_TRUNC;
pmod = S_IREAD | S_IWRITE; pmod = S_IREAD | S_IWRITE;
break; break;
case MODE_INSERT: case MODE_INSERT:
...@@ -2448,11 +2531,43 @@ bool XHUGE::Open(PGLOBAL g, char *filename, MODE mode) ...@@ -2448,11 +2531,43 @@ bool XHUGE::Open(PGLOBAL g, char *filename, MODE mode)
rc, oflag, mode, Hfile, filename); rc, oflag, mode, Hfile, filename);
#endif // TRACE #endif // TRACE
if (mode == MODE_INSERT) {
/*******************************************************************/
/* Position the cursor at end of file so ftell returns file size. */
/*******************************************************************/
if (!(Offset.Val = (longlong)lseek64(Hfile, 0LL, SEEK_END))) {
sprintf(g->Message, MSG(FUNC_ERRNO), errno, "Seek");
return true;
} // endif
} else if (mode == MODE_WRITE) {
if (id >= 0) {
// New not sep index file. Write the header.
memset(noff, 0, sizeof(noff));
Write(g, noff, sizeof(IOFF), MAX_INDX, rc);
Offset.Val = (longlong)(sizeof(IOFF) * MAX_INDX);
} // endif id
} else if (mode == MODE_READ && id >= 0) {
// Get offset from the header
if (read(Hfile, noff, sizeof(noff)) != sizeof(noff)) {
sprintf(g->Message, MSG(READ_ERROR), "Index file", strerror(errno));
return true;
} // endif MAX_INDX
// Position the cursor at the offset of this index
if (!lseek64(Hfile, noff[id].Val, SEEK_SET)) {
sprintf(g->Message, MSG(FUNC_ERRNO), errno, "Hseek");
return true;
} // endif
} // endif mode
#endif // UNIX #endif // UNIX
return false; return false;
} // end of Open } // end of Open
#if 0
/***********************************************************************/ /***********************************************************************/
/* Get the offset of this index in the index file. */ /* Get the offset of this index in the index file. */
/***********************************************************************/ /***********************************************************************/
...@@ -2486,6 +2601,7 @@ bool XHUGE::GetOff(int& low, int& high, PIXDEF sxp) ...@@ -2486,6 +2601,7 @@ bool XHUGE::GetOff(int& low, int& high, PIXDEF sxp)
#endif // UNIX #endif // UNIX
return false; return false;
} // end of GetOff } // end of GetOff
#endif // 0
/***********************************************************************/ /***********************************************************************/
/* Go to position in a huge file. */ /* Go to position in a huge file. */
...@@ -2608,6 +2724,38 @@ int XHUGE::Write(PGLOBAL g, void *buf, int n, int size, bool& rc) ...@@ -2608,6 +2724,38 @@ int XHUGE::Write(PGLOBAL g, void *buf, int n, int size, bool& rc)
#endif // UNIX #endif // UNIX
} // end of Write } // end of Write
/***********************************************************************/
/* Update the file header and close the index file. */
/***********************************************************************/
void XHUGE::Close(char *fn, int id)
{
#if defined(WIN32)
if (id >= 0 && fn) {
CloseFileHandle(Hfile);
Hfile = CreateFile(fn, GENERIC_READ | GENERIC_WRITE, 0, NULL,
OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
if (Hfile != INVALID_HANDLE_VALUE)
if (SetFilePointer(Hfile, id * sizeof(IOFF), NULL, FILE_BEGIN)
!= INVALID_SET_FILE_POINTER) {
DWORD nbw;
WriteFile(Hfile, &NewOff, sizeof(longlong), &nbw, NULL);
// WriteFile(Hfile, &Newhigh, sizeof(int), &nbw, NULL);
} // endif SetFilePointer
} // endif id
#else // !WIN32
if (id >= 0 && fn) {
fnctl(Hfile, F_SETFD, O_WRONLY);
if (lseek(Hfile, id * sizeof(IOFF), SEEK_SET))
write(Hfile, &noff[id], sizeof(IOFF));
} // endif id
#endif // !WIN32
XLOAD::Close();
} // end of Close
#if defined(XMAP) #if defined(XMAP)
#if defined(WIN32) #if defined(WIN32)
/***********************************************************************/ /***********************************************************************/
......
...@@ -58,6 +58,13 @@ typedef struct index_def : public BLOCK { ...@@ -58,6 +58,13 @@ typedef struct index_def : public BLOCK {
bool Alloc; // Must allocate values bool Alloc; // Must allocate values
} INDX; } INDX;
typedef struct index_off {
union {
struct {int Low; int High;};
longlong Val; // File position
}; // end of union
} IOFF;
/***********************************************************************/ /***********************************************************************/
/* Index definition block. */ /* Index definition block. */
/***********************************************************************/ /***********************************************************************/
...@@ -85,10 +92,10 @@ class DllExport INDEXDEF : public BLOCK { /* Index description block */ ...@@ -85,10 +92,10 @@ class DllExport INDEXDEF : public BLOCK { /* Index description block */
void SetNParts(uint np) {Nparts = (signed)np;} void SetNParts(uint np) {Nparts = (signed)np;}
void SetMaxSame(int mxs) {MaxSame = mxs;} void SetMaxSame(int mxs) {MaxSame = mxs;}
void SetMxsame(PXINDEX x); void SetMxsame(PXINDEX x);
int GetOffset(void) {return Offset;} //int GetOffset(void) {return Offset;}
void SetOffset(int off) {Offset = off;} //void SetOffset(int off) {Offset = off;}
int GetOffhigh(void) {return Offhigh;} //int GetOffhigh(void) {return Offhigh;}
void SetOffhigh(int hof) {Offhigh = hof;} //void SetOffhigh(int hof) {Offhigh = hof;}
int GetSize(void) {return Size;} int GetSize(void) {return Size;}
void SetSize(int size) {Size = size;} void SetSize(int size) {Size = size;}
int GetMaxSame(void) {return MaxSame;} int GetMaxSame(void) {return MaxSame;}
...@@ -110,8 +117,8 @@ class DllExport INDEXDEF : public BLOCK { /* Index description block */ ...@@ -110,8 +117,8 @@ class DllExport INDEXDEF : public BLOCK { /* Index description block */
bool AutoInc; /* true if unique key in auto increment */ bool AutoInc; /* true if unique key in auto increment */
int Nparts; /* Number of key parts */ int Nparts; /* Number of key parts */
int ID; /* Index ID number */ int ID; /* Index ID number */
int Offset; /* Offset in index file */ //int Offset; /* Offset in index file */
int Offhigh; /* Offset high in big index file */ //int Offhigh; /* Offset high in big index file */
int Size; /* Size of index file */ int Size; /* Size of index file */
int MaxSame; /* Max number of same values */ int MaxSame; /* Max number of same values */
}; // end of INDEXDEF }; // end of INDEXDEF
...@@ -308,6 +315,7 @@ class DllExport XINDXS : public XINDEX { ...@@ -308,6 +315,7 @@ class DllExport XINDXS : public XINDEX {
/* This is the saving/loading index utility base class. */ /* This is the saving/loading index utility base class. */
/***********************************************************************/ /***********************************************************************/
class DllExport XLOAD : public BLOCK { class DllExport XLOAD : public BLOCK {
friend class XINDEX;
friend class XBIGEX; friend class XBIGEX;
friend class XBIGXS; friend class XBIGXS;
public: public:
...@@ -315,12 +323,13 @@ class DllExport XLOAD : public BLOCK { ...@@ -315,12 +323,13 @@ class DllExport XLOAD : public BLOCK {
XLOAD(void); XLOAD(void);
// Methods // Methods
virtual bool Open(PGLOBAL g, char *filename, MODE mode) = 0; virtual bool Open(PGLOBAL g, char *filename, int id, MODE mode) = 0;
virtual bool GetOff(int& low, int& high, PIXDEF sxp) = 0; //virtual bool GetOff(int& low, int& high, PIXDEF sxp) = 0;
virtual bool Seek(PGLOBAL g, int low, int high, int origin) = 0; virtual bool Seek(PGLOBAL g, int low, int high, int origin) = 0;
virtual bool Read(PGLOBAL g, void *buf, int n, int size) = 0; virtual bool Read(PGLOBAL g, void *buf, int n, int size) = 0;
virtual int Write(PGLOBAL g, void *buf, int n, virtual int Write(PGLOBAL g, void *buf, int n,
int size, bool& rc) = 0; int size, bool& rc) = 0;
virtual void Close(char *fn, int id) = 0;
virtual void Close(void); virtual void Close(void);
#if defined(XMAP) #if defined(XMAP)
virtual void *FileView(PGLOBAL g, char *fn, int loff, virtual void *FileView(PGLOBAL g, char *fn, int loff,
...@@ -337,6 +346,7 @@ class DllExport XLOAD : public BLOCK { ...@@ -337,6 +346,7 @@ class DllExport XLOAD : public BLOCK {
#else // UNIX #else // UNIX
int Hfile; // Descriptor to file or map int Hfile; // Descriptor to file or map
#endif // UNIX #endif // UNIX
IOFF NewOff; // New offset
}; // end of class XLOAD }; // end of class XLOAD
/***********************************************************************/ /***********************************************************************/
...@@ -348,11 +358,12 @@ class DllExport XFILE : public XLOAD { ...@@ -348,11 +358,12 @@ class DllExport XFILE : public XLOAD {
XFILE(void); XFILE(void);
// Methods // Methods
virtual bool Open(PGLOBAL g, char *filename, MODE mode); virtual bool Open(PGLOBAL g, char *filename, int id, MODE mode);
virtual bool GetOff(int& low, int& high, PIXDEF sxp); //virtual bool GetOff(int& low, int& high, PIXDEF sxp);
virtual bool Seek(PGLOBAL g, int low, int high, int origin); virtual bool Seek(PGLOBAL g, int low, int high, int origin);
virtual bool Read(PGLOBAL g, void *buf, int n, int size); virtual bool Read(PGLOBAL g, void *buf, int n, int size);
virtual int Write(PGLOBAL g, void *buf, int n, int size, bool& rc); virtual int Write(PGLOBAL g, void *buf, int n, int size, bool& rc);
virtual void Close(char *fn, int id);
virtual void Close(void); virtual void Close(void);
#if defined(XMAP) #if defined(XMAP)
virtual void *FileView(PGLOBAL g, char *fn, int loff, virtual void *FileView(PGLOBAL g, char *fn, int loff,
...@@ -376,11 +387,12 @@ class DllExport XHUGE : public XLOAD { ...@@ -376,11 +387,12 @@ class DllExport XHUGE : public XLOAD {
XHUGE(void) : XLOAD() {} XHUGE(void) : XLOAD() {}
// Methods // Methods
virtual bool Open(PGLOBAL g, char *filename, MODE mode); virtual bool Open(PGLOBAL g, char *filename, int id, MODE mode);
virtual bool GetOff(int& low, int& high, PIXDEF sxp); //virtual bool GetOff(int& low, int& high, PIXDEF sxp);
virtual bool Seek(PGLOBAL g, int low, int high, int origin); virtual bool Seek(PGLOBAL g, int low, int high, int origin);
virtual bool Read(PGLOBAL g, void *buf, int n, int size); virtual bool Read(PGLOBAL g, void *buf, int n, int size);
virtual int Write(PGLOBAL g, void *buf, int n, int size, bool& rc); virtual int Write(PGLOBAL g, void *buf, int n, int size, bool& rc);
virtual void Close(char *fn, int id);
#if defined(XMAP) #if defined(XMAP)
virtual void *FileView(PGLOBAL g, char *fn, int loff, virtual void *FileView(PGLOBAL g, char *fn, int loff,
int hoff, int size); int hoff, int size);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment