public: remove Q_strcat and Q_strcpy, and patch the code that uses it

This commit is contained in:
Alibek Omarov 2023-04-24 02:18:40 +03:00
parent 2261b0dcab
commit b16fa8eddc
23 changed files with 68 additions and 57 deletions

View File

@ -45,7 +45,7 @@ const char *CL_MsgInfo( int cmd )
{ {
static string sz; static string sz;
Q_strcpy( sz, "???" ); Q_strncpy( sz, "???", sizeof( sz ));
if( cmd >= 0 && cmd <= svc_lastmsg ) if( cmd >= 0 && cmd <= svc_lastmsg )
{ {

View File

@ -2569,7 +2569,7 @@ const char *pfnGetGameDirectory( void )
{ {
static char szGetGameDir[MAX_SYSPATH]; static char szGetGameDir[MAX_SYSPATH];
Q_strcpy( szGetGameDir, GI->gamefolder ); Q_strncpy( szGetGameDir, GI->gamefolder, sizeof( szGetGameDir ));
return szGetGameDir; return szGetGameDir;
} }

View File

@ -1294,15 +1294,15 @@ void CL_Rcon_f( void )
NET_Config( true, false ); // allow remote NET_Config( true, false ); // allow remote
Q_strcat( message, "rcon " ); Q_strncat( message, "rcon ", sizeof( message ));
Q_strcat( message, rcon_password.string ); Q_strncat( message, rcon_password.string, sizeof( message ));
Q_strcat( message, " " ); Q_strncat( message, " ", sizeof( message ) );
for( i = 1; i < Cmd_Argc(); i++ ) for( i = 1; i < Cmd_Argc(); i++ )
{ {
Cmd_Escape( command, Cmd_Argv( i ), sizeof( command )); Cmd_Escape( command, Cmd_Argv( i ), sizeof( command ));
Q_strcat( message, command ); Q_strncat( message, command, sizeof( message ));
Q_strcat( message, " " ); Q_strncat( message, " ", sizeof( message ));
} }
if( cls.state >= ca_connected ) if( cls.state >= ca_connected )

View File

@ -1498,9 +1498,9 @@ static void Touch_EditMove( touchEventType type, int fingerID, float x, float y,
touch.hidebutton->flags &= ~TOUCH_FL_HIDE; touch.hidebutton->flags &= ~TOUCH_FL_HIDE;
if( FBitSet( button->flags, TOUCH_FL_HIDE )) if( FBitSet( button->flags, TOUCH_FL_HIDE ))
Q_strcpy( touch.hidebutton->texturefile, "touch_default/edit_show" ); Q_strncpy( touch.hidebutton->texturefile, "touch_default/edit_show", sizeof( touch.hidebutton->texturefile ));
else else
Q_strcpy( touch.hidebutton->texturefile, "touch_default/edit_hide" ); Q_strncpy( touch.hidebutton->texturefile, "touch_default/edit_hide", sizeof( touch.hidebutton->texturefile ));
} }
} }
if( type == event_motion ) // shutdown button move if( type == event_motion ) // shutdown button move

View File

@ -512,7 +512,7 @@ static void R_GetRendererName( char *dest, size_t size, const char *opt )
else else
{ {
// full path // full path
Q_strcpy( dest, opt ); Q_strncpy( dest, opt, size );
} }
} }

View File

@ -142,7 +142,7 @@ static const char *VOX_GetDirectory( char *szpath, const char *psz, int nsize )
if( !p ) if( !p )
{ {
Q_strcpy( szpath, "vox/" ); Q_strncpy( szpath, "vox/", nsize );
return psz; return psz;
} }

View File

