mirror of
https://github.com/nillerusr/source-engine.git
synced 2025-01-11 23:57:59 +00:00
tier1: rewrite Sys_LoadModule
This commit is contained in:
parent
653e08bce4
commit
e5eaf0fa9e
@ -5042,10 +5042,11 @@ CSysModule *CBaseFileSystem::LoadModule( const char *pFileName, const char *pPat
|
|||||||
|
|
||||||
char tempPathID[ MAX_PATH ];
|
char tempPathID[ MAX_PATH ];
|
||||||
ParsePathID( pFileName, pPathID, tempPathID );
|
ParsePathID( pFileName, pPathID, tempPathID );
|
||||||
|
|
||||||
CUtlSymbol lookup = g_PathIDTable.AddString( pPathID );
|
CUtlSymbol lookup = g_PathIDTable.AddString( pPathID );
|
||||||
|
|
||||||
// a pathID has been specified, find the first match in the path list
|
// a pathID has been specified, find the first match in the path list
|
||||||
|
#ifndef ANDROID
|
||||||
int c = m_SearchPaths.Count();
|
int c = m_SearchPaths.Count();
|
||||||
for ( int i = 0; i < c; i++ )
|
for ( int i = 0; i < c; i++ )
|
||||||
{
|
{
|
||||||
@ -5071,14 +5072,6 @@ CSysModule *CBaseFileSystem::LoadModule( const char *pFileName, const char *pPat
|
|||||||
return pModule;
|
return pModule;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#ifdef POSIX
|
|
||||||
if( !pModule )
|
|
||||||
{
|
|
||||||
Q_snprintf( tempPathID, sizeof(tempPathID), "lib%s", pFileName );
|
|
||||||
pModule = Sys_LoadModule( tempPathID );
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if( !pModule )
|
if( !pModule )
|
||||||
|
@ -258,7 +258,7 @@ HMODULE Sys_LoadLibrary( const char *pLibraryName, Sys_Flags flags )
|
|||||||
const char *pError = dlerror();
|
const char *pError = dlerror();
|
||||||
if ( pError && ( strstr( pError, "No such file" ) == 0 ) && ( strstr( pError, "image not found" ) == 0 ) )
|
if ( pError && ( strstr( pError, "No such file" ) == 0 ) && ( strstr( pError, "image not found" ) == 0 ) )
|
||||||
{
|
{
|
||||||
Msg( " failed to dlopen %s error=%s\n", str, pError );
|
Msg( "failed to dlopen %s error=%s\n", str, pError );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -267,6 +267,36 @@ HMODULE Sys_LoadLibrary( const char *pLibraryName, Sys_Flags flags )
|
|||||||
}
|
}
|
||||||
static bool s_bRunningWithDebugModules = false;
|
static bool s_bRunningWithDebugModules = false;
|
||||||
|
|
||||||
|
#ifdef POSIX
|
||||||
|
|
||||||
|
#ifdef ANDROID
|
||||||
|
#define DEFAULT_LIB_PATH ""
|
||||||
|
#else
|
||||||
|
#define DEFAULT_LIB_PATH "bin/"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
bool foundLibraryWithPrefix( char *pModuleAbsolutePath, size_t AbsolutePathSize, const char *pPath, const char *pModuleName )
|
||||||
|
{
|
||||||
|
char str[1024];
|
||||||
|
Q_strncpy( str, pModuleName, sizeof(str) );
|
||||||
|
V_SetExtension( str, DLL_EXT_STRING, sizeof(str) );
|
||||||
|
bool bFound = false;
|
||||||
|
|
||||||
|
struct stat statBuf;
|
||||||
|
Q_snprintf(pModuleAbsolutePath, AbsolutePathSize, "%s/" DEFAULT_LIB_PATH "lib%s", pPath, str);
|
||||||
|
bFound |= stat(pModuleAbsolutePath, &statBuf) == 0;
|
||||||
|
|
||||||
|
if( !bFound )
|
||||||
|
{
|
||||||
|
Q_snprintf(pModuleAbsolutePath, AbsolutePathSize, "%s/" DEFAULT_LIB_PATH "%s", pPath, str);
|
||||||
|
bFound |= stat(pModuleAbsolutePath, &statBuf) == 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return bFound;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Purpose: Loads a DLL/component from disk and returns a handle to it
|
// Purpose: Loads a DLL/component from disk and returns a handle to it
|
||||||
// Input : *pModuleName - filename of the component
|
// Input : *pModuleName - filename of the component
|
||||||
@ -301,52 +331,61 @@ CSysModule *Sys_LoadModule( const char *pModuleName, Sys_Flags flags /* = SYS_NO
|
|||||||
szCwd[strlen(szCwd) - 1] = 0;
|
szCwd[strlen(szCwd) - 1] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
char szAbsoluteModuleName[1024];
|
char szAbsoluteModuleName[2048];
|
||||||
bool bUseLibPrefix = false;
|
|
||||||
|
|
||||||
#ifdef ANDROID
|
#ifdef ANDROID
|
||||||
struct stat statBuf;
|
|
||||||
char *libPath = getenv("APP_LIB_PATH");
|
char *libPath = getenv("APP_LIB_PATH");
|
||||||
|
|
||||||
char *modLibPath = getenv("APP_MOD_LIB");
|
char *modLibPath = getenv("APP_MOD_LIB");
|
||||||
|
bool bFound;
|
||||||
|
|
||||||
if( modLibPath && *modLibPath ) // first load library from mod launcher
|
if( modLibPath && *modLibPath ) // first load library from mod launcher
|
||||||
{
|
{
|
||||||
bool bFound = true;
|
bFound = foundLibraryWithPrefix( szAbsoluteModuleName, sizeof(szAbsoluteModuleName), modLibPath, pModuleName );
|
||||||
Q_snprintf(szAbsoluteModuleName, sizeof(szAbsoluteModuleName), "%s/lib%s", modLibPath, pModuleName);
|
|
||||||
if( stat(szAbsoluteModuleName, &statBuf) != 0 )
|
|
||||||
{
|
|
||||||
Q_snprintf(szAbsoluteModuleName, sizeof(szAbsoluteModuleName), "%s/%s", modLibPath, pModuleName);
|
|
||||||
if( stat(szAbsoluteModuleName, &statBuf) != 0 )
|
|
||||||
bFound = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
hDLL = Sys_LoadLibrary(szAbsoluteModuleName, flags);
|
if( bFound )
|
||||||
|
hDLL = Sys_LoadLibrary( szAbsoluteModuleName, flags );
|
||||||
|
|
||||||
if( !hDLL && bFound )
|
if( !hDLL && bFound )
|
||||||
Error("Can't load mod library %s\n", szAbsoluteModuleName);
|
Error("Can't find mod library %s\n", szAbsoluteModuleName);
|
||||||
}
|
}
|
||||||
|
|
||||||
Q_snprintf(szAbsoluteModuleName, sizeof(szAbsoluteModuleName), "%s/lib%s", libPath ,pModuleName);
|
if( !foundLibraryWithPrefix( szAbsoluteModuleName, sizeof(szAbsoluteModuleName), libPath, pModuleName ) )
|
||||||
if( stat(szAbsoluteModuleName, &statBuf) != 0 )
|
{
|
||||||
Q_snprintf(szAbsoluteModuleName, sizeof(szAbsoluteModuleName), "%s/%s", libPath ,pModuleName);
|
Warning("Can't find module - %s\n", pModuleName);
|
||||||
|
return reinterpret_cast<CSysModule *>(hDLL);
|
||||||
|
}
|
||||||
|
|
||||||
|
#elif defined( POSIX )
|
||||||
|
if( !foundLibraryWithPrefix(szAbsoluteModuleName, sizeof(szAbsoluteModuleName), szCwd, pModuleName) )
|
||||||
|
{
|
||||||
|
Warning("Can't find module - %s\n", pModuleName);
|
||||||
|
return reinterpret_cast<CSysModule *>(hDLL);
|
||||||
|
}
|
||||||
#else
|
#else
|
||||||
#ifdef POSIX
|
Q_snprintf( szAbsoluteModuleName, sizeof(szAbsoluteModuleName), "%s/bin/%s", szCwd, pModuleName );
|
||||||
struct stat statBuf;
|
|
||||||
Q_snprintf(szModuleName, sizeof(szModuleName), "bin/lib%s", pModuleName);
|
|
||||||
bUseLibPrefix |= stat(szModuleName, &statBuf) == 0;
|
|
||||||
#endif
|
#endif
|
||||||
if( bUseLibPrefix )
|
|
||||||
Q_snprintf( szAbsoluteModuleName, sizeof(szAbsoluteModuleName), "%s/bin/lib%s", szCwd, pModuleName );
|
|
||||||
else
|
|
||||||
Q_snprintf( szAbsoluteModuleName, sizeof(szAbsoluteModuleName), "%s/bin/%s", szCwd, pModuleName );
|
|
||||||
#endif // ANDROID
|
|
||||||
Msg("LoadLibrary: pModule: %s, path: %s\n", pModuleName, szAbsoluteModuleName);
|
Msg("LoadLibrary: pModule: %s, path: %s\n", pModuleName, szAbsoluteModuleName);
|
||||||
|
|
||||||
if( !hDLL )
|
if( !hDLL )
|
||||||
hDLL = Sys_LoadLibrary( szAbsoluteModuleName, flags );
|
hDLL = Sys_LoadLibrary( szAbsoluteModuleName, flags );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
Msg("LoadLibrary: path: %s\n", pModuleName);
|
{
|
||||||
|
#ifdef POSIX
|
||||||
|
Q_strncpy( szModuleName, pModuleName, sizeof(szModuleName) );
|
||||||
|
V_SetExtension( szModuleName, DLL_EXT_STRING, sizeof(szModuleName) );
|
||||||
|
|
||||||
|
struct stat statBuf;
|
||||||
|
bool bFound = stat(szModuleName, &statBuf) == 0;
|
||||||
|
|
||||||
|
if( !bFound )
|
||||||
|
{
|
||||||
|
Warning("Can't find module - %s\n", pModuleName);
|
||||||
|
return reinterpret_cast<CSysModule *>(hDLL);
|
||||||
|
}
|
||||||
|
|
||||||
|
Msg("LoadLibrary: path: %s\n", szModuleName);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if ( !hDLL )
|
if ( !hDLL )
|
||||||
|
@ -155,7 +155,7 @@ m_HideTooltip( this, &HTML::BrowserHideToolTip )
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Warning("Unable to access SteamHTMLSurface");
|
Warning("Unable to access SteamHTMLSurface\n");
|
||||||
}
|
}
|
||||||
m_iScrollBorderX=m_iScrollBorderY=0;
|
m_iScrollBorderX=m_iScrollBorderY=0;
|
||||||
m_bScrollBarEnabled = true;
|
m_bScrollBarEnabled = true;
|
||||||
|
Loading…
Reference in New Issue
Block a user