Commit 6d76a209 authored by Ulrich Weigand's avatar Ulrich Weigand Committed by Alexandre Julliard

Modify NE_FindTypeSection and NE_FindResourceFromType so as to be

usable by the VERSION code.
parent 9a61495c
...@@ -174,6 +174,9 @@ extern INT16 NE_AccessResource( NE_MODULE *pModule, HRSRC16 hRsrc ); ...@@ -174,6 +174,9 @@ extern INT16 NE_AccessResource( NE_MODULE *pModule, HRSRC16 hRsrc );
extern DWORD NE_SizeofResource( NE_MODULE *pModule, HRSRC16 hRsrc ); extern DWORD NE_SizeofResource( NE_MODULE *pModule, HRSRC16 hRsrc );
extern HGLOBAL16 NE_LoadResource( NE_MODULE *pModule, HRSRC16 hRsrc ); extern HGLOBAL16 NE_LoadResource( NE_MODULE *pModule, HRSRC16 hRsrc );
extern BOOL16 NE_FreeResource( NE_MODULE *pModule, HGLOBAL16 handle ); extern BOOL16 NE_FreeResource( NE_MODULE *pModule, HGLOBAL16 handle );
extern NE_TYPEINFO *NE_FindTypeSection( LPBYTE pResTab, NE_TYPEINFO *pTypeInfo, LPCSTR typeId );
extern NE_NAMEINFO *NE_FindResourceFromType( LPBYTE pResTab, NE_TYPEINFO *pTypeInfo, LPCSTR resId );
/* loader/ne/segment.c */ /* loader/ne/segment.c */
extern BOOL32 NE_LoadSegment( NE_MODULE *pModule, WORD segnum ); extern BOOL32 NE_LoadSegment( NE_MODULE *pModule, WORD segnum );
......
...@@ -98,7 +98,7 @@ static DWORD NE_FindNameTableId( NE_MODULE *pModule, LPCSTR typeId, LPCSTR resId ...@@ -98,7 +98,7 @@ static DWORD NE_FindNameTableId( NE_MODULE *pModule, LPCSTR typeId, LPCSTR resId
* *
* Find header struct for a particular resource type. * Find header struct for a particular resource type.
*/ */
static NE_TYPEINFO* NE_FindTypeSection( NE_MODULE *pModule, NE_TYPEINFO *NE_FindTypeSection( LPBYTE pResTab,
NE_TYPEINFO *pTypeInfo, LPCSTR typeId ) NE_TYPEINFO *pTypeInfo, LPCSTR typeId )
{ {
/* start from pTypeInfo */ /* start from pTypeInfo */
...@@ -111,7 +111,7 @@ static NE_TYPEINFO* NE_FindTypeSection( NE_MODULE *pModule, ...@@ -111,7 +111,7 @@ static NE_TYPEINFO* NE_FindTypeSection( NE_MODULE *pModule,
{ {
if (!(pTypeInfo->type_id & 0x8000)) if (!(pTypeInfo->type_id & 0x8000))
{ {
BYTE *p = (BYTE*)pModule + pModule->res_table + pTypeInfo->type_id; BYTE *p = pResTab + pTypeInfo->type_id;
if ((*p == len) && !lstrncmpi32A( p+1, str, len )) if ((*p == len) && !lstrncmpi32A( p+1, str, len ))
{ {
TRACE(resource, " Found type '%s'\n", str ); TRACE(resource, " Found type '%s'\n", str );
...@@ -144,7 +144,7 @@ static NE_TYPEINFO* NE_FindTypeSection( NE_MODULE *pModule, ...@@ -144,7 +144,7 @@ static NE_TYPEINFO* NE_FindTypeSection( NE_MODULE *pModule,
* *
* Find a resource once the type info structure has been found. * Find a resource once the type info structure has been found.
*/ */
static HRSRC16 NE_FindResourceFromType( NE_MODULE *pModule, NE_NAMEINFO *NE_FindResourceFromType( LPBYTE pResTab,
NE_TYPEINFO *pTypeInfo, LPCSTR resId ) NE_TYPEINFO *pTypeInfo, LPCSTR resId )
{ {
BYTE *p; BYTE *p;
...@@ -158,9 +158,9 @@ static HRSRC16 NE_FindResourceFromType( NE_MODULE *pModule, ...@@ -158,9 +158,9 @@ static HRSRC16 NE_FindResourceFromType( NE_MODULE *pModule,
for (count = pTypeInfo->count; count > 0; count--, pNameInfo++) for (count = pTypeInfo->count; count > 0; count--, pNameInfo++)
{ {
if (pNameInfo->id & 0x8000) continue; if (pNameInfo->id & 0x8000) continue;
p = (BYTE *)pModule + pModule->res_table + pNameInfo->id; p = pResTab + pNameInfo->id;
if ((*p == len) && !lstrncmpi32A( p+1, str, len )) if ((*p == len) && !lstrncmpi32A( p+1, str, len ))
return (HRSRC16)((int)pNameInfo - (int)pModule); return pNameInfo;
} }
} }
else /* Numeric resource id */ else /* Numeric resource id */
...@@ -168,9 +168,9 @@ static HRSRC16 NE_FindResourceFromType( NE_MODULE *pModule, ...@@ -168,9 +168,9 @@ static HRSRC16 NE_FindResourceFromType( NE_MODULE *pModule,
WORD id = LOWORD(resId) | 0x8000; WORD id = LOWORD(resId) | 0x8000;
for (count = pTypeInfo->count; count > 0; count--, pNameInfo++) for (count = pTypeInfo->count; count > 0; count--, pNameInfo++)
if (pNameInfo->id == id) if (pNameInfo->id == id)
return (HRSRC16)((int)pNameInfo - (int)pModule); return pNameInfo;
} }
return 0; return NULL;
} }
...@@ -241,7 +241,8 @@ FARPROC16 WINAPI SetResourceHandler( HMODULE16 hModule, SEGPTR typeId, ...@@ -241,7 +241,8 @@ FARPROC16 WINAPI SetResourceHandler( HMODULE16 hModule, SEGPTR typeId,
{ {
FARPROC16 prevHandler = NULL; FARPROC16 prevHandler = NULL;
NE_MODULE *pModule = NE_GetPtr( hModule ); NE_MODULE *pModule = NE_GetPtr( hModule );
NE_TYPEINFO *pTypeInfo = (NE_TYPEINFO *)((char *)pModule + pModule->res_table + 2); LPBYTE pResTab = (LPBYTE)pModule + pModule->res_table;
NE_TYPEINFO *pTypeInfo = (NE_TYPEINFO *)(pResTab + 2);
if (!pModule || !pModule->res_table) return NULL; if (!pModule || !pModule->res_table) return NULL;
...@@ -250,7 +251,7 @@ FARPROC16 WINAPI SetResourceHandler( HMODULE16 hModule, SEGPTR typeId, ...@@ -250,7 +251,7 @@ FARPROC16 WINAPI SetResourceHandler( HMODULE16 hModule, SEGPTR typeId,
for (;;) for (;;)
{ {
if (!(pTypeInfo = NE_FindTypeSection( pModule, pTypeInfo, PTR_SEG_TO_LIN(typeId) ))) if (!(pTypeInfo = NE_FindTypeSection( pResTab, pTypeInfo, PTR_SEG_TO_LIN(typeId) )))
break; break;
prevHandler = pTypeInfo->resloader; prevHandler = pTypeInfo->resloader;
pTypeInfo->resloader = resourceHandler; pTypeInfo->resloader = resourceHandler;
...@@ -266,7 +267,8 @@ FARPROC16 WINAPI SetResourceHandler( HMODULE16 hModule, SEGPTR typeId, ...@@ -266,7 +267,8 @@ FARPROC16 WINAPI SetResourceHandler( HMODULE16 hModule, SEGPTR typeId,
HRSRC16 NE_FindResource( NE_MODULE *pModule, LPCSTR name, LPCSTR type ) HRSRC16 NE_FindResource( NE_MODULE *pModule, LPCSTR name, LPCSTR type )
{ {
NE_TYPEINFO *pTypeInfo; NE_TYPEINFO *pTypeInfo;
HRSRC16 hRsrc; NE_NAMEINFO *pNameInfo;
LPBYTE pResTab;
if (!pModule || !pModule->res_table) return 0; if (!pModule || !pModule->res_table) return 0;
...@@ -306,16 +308,17 @@ HRSRC16 NE_FindResource( NE_MODULE *pModule, LPCSTR name, LPCSTR type ) ...@@ -306,16 +308,17 @@ HRSRC16 NE_FindResource( NE_MODULE *pModule, LPCSTR name, LPCSTR type )
} }
} }
pTypeInfo = (NE_TYPEINFO *)((char *)pModule + pModule->res_table + 2); pResTab = (LPBYTE)pModule + pModule->res_table;
pTypeInfo = (NE_TYPEINFO *)( pResTab + 2 );
for (;;) for (;;)
{ {
if (!(pTypeInfo = NE_FindTypeSection( pModule, pTypeInfo, type ))) if (!(pTypeInfo = NE_FindTypeSection( pResTab, pTypeInfo, type )))
break; break;
if ((hRsrc = NE_FindResourceFromType(pModule, pTypeInfo, name))) if ((pNameInfo = NE_FindResourceFromType( pResTab, pTypeInfo, name )))
{ {
TRACE(resource, " Found id %08lx\n", (DWORD)name ); TRACE(resource, " Found id %08lx\n", (DWORD)name );
return hRsrc; return (HRSRC16)( (int)pNameInfo - (int)pModule );
} }
TRACE(resource, " Not found, going on\n" ); TRACE(resource, " Not found, going on\n" );
pTypeInfo = NEXT_TYPEINFO(pTypeInfo); pTypeInfo = NEXT_TYPEINFO(pTypeInfo);
......
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