@ -218,6 +218,7 @@ void CL_TextMessageParse( byte *pMemFile, int fileSize )
client_textmessage_t textMessages[MAX_MESSAGES]; client_textmessage_t textMessages[MAX_MESSAGES];
int i, nameHeapSize, textHeapSize, messageSize, nameOffset; int i, nameHeapSize, textHeapSize, messageSize, nameOffset;
int messageCount, lastNamePos; int messageCount, lastNamePos;
size_t textHeapSizeRemaining;
lastNamePos = 0; lastNamePos = 0;
lineNumber = 0; lineNumber = 0;
@ -252,7 +253,7 @@ void CL_TextMessageParse( byte *pMemFile, int fileSize )
Con_Reportf( "TextMessage: unexpected '}' found, line %d\n", lineNumber ); Con_Reportf( "TextMessage: unexpected '}' found, line %d\n", lineNumber );
return; return;
} }
Q_strcpy( currentName, trim ); Q_strncpy( currentName, trim, sizeof( currentName ));
break; break;
case MSGFILE_TEXT: case MSGFILE_TEXT:
if( IsEndOfText( trim )) if( IsEndOfText( trim ))
@ -266,7 +267,7 @@ void CL_TextMessageParse( byte *pMemFile, int fileSize )
return; return;
} }
Q_strcpy( nameHeap + lastNamePos, currentName ); Q_strncpy( nameHeap + lastNamePos, currentName, sizeof( nameHeap ) - lastNamePos );
// terminate text in-place in the memory file // terminate text in-place in the memory file
// (it's temporary memory that will be deleted) // (it's temporary memory that will be deleted)
@ -329,15 +330,20 @@ void CL_TextMessageParse( byte *pMemFile, int fileSize )
// copy text & fixup pointers // copy text & fixup pointers
textHeapSizeRemaining = textHeapSize;
pCurrentText = pNameHeap + nameHeapSize; pCurrentText = pNameHeap + nameHeapSize;
for( i = 0; i < messageCount; i++ ) for( i = 0; i < messageCount; i++ )
{ {
size_t currentTextSize = Q_strlen( clgame.titles[i].pMessage ) + 1;
clgame.titles[i].pName = pNameHeap; // adjust name pointer (parallel buffer) clgame.titles[i].pName = pNameHeap; // adjust name pointer (parallel buffer)
Q_strcpy( pCurrentText, clgame.titles[i].pMessage ); // copy text over Q_strncpy( pCurrentText, clgame.titles[i].pMessage, textHeapSizeRemaining ); // copy text over
clgame.titles[i].pMessage = pCurrentText; clgame.titles[i].pMessage = pCurrentText;
pNameHeap += Q_strlen( pNameHeap ) + 1; pNameHeap += Q_strlen( pNameHeap ) + 1;
pCurrentText += Q_strlen( pCurrentText ) + 1; pCurrentText += currentTextSize;
textHeapSizeRemaining -= currentTextSize;
} }
if(( pCurrentText - (char *)clgame.titles ) != ( textHeapSize + nameHeapSize + messageSize )) if(( pCurrentText - (char *)clgame.titles ) != ( textHeapSize + nameHeapSize + messageSize ))

View File

@ -1162,13 +1162,13 @@ void Cmd_ForwardToServer( void )
str[0] = 0; str[0] = 0;
if( Q_stricmp( Cmd_Argv( 0 ), "cmd" )) if( Q_stricmp( Cmd_Argv( 0 ), "cmd" ))
{ {
Q_strcat( str, Cmd_Argv( 0 )); Q_strncat( str, Cmd_Argv( 0 ), sizeof( str ));
Q_strcat( str, " " ); Q_strncat( str, " ", sizeof( str ));
} }
if( Cmd_Argc() > 1 ) if( Cmd_Argc() > 1 )
Q_strcat( str, Cmd_Args( )); Q_strncat( str, Cmd_Args( ), sizeof( str ));
else Q_strcat( str, "\n" ); else Q_strncat( str, "\n", sizeof( str ));
MSG_WriteString( &cls.netchan.message, str ); MSG_WriteString( &cls.netchan.message, str );
} }

View File

@ -1006,7 +1006,7 @@ pfnGetGameDir
void GAME_EXPORT pfnGetGameDir( char *szGetGameDir ) void GAME_EXPORT pfnGetGameDir( char *szGetGameDir )
{ {
if( !szGetGameDir ) return; if( !szGetGameDir ) return;
Q_strcpy( szGetGameDir, GI->gamefolder ); Q_strncpy( szGetGameDir, GI->gamefolder, sizeof( GI->gamefolder ));
} }
qboolean COM_IsSafeFileToDownload( const char *filename ) qboolean COM_IsSafeFileToDownload( const char *filename )
@ -1070,13 +1070,15 @@ const char *COM_GetResourceTypeName( resourcetype_t restype )
char *_copystring( poolhandle_t mempool, const char *s, const char *filename, int fileline ) char *_copystring( poolhandle_t mempool, const char *s, const char *filename, int fileline )
{ {
size_t size;
char *b; char *b;
if( !s ) return NULL; if( !s ) return NULL;
if( !mempool ) mempool = host.mempool; if( !mempool ) mempool = host.mempool;
b = _Mem_Alloc( mempool, Q_strlen( s ) + 1, false, filename, fileline ); size = Q_strlen( s ) + 1;
Q_strcpy( b, s ); b = _Mem_Alloc( mempool, size, false, filename, fileline );
Q_strncpy( b, s, size );
return b; return b;
} }
@ -1101,7 +1103,6 @@ void *GAME_EXPORT pfnSequenceGet( const char *fileName, const char *entryName )
{ {
Msg( "Sequence_Get: file %s, entry %s\n", fileName, entryName ); Msg( "Sequence_Get: file %s, entry %s\n", fileName, entryName );
return Sequence_Get( fileName, entryName ); return Sequence_Get( fileName, entryName );
} }

View File

@ -571,7 +571,7 @@ qboolean Cmd_GetKeysList( const char *s, char *completedname, int length )
const char *keyname = Key_KeynumToString( i ); const char *keyname = Key_KeynumToString( i );
if(( *s == '*' ) || !Q_strnicmp( keyname, s, len)) if(( *s == '*' ) || !Q_strnicmp( keyname, s, len))
Q_strcpy( keys[numkeys++], keyname ); Q_strncpy( keys[numkeys++], keyname, sizeof( keys[0] ));
} }
if( !numkeys ) return false; if( !numkeys ) return false;
@ -765,7 +765,7 @@ qboolean Cmd_GetGamesList( const char *s, char *completedname, int length )
for( i = 0, numgamedirs = 0; i < FI->numgames; i++ ) for( i = 0, numgamedirs = 0; i < FI->numgames; i++ )
{ {
if(( *s == '*' ) || !Q_strnicmp( FI->games[i]->gamefolder, s, len)) if(( *s == '*' ) || !Q_strnicmp( FI->games[i]->gamefolder, s, len))
Q_strcpy( gamedirs[numgamedirs++], FI->games[i]->gamefolder ); Q_strncpy( gamedirs[numgamedirs++], FI->games[i]->gamefolder, sizeof( gamedirs[0] ));
} }
if( !numgamedirs ) return false; if( !numgamedirs ) return false;
@ -826,7 +826,7 @@ qboolean Cmd_GetCDList( const char *s, char *completedname, int length )
for( i = 0, numcdcommands = 0; i < 8; i++ ) for( i = 0, numcdcommands = 0; i < 8; i++ )
{ {
if(( *s == '*' ) || !Q_strnicmp( cd_command[i], s, len)) if(( *s == '*' ) || !Q_strnicmp( cd_command[i], s, len))
Q_strcpy( cdcommands[numcdcommands++], cd_command[i] ); Q_strncpy( cdcommands[numcdcommands++], cd_command[i], sizeof( cdcommands[0] ));
} }
if( !numcdcommands ) return false; if( !numcdcommands ) return false;

View File

@ -1119,8 +1119,8 @@ void Cvar_Set_f( void )
len = Q_strlen( Cmd_Argv(i) + 1 ); len = Q_strlen( Cmd_Argv(i) + 1 );
if( l + len >= MAX_CMD_TOKENS - 2 ) if( l + len >= MAX_CMD_TOKENS - 2 )
break; break;
Q_strcat( combined, Cmd_Argv( i )); Q_strncat( combined, Cmd_Argv( i ), sizeof( combined ));
if( i != c-1 ) Q_strcat( combined, " " ); if( i != c-1 ) Q_strncat( combined, " ", sizeof( combined ));
l += len; l += len;
} }

View File

@ -277,7 +277,9 @@ qboolean GAME_EXPORT Info_RemoveKey( char *s, const char *key )
if( !Q_strncmp( key, pkey, cmpsize )) if( !Q_strncmp( key, pkey, cmpsize ))
{ {
Q_strcpy( start, s ); // remove this part size_t size = Q_strlen( s ) + 1;
memmove( start, s, size ); // remove this part
return true; return true;
} }

View File

@ -1827,7 +1827,7 @@ static void Mod_LoadEntities( dbspmodel_t *bmod )
wadstring[MAX_TOKEN - 2] = 0; wadstring[MAX_TOKEN - 2] = 0;
if( !Q_strchr( wadstring, ';' )) if( !Q_strchr( wadstring, ';' ))
Q_strcat( wadstring, ";" ); Q_strncat( wadstring, ";", sizeof( wadstring ));
// parse wad pathes // parse wad pathes
for( pszWadFile = strtok( wadstring, ";" ); pszWadFile != NULL; pszWadFile = strtok( NULL, ";" )) for( pszWadFile = strtok( wadstring, ";" ); pszWadFile != NULL; pszWadFile = strtok( NULL, ";" ))

View File

@ -273,8 +273,8 @@ void Netchan_ReportFlow( netchan_t *chan )
Assert( chan != NULL ); Assert( chan != NULL );
Q_strcpy( incoming, Q_pretifymem((float)chan->flow[FLOW_INCOMING].totalbytes, 3 )); Q_strncpy( incoming, Q_pretifymem((float)chan->flow[FLOW_INCOMING].totalbytes, 3 ), sizeof( incoming ));
Q_strcpy( outgoing, Q_pretifymem((float)chan->flow[FLOW_OUTGOING].totalbytes, 3 )); Q_strncpy( outgoing, Q_pretifymem((float)chan->flow[FLOW_OUTGOING].totalbytes, 3 ), sizeof( outgoing ));
Con_DPrintf( "Signon network traffic: %s from server, %s to server\n", incoming, outgoing ); Con_DPrintf( "Signon network traffic: %s from server, %s to server\n", incoming, outgoing );
} }

View File

@ -793,7 +793,7 @@ static void Delta_InitFields( void )
pfile = COM_ParseFile( pfile, encodeDll, sizeof( encodeDll )); pfile = COM_ParseFile( pfile, encodeDll, sizeof( encodeDll ));
if( !Q_stricmp( encodeDll, "none" )) if( !Q_stricmp( encodeDll, "none" ))
Q_strcpy( encodeFunc, "null" ); Q_strncpy( encodeFunc, "null", sizeof( encodeFunc ));
else pfile = COM_ParseFile( pfile, encodeFunc, sizeof( encodeFunc )); else pfile = COM_ParseFile( pfile, encodeFunc, sizeof( encodeFunc ));
// jump to '{' // jump to '{'

View File

@ -1556,7 +1556,7 @@ static void Sequence_ParseFile( const char *fileName, qboolean isGlobal )
byte *buffer; byte *buffer;
fs_offset_t bufSize = 0; fs_offset_t bufSize = 0;
Q_strcpy( g_sequenceParseFileName, fileName ); Q_strncpy( g_sequenceParseFileName, fileName, sizeof( g_sequenceParseFileName ));
g_sequenceParseFileIsGlobal = isGlobal; g_sequenceParseFileIsGlobal = isGlobal;
buffer = FS_LoadFile( va("sequences/%s.seq", fileName ), &bufSize, true ); buffer = FS_LoadFile( va("sequences/%s.seq", fileName ), &bufSize, true );

