mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-15 15:41:24 +01:00
dicts are read-only: use query rather than get
This commit is contained in:
parent
a4c3922d6e
commit
d3c06219c1
1 changed files with 7 additions and 17 deletions
|
@ -52,7 +52,6 @@ static void palm_dictionary_destroy( DictionaryCtxt* dict );
|
||||||
static XP_U16 countSpecials( unsigned char* ptr, UInt16 nChars );
|
static XP_U16 countSpecials( unsigned char* ptr, UInt16 nChars );
|
||||||
static void setupSpecials( MPFORMAL PalmDictionaryCtxt* ctxt,
|
static void setupSpecials( MPFORMAL PalmDictionaryCtxt* ctxt,
|
||||||
Xloc_specialEntry* specialStart, XP_U16 nSpecials );
|
Xloc_specialEntry* specialStart, XP_U16 nSpecials );
|
||||||
static void unlockAndRelease( MemPtr p, DmOpenRef dbRef, short recIndex );
|
|
||||||
|
|
||||||
DictionaryCtxt*
|
DictionaryCtxt*
|
||||||
palm_dictionary_make( MPFORMAL XP_UCHAR* dictName, PalmDictList* dl )
|
palm_dictionary_make( MPFORMAL XP_UCHAR* dictName, PalmDictList* dl )
|
||||||
|
@ -124,7 +123,7 @@ palm_dictionary_make( MPFORMAL XP_UCHAR* dictName, PalmDictList* dl )
|
||||||
ctxt->location = dle->location;
|
ctxt->location = dle->location;
|
||||||
|
|
||||||
ctxt->dbRef = dbRef = DmOpenDatabase( cardNo, dbID, dmModeReadOnly );
|
ctxt->dbRef = dbRef = DmOpenDatabase( cardNo, dbID, dmModeReadOnly );
|
||||||
tmpH = DmGetRecord( dbRef, 0 ); // <- <eeh> should be a constant
|
tmpH = DmQueryRecord( dbRef, 0 ); // <- <eeh> should be a constant
|
||||||
ctxt->headerRecP = headerRecP = (dawg_header*)MemHandleLock( tmpH );
|
ctxt->headerRecP = headerRecP = (dawg_header*)MemHandleLock( tmpH );
|
||||||
XP_ASSERT( MemHandleLockCount(tmpH) == 1 );
|
XP_ASSERT( MemHandleLockCount(tmpH) == 1 );
|
||||||
|
|
||||||
|
@ -140,9 +139,9 @@ palm_dictionary_make( MPFORMAL XP_UCHAR* dictName, PalmDictList* dl )
|
||||||
ctxt->super.faces16[i] = charPtr[i];
|
ctxt->super.faces16[i] = charPtr[i];
|
||||||
}
|
}
|
||||||
nSpecials = countSpecials( charPtr, nChars );
|
nSpecials = countSpecials( charPtr, nChars );
|
||||||
unlockAndRelease( charPtr, dbRef, headerRecP->charTableRecNum );
|
MemPtrUnlock( charPtr );
|
||||||
|
|
||||||
tmpH = DmGetRecord( dbRef, headerRecP->valTableRecNum );
|
tmpH = DmQueryRecord( dbRef, headerRecP->valTableRecNum );
|
||||||
charPtr = (unsigned char*)MemHandleLock(tmpH);
|
charPtr = (unsigned char*)MemHandleLock(tmpH);
|
||||||
XP_ASSERT( MemHandleLockCount( tmpH ) == 1 );
|
XP_ASSERT( MemHandleLockCount( tmpH ) == 1 );
|
||||||
ctxt->super.countsAndValues = charPtr + sizeof(Xloc_header);
|
ctxt->super.countsAndValues = charPtr + sizeof(Xloc_header);
|
||||||
|
@ -171,7 +170,7 @@ palm_dictionary_make( MPFORMAL XP_UCHAR* dictName, PalmDictList* dl )
|
||||||
|
|
||||||
for ( index = 0; index < nRecords; ++index ) {
|
for ( index = 0; index < nRecords; ++index ) {
|
||||||
MemHandle record =
|
MemHandle record =
|
||||||
DmGetRecord( dbRef, index + headerRecP->firstEdgeRecNum );
|
DmQueryRecord( dbRef, index + headerRecP->firstEdgeRecNum );
|
||||||
ctxt->dictStarts[index].indexStart = offset;
|
ctxt->dictStarts[index].indexStart = offset;
|
||||||
|
|
||||||
/* cast to short to avoid libc call */
|
/* cast to short to avoid libc call */
|
||||||
|
@ -248,13 +247,6 @@ setupSpecials( MPFORMAL PalmDictionaryCtxt* ctxt,
|
||||||
ctxt->super.chars = chars;
|
ctxt->super.chars = chars;
|
||||||
} /* setupSpecials */
|
} /* setupSpecials */
|
||||||
|
|
||||||
static void
|
|
||||||
unlockAndRelease( MemPtr p, DmOpenRef dbRef, short recIndex )
|
|
||||||
{
|
|
||||||
MemPtrUnlock( p );
|
|
||||||
DmReleaseRecord( dbRef, recIndex, false );
|
|
||||||
} /* unlockAndRelease */
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
palm_dictionary_destroy( DictionaryCtxt* dict )
|
palm_dictionary_destroy( DictionaryCtxt* dict )
|
||||||
{
|
{
|
||||||
|
@ -275,17 +267,15 @@ palm_dictionary_destroy( DictionaryCtxt* dict )
|
||||||
|
|
||||||
XP_ASSERT( !!dbRef );
|
XP_ASSERT( !!dbRef );
|
||||||
|
|
||||||
unlockAndRelease( ctxt->super.countsAndValues - sizeof(Xloc_header),
|
MemPtrUnlock( ctxt->super.countsAndValues - sizeof(Xloc_header) );
|
||||||
dbRef, headerRecP->valTableRecNum );
|
|
||||||
|
|
||||||
XP_FREE( dict->mpool, ctxt->super.faces16 );
|
XP_FREE( dict->mpool, ctxt->super.faces16 );
|
||||||
|
|
||||||
for ( i = 0; i < ctxt->nRecords; ++i ) {
|
for ( i = 0; i < ctxt->nRecords; ++i ) {
|
||||||
unlockAndRelease( ctxt->dictStarts[i].array,
|
MemPtrUnlock( ctxt->dictStarts[i].array );
|
||||||
dbRef, i + headerRecP->firstEdgeRecNum );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
unlockAndRelease( headerRecP, dbRef, 0 );
|
MemPtrUnlock( headerRecP );
|
||||||
|
|
||||||
DmCloseDatabase( dbRef );
|
DmCloseDatabase( dbRef );
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue