From c4f739b8d03ca203435744c4a96e3561863ccdfe Mon Sep 17 00:00:00 2001 From: Thilo Schulz Date: Sun, 24 Jul 2011 22:12:21 +0000 Subject: [PATCH] Fix extension name comparison for DLL files --- code/qcommon/files.c | 2 +- code/qcommon/q_shared.c | 24 ++++++++++++++++++++++++ code/qcommon/q_shared.h | 1 + 3 files changed, 26 insertions(+), 1 deletion(-) diff --git a/code/qcommon/files.c b/code/qcommon/files.c index 7a7d80bb..d6921c92 100644 --- a/code/qcommon/files.c +++ b/code/qcommon/files.c @@ -557,7 +557,7 @@ static void FS_CheckFilenameIsNotExecutable( const char *filename, const char *function ) { // Check if the filename ends with the library extension - if( !Q_stricmp( COM_GetExtension( filename ), DLL_EXT ) ) + if(COM_CompareExtension(filename, DLL_EXT)) { Com_Error( ERR_FATAL, "%s: Not allowed to manipulate '%s' due " "to %s extension", function, filename, DLL_EXT ); diff --git a/code/qcommon/q_shared.c b/code/qcommon/q_shared.c index 4d6828dc..7285e51d 100644 --- a/code/qcommon/q_shared.c +++ b/code/qcommon/q_shared.c @@ -82,6 +82,30 @@ void COM_StripExtension( const char *in, char *out, int destsize ) Q_strncpyz(out, in, destsize); } +/* +============ +COM_CompareExtension + +string compare the end of the strings and return qtrue if strings match +============ +*/ +qboolean COM_CompareExtension(const char *in, const char *ext) +{ + int inlen, extlen; + + inlen = strlen(in); + extlen = strlen(ext); + + if(extlen <= inlen) + { + in += inlen - extlen; + + if(!Q_stricmp(in, ext)) + return qtrue; + } + + return qfalse; +} /* ================== diff --git a/code/qcommon/q_shared.h b/code/qcommon/q_shared.h index 6e97da56..b806e8f1 100644 --- a/code/qcommon/q_shared.h +++ b/code/qcommon/q_shared.h @@ -709,6 +709,7 @@ float Com_Clamp( float min, float max, float value ); char *COM_SkipPath( char *pathname ); const char *COM_GetExtension( const char *name ); void COM_StripExtension(const char *in, char *out, int destsize); +qboolean COM_CompareExtension(const char *in, const char *ext); void COM_DefaultExtension( char *path, int maxSize, const char *extension ); void COM_BeginParseSession( const char *name );