View File

@ -50,11 +50,12 @@ static qboolean Sys_FindExecutable( const char *baseName, char *buf, size_t size
needTrailingSlash = ( envPath[length - 1] == '/' ) ? 0 : 1; needTrailingSlash = ( envPath[length - 1] == '/' ) ? 0 : 1;
if( length + baseNameLength + needTrailingSlash < size ) if( length + baseNameLength + needTrailingSlash < size )
{ {
Q_strncpy( buf, envPath, length + 1 ); string temp;
if( needTrailingSlash )
Q_strcpy( buf + length, "/" ); Q_strncpy( temp, envPath, length + 1 );
Q_strcpy( buf + length + needTrailingSlash, baseName ); Q_snprintf( buf, size, "%s%s%s",
buf[length + needTrailingSlash + baseNameLength] = '\0'; temp, needTrailingSlash ? "/" : "", baseName );
if( access( buf, X_OK ) == 0 ) if( access( buf, X_OK ) == 0 )
return true; return true;
} }

View File

@ -1050,8 +1050,8 @@ void SV_RemoteCommand( netadr_t from, sizebuf_t *msg )
remaining[0] = 0; remaining[0] = 0;
for( i = 2; i < Cmd_Argc(); i++ ) for( i = 2; i < Cmd_Argc(); i++ )
{ {
Q_strcat( remaining, Cmd_Argv( i )); Q_strncat( remaining, Cmd_Argv( i ), sizeof( remaining ));
Q_strcat( remaining, " " ); Q_strncat( remaining, " ", sizeof( remaining ));
} }
Cmd_ExecuteString( remaining ); Cmd_ExecuteString( remaining );
} }
@ -3384,8 +3384,8 @@ void SV_ParseCvarValue2( sv_client_t *cl, sizebuf_t *msg )
string name, value; string name, value;
int requestID = MSG_ReadLong( msg ); int requestID = MSG_ReadLong( msg );
Q_strcpy( name, MSG_ReadString( msg )); Q_strncpy( name, MSG_ReadString( msg ), sizeof( name ));
Q_strcpy( value, MSG_ReadString( msg )); Q_strncpy( value, MSG_ReadString( msg ), sizeof( value ));
if( svgame.dllFuncs2.pfnCvarValue2 != NULL ) if( svgame.dllFuncs2.pfnCvarValue2 != NULL )
svgame.dllFuncs2.pfnCvarValue2( cl->edict, requestID, name, value ); svgame.dllFuncs2.pfnCvarValue2( cl->edict, requestID, name, value );

View File

@ -37,9 +37,12 @@ GNU General Public License for more details.
// PLATFORM platform // PLATFORM platform
// CONFIG platform/config // CONFIG platform/config
// This is a macro because pointers returned by alloca
// shouldn't leave current scope
#define FixupPath( var, str ) \ #define FixupPath( var, str ) \
char *var = static_cast<char *>( alloca( Q_strlen(( str )) + 1 )); \ const size_t var ## _size = Q_strlen(( str )) + 1; \
CopyAndFixSlashes(( var ),( str )) char * const var = static_cast<char *>( alloca( var ## _size )); \
CopyAndFixSlashes( var, ( str ), var ## _size )
static inline bool IsIdGamedir( const char *id ) static inline bool IsIdGamedir( const char *id )
{ {
@ -72,9 +75,9 @@ static inline const char *IdToDir( char *dir, size_t size, const char *id )
return fs_rootdir; // give at least root directory return fs_rootdir; // give at least root directory
} }
static inline void CopyAndFixSlashes( char *p, const char *in ) static inline void CopyAndFixSlashes( char *p, const char *in, size_t size )
{ {
Q_strcpy( p, in ); Q_strncpy( p, in, size );
COM_FixSlashes( p ); COM_FixSlashes( p );
} }
@ -419,12 +422,12 @@ public:
if( !Q_strnicmp( sp->filename, p, splen )) if( !Q_strnicmp( sp->filename, p, splen ))
{ {
Q_strcpy( out, p + splen + 1 ); Q_strncpy( out, p + splen + 1, 512 );
return true; return true;
} }
} }
Q_strcpy( out, p ); Q_strncpy( out, p, 512 );
return false; return false;
} }
@ -469,7 +472,7 @@ public:
char dir[MAX_VA_STRING], fullpath[MAX_VA_STRING]; char dir[MAX_VA_STRING], fullpath[MAX_VA_STRING];
Q_snprintf( fullpath, sizeof( fullpath ), "%s/%s", IdToDir( dir, sizeof( dir ), id ), path ); Q_snprintf( fullpath, sizeof( fullpath ), "%s/%s", IdToDir( dir, sizeof( dir ), id ), path );
CopyAndFixSlashes( fullpath, path ); CopyAndFixSlashes( fullpath, path, sizeof( fullpath ));
return !!FS_AddPak_Fullpath( fullpath, nullptr, FS_CUSTOM_PATH ); return !!FS_AddPak_Fullpath( fullpath, nullptr, FS_CUSTOM_PATH );
} }

View File

@ -1150,7 +1150,7 @@ void FS_LoadGameInfo( const char *rootfolder )
// lock uplevel of gamedir for read\write // lock uplevel of gamedir for read\write
fs_ext_path = false; fs_ext_path = false;
if( rootfolder ) Q_strcpy( fs_gamedir, rootfolder ); if( rootfolder ) Q_strncpy( fs_gamedir, rootfolder, sizeof( fs_gamedir ));
Con_Reportf( "FS_LoadGameInfo( %s )\n", fs_gamedir ); Con_Reportf( "FS_LoadGameInfo( %s )\n", fs_gamedir );
// clear any old pathes // clear any old pathes

View File

@ -803,7 +803,10 @@ void COM_PathSlashFix( char *path )
len = Q_strlen( path ); len = Q_strlen( path );
if( path[len - 1] != '\\' && path[len - 1] != '/' ) if( path[len - 1] != '\\' && path[len - 1] != '/' )
Q_strcpy( &path[len], "/" ); {
path[len] = '/';
path[len + 1] = '\0';
}
} }
/* /*

View File

@ -64,9 +64,7 @@ void Q_strnlwr( const char *in, char *out, size_t size_out );
size_t Q_colorstr( const char *string ); size_t Q_colorstr( const char *string );
char Q_toupper( const char in ); char Q_toupper( const char in );
char Q_tolower( const char in ); char Q_tolower( const char in );
#define Q_strcat( dst, src ) Q_strncat( dst, src, 99999 )
size_t Q_strncat( char *dst, const char *src, size_t siz ); size_t Q_strncat( char *dst, const char *src, size_t siz );
#define Q_strcpy( dst, src ) Q_strncpy( dst, src, 99999 )
size_t Q_strncpy( char *dst, const char *src, size_t siz ); size_t Q_strncpy( char *dst, const char *src, size_t siz );
qboolean Q_isdigit( const char *str ); qboolean Q_isdigit( const char *str );
qboolean Q_isspace( const char *str ); qboolean Q_isspace( const char *str );

View File

@ -12,9 +12,6 @@ int Test_Strcpycatcmp( void )
if( Q_strcmp( dst, buf )) if( Q_strcmp( dst, buf ))
return 2; return 2;
if( Q_strcpy( dst, buf ) != sizeof( buf ) - 1 )
return 3;
if( Q_strcmp( dst, buf )) if( Q_strcmp( dst, buf ))
return 4; return 4;