mirror of
https://github.com/TorqueGameEngines/Torque3D.git
synced 2026-01-20 04:34:48 +00:00
Merge pull request #2219 from CouleeApps/security-fixes
Security Fixes: String Buffers
This commit is contained in:
commit
71ac83fc9f
|
|
@ -547,8 +547,9 @@ const char * Component::getDescriptionText(const char *desc)
|
|||
// [tom, 1/12/2007] If it isn't a file, just do it the easy way
|
||||
if (!Platform::isFile(desc))
|
||||
{
|
||||
newDesc = new char[dStrlen(desc) + 1];
|
||||
dStrcpy(newDesc, desc);
|
||||
dsize_t newDescLen = dStrlen(desc) + 1;
|
||||
newDesc = new char[newDescLen];
|
||||
dStrcpy(newDesc, desc, newDescLen);
|
||||
|
||||
return newDesc;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1495,7 +1495,7 @@ bool DecalManager::_createDataFile()
|
|||
|
||||
// See if we know our current mission name
|
||||
char missionName[1024];
|
||||
dStrcpy( missionName, Con::getVariable( "$Client::MissionFile" ) );
|
||||
dStrcpy( missionName, Con::getVariable( "$Client::MissionFile" ), 1024 );
|
||||
char *dot = dStrstr((const char*)missionName, ".mis");
|
||||
if(dot)
|
||||
*dot = '\0';
|
||||
|
|
|
|||
|
|
@ -594,8 +594,9 @@ bool ParticleData::preload(bool server, String &errorStr)
|
|||
|
||||
animTexFrames.clear();
|
||||
|
||||
char* tokCopy = new char[dStrlen(animTexFramesString) + 1];
|
||||
dStrcpy(tokCopy, animTexFramesString);
|
||||
dsize_t tokLen = dStrlen(animTexFramesString) + 1;
|
||||
char* tokCopy = new char[tokLen];
|
||||
dStrcpy(tokCopy, animTexFramesString, tokLen);
|
||||
|
||||
char* currTok = dStrtok(tokCopy, " \t");
|
||||
while (currTok != NULL)
|
||||
|
|
|
|||
|
|
@ -608,8 +608,9 @@ bool ParticleEmitterData::onAdd()
|
|||
|
||||
// First we parse particleString into a list of particle name tokens
|
||||
Vector<char*> dataBlocks(__FILE__, __LINE__);
|
||||
char* tokCopy = new char[dStrlen(particleString) + 1];
|
||||
dStrcpy(tokCopy, particleString);
|
||||
dsize_t tokLen = dStrlen(particleString) + 1;
|
||||
char* tokCopy = new char[tokLen];
|
||||
dStrcpy(tokCopy, particleString, tokLen);
|
||||
|
||||
char* currTok = dStrtok(tokCopy, " \t");
|
||||
while (currTok != NULL)
|
||||
|
|
|
|||
|
|
@ -1254,7 +1254,7 @@ DefineEngineMethod( Item, getLastStickyPos, const char*, (),,
|
|||
object->mStickyCollisionPos.y,
|
||||
object->mStickyCollisionPos.z);
|
||||
else
|
||||
dStrcpy(ret, "0 0 0");
|
||||
dStrcpy(ret, "0 0 0", bufSize);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
|
@ -1277,7 +1277,7 @@ DefineEngineMethod( Item, getLastStickyNormal, const char *, (),,
|
|||
object->mStickyCollisionNormal.y,
|
||||
object->mStickyCollisionNormal.z);
|
||||
else
|
||||
dStrcpy(ret, "0 0 0");
|
||||
dStrcpy(ret, "0 0 0", bufSize);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -522,7 +522,7 @@ bool ShapeBaseImageData::preload(bool server, String &errorStr)
|
|||
if (stateSequence[j] && stateSequence[j][0] && stateSequenceRandomFlash[j]) {
|
||||
char bufferVis[128];
|
||||
dStrncpy(bufferVis, stateSequence[j], 100);
|
||||
dStrcat(bufferVis, "_vis");
|
||||
dStrcat(bufferVis, "_vis", 128);
|
||||
s.sequenceVis[i] = shape[i]->findSequence(bufferVis);
|
||||
}
|
||||
if (s.sequenceVis[i] != -1)
|
||||
|
|
|
|||
|
|
@ -446,8 +446,9 @@ bool afxMagicMissileData::onAdd()
|
|||
Vector<char*> dataBlocks(__FILE__, __LINE__);
|
||||
|
||||
// make a copy of points_string
|
||||
char* tokCopy = new char[dStrlen(wiggle_axis_string) + 1];
|
||||
dStrcpy(tokCopy, wiggle_axis_string);
|
||||
dsize_t tokCopyLen = dStrlen(wiggle_axis_string) + 1;
|
||||
char* tokCopy = new char[tokCopyLen];
|
||||
dStrcpy(tokCopy, wiggle_axis_string, tokCopyLen);
|
||||
|
||||
// extract tokens one by one, adding them to dataBlocks
|
||||
char* currTok = dStrtok(tokCopy, " \t");
|
||||
|
|
|
|||
|
|
@ -908,7 +908,7 @@ ConsoleFunction(echoThru, const char*, 2, 0, "(string passthru, string text...)"
|
|||
char *ret = Con::getReturnBuffer(len + 1);
|
||||
ret[0] = 0;
|
||||
for(i = 2; i < argc; i++)
|
||||
dStrcat(ret, argv[i]);
|
||||
dStrcat(ret, argv[i], len + 1);
|
||||
|
||||
Con::printf("%s -- [%s]", ret, argv[1].getStringValue());
|
||||
ret[0] = 0;
|
||||
|
|
@ -928,7 +928,7 @@ ConsoleFunction(warnThru, const char*, 2, 0, "(string passthru, string text...)"
|
|||
char *ret = Con::getReturnBuffer(len + 1);
|
||||
ret[0] = 0;
|
||||
for(i = 2; i < argc; i++)
|
||||
dStrcat(ret, argv[i]);
|
||||
dStrcat(ret, argv[i], len + 1);
|
||||
|
||||
Con::warnf("%s -- [%s]", ret, argv[1].getStringValue());
|
||||
ret[0] = 0;
|
||||
|
|
@ -948,7 +948,7 @@ ConsoleFunction(errorThru, const char*, 2, 0, "(string passthru, string text...)
|
|||
char *ret = Con::getReturnBuffer(len + 1);
|
||||
ret[0] = 0;
|
||||
for(i = 2; i < argc; i++)
|
||||
dStrcat(ret, argv[i]);
|
||||
dStrcat(ret, argv[i], len + 1);
|
||||
|
||||
Con::errorf("%s -- [%s]", ret, argv[1].getStringValue());
|
||||
ret[0] = 0;
|
||||
|
|
|
|||
|
|
@ -184,7 +184,7 @@ void afxAudioBank::packData(BitStream* stream)
|
|||
if(!mFilename)
|
||||
buffer[0] = 0;
|
||||
else
|
||||
dStrcpy(buffer, mFilename);
|
||||
dStrcpy(buffer, mFilename, 256);
|
||||
stream->writeString(buffer);
|
||||
*/
|
||||
|
||||
|
|
|
|||
|
|
@ -141,8 +141,9 @@ bool afxParticleEmitterData::onAdd()
|
|||
if (tpaths_string != ST_NULLSTRING)
|
||||
{
|
||||
Vector<char*> dataBlocks(__FILE__, __LINE__);
|
||||
char* tokCopy = new char[dStrlen(tpaths_string) + 1];
|
||||
dStrcpy(tokCopy, tpaths_string);
|
||||
dsize_t tokCopyLen = dStrlen(tpaths_string) + 1;
|
||||
char* tokCopy = new char[tokCopyLen];
|
||||
dStrcpy(tokCopy, tpaths_string, tokCopyLen);
|
||||
|
||||
char* currTok = dStrtok(tokCopy, " \t");
|
||||
while (currTok != NULL)
|
||||
|
|
@ -467,8 +468,9 @@ bool afxParticleEmitterPathData::onAdd()
|
|||
if (epaths_string != ST_NULLSTRING)
|
||||
{
|
||||
Vector<char*> dataBlocks(__FILE__, __LINE__);
|
||||
char* tokCopy = new char[dStrlen(epaths_string) + 1];
|
||||
dStrcpy(tokCopy, epaths_string);
|
||||
dsize_t tokCopyLen = dStrlen(epaths_string) + 1;
|
||||
char* tokCopy = new char[tokCopyLen];
|
||||
dStrcpy(tokCopy, epaths_string, tokCopyLen);
|
||||
|
||||
char* currTok = dStrtok(tokCopy, " \t");
|
||||
while (currTok != NULL)
|
||||
|
|
@ -552,8 +554,9 @@ void afxParticleEmitterPathData::onPerformSubstitutions()
|
|||
if (epaths_string != ST_NULLSTRING)
|
||||
{
|
||||
Vector<char*> dataBlocks(__FILE__, __LINE__);
|
||||
char* tokCopy = new char[dStrlen(epaths_string) + 1];
|
||||
dStrcpy(tokCopy, epaths_string);
|
||||
dsize_t tokCopyLen = dStrlen(epaths_string) + 1;
|
||||
char* tokCopy = new char[tokCopyLen];
|
||||
dStrcpy(tokCopy, epaths_string, tokCopyLen);
|
||||
|
||||
char* currTok = dStrtok(tokCopy, " \t");
|
||||
while (currTok != NULL)
|
||||
|
|
|
|||
|
|
@ -272,10 +272,10 @@ void afxEA_PhraseEffect::trigger_new_phrase()
|
|||
if (phrase_fx_data->on_trig_cmd != ST_NULLSTRING)
|
||||
{
|
||||
char obj_str[32];
|
||||
dStrcpy(obj_str, Con::getIntArg(choreographer->getId()));
|
||||
dStrcpy(obj_str, Con::getIntArg(choreographer->getId()), 32);
|
||||
|
||||
char index_str[32];
|
||||
dStrcpy(index_str, Con::getIntArg(group_index));
|
||||
dStrcpy(index_str, Con::getIntArg(group_index), 32);
|
||||
|
||||
char buffer[1024];
|
||||
char* b = buffer;
|
||||
|
|
@ -382,4 +382,4 @@ bool afxEA_PhraseEffectDesc::requiresStop(const afxEffectWrapperData* ew, const
|
|||
return (timing.lifetime < 0);
|
||||
}
|
||||
|
||||
//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~~//
|
||||
//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~//~~~~~~~~~~~~~~~~~~~~~//
|
||||
|
|
|
|||
|
|
@ -194,7 +194,7 @@ char* afxRPGMagicSpellData::fmt_placeholder_desc(char* buffer, int len) const
|
|||
{
|
||||
char pack_str[32];
|
||||
if (source_pack == ST_NULLSTRING)
|
||||
dStrcpy(pack_str, "unknown");
|
||||
dStrcpy(pack_str, "unknown", 32);
|
||||
else
|
||||
dSprintf(pack_str, 32, "%s", source_pack);
|
||||
|
||||
|
|
@ -225,9 +225,9 @@ char* afxRPGMagicSpellData::formatDesc(char* buffer, int len) const
|
|||
{
|
||||
if (spell_target != TARGET_NOTHING)
|
||||
{
|
||||
dStrcpy(target_str, _afxRPGMagicSpell_TargetType::_sEnumTable[i].mName);
|
||||
dStrcpy(target_str, _afxRPGMagicSpell_TargetType::_sEnumTable[i].mName, 32);
|
||||
if (spell_target != TARGET_FREE && target_optional)
|
||||
dStrcat(target_str, " (opt)");
|
||||
dStrcat(target_str, " (opt)", 32);
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
|
@ -245,13 +245,13 @@ char* afxRPGMagicSpellData::formatDesc(char* buffer, int len) const
|
|||
|
||||
char casting_str[32];
|
||||
if (casting_dur <= 0)
|
||||
dStrcpy(casting_str, "instant");
|
||||
dStrcpy(casting_str, "instant", 32);
|
||||
else
|
||||
dSprintf(casting_str, 32, "%.1f sec cast", casting_dur);
|
||||
|
||||
char pack_str[32];
|
||||
if (source_pack == ST_NULLSTRING)
|
||||
dStrcpy(pack_str, "unknown");
|
||||
dStrcpy(pack_str, "unknown", 32);
|
||||
else
|
||||
dSprintf(pack_str, 32, "%s", source_pack);
|
||||
|
||||
|
|
|
|||
|
|
@ -171,10 +171,11 @@ void afxSpellButton::setBitmap(const char *name, bool placeholder)
|
|||
|
||||
if (placeholder)
|
||||
{
|
||||
dStrcpy(buffer, name);
|
||||
dStrcpy(buffer, name, 1024);
|
||||
S32 pLen = 1024 - dStrlen(buffer);
|
||||
p = buffer + dStrlen(buffer);
|
||||
|
||||
dStrcpy(p, "_i");
|
||||
dStrcpy(p, "_i", pLen);
|
||||
mTextureInactive.set(buffer, COOLDOWN_PROFILE);
|
||||
mTextureNormal = mTextureInactive;
|
||||
mTextureHilight = mTextureInactive;
|
||||
|
|
@ -183,19 +184,20 @@ void afxSpellButton::setBitmap(const char *name, bool placeholder)
|
|||
}
|
||||
else
|
||||
{
|
||||
dStrcpy(buffer, name);
|
||||
dStrcpy(buffer, name, 1024);
|
||||
S32 pLen = 1024 - dStrlen(buffer);
|
||||
p = buffer + dStrlen(buffer);
|
||||
dStrcpy(p, "_n");
|
||||
dStrcpy(p, "_n", pLen);
|
||||
mTextureNormal.set(buffer, COOLDOWN_PROFILE);
|
||||
dStrcpy(p, "_h");
|
||||
dStrcpy(p, "_h", pLen);
|
||||
mTextureHilight.set(buffer, COOLDOWN_PROFILE);
|
||||
if (!mTextureHilight)
|
||||
mTextureHilight = mTextureNormal;
|
||||
dStrcpy(p, "_d");
|
||||
dStrcpy(p, "_d", pLen);
|
||||
mTextureDepressed.set(buffer, COOLDOWN_PROFILE);
|
||||
if (!mTextureDepressed)
|
||||
mTextureDepressed = mTextureHilight;
|
||||
dStrcpy(p, "_i");
|
||||
dStrcpy(p, "_i", pLen);
|
||||
mTextureInactive.set(buffer, COOLDOWN_PROFILE);
|
||||
if (!mTextureInactive)
|
||||
mTextureInactive = mTextureNormal;
|
||||
|
|
|
|||
|
|
@ -194,8 +194,9 @@ bool afxXM_PathConformData::onAdd()
|
|||
if (paths_string != ST_NULLSTRING)
|
||||
{
|
||||
Vector<char*> dataBlocks(__FILE__, __LINE__);
|
||||
char* tokCopy = new char[dStrlen(paths_string) + 1];
|
||||
dStrcpy(tokCopy, paths_string);
|
||||
dsize_t tokCopyLen = dStrlen(paths_string) + 1;
|
||||
char* tokCopy = new char[tokCopyLen];
|
||||
dStrcpy(tokCopy, paths_string, tokCopyLen);
|
||||
|
||||
char* currTok = dStrtok(tokCopy, " \t");
|
||||
while (currTok != NULL)
|
||||
|
|
|
|||
|
|
@ -50,7 +50,7 @@ BadWordFilter::BadWordFilter()
|
|||
{
|
||||
VECTOR_SET_ASSOCIATION( filterTables );
|
||||
|
||||
dStrcpy(defaultReplaceStr, "knqwrtlzs");
|
||||
dStrcpy(defaultReplaceStr, "knqwrtlzs", 32);
|
||||
filterTables.push_back(new FilterTable);
|
||||
curOffset = 0;
|
||||
}
|
||||
|
|
@ -147,7 +147,7 @@ bool BadWordFilter::setDefaultReplaceStr(const char *str)
|
|||
U32 len = dStrlen(str);
|
||||
if(len < 2 || len >= sizeof(defaultReplaceStr))
|
||||
return false;
|
||||
dStrcpy(defaultReplaceStr, str);
|
||||
dStrcpy(defaultReplaceStr, str, 32);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
|
@ -286,8 +286,9 @@ DefineEngineFunction(filterString, const char *, (const char* baseString, const
|
|||
else
|
||||
replaceStr = gBadWordFilter->getDefaultReplaceStr();
|
||||
|
||||
char *ret = Con::getReturnBuffer(dStrlen(baseString) + 1);
|
||||
dStrcpy(ret, baseString);
|
||||
dsize_t retLen = dStrlen(baseString) + 1;
|
||||
char *ret = Con::getReturnBuffer(retLen);
|
||||
dStrcpy(ret, baseString, retLen);
|
||||
gBadWordFilter->filterString(ret, replaceStr);
|
||||
return ret;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -86,7 +86,7 @@ void BanList::addBan(S32 uniqueId, const char *TA, S32 banTime)
|
|||
}
|
||||
|
||||
BanInfo b;
|
||||
dStrcpy(b.transportAddress, TA);
|
||||
dStrcpy(b.transportAddress, TA, 128);
|
||||
b.uniqueId = uniqueId;
|
||||
b.bannedUntil = banTime;
|
||||
|
||||
|
|
|
|||
|
|
@ -495,7 +495,7 @@ bool StandardMainLoop::handleCommandLine( S32 argc, const char **argv )
|
|||
S32 pathLen = dStrlen( fdd.mFile );
|
||||
FrameTemp<char> szPathCopy( pathLen + 1);
|
||||
|
||||
dStrcpy( szPathCopy, fdd.mFile );
|
||||
dStrcpy( szPathCopy, fdd.mFile, pathLen + 1 );
|
||||
//forwardslash( szPathCopy );
|
||||
|
||||
const char *path = dStrrchr(szPathCopy, '/');
|
||||
|
|
|
|||
|
|
@ -128,8 +128,8 @@
|
|||
const char *rmtCommandName = dStrchr(mArgv[1], ' ') + 1;
|
||||
if(conn->isConnectionToServer())
|
||||
{
|
||||
dStrcpy(mBuf, "clientCmd");
|
||||
dStrcat(mBuf, rmtCommandName);
|
||||
dStrcpy(mBuf, "clientCmd", 1024);
|
||||
dStrcat(mBuf, rmtCommandName, 1024);
|
||||
|
||||
char *temp = mArgv[1];
|
||||
mArgv[1] = mBuf;
|
||||
|
|
@ -139,8 +139,8 @@
|
|||
}
|
||||
else
|
||||
{
|
||||
dStrcpy(mBuf, "serverCmd");
|
||||
dStrcat(mBuf, rmtCommandName);
|
||||
dStrcpy(mBuf, "serverCmd", 1024);
|
||||
dStrcat(mBuf, rmtCommandName, 1024);
|
||||
char *temp = mArgv[1];
|
||||
|
||||
dSprintf(idBuf, sizeof(idBuf), "%d", conn->getId());
|
||||
|
|
@ -409,7 +409,7 @@ ConsoleFunction( buildTaggedString, const char*, 2, 11, "(string format, ...)"
|
|||
S32 strLength = dStrlen(argStr);
|
||||
if (strLength > strMaxLength)
|
||||
goto done;
|
||||
dStrcpy(strBufPtr, argStr);
|
||||
dStrcpy(strBufPtr, argStr, strMaxLength);
|
||||
strBufPtr += strLength;
|
||||
strMaxLength -= strLength;
|
||||
fmtStrPtr += 2;
|
||||
|
|
|
|||
|
|
@ -110,7 +110,7 @@ public:
|
|||
SimpleNetObject()
|
||||
{
|
||||
mNetFlags.set(ScopeAlways | Ghostable);
|
||||
dStrcpy(message, "Hello World!");
|
||||
dStrcpy(message, "Hello World!", 256);
|
||||
}
|
||||
U32 packUpdate(NetConnection *conn, U32 mask, BitStream *stream)
|
||||
{
|
||||
|
|
@ -125,7 +125,7 @@ public:
|
|||
void setMessage(const char *msg)
|
||||
{
|
||||
setMaskBits(1);
|
||||
dStrcpy(message, msg);
|
||||
dStrcpy(message, msg, 256);
|
||||
}
|
||||
|
||||
DECLARE_CONOBJECT(SimpleNetObject);
|
||||
|
|
|
|||
|
|
@ -394,12 +394,12 @@ void queryLanServers(U32 port, U8 flags, const char* gameType, const char* missi
|
|||
if ( !sActiveFilter.gameType || dStricmp( sActiveFilter.gameType, "Any" ) != 0 )
|
||||
{
|
||||
sActiveFilter.gameType = (char*) dRealloc( sActiveFilter.gameType, 4 );
|
||||
dStrcpy( sActiveFilter.gameType, "Any" );
|
||||
dStrcpy( sActiveFilter.gameType, "Any", 4 );
|
||||
}
|
||||
if ( !sActiveFilter.missionType || dStricmp( sActiveFilter.missionType, "Any" ) != 0 )
|
||||
{
|
||||
sActiveFilter.missionType = (char*) dRealloc( sActiveFilter.missionType, 4 );
|
||||
dStrcpy( sActiveFilter.missionType, "Any" );
|
||||
dStrcpy( sActiveFilter.missionType, "Any", 4 );
|
||||
}
|
||||
sActiveFilter.queryFlags = 0;
|
||||
sActiveFilter.minPlayers = minPlayers;
|
||||
|
|
@ -510,14 +510,16 @@ void queryMasterServer(U8 flags, const char* gameType, const char* missionType,
|
|||
// Update the active filter:
|
||||
if ( !sActiveFilter.gameType || dStrcmp( sActiveFilter.gameType, gameType ) != 0 )
|
||||
{
|
||||
sActiveFilter.gameType = (char*) dRealloc( sActiveFilter.gameType, dStrlen( gameType ) + 1 );
|
||||
dStrcpy( sActiveFilter.gameType, gameType );
|
||||
dsize_t gameTypeLen = dStrlen(gameType) + 1;
|
||||
sActiveFilter.gameType = (char*) dRealloc( sActiveFilter.gameType, gameTypeLen );
|
||||
dStrcpy( sActiveFilter.gameType, gameType, gameTypeLen );
|
||||
}
|
||||
|
||||
if ( !sActiveFilter.missionType || dStrcmp( sActiveFilter.missionType, missionType ) != 0 )
|
||||
{
|
||||
sActiveFilter.missionType = (char*) dRealloc( sActiveFilter.missionType, dStrlen( missionType ) + 1 );
|
||||
dStrcpy( sActiveFilter.missionType, missionType );
|
||||
dsize_t missionTypeLen = dStrlen(missionType) + 1;
|
||||
sActiveFilter.missionType = (char*) dRealloc( sActiveFilter.missionType, missionTypeLen );
|
||||
dStrcpy( sActiveFilter.missionType, missionType, missionTypeLen );
|
||||
}
|
||||
|
||||
sActiveFilter.queryFlags = flags | ServerFilter::NewStyleResponse;
|
||||
|
|
@ -969,8 +971,9 @@ static void pushServerFavorites()
|
|||
Net::stringToAddress( addrString, &addr );
|
||||
ServerInfo* si = findOrCreateServerInfo( &addr );
|
||||
AssertFatal(si, "pushServerFavorites - failed to create Server Info!" );
|
||||
si->name = (char*) dRealloc( (void*) si->name, dStrlen( serverName ) + 1 );
|
||||
dStrcpy( si->name, serverName );
|
||||
dsize_t nameLen = dStrlen(serverName) + 1;
|
||||
si->name = (char*) dRealloc( (void*) si->name, nameLen );
|
||||
dStrcpy( si->name, serverName, nameLen );
|
||||
si->isFavorite = true;
|
||||
pushPingRequest( &addr );
|
||||
}
|
||||
|
|
@ -1053,14 +1056,15 @@ void addFakeServers( S32 howMany )
|
|||
newServer.maxPlayers = 64;
|
||||
char buf[256];
|
||||
dSprintf( buf, 255, "Fake server #%d", sNumFakeServers );
|
||||
newServer.name = (char*) dMalloc( dStrlen( buf ) + 1 );
|
||||
dStrcpy( newServer.name, buf );
|
||||
dsize_t nameLen = dStrlen(buf) + 1;
|
||||
newServer.name = (char*) dMalloc( nameLen );
|
||||
dStrcpy( newServer.name, buf, nameLen );
|
||||
newServer.gameType = (char*) dMalloc( 5 );
|
||||
dStrcpy( newServer.gameType, "Fake" );
|
||||
newServer.missionType = (char*) dMalloc( 4 );
|
||||
dStrcpy( newServer.missionType, "FakeMissionType" );
|
||||
dStrcpy( newServer.gameType, "Fake", 5 );
|
||||
newServer.missionType = (char*) dMalloc( 16 );
|
||||
dStrcpy( newServer.missionType, "FakeMissionType", 16 );
|
||||
newServer.missionName = (char*) dMalloc( 14 );
|
||||
dStrcpy( newServer.missionName, "FakeMapName" );
|
||||
dStrcpy( newServer.missionName, "FakeMapName", 14 );
|
||||
Net::stringToAddress( "IP:198.74.33.35:28000", &newServer.address );
|
||||
newServer.ping = (U32)( Platform::getRandom() * 200.0f );
|
||||
newServer.cpuSpeed = 470;
|
||||
|
|
@ -1353,9 +1357,9 @@ static void processPingsAndQueries( U32 session, bool schedule )
|
|||
char msg[64];
|
||||
U32 foundCount = gServerList.size();
|
||||
if ( foundCount == 0 )
|
||||
dStrcpy( msg, "No servers found." );
|
||||
dStrcpy( msg, "No servers found.", 64 );
|
||||
else if ( foundCount == 1 )
|
||||
dStrcpy( msg, "One server found." );
|
||||
dStrcpy( msg, "One server found.", 64 );
|
||||
else
|
||||
dSprintf( msg, sizeof( msg ), "%d servers found.", foundCount );
|
||||
|
||||
|
|
@ -1753,8 +1757,9 @@ static void handleGameMasterInfoRequest( const NetAddress* address, U32 key, U8
|
|||
out->write( playerCount );
|
||||
|
||||
const char* guidList = Con::getVariable( "Server::GuidList" );
|
||||
char* buf = new char[dStrlen( guidList ) + 1];
|
||||
dStrcpy( buf, guidList );
|
||||
dsize_t bufLen = dStrlen(guidList) + 1;
|
||||
char* buf = new char[bufLen];
|
||||
dStrcpy( buf, guidList, bufLen );
|
||||
char* temp = dStrtok( buf, "\t" );
|
||||
temp8 = 0;
|
||||
for ( ; temp && temp8 < playerCount; temp8++ )
|
||||
|
|
@ -1948,8 +1953,9 @@ static void handleGamePingResponse( const NetAddress* address, BitStream* stream
|
|||
stream->readString( buf );
|
||||
if ( !si->name )
|
||||
{
|
||||
si->name = (char*) dMalloc( dStrlen( buf ) + 1 );
|
||||
dStrcpy( si->name, buf );
|
||||
dsize_t bufLen = dStrlen(buf) + 1;
|
||||
si->name = (char*) dMalloc(bufLen);
|
||||
dStrcpy( si->name, buf, bufLen );
|
||||
}
|
||||
|
||||
// Set the server up to be queried:
|
||||
|
|
@ -2050,8 +2056,9 @@ static void handleGameInfoResponse( const NetAddress* address, BitStream* stream
|
|||
stream->readString( stringBuf );
|
||||
if ( !si->gameType || dStricmp( si->gameType, stringBuf ) != 0 )
|
||||
{
|
||||
si->gameType = (char*) dRealloc( (void*) si->gameType, dStrlen( stringBuf ) + 1 );
|
||||
dStrcpy( si->gameType, stringBuf );
|
||||
dsize_t gameTypeLen = dStrlen(stringBuf) + 1;
|
||||
si->gameType = (char*) dRealloc( (void*) si->gameType, gameTypeLen );
|
||||
dStrcpy( si->gameType, stringBuf, gameTypeLen );
|
||||
|
||||
// Test against the active filter:
|
||||
if ( applyFilter && dStricmp( sActiveFilter.gameType, "any" ) != 0
|
||||
|
|
@ -2067,8 +2074,9 @@ static void handleGameInfoResponse( const NetAddress* address, BitStream* stream
|
|||
stream->readString( stringBuf );
|
||||
if ( !si->missionType || dStrcmp( si->missionType, stringBuf ) != 0 )
|
||||
{
|
||||
si->missionType = (char*) dRealloc( (void*) si->missionType, dStrlen( stringBuf ) + 1 );
|
||||
dStrcpy( si->missionType, stringBuf );
|
||||
dsize_t missionTypeLen = dStrlen(stringBuf) + 1;
|
||||
si->missionType = (char*) dRealloc( (void*) si->missionType, missionTypeLen );
|
||||
dStrcpy( si->missionType, stringBuf, missionTypeLen );
|
||||
|
||||
// Test against the active filter:
|
||||
if ( applyFilter && dStricmp( sActiveFilter.missionType, "any" ) != 0
|
||||
|
|
@ -2088,8 +2096,9 @@ static void handleGameInfoResponse( const NetAddress* address, BitStream* stream
|
|||
*temp = '\0';
|
||||
if ( !si->missionName || dStrcmp( si->missionName, stringBuf ) != 0 )
|
||||
{
|
||||
si->missionName = (char*) dRealloc( (void*) si->missionName, dStrlen( stringBuf ) + 1 );
|
||||
dStrcpy( si->missionName, stringBuf );
|
||||
dsize_t missionNameLen = dStrlen(stringBuf) + 1;
|
||||
si->missionName = (char*) dRealloc( (void*) si->missionName, missionNameLen );
|
||||
dStrcpy( si->missionName, stringBuf, missionNameLen );
|
||||
}
|
||||
|
||||
// Get the server status:
|
||||
|
|
@ -2157,16 +2166,18 @@ static void handleGameInfoResponse( const NetAddress* address, BitStream* stream
|
|||
stream->readString( stringBuf );
|
||||
if ( !si->statusString || ( isUpdate && dStrcmp( si->statusString, stringBuf ) != 0 ) )
|
||||
{
|
||||
si->infoString = (char*) dRealloc( (void*) si->infoString, dStrlen( stringBuf ) + 1 );
|
||||
dStrcpy( si->infoString, stringBuf );
|
||||
dsize_t infoLen = dStrlen(stringBuf) + 1;
|
||||
si->infoString = (char*) dRealloc( (void*) si->infoString, infoLen );
|
||||
dStrcpy( si->infoString, stringBuf, infoLen );
|
||||
}
|
||||
|
||||
// Get the content string:
|
||||
readLongCString( stream, stringBuf );
|
||||
if ( !si->statusString || ( isUpdate && dStrcmp( si->statusString, stringBuf ) != 0 ) )
|
||||
{
|
||||
si->statusString = (char*) dRealloc( (void*) si->statusString, dStrlen( stringBuf ) + 1 );
|
||||
dStrcpy( si->statusString, stringBuf );
|
||||
dsize_t statusLen = dStrlen(stringBuf) + 1;
|
||||
si->statusString = (char*) dRealloc( (void*) si->statusString, statusLen );
|
||||
dStrcpy( si->statusString, stringBuf, statusLen );
|
||||
}
|
||||
|
||||
// Update the server browser gui!
|
||||
|
|
|
|||
|
|
@ -182,8 +182,9 @@ extern "C" {
|
|||
|
||||
void torque_setexecutablepath(const char* directory)
|
||||
{
|
||||
gExecutablePath = new char[strlen(directory)+1];
|
||||
strcpy(gExecutablePath, directory);
|
||||
dsize_t pathLen = dStrlen(directory) + 1;
|
||||
gExecutablePath = new char[pathLen];
|
||||
dStrcpy(gExecutablePath, directory, pathLen);
|
||||
}
|
||||
|
||||
// set Torque 3D into web deployment mode (disable fullscreen exlusive mode, etc)
|
||||
|
|
|
|||
|
|
@ -2340,8 +2340,9 @@ static int Sc_ScanString(int ret)
|
|||
if (!collapseEscape(CMDtext + 1))
|
||||
return -1;
|
||||
|
||||
char* buffer = (char*)consoleAlloc(dStrlen(CMDtext));
|
||||
dStrcpy(buffer, CMDtext + 1);
|
||||
dsize_t bufferLen = dStrlen(CMDtext);
|
||||
char* buffer = (char*)consoleAlloc(bufferLen);
|
||||
dStrcpy(buffer, CMDtext + 1, bufferLen);
|
||||
|
||||
CMDlval.str = MakeToken< char* >(buffer, lineIndex);
|
||||
return ret;
|
||||
|
|
|
|||
|
|
@ -71,7 +71,7 @@ inline int isatty(int) { return 0; }
|
|||
buf[n++] = (char) c; \
|
||||
result = n; \
|
||||
}
|
||||
|
||||
|
||||
// General helper stuff.
|
||||
static int lineIndex;
|
||||
|
||||
|
|
@ -411,10 +411,11 @@ static int Sc_ScanString(int ret)
|
|||
CMDtext[CMDleng - 1] = 0;
|
||||
if(!collapseEscape(CMDtext+1))
|
||||
return -1;
|
||||
|
||||
char* buffer = ( char* ) consoleAlloc( dStrlen( CMDtext ) );
|
||||
dStrcpy( buffer, CMDtext + 1 );
|
||||
|
||||
|
||||
dsize_t bufferLen = dStrlen( CMDtext );
|
||||
char* buffer = ( char* ) consoleAlloc( bufferLen );
|
||||
dStrcpy( buffer, CMDtext + 1, bufferLen );
|
||||
|
||||
CMDlval.str = MakeToken< char* >( buffer, lineIndex );
|
||||
return ret;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -833,7 +833,7 @@ void SimXMLDocument::setObjectAttributes(const char* objectID)
|
|||
continue;
|
||||
|
||||
FrameTemp<char> valCopy( dStrlen( val ) + 1 );
|
||||
dStrcpy( (char *)valCopy, val );
|
||||
dStrcpy( (char *)valCopy, val, valCopy.size() );
|
||||
|
||||
if (!pObject->writeField(itr->pFieldname, valCopy))
|
||||
continue;
|
||||
|
|
@ -873,7 +873,7 @@ void SimXMLDocument::setObjectAttributes(const char* objectID)
|
|||
// continue;
|
||||
|
||||
// FrameTemp<char> valCopy( dStrlen( val ) + 1 );
|
||||
// dStrcpy( (char *)valCopy, val );
|
||||
// dStrcpy( (char *)valCopy, val, valCopy.size() );
|
||||
|
||||
// if (!pObject->writeField(itr->pFieldname, valCopy))
|
||||
// continue;
|
||||
|
|
|
|||
|
|
@ -238,10 +238,11 @@ StrConstNode *StrConstNode::alloc(S32 lineNumber, char *str, bool tag, bool doc)
|
|||
StrConstNode *ret = (StrConstNode *)consoleAlloc(sizeof(StrConstNode));
|
||||
constructInPlace(ret);
|
||||
ret->dbgLineNumber = lineNumber;
|
||||
ret->str = (char *)consoleAlloc(dStrlen(str) + 1);
|
||||
dsize_t retStrLen = dStrlen(str) + 1;
|
||||
ret->str = (char *)consoleAlloc(retStrLen);
|
||||
ret->tag = tag;
|
||||
ret->doc = doc;
|
||||
dStrcpy(ret->str, str);
|
||||
dStrcpy(ret->str, str, retStrLen);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -95,19 +95,17 @@ static void getFieldComponent(SimObject* object, StringTableEntry field, const c
|
|||
|
||||
// Translate xyzw and rgba into the indexed component
|
||||
// of the variable or field.
|
||||
//
|
||||
// Review: Should we use strncpy to prevent a buffer overflow?
|
||||
if (subField == xyzw[0] || subField == rgba[0])
|
||||
dStrcpy(val, StringUnit::getUnit(prevVal, 0, " \t\n"));
|
||||
dStrcpy(val, StringUnit::getUnit(prevVal, 0, " \t\n"), 128);
|
||||
|
||||
else if (subField == xyzw[1] || subField == rgba[1])
|
||||
dStrcpy(val, StringUnit::getUnit(prevVal, 1, " \t\n"));
|
||||
dStrcpy(val, StringUnit::getUnit(prevVal, 1, " \t\n"), 128);
|
||||
|
||||
else if (subField == xyzw[2] || subField == rgba[2])
|
||||
dStrcpy(val, StringUnit::getUnit(prevVal, 2, " \t\n"));
|
||||
dStrcpy(val, StringUnit::getUnit(prevVal, 2, " \t\n"), 128);
|
||||
|
||||
else if (subField == xyzw[3] || subField == rgba[3])
|
||||
dStrcpy(val, StringUnit::getUnit(prevVal, 3, " \t\n"));
|
||||
dStrcpy(val, StringUnit::getUnit(prevVal, 3, " \t\n"), 128);
|
||||
|
||||
else
|
||||
val[0] = 0;
|
||||
|
|
@ -157,19 +155,17 @@ static void setFieldComponent(SimObject* object, StringTableEntry field, const c
|
|||
|
||||
// Insert the value into the specified
|
||||
// component of the string.
|
||||
//
|
||||
// Review: Should we use strncpy to prevent a buffer overflow?
|
||||
if (subField == xyzw[0] || subField == rgba[0])
|
||||
dStrcpy(val, StringUnit::setUnit(prevVal, 0, strValue, " \t\n"));
|
||||
dStrcpy(val, StringUnit::setUnit(prevVal, 0, strValue, " \t\n"), 128);
|
||||
|
||||
else if (subField == xyzw[1] || subField == rgba[1])
|
||||
dStrcpy(val, StringUnit::setUnit(prevVal, 1, strValue, " \t\n"));
|
||||
dStrcpy(val, StringUnit::setUnit(prevVal, 1, strValue, " \t\n"), 128);
|
||||
|
||||
else if (subField == xyzw[2] || subField == rgba[2])
|
||||
dStrcpy(val, StringUnit::setUnit(prevVal, 2, strValue, " \t\n"));
|
||||
dStrcpy(val, StringUnit::setUnit(prevVal, 2, strValue, " \t\n"), 128);
|
||||
|
||||
else if (subField == xyzw[3] || subField == rgba[3])
|
||||
dStrcpy(val, StringUnit::setUnit(prevVal, 3, strValue, " \t\n"));
|
||||
dStrcpy(val, StringUnit::setUnit(prevVal, 3, strValue, " \t\n"), 128);
|
||||
|
||||
if (val[0] != 0)
|
||||
{
|
||||
|
|
@ -420,13 +416,13 @@ exitLabel:
|
|||
if (gEvalState.traceOn)
|
||||
{
|
||||
sTraceBuffer[0] = 0;
|
||||
dStrcat(sTraceBuffer, "Leaving ");
|
||||
dStrcat(sTraceBuffer, "Leaving ", 1024);
|
||||
|
||||
if (packageName)
|
||||
{
|
||||
dStrcat(sTraceBuffer, "[");
|
||||
dStrcat(sTraceBuffer, packageName);
|
||||
dStrcat(sTraceBuffer, "]");
|
||||
dStrcat(sTraceBuffer, "[", 1024);
|
||||
dStrcat(sTraceBuffer, packageName, 1024);
|
||||
dStrcat(sTraceBuffer, "]", 1024);
|
||||
}
|
||||
if (thisNamespace && thisNamespace->mName)
|
||||
{
|
||||
|
|
@ -471,13 +467,13 @@ void CodeInterpreter::parseArgs(U32 &ip)
|
|||
if (gEvalState.traceOn)
|
||||
{
|
||||
sTraceBuffer[0] = 0;
|
||||
dStrcat(sTraceBuffer, "Entering ");
|
||||
dStrcat(sTraceBuffer, "Entering ", 1024);
|
||||
|
||||
if (mExec.packageName)
|
||||
{
|
||||
dStrcat(sTraceBuffer, "[");
|
||||
dStrcat(sTraceBuffer, mExec.packageName);
|
||||
dStrcat(sTraceBuffer, "]");
|
||||
dStrcat(sTraceBuffer, "[", 1024);
|
||||
dStrcat(sTraceBuffer, mExec.packageName, 1024);
|
||||
dStrcat(sTraceBuffer, "]", 1024);
|
||||
}
|
||||
if (mExec.thisNamespace && mExec.thisNamespace->mName)
|
||||
{
|
||||
|
|
@ -491,11 +487,11 @@ void CodeInterpreter::parseArgs(U32 &ip)
|
|||
}
|
||||
for (S32 i = 0; i < wantedArgc; i++)
|
||||
{
|
||||
dStrcat(sTraceBuffer, mExec.argv[i + 1]);
|
||||
dStrcat(sTraceBuffer, mExec.argv[i + 1], 1024);
|
||||
if (i != wantedArgc - 1)
|
||||
dStrcat(sTraceBuffer, ", ");
|
||||
dStrcat(sTraceBuffer, ", ", 1024);
|
||||
}
|
||||
dStrcat(sTraceBuffer, ")");
|
||||
dStrcat(sTraceBuffer, ")", 1024);
|
||||
Con::printf("%s", sTraceBuffer);
|
||||
}
|
||||
|
||||
|
|
@ -1729,7 +1725,7 @@ OPCodeReturn CodeInterpreter::op_setcurfield(U32 &ip)
|
|||
{
|
||||
// Save the previous field for parsing vector fields.
|
||||
mPrevField = mCurField;
|
||||
dStrcpy(prevFieldArray, curFieldArray);
|
||||
dStrcpy(prevFieldArray, curFieldArray, 256);
|
||||
mCurField = CodeToSTE(mCodeBlock->code, ip);
|
||||
curFieldArray[0] = 0;
|
||||
ip += 2;
|
||||
|
|
@ -1738,7 +1734,7 @@ OPCodeReturn CodeInterpreter::op_setcurfield(U32 &ip)
|
|||
|
||||
OPCodeReturn CodeInterpreter::op_setcurfield_array(U32 &ip)
|
||||
{
|
||||
dStrcpy(curFieldArray, STR.getStringValue());
|
||||
dStrcpy(curFieldArray, STR.getStringValue(), 256);
|
||||
return OPCodeReturn::success;
|
||||
}
|
||||
|
||||
|
|
@ -1771,7 +1767,7 @@ OPCodeReturn CodeInterpreter::op_setcurfield_this(U32 &ip)
|
|||
mCurObject = mThisObject;
|
||||
|
||||
mPrevField = mCurField;
|
||||
dStrcpy(prevFieldArray, curFieldArray);
|
||||
dStrcpy(prevFieldArray, curFieldArray, 256);
|
||||
mCurField = CodeToSTE(mCodeBlock->code, ip);
|
||||
curFieldArray[0] = 0;
|
||||
ip += 2;
|
||||
|
|
|
|||
|
|
@ -70,9 +70,9 @@ namespace Con
|
|||
ret[0] = 0;
|
||||
for (walk = ns; walk; walk = walk->mParent)
|
||||
{
|
||||
dStrcat(ret, walk->mName);
|
||||
dStrcat(ret, walk->mName, size);
|
||||
if (walk->mParent)
|
||||
dStrcat(ret, " -> ");
|
||||
dStrcat(ret, " -> ", size);
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -164,7 +164,7 @@ U32 CompilerStringTable::add(const char *str, bool caseSens, bool tag)
|
|||
newStr->string = (char *)consoleAlloc(len);
|
||||
newStr->len = len;
|
||||
newStr->tag = tag;
|
||||
dStrcpy(newStr->string, str);
|
||||
dStrcpy(newStr->string, str, len);
|
||||
|
||||
// Put into the hash table.
|
||||
hashTable[str] = newStr;
|
||||
|
|
@ -195,7 +195,7 @@ char *CompilerStringTable::build()
|
|||
char *ret = new char[totalLen];
|
||||
dMemset(ret, 0, totalLen);
|
||||
for (Entry *walk = list; walk; walk = walk->next)
|
||||
dStrcpy(ret + walk->start, walk->string);
|
||||
dStrcpy(ret + walk->start, walk->string, totalLen - walk->start);
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -440,7 +440,7 @@ U32 tabComplete(char* inputBuffer, U32 cursorPos, U32 maxResultLength, bool forw
|
|||
{
|
||||
// If not...
|
||||
// Save it for checking next time.
|
||||
dStrcpy(tabBuffer, inputBuffer);
|
||||
dStrcpy(tabBuffer, inputBuffer, MaxCompletionBufferSize);
|
||||
// Scan backward from the cursor position to find the base to complete from.
|
||||
S32 p = cursorPos;
|
||||
while ((p > 0) && (inputBuffer[p - 1] != ' ') && (inputBuffer[p - 1] != '.') && (inputBuffer[p - 1] != '('))
|
||||
|
|
@ -527,7 +527,7 @@ U32 tabComplete(char* inputBuffer, U32 cursorPos, U32 maxResultLength, bool forw
|
|||
}
|
||||
|
||||
// Save the modified input buffer for checking next time.
|
||||
dStrcpy(tabBuffer, inputBuffer);
|
||||
dStrcpy(tabBuffer, inputBuffer, MaxCompletionBufferSize);
|
||||
|
||||
// Return the new (maybe) cursor position.
|
||||
return cursorPos;
|
||||
|
|
@ -646,8 +646,9 @@ static void _printf(ConsoleLogEntry::Level level, ConsoleLogEntry::Type type, co
|
|||
entry.mLevel = level;
|
||||
entry.mType = type;
|
||||
#ifndef TORQUE_SHIPPING // this is equivalent to a memory leak, turn it off in ship build
|
||||
entry.mString = (const char *)consoleLogChunker.alloc(dStrlen(pos) + 1);
|
||||
dStrcpy(const_cast<char*>(entry.mString), pos);
|
||||
dsize_t logStringLen = dStrlen(pos) + 1;
|
||||
entry.mString = (const char *)consoleLogChunker.alloc(logStringLen);
|
||||
dStrcpy(const_cast<char*>(entry.mString), pos, logStringLen);
|
||||
|
||||
// This prevents infinite recursion if the console itself needs to
|
||||
// re-allocate memory to accommodate the new console log entry, and
|
||||
|
|
@ -1271,7 +1272,7 @@ bool executeFile(const char* fileName, bool noCalls, bool journalScript)
|
|||
scriptFile = NULL;
|
||||
|
||||
dsoModifiedTime = dsoFile->getModifiedTime();
|
||||
dStrcpy(nameBuffer, scriptFileName);
|
||||
dStrcpy(nameBuffer, scriptFileName, 512);
|
||||
}
|
||||
|
||||
// If we're supposed to be compiling this file, check to see if there's a DSO
|
||||
|
|
@ -2097,12 +2098,12 @@ bool expandPath(char* pDstPath, U32 size, const char* pSrcPath, const char* pWor
|
|||
if (ensureTrailingSlash)
|
||||
{
|
||||
// Yes, so ensure it.
|
||||
Con::ensureTrailingSlash(pDstPath, pSrcPath);
|
||||
Con::ensureTrailingSlash(pDstPath, pSrcPath, size);
|
||||
}
|
||||
else
|
||||
{
|
||||
// No, so just use the source path.
|
||||
dStrcpy(pDstPath, pSrcPath);
|
||||
dStrcpy(pDstPath, pSrcPath, size);
|
||||
}
|
||||
|
||||
return false;
|
||||
|
|
@ -2118,7 +2119,7 @@ bool expandPath(char* pDstPath, U32 size, const char* pSrcPath, const char* pWor
|
|||
if (ensureTrailingSlash)
|
||||
{
|
||||
// Yes, so ensure it.
|
||||
Con::ensureTrailingSlash(pathBuffer, pathBuffer);
|
||||
Con::ensureTrailingSlash(pathBuffer, pathBuffer, size);
|
||||
}
|
||||
|
||||
// Strip repeat slashes.
|
||||
|
|
@ -2143,12 +2144,12 @@ bool expandPath(char* pDstPath, U32 size, const char* pSrcPath, const char* pWor
|
|||
if (ensureTrailingSlash)
|
||||
{
|
||||
// Yes, so ensure it.
|
||||
Con::ensureTrailingSlash(pDstPath, pSrcPath);
|
||||
Con::ensureTrailingSlash(pDstPath, pSrcPath, size);
|
||||
}
|
||||
else
|
||||
{
|
||||
// No, so just use the source path.
|
||||
dStrcpy(pDstPath, pSrcPath);
|
||||
dStrcpy(pDstPath, pSrcPath, size);
|
||||
}
|
||||
|
||||
return false;
|
||||
|
|
@ -2183,7 +2184,7 @@ bool expandPath(char* pDstPath, U32 size, const char* pSrcPath, const char* pWor
|
|||
if (ensureTrailingSlash)
|
||||
{
|
||||
// Yes, so ensure it.
|
||||
Con::ensureTrailingSlash(pathBuffer, pathBuffer);
|
||||
Con::ensureTrailingSlash(pathBuffer, pathBuffer, size);
|
||||
}
|
||||
|
||||
// Strip repeat slashes.
|
||||
|
|
@ -2208,7 +2209,7 @@ bool expandPath(char* pDstPath, U32 size, const char* pSrcPath, const char* pWor
|
|||
if (ensureTrailingSlash)
|
||||
{
|
||||
// Yes, so ensure it.
|
||||
Con::ensureTrailingSlash(pathBuffer, pathBuffer);
|
||||
Con::ensureTrailingSlash(pathBuffer, pathBuffer, size);
|
||||
}
|
||||
|
||||
// Strip repeat slashes.
|
||||
|
|
@ -2300,10 +2301,10 @@ void collapsePath(char* pDstPath, U32 size, const char* pSrcPath, const char* pW
|
|||
}
|
||||
|
||||
|
||||
void ensureTrailingSlash(char* pDstPath, const char* pSrcPath)
|
||||
void ensureTrailingSlash(char* pDstPath, const char* pSrcPath, S32 dstSize)
|
||||
{
|
||||
// Copy to target.
|
||||
dStrcpy(pDstPath, pSrcPath);
|
||||
dStrcpy(pDstPath, pSrcPath, dstSize);
|
||||
|
||||
// Find trailing character index.
|
||||
S32 trailIndex = dStrlen(pDstPath);
|
||||
|
|
@ -2353,7 +2354,7 @@ StringTableEntry getDSOPath(const char *scriptPath)
|
|||
else
|
||||
{
|
||||
StringTableEntry strippedPath = Platform::stripBasePath(scriptPath);
|
||||
dStrcpy(relPath, strippedPath);
|
||||
dStrcpy(relPath, strippedPath, 1024);
|
||||
|
||||
char *slash = dStrrchr(relPath, '/');
|
||||
if (slash)
|
||||
|
|
@ -2616,7 +2617,7 @@ const char *ConsoleValue::getStringValue()
|
|||
else if(newLen > bufferLen)
|
||||
sval = (char *) dRealloc(sval, newLen);
|
||||
|
||||
dStrcpy(sval, internalValue);
|
||||
dStrcpy(sval, internalValue, newLen);
|
||||
bufferLen = newLen;
|
||||
|
||||
return sval;
|
||||
|
|
|
|||
|
|
@ -491,7 +491,7 @@ namespace Con
|
|||
bool expandPath(char* pDstPath, U32 size, const char* pSrcPath, const char* pWorkingDirectoryHint = NULL, const bool ensureTrailingSlash = false);
|
||||
void collapsePath(char* pDstPath, U32 size, const char* pSrcPath, const char* pWorkingDirectoryHint = NULL);
|
||||
bool isBasePath(const char* SrcPath, const char* pBasePath);
|
||||
void ensureTrailingSlash(char* pDstPath, const char* pSrcPath);
|
||||
void ensureTrailingSlash(char* pDstPath, const char* pSrcPath, S32 dstSize);
|
||||
bool stripRepeatSlashes(char* pDstPath, const char* pSrcPath, S32 dstSize);
|
||||
StringTableEntry getDSOPath(const char *scriptPath);
|
||||
|
||||
|
|
|
|||
|
|
@ -90,7 +90,7 @@ void printClassHeader(const char* usage, const char * className, const char * su
|
|||
// Copy Usage Document
|
||||
S32 usageLen = dStrlen( usage );
|
||||
FrameTemp<char> usageStr( usageLen );
|
||||
dStrcpy( usageStr, usage );
|
||||
dStrcpy( usageStr, usage, usageLen );
|
||||
|
||||
// Print Header
|
||||
Con::printf( "/*!" );
|
||||
|
|
@ -117,7 +117,7 @@ void printClassHeader(const char* usage, const char * className, const char * su
|
|||
}
|
||||
|
||||
// Copy line and update usagePtr
|
||||
dStrcpy( lineStr, usagePtr );
|
||||
dStrcpy( lineStr, usagePtr, 2048 );
|
||||
usagePtr = (newLine != NULL ) ? newLine : usagePtr;
|
||||
lineLen = dStrlen( lineStr );
|
||||
|
||||
|
|
|
|||
|
|
@ -561,12 +561,13 @@ DefineConsoleFunction( stripChars, const char*, ( const char* str, const char* c
|
|||
"@endtsexample\n"
|
||||
"@ingroup Strings" )
|
||||
{
|
||||
char* ret = Con::getReturnBuffer( dStrlen( str ) + 1 );
|
||||
dStrcpy( ret, str );
|
||||
S32 len = dStrlen(str) + 1;
|
||||
char* ret = Con::getReturnBuffer( len );
|
||||
dStrcpy( ret, str, len );
|
||||
U32 pos = dStrcspn( ret, chars );
|
||||
while ( pos < dStrlen( ret ) )
|
||||
{
|
||||
dStrcpy( ret + pos, ret + pos + 1 );
|
||||
dStrcpy( ret + pos, ret + pos + 1, len - pos );
|
||||
pos = dStrcspn( ret, chars );
|
||||
}
|
||||
return( ret );
|
||||
|
|
@ -584,8 +585,9 @@ DefineConsoleFunction( strlwr, const char*, ( const char* str ),,
|
|||
"@see strupr\n"
|
||||
"@ingroup Strings" )
|
||||
{
|
||||
char *ret = Con::getReturnBuffer(dStrlen(str) + 1);
|
||||
dStrcpy(ret, str);
|
||||
dsize_t retLen = dStrlen(str) + 1;
|
||||
char *ret = Con::getReturnBuffer(retLen);
|
||||
dStrcpy(ret, str, retLen);
|
||||
return dStrlwr(ret);
|
||||
}
|
||||
|
||||
|
|
@ -601,8 +603,9 @@ DefineConsoleFunction( strupr, const char*, ( const char* str ),,
|
|||
"@see strlwr\n"
|
||||
"@ingroup Strings" )
|
||||
{
|
||||
char *ret = Con::getReturnBuffer(dStrlen(str) + 1);
|
||||
dStrcpy(ret, str);
|
||||
dsize_t retLen = dStrlen(str) + 1;
|
||||
char *ret = Con::getReturnBuffer(retLen);
|
||||
dStrcpy(ret, str, retLen);
|
||||
return dStrupr(ret);
|
||||
}
|
||||
|
||||
|
|
@ -663,7 +666,8 @@ DefineConsoleFunction( strreplace, const char*, ( const char* source, const char
|
|||
count++;
|
||||
}
|
||||
}
|
||||
char *ret = Con::getReturnBuffer(dStrlen(source) + 1 + (toLen - fromLen) * count);
|
||||
S32 retLen = dStrlen(source) + 1 + (toLen - fromLen) * count;
|
||||
char *ret = Con::getReturnBuffer(retLen);
|
||||
U32 scanp = 0;
|
||||
U32 dstp = 0;
|
||||
for(;;)
|
||||
|
|
@ -671,13 +675,13 @@ DefineConsoleFunction( strreplace, const char*, ( const char* source, const char
|
|||
const char *scan = dStrstr(source + scanp, from);
|
||||
if(!scan)
|
||||
{
|
||||
dStrcpy(ret + dstp, source + scanp);
|
||||
dStrcpy(ret + dstp, source + scanp, retLen - dstp);
|
||||
return ret;
|
||||
}
|
||||
U32 len = scan - (source + scanp);
|
||||
dStrncpy(ret + dstp, source + scanp, len);
|
||||
dStrncpy(ret + dstp, source + scanp, getMin(len, retLen - dstp));
|
||||
dstp += len;
|
||||
dStrcpy(ret + dstp, to);
|
||||
dStrcpy(ret + dstp, to, retLen - dstp);
|
||||
dstp += toLen;
|
||||
scanp += len + fromLen;
|
||||
}
|
||||
|
|
@ -901,8 +905,8 @@ DefineConsoleFunction( startsWith, bool, ( const char* str, const char* prefix,
|
|||
char* targetBuf = new char[ targetLen + 1 ];
|
||||
|
||||
// copy src and target into buffers
|
||||
dStrcpy( srcBuf, str );
|
||||
dStrcpy( targetBuf, prefix );
|
||||
dStrcpy( srcBuf, str, srcLen + 1 );
|
||||
dStrcpy( targetBuf, prefix, targetLen + 1 );
|
||||
|
||||
// reassign src/target pointers to lowercase versions
|
||||
str = dStrlwr( srcBuf );
|
||||
|
|
@ -952,8 +956,8 @@ DefineConsoleFunction( endsWith, bool, ( const char* str, const char* suffix, bo
|
|||
char* targetBuf = new char[ targetLen + 1 ];
|
||||
|
||||
// copy src and target into buffers
|
||||
dStrcpy( srcBuf, str );
|
||||
dStrcpy( targetBuf, suffix );
|
||||
dStrcpy( srcBuf, str, srcLen + 1 );
|
||||
dStrcpy( targetBuf, suffix, targetLen + 1 );
|
||||
|
||||
// reassign src/target pointers to lowercase versions
|
||||
str = dStrlwr( srcBuf );
|
||||
|
|
@ -1824,8 +1828,9 @@ DefineEngineFunction( detag, const char*, ( const char* str ),,
|
|||
if( word == NULL )
|
||||
return "";
|
||||
|
||||
char* ret = Con::getReturnBuffer( dStrlen( word + 1 ) + 1 );
|
||||
dStrcpy( ret, word + 1 );
|
||||
dsize_t retLen = dStrlen(word + 1) + 1;
|
||||
char* ret = Con::getReturnBuffer(retLen);
|
||||
dStrcpy( ret, word + 1, retLen );
|
||||
return ret;
|
||||
}
|
||||
else
|
||||
|
|
@ -1889,7 +1894,7 @@ ConsoleFunction( echo, void, 2, 0, "( string message... ) "
|
|||
char *ret = Con::getReturnBuffer(len + 1);
|
||||
ret[0] = 0;
|
||||
for(i = 1; i < argc; i++)
|
||||
dStrcat(ret, argv[i]);
|
||||
dStrcat(ret, argv[i], len + 1);
|
||||
|
||||
Con::printf("%s", ret);
|
||||
ret[0] = 0;
|
||||
|
|
@ -1913,7 +1918,7 @@ ConsoleFunction( warn, void, 2, 0, "( string message... ) "
|
|||
char *ret = Con::getReturnBuffer(len + 1);
|
||||
ret[0] = 0;
|
||||
for(i = 1; i < argc; i++)
|
||||
dStrcat(ret, argv[i]);
|
||||
dStrcat(ret, argv[i], len + 1);
|
||||
|
||||
Con::warnf(ConsoleLogEntry::General, "%s", ret);
|
||||
ret[0] = 0;
|
||||
|
|
@ -1937,7 +1942,7 @@ ConsoleFunction( error, void, 2, 0, "( string message... ) "
|
|||
char *ret = Con::getReturnBuffer(len + 1);
|
||||
ret[0] = 0;
|
||||
for(i = 1; i < argc; i++)
|
||||
dStrcat(ret, argv[i]);
|
||||
dStrcat(ret, argv[i], len + 1);
|
||||
|
||||
Con::errorf(ConsoleLogEntry::General, "%s", ret);
|
||||
ret[0] = 0;
|
||||
|
|
|
|||
|
|
@ -125,7 +125,7 @@ StringValue & StringValue::operator=(const char *string)
|
|||
{
|
||||
S32 len = dStrlen(string);
|
||||
if (len < size)
|
||||
dStrcpy(val, string);
|
||||
dStrcpy(val, string, size);
|
||||
else
|
||||
{
|
||||
size = len;
|
||||
|
|
@ -569,7 +569,7 @@ void ConsoleValue::setStringValue(const char * value)
|
|||
type = TypeInternalString;
|
||||
|
||||
bufferLen = newLen;
|
||||
dStrcpy(sval, value);
|
||||
dStrcpy(sval, value, newLen);
|
||||
}
|
||||
else
|
||||
Con::setData(type, dataPtr, 0, 1, &value, enumTable);
|
||||
|
|
@ -702,7 +702,7 @@ Dictionary::Entry* Dictionary::addVariable(const char *name,
|
|||
if (name[0] != '$')
|
||||
{
|
||||
scratchBuffer[0] = '$';
|
||||
dStrcpy(scratchBuffer + 1, name);
|
||||
dStrcpy(scratchBuffer + 1, name, 1023);
|
||||
name = scratchBuffer;
|
||||
}
|
||||
|
||||
|
|
@ -900,21 +900,21 @@ DefineEngineFunction(backtrace, void, (), ,
|
|||
buf[0] = 0;
|
||||
for (U32 i = 0; i < gEvalState.getStackDepth(); i++)
|
||||
{
|
||||
dStrcat(buf, "->");
|
||||
dStrcat(buf, "->", totalSize);
|
||||
|
||||
if (gEvalState.stack[i]->scopeNamespace && gEvalState.stack[i]->scopeNamespace->mEntryList->mPackage)
|
||||
{
|
||||
dStrcat(buf, "[");
|
||||
dStrcat(buf, gEvalState.stack[i]->scopeNamespace->mEntryList->mPackage);
|
||||
dStrcat(buf, "]");
|
||||
dStrcat(buf, "[", totalSize);
|
||||
dStrcat(buf, gEvalState.stack[i]->scopeNamespace->mEntryList->mPackage, totalSize);
|
||||
dStrcat(buf, "]", totalSize);
|
||||
}
|
||||
if (gEvalState.stack[i]->scopeNamespace && gEvalState.stack[i]->scopeNamespace->mName)
|
||||
{
|
||||
dStrcat(buf, gEvalState.stack[i]->scopeNamespace->mName);
|
||||
dStrcat(buf, "::");
|
||||
dStrcat(buf, gEvalState.stack[i]->scopeNamespace->mName, totalSize);
|
||||
dStrcat(buf, "::", totalSize);
|
||||
}
|
||||
if (gEvalState.stack[i]->scopeName)
|
||||
dStrcat(buf, gEvalState.stack[i]->scopeName);
|
||||
dStrcat(buf, gEvalState.stack[i]->scopeName, totalSize);
|
||||
}
|
||||
|
||||
Con::printf("BackTrace: %s", buf);
|
||||
|
|
@ -1360,9 +1360,9 @@ void Namespace::addScriptCallback(const char *funcName, const char *usage, Conso
|
|||
static U32 uid = 0;
|
||||
char buffer[1024];
|
||||
char lilBuffer[32];
|
||||
dStrcpy(buffer, funcName);
|
||||
dStrcpy(buffer, funcName, 1024);
|
||||
dSprintf(lilBuffer, 32, "_%d_cb", uid++);
|
||||
dStrcat(buffer, lilBuffer);
|
||||
dStrcat(buffer, lilBuffer, 1024);
|
||||
|
||||
Entry *ent = createLocalEntry(StringTable->insert(buffer));
|
||||
trashCache();
|
||||
|
|
@ -1381,9 +1381,9 @@ void Namespace::markGroup(const char* name, const char* usage)
|
|||
static U32 uid = 0;
|
||||
char buffer[1024];
|
||||
char lilBuffer[32];
|
||||
dStrcpy(buffer, name);
|
||||
dStrcpy(buffer, name, 1024);
|
||||
dSprintf(lilBuffer, 32, "_%d", uid++);
|
||||
dStrcat(buffer, lilBuffer);
|
||||
dStrcat(buffer, lilBuffer, 1024);
|
||||
|
||||
Entry *ent = createLocalEntry(StringTable->insert(buffer));
|
||||
trashCache();
|
||||
|
|
|
|||
|
|
@ -356,7 +356,7 @@ void ConsoleObject::addGroup(const char* in_pGroupname, const char* in_pGroupDoc
|
|||
char* pFieldNameBuf = suppressSpaces(in_pGroupname);
|
||||
|
||||
// Append group type to fieldname.
|
||||
dStrcat(pFieldNameBuf, "_begingroup");
|
||||
dStrcat(pFieldNameBuf, "_begingroup", 1024);
|
||||
|
||||
// Create Field.
|
||||
AbstractClassRep::Field f;
|
||||
|
|
@ -385,7 +385,7 @@ void ConsoleObject::endGroup(const char* in_pGroupname)
|
|||
char* pFieldNameBuf = suppressSpaces(in_pGroupname);
|
||||
|
||||
// Append group type to fieldname.
|
||||
dStrcat(pFieldNameBuf, "_endgroup");
|
||||
dStrcat(pFieldNameBuf, "_endgroup", 1024);
|
||||
|
||||
// Create Field.
|
||||
AbstractClassRep::Field f;
|
||||
|
|
@ -407,7 +407,7 @@ void ConsoleObject::endGroup(const char* in_pGroupname)
|
|||
void ConsoleObject::addArray( const char *arrayName, S32 count )
|
||||
{
|
||||
char *nameBuff = suppressSpaces(arrayName);
|
||||
dStrcat(nameBuff, "_beginarray");
|
||||
dStrcat(nameBuff, "_beginarray", 1024);
|
||||
|
||||
// Create Field.
|
||||
AbstractClassRep::Field f;
|
||||
|
|
@ -430,7 +430,7 @@ void ConsoleObject::addArray( const char *arrayName, S32 count )
|
|||
void ConsoleObject::endArray( const char *arrayName )
|
||||
{
|
||||
char *nameBuff = suppressSpaces(arrayName);
|
||||
dStrcat(nameBuff, "_endarray");
|
||||
dStrcat(nameBuff, "_endarray", 1024);
|
||||
|
||||
// Create Field.
|
||||
AbstractClassRep::Field f;
|
||||
|
|
@ -773,11 +773,11 @@ static const char* returnClassList( Vector< AbstractClassRep* >& classes, U32 bu
|
|||
dQsort( classes.address(), classes.size(), sizeof( AbstractClassRep* ), ACRCompare );
|
||||
|
||||
char* ret = Con::getReturnBuffer( bufSize );
|
||||
dStrcpy( ret, classes[ 0 ]->getClassName() );
|
||||
dStrcpy( ret, classes[ 0 ]->getClassName(), bufSize );
|
||||
for( U32 i = 1; i < classes.size(); i ++ )
|
||||
{
|
||||
dStrcat( ret, "\t" );
|
||||
dStrcat( ret, classes[ i ]->getClassName() );
|
||||
dStrcat( ret, "\t", bufSize );
|
||||
dStrcat( ret, classes[ i ]->getClassName(), bufSize );
|
||||
}
|
||||
|
||||
return ret;
|
||||
|
|
@ -888,7 +888,7 @@ DefineEngineFunction( enumerateConsoleClassesByCategory, const char*, ( String c
|
|||
&& ( repCategory[ categoryLength ] == ' ' || repCategory[ categoryLength ] == '\0' ) )
|
||||
{
|
||||
classes.push_back( rep );
|
||||
bufSize += dStrlen( rep->getClassName() + 1 );
|
||||
bufSize += dStrlen( rep->getClassName() ) + 1;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -319,8 +319,8 @@ DefineConsoleFunction( consoleExportXML, const char*, (), ,"Exports console defi
|
|||
Con::XMLExport xmlExport;
|
||||
String xml;
|
||||
xmlExport.exportXML(xml);
|
||||
char* ret = Con::getReturnBuffer(xml.length() + 1);
|
||||
dStrcpy(ret, xml.c_str());
|
||||
char* ret = Con::getReturnBuffer(xml.size());
|
||||
dStrcpy(ret, xml.c_str(), xml.size());
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -273,9 +273,9 @@ DefineConsoleMethod(FieldBrushObject, queryFields, const char*, (const char* sim
|
|||
for ( U32 groupIndex = 0; groupIndex < groupCount; ++groupIndex )
|
||||
{
|
||||
// Copy string element.
|
||||
dStrcpy( tempBuf, StringUnit::getUnit( groupList, groupIndex, " \t\n" ) );
|
||||
dStrcpy( tempBuf, StringUnit::getUnit( groupList, groupIndex, " \t\n" ), 256 );
|
||||
// Append internal name.
|
||||
dStrcat( tempBuf, "_begingroup" );
|
||||
dStrcat( tempBuf, "_begingroup", 256 );
|
||||
// Store Group.
|
||||
groups.push_back( StringTable->insert( tempBuf ) );
|
||||
}
|
||||
|
|
@ -416,7 +416,7 @@ void FieldBrushObject::copyFields( SimObject* pSimObject, const char* fieldList
|
|||
for ( U32 fieldIndex = 0; fieldIndex < fieldCount; ++fieldIndex )
|
||||
{
|
||||
// Copy string element.
|
||||
dStrcpy( tempBuf, StringUnit::getUnit( fieldList, fieldIndex, " \t\n" ) );
|
||||
dStrcpy( tempBuf, StringUnit::getUnit( fieldList, fieldIndex, " \t\n" ), bufferSizes );
|
||||
|
||||
// Store field.
|
||||
fields.push_back( StringTable->insert( tempBuf ) );
|
||||
|
|
|
|||
|
|
@ -495,7 +495,7 @@ DefineEngineFunction(getDirectoryList, String, ( const char* path, S32 depth ),
|
|||
// Copy the directory names to the buffer.
|
||||
for (S32 i = 0; i < directories.size(); i++)
|
||||
{
|
||||
dStrcpy(p, directories[i]);
|
||||
dStrcpy(p, directories[i], length - (p - buffer));
|
||||
p += dStrlen(directories[i]);
|
||||
// Tab separated.
|
||||
p[0] = '\t';
|
||||
|
|
@ -537,7 +537,7 @@ DefineEngineFunction( fileModifiedTime, String, ( const char* fileName ),,
|
|||
String fileStr = Platform::localTimeToString( lt );
|
||||
|
||||
char *buffer = Con::getReturnBuffer( fileStr.size() );
|
||||
dStrcpy( buffer, fileStr );
|
||||
dStrcpy( buffer, fileStr, fileStr.size() );
|
||||
|
||||
return buffer;
|
||||
}
|
||||
|
|
@ -560,7 +560,7 @@ DefineEngineFunction( fileCreatedTime, String, ( const char* fileName ),,
|
|||
String fileStr = Platform::localTimeToString( lt );
|
||||
|
||||
char *buffer = Con::getReturnBuffer( fileStr.size() );
|
||||
dStrcpy( buffer, fileStr );
|
||||
dStrcpy( buffer, fileStr, fileStr.size() );
|
||||
|
||||
return buffer;
|
||||
}
|
||||
|
|
@ -609,7 +609,7 @@ DefineEngineFunction(fileBase, String, ( const char* fileName ),,
|
|||
S32 pathLen = dStrlen( fileName );
|
||||
FrameTemp<char> szPathCopy( pathLen + 1);
|
||||
|
||||
dStrcpy( szPathCopy, fileName );
|
||||
dStrcpy( szPathCopy, fileName, pathLen + 1 );
|
||||
forwardslash( szPathCopy );
|
||||
|
||||
const char *path = dStrrchr(szPathCopy, '/');
|
||||
|
|
@ -617,8 +617,9 @@ DefineEngineFunction(fileBase, String, ( const char* fileName ),,
|
|||
path = szPathCopy;
|
||||
else
|
||||
path++;
|
||||
char *ret = Con::getReturnBuffer(dStrlen(path) + 1);
|
||||
dStrcpy(ret, path);
|
||||
dsize_t retLen = dStrlen(path) + 1;
|
||||
char *ret = Con::getReturnBuffer(retLen);
|
||||
dStrcpy(ret, path, retLen);
|
||||
char *ext = dStrrchr(ret, '.');
|
||||
if(ext)
|
||||
*ext = 0;
|
||||
|
|
@ -635,7 +636,7 @@ DefineEngineFunction(fileName, String, ( const char* fileName ),,
|
|||
S32 pathLen = dStrlen( fileName );
|
||||
FrameTemp<char> szPathCopy( pathLen + 1);
|
||||
|
||||
dStrcpy( szPathCopy, fileName );
|
||||
dStrcpy( szPathCopy, fileName, pathLen + 1 );
|
||||
forwardslash( szPathCopy );
|
||||
|
||||
const char *name = dStrrchr(szPathCopy, '/');
|
||||
|
|
@ -643,8 +644,9 @@ DefineEngineFunction(fileName, String, ( const char* fileName ),,
|
|||
name = szPathCopy;
|
||||
else
|
||||
name++;
|
||||
char *ret = Con::getReturnBuffer(dStrlen(name));
|
||||
dStrcpy(ret, name);
|
||||
dsize_t retLen = dStrlen(name) + 1;
|
||||
char *ret = Con::getReturnBuffer(retLen);
|
||||
dStrcpy(ret, name, retLen);
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
|
@ -658,7 +660,7 @@ DefineEngineFunction(filePath, String, ( const char* fileName ),,
|
|||
S32 pathLen = dStrlen( fileName );
|
||||
FrameTemp<char> szPathCopy( pathLen + 1);
|
||||
|
||||
dStrcpy( szPathCopy, fileName );
|
||||
dStrcpy( szPathCopy, fileName, pathLen + 1 );
|
||||
forwardslash( szPathCopy );
|
||||
|
||||
const char *path = dStrrchr(szPathCopy, '/');
|
||||
|
|
|
|||
|
|
@ -950,7 +950,7 @@ void PersistenceManager::updateToken( const U32 lineNumber, const U32 linePositi
|
|||
char* postString = ( char* ) dMalloc( postStringLen + 1 );
|
||||
if( needQuotes )
|
||||
postString[ 0 ] = '"';
|
||||
dStrcpy( &postString[ needQuotes ? 1 : 0 ], postStringSrc );
|
||||
dStrcpy( &postString[ needQuotes ? 1 : 0 ], postStringSrc, postStringLen + (needQuotes ? 0 : 1) );
|
||||
postString[ postStringLen ] = 0;
|
||||
|
||||
// Calculate the length of our new line
|
||||
|
|
@ -967,10 +967,10 @@ void PersistenceManager::updateToken( const U32 lineNumber, const U32 linePositi
|
|||
|
||||
// Build the new line with the
|
||||
// preString + newValue + postString
|
||||
dStrcat(newLine, preString);
|
||||
dStrcat(newLine, preString, newLineLen + 1);
|
||||
if ( newValue )
|
||||
dStrcat(newLine, newValue);
|
||||
dStrcat(newLine, postString);
|
||||
dStrcat(newLine, newValue, newLineLen + 1);
|
||||
dStrcat(newLine, postString, newLineLen + 1);
|
||||
|
||||
// Clear our existing line
|
||||
if (mLineBuffer[lineNumber])
|
||||
|
|
@ -1243,7 +1243,7 @@ PersistenceManager::ParsedObject* PersistenceManager::writeNewObject(SimObject*
|
|||
char* indent = getObjectIndent(parentObject);
|
||||
|
||||
if (parentObject)
|
||||
dStrcat(indent, " \0");
|
||||
dStrcat(indent, " \0", 2048);
|
||||
|
||||
// Write out the beginning of the object declaration
|
||||
const char* dclToken = "new";
|
||||
|
|
|
|||
|
|
@ -189,7 +189,7 @@ bool expandToolScriptFilename(char *filename, U32 size, const char *src)
|
|||
// Relative to script directory
|
||||
if(cbFullPath)
|
||||
{
|
||||
dStrcpy(varBuf, cbFullPath);
|
||||
dStrcpy(varBuf, cbFullPath, 1024);
|
||||
slash = dStrrchr(varBuf, '/');
|
||||
if(slash) *slash = 0;
|
||||
|
||||
|
|
@ -219,7 +219,7 @@ bool expandOldScriptFilename(char *filename, U32 size, const char *src)
|
|||
const StringTableEntry cbName = CodeBlock::getCurrentCodeBlockName();
|
||||
if (!cbName)
|
||||
{
|
||||
dStrcpy(filename, src);
|
||||
dStrcpy(filename, src, size);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
|
@ -244,7 +244,7 @@ bool expandOldScriptFilename(char *filename, U32 size, const char *src)
|
|||
*filename = 0;
|
||||
return false;
|
||||
}
|
||||
dStrcpy(filename, src);
|
||||
dStrcpy(filename, src, size);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
|
@ -264,7 +264,7 @@ bool expandOldScriptFilename(char *filename, U32 size, const char *src)
|
|||
}
|
||||
|
||||
dStrncpy(filename, cbName, length);
|
||||
dStrcpy(filename+length, src+1);
|
||||
dStrcpy(filename+length, src+1, size - length);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
|
@ -325,7 +325,7 @@ bool collapseScriptFilename(char *filename, U32 size, const char *src)
|
|||
*filename = 0;
|
||||
if(*test[i].replace)
|
||||
dSprintf(filename, size, "%s/", test[i].replace);
|
||||
dStrcat(filename, rel);
|
||||
dStrcat(filename, rel, size);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -216,7 +216,7 @@ DefineConsoleFunction( getUniqueName, const char*, (const char * baseName), ,
|
|||
return NULL;
|
||||
|
||||
char *buffer = Con::getReturnBuffer( outName.size() );
|
||||
dStrcpy( buffer, outName );
|
||||
dStrcpy( buffer, outName, outName.size() );
|
||||
|
||||
return buffer;
|
||||
}
|
||||
|
|
@ -241,7 +241,7 @@ DefineConsoleFunction( getUniqueInternalName, const char*, (const char * baseNam
|
|||
return NULL;
|
||||
|
||||
char *buffer = Con::getReturnBuffer( outName.size() );
|
||||
dStrcpy( buffer, outName );
|
||||
dStrcpy( buffer, outName, outName.size() );
|
||||
|
||||
return buffer;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -198,10 +198,10 @@ void SimDataBlock::performSubstitutions(SimDataBlock* dblock, const SimObject* o
|
|||
}
|
||||
|
||||
char obj_str[32];
|
||||
dStrcpy(obj_str, Con::getIntArg(obj->getId()));
|
||||
dStrcpy(obj_str, Con::getIntArg(obj->getId()), 32);
|
||||
|
||||
char index_str[32];
|
||||
dStrcpy(index_str, Con::getIntArg(index));
|
||||
dStrcpy(index_str, Con::getIntArg(index), 32);
|
||||
|
||||
for (S32 i = 0; i < substitutions.size(); i++)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -281,7 +281,7 @@ void SimFieldDictionary::writeFields(SimObject *obj, Stream &stream, U32 tabStop
|
|||
dSprintf(expandedBuffer, nBufferSize, "%s%s%s = \"", typeName, *typeName ? " " : "", (*itr)->slotName);
|
||||
if ((*itr)->value)
|
||||
expandEscape((char*)expandedBuffer + dStrlen(expandedBuffer), (*itr)->value);
|
||||
dStrcat(expandedBuffer, "\";\r\n");
|
||||
dStrcat(expandedBuffer, "\";\r\n", nBufferSize);
|
||||
|
||||
stream.write(dStrlen(expandedBuffer), expandedBuffer);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -320,7 +320,7 @@ void SimObject::writeFields(Stream &stream, U32 tabStop)
|
|||
|
||||
U32 nBufferSize = dStrlen( val ) + 1;
|
||||
FrameTemp<char> valCopy( nBufferSize );
|
||||
dStrcpy( (char *)valCopy, val );
|
||||
dStrcpy( (char *)valCopy, val, nBufferSize );
|
||||
|
||||
if (!writeField(f->pFieldname, valCopy))
|
||||
continue;
|
||||
|
|
@ -347,7 +347,7 @@ void SimObject::writeFields(Stream &stream, U32 tabStop)
|
|||
}
|
||||
|
||||
expandEscape((char*)expandedBuffer + dStrlen(expandedBuffer), val);
|
||||
dStrcat(expandedBuffer, "\";\r\n");
|
||||
dStrcat(expandedBuffer, "\";\r\n", expandedBufferSize);
|
||||
|
||||
stream.writeTabs(tabStop);
|
||||
stream.write(dStrlen(expandedBuffer),expandedBuffer);
|
||||
|
|
@ -402,12 +402,12 @@ bool SimObject::save(const char *pcFileName, bool bOnlySelected, const char *pre
|
|||
char docRoot[256];
|
||||
char modRoot[256];
|
||||
|
||||
dStrcpy(docRoot, pcFileName);
|
||||
dStrcpy(docRoot, pcFileName, 256);
|
||||
char *p = dStrrchr(docRoot, '/');
|
||||
if (p) *++p = '\0';
|
||||
else docRoot[0] = '\0';
|
||||
|
||||
dStrcpy(modRoot, pcFileName);
|
||||
dStrcpy(modRoot, pcFileName, 256);
|
||||
p = dStrchr(modRoot, '/');
|
||||
if (p) *++p = '\0';
|
||||
else modRoot[0] = '\0';
|
||||
|
|
@ -1028,8 +1028,8 @@ void SimObject::setDataField(StringTableEntry slotName, const char *array, const
|
|||
else
|
||||
{
|
||||
char buf[256];
|
||||
dStrcpy(buf, slotName);
|
||||
dStrcat(buf, array);
|
||||
dStrcpy(buf, slotName, 256);
|
||||
dStrcat(buf, array, 256);
|
||||
StringTableEntry permanentSlotName = StringTable->insert(buf);
|
||||
mFieldDictionary->setFieldValue(permanentSlotName, value);
|
||||
onDynamicModified( permanentSlotName, value );
|
||||
|
|
@ -1069,8 +1069,8 @@ const char *SimObject::getDataField(StringTableEntry slotName, const char *array
|
|||
else
|
||||
{
|
||||
static char buf[256];
|
||||
dStrcpy(buf, slotName);
|
||||
dStrcat(buf, array);
|
||||
dStrcpy(buf, slotName, 256);
|
||||
dStrcat(buf, array, 256);
|
||||
if (const char* val = mFieldDictionary->getFieldValue(StringTable->insert(buf)))
|
||||
return val;
|
||||
}
|
||||
|
|
@ -1310,8 +1310,8 @@ U32 SimObject::getDataFieldType( StringTableEntry slotName, const char* array )
|
|||
else
|
||||
{
|
||||
static char buf[256];
|
||||
dStrcpy( buf, slotName );
|
||||
dStrcat( buf, array );
|
||||
dStrcpy( buf, slotName, 256 );
|
||||
dStrcat( buf, array, 256 );
|
||||
|
||||
return mFieldDictionary->getFieldType( StringTable->insert( buf ) );
|
||||
}
|
||||
|
|
@ -1333,8 +1333,8 @@ void SimObject::setDataFieldType(const U32 fieldTypeId, StringTableEntry slotNam
|
|||
else
|
||||
{
|
||||
static char buf[256];
|
||||
dStrcpy( buf, slotName );
|
||||
dStrcat( buf, array );
|
||||
dStrcpy( buf, slotName, 256 );
|
||||
dStrcat( buf, array, 256 );
|
||||
|
||||
mFieldDictionary->setFieldType( StringTable->insert( buf ), fieldTypeId );
|
||||
onDynamicModified( slotName, mFieldDictionary->getFieldValue(slotName) );
|
||||
|
|
@ -1354,8 +1354,8 @@ void SimObject::setDataFieldType(const char *typeName, StringTableEntry slotName
|
|||
else
|
||||
{
|
||||
static char buf[256];
|
||||
dStrcpy( buf, slotName );
|
||||
dStrcat( buf, array );
|
||||
dStrcpy( buf, slotName, 256 );
|
||||
dStrcat( buf, array, 256 );
|
||||
StringTableEntry permanentSlotName = StringTable->insert(buf);
|
||||
|
||||
mFieldDictionary->setFieldType( permanentSlotName, typeName );
|
||||
|
|
|
|||
|
|
@ -134,10 +134,11 @@ SimObject *SimObjectMemento::restore() const
|
|||
return NULL;
|
||||
U32 numCharsToLeftParen = pLeftParen - mState;
|
||||
|
||||
tempBuffer = ( char* ) dMalloc( dStrlen( mState ) + uniqueNameLen + 1 );
|
||||
dsize_t tempBufferLen = dStrlen(mState) + uniqueNameLen + 1;
|
||||
tempBuffer = ( char* ) dMalloc( tempBufferLen );
|
||||
dMemcpy( tempBuffer, mState, numCharsToLeftParen );
|
||||
dMemcpy( &tempBuffer[ numCharsToLeftParen ], uniqueName, uniqueNameLen );
|
||||
dStrcpy( &tempBuffer[ numCharsToLeftParen + uniqueNameLen ], &mState[ numCharsToLeftParen ] );
|
||||
dStrcpy( &tempBuffer[ numCharsToLeftParen + uniqueNameLen ], &mState[ numCharsToLeftParen ], tempBufferLen - numCharsToLeftParen - uniqueNameLen );
|
||||
}
|
||||
|
||||
Con::evaluate( tempBuffer );
|
||||
|
|
|
|||
|
|
@ -176,7 +176,7 @@ struct StringStack
|
|||
mLen = dStrlen(s);
|
||||
|
||||
validateBufferSize(mStart + mLen + 2);
|
||||
dStrcpy(mBuffer + mStart, s);
|
||||
dStrcpy(mBuffer + mStart, s, mBufferSize - mStart);
|
||||
}
|
||||
|
||||
/// Get the top of the stack, as a StringTableEntry.
|
||||
|
|
|
|||
|
|
@ -470,19 +470,19 @@ void TelnetDebugger::sendBreak()
|
|||
if ( ns ) {
|
||||
|
||||
if ( ns->mParent && ns->mParent->mPackage && ns->mParent->mPackage[0] ) {
|
||||
dStrcat( scope, ns->mParent->mPackage );
|
||||
dStrcat( scope, "::" );
|
||||
dStrcat( scope, ns->mParent->mPackage, MaxCommandSize );
|
||||
dStrcat( scope, "::", MaxCommandSize );
|
||||
}
|
||||
if ( ns->mName && ns->mName[0] ) {
|
||||
dStrcat( scope, ns->mName );
|
||||
dStrcat( scope, "::" );
|
||||
dStrcat( scope, ns->mName, MaxCommandSize );
|
||||
dStrcat( scope, "::", MaxCommandSize );
|
||||
}
|
||||
}
|
||||
|
||||
const char *function = gEvalState.stack[i]->scopeName;
|
||||
if ((!function) || (!function[0]))
|
||||
function = "<none>";
|
||||
dStrcat( scope, function );
|
||||
dStrcat( scope, function, MaxCommandSize );
|
||||
|
||||
U32 line=0, inst;
|
||||
U32 ip = gEvalState.stack[i]->ip;
|
||||
|
|
|
|||
|
|
@ -185,7 +185,7 @@ public:
|
|||
/// the FrameAllocator. For example:
|
||||
/// @code
|
||||
/// FrameTemp<char> tempStr(32); // NOTE! This parameter is NOT THE SIZE IN BYTES. See constructor docs.
|
||||
/// dStrcat( tempStr, SomeOtherString );
|
||||
/// dStrcat( tempStr, SomeOtherString, 32 * sizeof(char) );
|
||||
/// tempStr[2] = 'l';
|
||||
/// Con::printf( tempStr );
|
||||
/// Con::printf( "Foo: %s", ~tempStr );
|
||||
|
|
|
|||
|
|
@ -668,13 +668,13 @@ void BitStream::readString(char buf[256])
|
|||
{
|
||||
S32 offset = readInt(8);
|
||||
HuffmanProcessor::g_huffProcessor.readHuffBuffer(this, stringBuffer + offset);
|
||||
dStrcpy(buf, stringBuffer);
|
||||
dStrcpy(buf, stringBuffer, 256);
|
||||
return;
|
||||
}
|
||||
}
|
||||
HuffmanProcessor::g_huffProcessor.readHuffBuffer(this, buf);
|
||||
if(stringBuffer)
|
||||
dStrcpy(stringBuffer, buf);
|
||||
dStrcpy(stringBuffer, buf, 256);
|
||||
}
|
||||
|
||||
void BitStream::writeString(const char *string, S32 maxLen)
|
||||
|
|
|
|||
|
|
@ -142,10 +142,11 @@ StringTableEntry _StringTable::insert(const char* _val, const bool caseSens)
|
|||
}
|
||||
char *ret = 0;
|
||||
if(!*walk) {
|
||||
dsize_t valLen = dStrlen(val) + 1;
|
||||
*walk = (Node *) mempool.alloc(sizeof(Node));
|
||||
(*walk)->next = 0;
|
||||
(*walk)->val = (char *) mempool.alloc(dStrlen(val) + 1);
|
||||
dStrcpy((*walk)->val, val);
|
||||
(*walk)->val = (char *) mempool.alloc(valLen);
|
||||
dStrcpy((*walk)->val, val, valLen);
|
||||
ret = (*walk)->val;
|
||||
itemCount ++;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -71,8 +71,9 @@ void FindMatch::setExpression( const char *_expression )
|
|||
{
|
||||
delete [] expression;
|
||||
|
||||
expression = new char[dStrlen(_expression) + 1];
|
||||
dStrcpy(expression, _expression);
|
||||
dsize_t expressionLen = dStrlen(_expression) + 1;
|
||||
expression = new char[expressionLen];
|
||||
dStrcpy(expression, _expression, expressionLen);
|
||||
dStrupr(expression);
|
||||
}
|
||||
|
||||
|
|
@ -82,7 +83,7 @@ bool FindMatch::findMatch( const char *str, bool caseSensitive )
|
|||
return false;
|
||||
|
||||
char nstr[512];
|
||||
dStrcpy( nstr,str );
|
||||
dStrcpy( nstr,str,512 );
|
||||
dStrupr(nstr);
|
||||
if ( isMatch( expression, nstr, caseSensitive ) )
|
||||
{
|
||||
|
|
@ -143,7 +144,7 @@ bool FindMatch::isMatchMultipleExprs( const char *exps, const char *str, bool ca
|
|||
S32 len = dStrlen(exps);
|
||||
|
||||
char *e = new char[len+1];
|
||||
dStrcpy(e,exps);
|
||||
dStrcpy(e,exps,len+1);
|
||||
|
||||
// [tom, 12/18/2006] This no longer supports space separated expressions as
|
||||
// they don't work when the paths have spaces in.
|
||||
|
|
|
|||
|
|
@ -215,8 +215,9 @@ S32 dStrnatcasecmp(const nat_char* a, const nat_char* b) {
|
|||
|
||||
char *dStrdup_r(const char *src, const char *fileName, dsize_t lineNumber)
|
||||
{
|
||||
char *buffer = (char *) dMalloc_r(dStrlen(src) + 1, fileName, lineNumber);
|
||||
dStrcpy(buffer, src);
|
||||
dsize_t bufferLen = dStrlen(src) + 1;
|
||||
char *buffer = (char *) dMalloc_r(bufferLen, fileName, lineNumber);
|
||||
dStrcpy(buffer, src, bufferLen);
|
||||
return buffer;
|
||||
}
|
||||
|
||||
|
|
@ -381,6 +382,67 @@ char* dStrlwr(char *str)
|
|||
#endif
|
||||
}
|
||||
|
||||
//------------------------------------------------------------------------------
|
||||
|
||||
S32 dStrlcat(char *dst, const char *src, dsize_t dstSize)
|
||||
{
|
||||
//TODO: Do other platforms support strlcat in their libc
|
||||
#ifdef TORQUE_OS_MAC
|
||||
S32 len = strlcat(dst, src, dstSize);
|
||||
|
||||
AssertWarn(len < dstSize, "Buffer too small in call to dStrlcat!");
|
||||
|
||||
return len;
|
||||
#else //TORQUE_OS_MAC
|
||||
S32 dstLen = dStrlen(dst);
|
||||
S32 srcLen = dStrlen(src);
|
||||
S32 copyLen = srcLen;
|
||||
|
||||
//Check for buffer overflow and don't allow it. Warn on debug so we can fix it
|
||||
AssertWarn(dstLen + copyLen < dstSize, "Buffer too small in call to dStrlcat!");
|
||||
if (dstLen + copyLen + 1 > dstSize)
|
||||
{
|
||||
copyLen = dstSize - dstLen - 1;
|
||||
}
|
||||
|
||||
//Copy src after dst and null terminate
|
||||
memcpy(dst + dstLen, src, copyLen);
|
||||
dst[dstLen + copyLen] = 0;
|
||||
|
||||
//Return the length of the string we would have generated
|
||||
return dstLen + srcLen;
|
||||
#endif //TORQUE_OS_MAC
|
||||
}
|
||||
|
||||
S32 dStrlcpy(char *dst, const char *src, dsize_t dstSize)
|
||||
{
|
||||
//TODO: Do other platforms support strlcpy in their libc
|
||||
#ifdef TORQUE_OS_MAC
|
||||
S32 len = strlcpy(dst, src, dstSize);
|
||||
|
||||
AssertWarn(len < dstSize, "Buffer too small in call to dStrlcpy!");
|
||||
|
||||
return len;
|
||||
#else //TORQUE_OS_MAC
|
||||
S32 srcLen = dStrlen(src);
|
||||
S32 copyLen = srcLen;
|
||||
|
||||
//Check for buffer overflow and don't allow it. Warn on debug so we can fix it
|
||||
AssertWarn(copyLen < dstSize, "Buffer too small in call to dStrlcpy!");
|
||||
if (srcLen + 1 > dstSize)
|
||||
{
|
||||
copyLen = dstSize - 1;
|
||||
}
|
||||
|
||||
//Copy src and null terminate
|
||||
memcpy(dst, src, copyLen);
|
||||
dst[copyLen] = 0;
|
||||
|
||||
//Return the length of the string we would have generated
|
||||
return srcLen;
|
||||
#endif //TORQUE_OS_MAC
|
||||
}
|
||||
|
||||
//------------------------------------------------------------------------------
|
||||
// standard I/O functions
|
||||
|
||||
|
|
|
|||
|
|
@ -32,6 +32,10 @@
|
|||
#include "platform/types.h"
|
||||
#endif
|
||||
|
||||
#ifndef _PLATFORMASSERT_H_
|
||||
#include "platform/platformAssert.h"
|
||||
#endif
|
||||
|
||||
#if defined(TORQUE_OS_WIN)
|
||||
// These standard functions are not defined on Win32 and other Microsoft platforms...
|
||||
#define strcasecmp _stricmp
|
||||
|
|
@ -43,18 +47,37 @@
|
|||
|
||||
#endif // defined(TORQUE_OS_WIN)
|
||||
|
||||
|
||||
//------------------------------------------------------------------------------
|
||||
// standard string functions [defined in platformString.cpp]
|
||||
|
||||
// Buffer size bounds checking "safe" versions of strcat and strcpy. Ideally you
|
||||
// should use these and check if they return >= dstSize and throw an error if so.
|
||||
extern S32 dStrlcat(char *dst, const char *src, dsize_t dstSize);
|
||||
extern S32 dStrlcpy(char *dst, const char *src, dsize_t dstSize);
|
||||
|
||||
#ifdef UNSAFE_STRING_FUNCTIONS
|
||||
/// @deprecated Use dStrcat(char *, const char *, dsize_t) instead
|
||||
inline char *dStrcat(char *dst, const char *src)
|
||||
{
|
||||
AssertFatal(false, "dStrcat without length is deprecated");
|
||||
return strcat(dst,src);
|
||||
}
|
||||
#endif
|
||||
|
||||
/// Concatenate strings.
|
||||
/// @note The third parameter is the size of the destination buffer like strlcat
|
||||
/// instead of the number of characters to copy like strncat. This is done
|
||||
/// under the assumption that being easier to use will make this safer.
|
||||
/// If you want the original behavior use dStrncat.
|
||||
inline char *dStrcat(char *dst, const char *src, dsize_t dstSize)
|
||||
{
|
||||
dStrlcat(dst, src, dstSize);
|
||||
return dst;
|
||||
}
|
||||
|
||||
inline char *dStrncat(char *dst, const char *src, dsize_t len)
|
||||
{
|
||||
return strncat(dst,src,len);
|
||||
return strncat(dst, src, len);
|
||||
}
|
||||
|
||||
inline S32 dStrcmp(const char *str1, const char *str2)
|
||||
|
|
@ -82,9 +105,19 @@ inline S32 dStrnicmp(const char *str1, const char *str2, dsize_t len)
|
|||
return strncasecmp( str1, str2, len );
|
||||
}
|
||||
|
||||
#ifdef UNSAFE_STRING_FUNCTIONS
|
||||
/// @deprecated Use strcpy(char *, const char *, dsize_t) instead
|
||||
inline char *dStrcpy(char *dst, const char *src)
|
||||
{
|
||||
AssertFatal(false, "dStrcpy without length is deprecated");
|
||||
return strcpy(dst,src);
|
||||
}
|
||||
#endif
|
||||
|
||||
inline char *dStrcpy(char *dst, const char *src, dsize_t dstSize)
|
||||
{
|
||||
dStrlcpy(dst, src, dstSize);
|
||||
return dst;
|
||||
}
|
||||
|
||||
inline char *dStrncpy(char *dst, const char *src, dsize_t len)
|
||||
|
|
|
|||
|
|
@ -164,7 +164,7 @@ namespace StringUnit
|
|||
|
||||
// replace this unit
|
||||
ret[sz] = '\0';
|
||||
dStrcat(ret, replace);
|
||||
dStrcat(ret, replace, 2048);
|
||||
|
||||
// copy remaining chunks
|
||||
sz = dStrcspn(string, set); // skip chunk we're replacing
|
||||
|
|
@ -172,7 +172,7 @@ namespace StringUnit
|
|||
return ret;
|
||||
|
||||
string += sz;
|
||||
dStrcat(ret, string);
|
||||
dStrcat(ret, string, 2048);
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
|
@ -211,7 +211,7 @@ namespace StringUnit
|
|||
}
|
||||
|
||||
string += sz + 1; // skip the extra field delimiter
|
||||
dStrcat(ret, string);
|
||||
dStrcat(ret, string, 2048);
|
||||
return ret;
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -61,7 +61,7 @@ bool Tokenizer::openFile(const char* pFileName)
|
|||
delete pStream;
|
||||
return false;
|
||||
}
|
||||
dStrcpy(mFileName, pFileName);
|
||||
dStrcpy(mFileName, pFileName, 1024);
|
||||
|
||||
mBufferSize = pStream->getStreamSize();
|
||||
mpBuffer = new char[mBufferSize];
|
||||
|
|
@ -99,7 +99,7 @@ void Tokenizer::setBuffer(const char* buffer, U32 bufferSize)
|
|||
|
||||
mBufferSize = bufferSize;
|
||||
mpBuffer = new char[mBufferSize + 1];
|
||||
dStrcpy(mpBuffer, buffer);
|
||||
dStrcpy(mpBuffer, buffer, mBufferSize + 1);
|
||||
|
||||
reset();
|
||||
|
||||
|
|
@ -634,4 +634,4 @@ bool Tokenizer::endOfFile()
|
|||
return false;
|
||||
else
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -177,8 +177,9 @@ bool CentralDir::write(Stream *stream)
|
|||
void CentralDir::setFileComment(const char *comment)
|
||||
{
|
||||
SAFE_DELETE_ARRAY(mFileComment);
|
||||
mFileComment = new char [dStrlen(comment)+1];
|
||||
dStrcpy(mFileComment, comment);
|
||||
dsize_t commentLen = dStrlen(comment) + 1;
|
||||
mFileComment = new char [commentLen];
|
||||
dStrcpy(mFileComment, comment, commentLen);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
|
|
|
|||
|
|
@ -95,7 +95,7 @@ private:
|
|||
{
|
||||
// Find a unique filename
|
||||
U32 count = 1;
|
||||
dStrcpy(fileBuf, filename);
|
||||
dStrcpy(fileBuf, filename, bufSize);
|
||||
|
||||
while(zip->findFileInfo(fileBuf))
|
||||
{
|
||||
|
|
@ -109,7 +109,7 @@ private:
|
|||
}
|
||||
}
|
||||
else if(fileBuf && bufSize > 0)
|
||||
dStrcpy(fileBuf, filename);
|
||||
dStrcpy(fileBuf, filename, bufSize);
|
||||
|
||||
// Try and write to the file
|
||||
Stream * stream = zip->openFile(fileBuf ? fileBuf : filename, ZipArchive::Write);
|
||||
|
|
|
|||
|
|
@ -309,7 +309,7 @@ void GFXNullDevice::enumerateAdapters( Vector<GFXAdapter*> &adapterList )
|
|||
vm.resolution.set(800,600);
|
||||
toAdd->mAvailableModes.push_back(vm);
|
||||
|
||||
dStrcpy(toAdd->mName, "GFX Null Device");
|
||||
dStrcpy(toAdd->mName, "GFX Null Device", GFXAdapter::MaxAdapterNameLen);
|
||||
|
||||
adapterList.push_back(toAdd);
|
||||
}
|
||||
|
|
@ -342,4 +342,4 @@ public:
|
|||
}
|
||||
};
|
||||
|
||||
static GFXNullRegisterDevice pNullRegisterDevice;
|
||||
static GFXNullRegisterDevice pNullRegisterDevice;
|
||||
|
|
|
|||
|
|
@ -39,8 +39,9 @@ void GFXVideoMode::parseFromString( const char *str )
|
|||
return;
|
||||
|
||||
// Copy the string, as dStrtok is destructive
|
||||
char *tempBuf = new char[dStrlen( str ) + 1];
|
||||
dStrcpy( tempBuf, str );
|
||||
dsize_t tempBufLen = dStrlen(str) + 1;
|
||||
char *tempBuf = new char[tempBufLen];
|
||||
dStrcpy( tempBuf, str, tempBufLen );
|
||||
|
||||
#define PARSE_ELEM(type, var, func, tokParam, sep) \
|
||||
if(const char *ptr = dStrtok( tokParam, sep)) \
|
||||
|
|
@ -76,4 +77,4 @@ void GFXShaderMacro::stringize( const Vector<GFXShaderMacro> ¯os, String *ou
|
|||
}
|
||||
(*outString) += ";";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -128,11 +128,11 @@ void GFXGLDevice::enumerateAdapters( Vector<GFXAdapter*> &adapterList )
|
|||
|
||||
if (renderer)
|
||||
{
|
||||
dStrcpy(toAdd->mName, renderer);
|
||||
dStrncat(toAdd->mName, " OpenGL", GFXAdapter::MaxAdapterNameLen);
|
||||
dStrcpy(toAdd->mName, renderer, GFXAdapter::MaxAdapterNameLen);
|
||||
dStrcat(toAdd->mName, " OpenGL", GFXAdapter::MaxAdapterNameLen);
|
||||
}
|
||||
else
|
||||
dStrcpy(toAdd->mName, "OpenGL");
|
||||
dStrcpy(toAdd->mName, "OpenGL", GFXAdapter::MaxAdapterNameLen);
|
||||
|
||||
toAdd->mType = OpenGL;
|
||||
toAdd->mShaderModel = 0.f;
|
||||
|
|
|
|||
|
|
@ -129,11 +129,11 @@ void GFXGLDevice::enumerateAdapters( Vector<GFXAdapter*> &adapterList )
|
|||
|
||||
if (renderer)
|
||||
{
|
||||
dStrcpy(toAdd->mName, renderer);
|
||||
dStrcpy(toAdd->mName, renderer, GFXAdapter::MaxAdapterNameLen);
|
||||
dStrncat(toAdd->mName, " OpenGL", GFXAdapter::MaxAdapterNameLen);
|
||||
}
|
||||
else
|
||||
dStrcpy(toAdd->mName, "OpenGL");
|
||||
dStrcpy(toAdd->mName, "OpenGL", GFXAdapter::MaxAdapterNameLen);
|
||||
|
||||
toAdd->mType = OpenGL;
|
||||
toAdd->mShaderModel = 0.f;
|
||||
|
|
|
|||
|
|
@ -55,7 +55,7 @@ ScreenShot::ScreenShot()
|
|||
|
||||
void ScreenShot::setPending( const char *filename, bool writeJPG, S32 tiles, F32 overlap )
|
||||
{
|
||||
dStrcpy( mFilename, filename );
|
||||
dStrcpy( mFilename, filename, 256 );
|
||||
mWriteJPG = writeJPG;
|
||||
mTiles = getMax( tiles, 1 );
|
||||
mPixelOverlap.set(getMin(overlap, 0.25f), getMin(overlap, 0.25f));
|
||||
|
|
|
|||
|
|
@ -218,9 +218,9 @@ bool GuiFormCtrl::resize(const Point2I &newPosition, const Point2I &newExtent)
|
|||
S32 strlen = dStrlen((const char*)mCaption);
|
||||
for(S32 i=strlen; i>=0; --i)
|
||||
{
|
||||
dStrcpy(buf, "");
|
||||
dStrncat(buf, (const char*)mCaption, i);
|
||||
dStrcat(buf, "...");
|
||||
dStrcpy(buf, "", i);
|
||||
dStrcat(buf, (const char*)mCaption, i);
|
||||
dStrcat(buf, "...", i);
|
||||
|
||||
textWidth = mProfile->mFont->getStrWidth(buf);
|
||||
|
||||
|
|
|
|||
|
|
@ -167,8 +167,9 @@ bool guiAnimBitmapCtrl::ptSetFrameRanges(void *object, const char *index, const
|
|||
pData->mCurFrameIndex = pData->mNumFrames;
|
||||
return true;
|
||||
}
|
||||
char* tokCopy = new char[dStrlen(data) + 1];
|
||||
dStrcpy(tokCopy, data);
|
||||
dsize_t tokLen = dStrlen(data) + 1;
|
||||
char* tokCopy = new char[tokLen];
|
||||
dStrcpy(tokCopy, data, tokLen);
|
||||
|
||||
char* currTok = dStrtok(tokCopy, " \t");
|
||||
while (currTok != NULL)
|
||||
|
|
@ -291,4 +292,4 @@ void guiAnimBitmapCtrl::onRender(Point2I offset, const RectI &updateRect)
|
|||
}
|
||||
|
||||
renderChildControls(offset, updateRect);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -195,7 +195,7 @@ DefineEngineMethod( GuiDirectoryFileListCtrl, getSelectedFiles, const char*, (),
|
|||
|
||||
dMemset( itemBuffer, 0, itemBufSize );
|
||||
dSprintf( itemBuffer, itemBufSize, " %s", itemText );
|
||||
dStrcat( returnBuffer, itemBuffer );
|
||||
dStrcat( returnBuffer, itemBuffer, itemBufSize );
|
||||
}
|
||||
|
||||
return returnBuffer;
|
||||
|
|
|
|||
|
|
@ -276,7 +276,7 @@ void GuiFileTreeCtrl::recurseInsert( Item* parent, StringTableEntry path )
|
|||
|
||||
char szPathCopy [ 1024 ];
|
||||
dMemset( szPathCopy, 0, 1024 );
|
||||
dStrcpy( szPathCopy, path );
|
||||
dStrcpy( szPathCopy, path, 1024 );
|
||||
|
||||
// Jump over the first character if it's a root /
|
||||
char *curPos = szPathCopy;
|
||||
|
|
|
|||
|
|
@ -458,7 +458,7 @@ DefineEngineMethod( GuiListBoxCtrl, getSelectedItems, const char*, (),,
|
|||
{
|
||||
UTF8 retFormat[12];
|
||||
dSprintf( retFormat, 12, "%d ", (*i) );
|
||||
dStrcat( retBuffer, retFormat );
|
||||
dStrcat( retBuffer, retFormat, 12 );
|
||||
}
|
||||
|
||||
return retBuffer;
|
||||
|
|
|
|||
|
|
@ -566,13 +566,14 @@ void GuiPopUpMenuCtrl::setBitmap( const char *name )
|
|||
{
|
||||
char buffer[1024];
|
||||
char *p;
|
||||
dStrcpy(buffer, name);
|
||||
dStrcpy(buffer, name, 1024);
|
||||
p = buffer + dStrlen(buffer);
|
||||
S32 pLen = 1024 - dStrlen(buffer);
|
||||
|
||||
dStrcpy(p, "_n");
|
||||
dStrcpy(p, "_n", pLen);
|
||||
mTextureNormal = GFXTexHandle( (StringTableEntry)buffer, &GFXDefaultGUIProfile, avar("%s() - mTextureNormal (line %d)", __FUNCTION__, __LINE__) );
|
||||
|
||||
dStrcpy(p, "_d");
|
||||
dStrcpy(p, "_d", pLen);
|
||||
mTextureDepressed = GFXTexHandle( (StringTableEntry)buffer, &GFXDefaultGUIProfile, avar("%s() - mTextureDepressed (line %d)", __FUNCTION__, __LINE__) );
|
||||
if ( !mTextureDepressed )
|
||||
mTextureDepressed = mTextureNormal;
|
||||
|
|
@ -637,7 +638,7 @@ void GuiPopUpMenuCtrl::addEntry( const char *buf, S32 id, U32 scheme )
|
|||
mIdMax = id;
|
||||
|
||||
Entry e;
|
||||
dStrcpy( e.buf, buf );
|
||||
dStrcpy( e.buf, buf, 256 );
|
||||
e.id = id;
|
||||
e.scheme = scheme;
|
||||
|
||||
|
|
|
|||
|
|
@ -390,7 +390,7 @@ DefineEngineMethod( GuiPopUpMenuCtrlEx, addScheme, void, (S32 id, ColorI fontCol
|
|||
U32 r, g, b;
|
||||
char buf[64];
|
||||
|
||||
dStrcpy( buf, argv[3] );
|
||||
dStrcpy( buf, argv[3], 64 );
|
||||
char* temp = dStrtok( buf, " \0" );
|
||||
r = temp ? dAtoi( temp ) : 0;
|
||||
temp = dStrtok( NULL, " \0" );
|
||||
|
|
@ -399,7 +399,7 @@ DefineEngineMethod( GuiPopUpMenuCtrlEx, addScheme, void, (S32 id, ColorI fontCol
|
|||
b = temp ? dAtoi( temp ) : 0;
|
||||
fontColor.set( r, g, b );
|
||||
|
||||
dStrcpy( buf, argv[4] );
|
||||
dStrcpy( buf, argv[4], 64 );
|
||||
temp = dStrtok( buf, " \0" );
|
||||
r = temp ? dAtoi( temp ) : 0;
|
||||
temp = dStrtok( NULL, " \0" );
|
||||
|
|
@ -408,7 +408,7 @@ DefineEngineMethod( GuiPopUpMenuCtrlEx, addScheme, void, (S32 id, ColorI fontCol
|
|||
b = temp ? dAtoi( temp ) : 0;
|
||||
fontColorHL.set( r, g, b );
|
||||
|
||||
dStrcpy( buf, argv[5] );
|
||||
dStrcpy( buf, argv[5], 64 );
|
||||
temp = dStrtok( buf, " \0" );
|
||||
r = temp ? dAtoi( temp ) : 0;
|
||||
temp = dStrtok( NULL, " \0" );
|
||||
|
|
@ -426,7 +426,7 @@ DefineEngineMethod( GuiPopUpMenuCtrlEx, addScheme, void, (S32 id, ColorI fontCol
|
|||
// U32 r, g, b;
|
||||
// char buf[64];
|
||||
//
|
||||
// dStrcpy( buf, argv[3] );
|
||||
// dStrcpy( buf, argv[3], 64 );
|
||||
// char* temp = dStrtok( buf, " \0" );
|
||||
// r = temp ? dAtoi( temp ) : 0;
|
||||
// temp = dStrtok( NULL, " \0" );
|
||||
|
|
@ -435,7 +435,7 @@ DefineEngineMethod( GuiPopUpMenuCtrlEx, addScheme, void, (S32 id, ColorI fontCol
|
|||
// b = temp ? dAtoi( temp ) : 0;
|
||||
// fontColor.set( r, g, b );
|
||||
//
|
||||
// dStrcpy( buf, argv[4] );
|
||||
// dStrcpy( buf, argv[4], 64 );
|
||||
// temp = dStrtok( buf, " \0" );
|
||||
// r = temp ? dAtoi( temp ) : 0;
|
||||
// temp = dStrtok( NULL, " \0" );
|
||||
|
|
@ -444,7 +444,7 @@ DefineEngineMethod( GuiPopUpMenuCtrlEx, addScheme, void, (S32 id, ColorI fontCol
|
|||
// b = temp ? dAtoi( temp ) : 0;
|
||||
// fontColorHL.set( r, g, b );
|
||||
//
|
||||
// dStrcpy( buf, argv[5] );
|
||||
// dStrcpy( buf, argv[5], 64 );
|
||||
// temp = dStrtok( buf, " \0" );
|
||||
// r = temp ? dAtoi( temp ) : 0;
|
||||
// temp = dStrtok( NULL, " \0" );
|
||||
|
|
@ -771,13 +771,14 @@ void GuiPopUpMenuCtrlEx::setBitmap(const char *name)
|
|||
{
|
||||
char buffer[1024];
|
||||
char *p;
|
||||
dStrcpy(buffer, name);
|
||||
dStrcpy(buffer, name, 1024);
|
||||
p = buffer + dStrlen(buffer);
|
||||
S32 pLen = 1024 - dStrlen(buffer);
|
||||
|
||||
dStrcpy(p, "_n");
|
||||
dStrcpy(p, "_n", pLen);
|
||||
mTextureNormal = GFXTexHandle( (StringTableEntry)buffer, &GFXDefaultGUIProfile, avar("%s() - mTextureNormal (line %d)", __FUNCTION__, __LINE__) );
|
||||
|
||||
dStrcpy(p, "_d");
|
||||
dStrcpy(p, "_d", pLen);
|
||||
mTextureDepressed = GFXTexHandle( (StringTableEntry)buffer, &GFXDefaultGUIProfile, avar("%s() - mTextureDepressed (line %d)", __FUNCTION__, __LINE__) );
|
||||
if ( !mTextureDepressed )
|
||||
mTextureDepressed = mTextureNormal;
|
||||
|
|
@ -840,7 +841,7 @@ void GuiPopUpMenuCtrlEx::addEntry(const char *buf, S32 id, U32 scheme)
|
|||
mIdMax = id;
|
||||
|
||||
Entry e;
|
||||
dStrcpy( e.buf, buf );
|
||||
dStrcpy( e.buf, buf, 256 );
|
||||
e.id = id;
|
||||
e.scheme = scheme;
|
||||
|
||||
|
|
|
|||
|
|
@ -50,7 +50,7 @@ GuiTabPageCtrl::GuiTabPageCtrl(void)
|
|||
{
|
||||
setExtent(Point2I(100, 200));
|
||||
mFitBook = false;
|
||||
dStrcpy(mText,(UTF8*)"TabPage");
|
||||
dStrcpy(mText,(UTF8*)"TabPage", MAX_STRING_LENGTH);
|
||||
mActive = true;
|
||||
mIsContainer = true;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -4754,15 +4754,15 @@ StringTableEntry GuiTreeViewCtrl::getTextToRoot( S32 itemId, const char * delimi
|
|||
dMemset( bufferOne, 0, sizeof(bufferOne) );
|
||||
dMemset( bufferTwo, 0, sizeof(bufferTwo) );
|
||||
|
||||
dStrcpy( bufferOne, item->getText() );
|
||||
dStrcpy( bufferOne, item->getText(), 1024 );
|
||||
|
||||
Item *prevNode = item->mParent;
|
||||
while ( prevNode )
|
||||
{
|
||||
dMemset( bufferNodeText, 0, sizeof(bufferNodeText) );
|
||||
dStrcpy( bufferNodeText, prevNode->getText() );
|
||||
dStrcpy( bufferNodeText, prevNode->getText(), 128 );
|
||||
dSprintf( bufferTwo, 1024, "%s%s%s",bufferNodeText, delimiter, bufferOne );
|
||||
dStrcpy( bufferOne, bufferTwo );
|
||||
dStrcpy( bufferOne, bufferTwo, 1024 );
|
||||
dMemset( bufferTwo, 0, sizeof(bufferTwo) );
|
||||
prevNode = prevNode->mParent;
|
||||
}
|
||||
|
|
@ -5570,4 +5570,4 @@ DefineEngineMethod(GuiTreeViewCtrl, getItemAtPosition, S32, (Point2I position),
|
|||
"@return The id of the item under the position.")
|
||||
{
|
||||
return object->getItemAtPosition(position);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -2570,7 +2570,7 @@ DefineEngineMethod( GuiControl, findHitControls, const char*, ( S32 x, S32 y, S3
|
|||
return "";
|
||||
|
||||
char* buffer = Con::getReturnBuffer( s.size() );
|
||||
dStrcpy( buffer, s.c_str() );
|
||||
dStrcpy( buffer, s.c_str(), s.size() );
|
||||
|
||||
return buffer;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -431,7 +431,7 @@ bool DbgFileView::findMouseOverVariable()
|
|||
{
|
||||
S32 stringPosition = pt.x - gFileXOffset;
|
||||
char tempBuf[256], *varNamePtr = &tempBuf[1];
|
||||
dStrcpy(tempBuf, mFileView[cell.y].text);
|
||||
dStrcpy(tempBuf, mFileView[cell.y].text, 256);
|
||||
|
||||
//find the current mouse over char
|
||||
S32 charNum = findMouseOverChar(mFileView[cell.y].text, stringPosition);
|
||||
|
|
@ -526,7 +526,7 @@ void DbgFileView::onPreRender()
|
|||
{
|
||||
setUpdate();
|
||||
char oldVar[256];
|
||||
dStrcpy(oldVar, mMouseOverVariable);
|
||||
dStrcpy(oldVar, mMouseOverVariable, 256);
|
||||
bool found = findMouseOverVariable();
|
||||
if (found && mPCCurrentLine >= 0)
|
||||
{
|
||||
|
|
@ -685,7 +685,7 @@ void DbgFileView::onRenderCell(Point2I offset, Point2I cell, bool selected, bool
|
|||
{
|
||||
S32 startPos, endPos;
|
||||
char tempBuf[256];
|
||||
dStrcpy(tempBuf, mFileView[cell.y].text);
|
||||
dStrcpy(tempBuf, mFileView[cell.y].text, 256);
|
||||
|
||||
//get the end coord
|
||||
tempBuf[mBlockEnd] = '\0';
|
||||
|
|
|
|||
|
|
@ -2625,8 +2625,8 @@ DefineConsoleMethod( GuiEditCtrl, getSelectionGlobalBounds, const char*, (), , "
|
|||
RectI bounds = object->getSelectionGlobalBounds();
|
||||
String str = String::ToString( "%i %i %i %i", bounds.point.x, bounds.point.y, bounds.extent.x, bounds.extent.y );
|
||||
|
||||
char* buffer = Con::getReturnBuffer( str.length() );
|
||||
dStrcpy( buffer, str.c_str() );
|
||||
char* buffer = Con::getReturnBuffer( str.size() );
|
||||
dStrcpy( buffer, str.c_str(), str.size() );
|
||||
|
||||
return buffer;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -70,8 +70,8 @@ DefineConsoleMethod( GuiFilterCtrl, getValue, const char*, (), , "Return a tuple
|
|||
for (U32 i=0; i < filter->size(); i++)
|
||||
{
|
||||
char value[32];
|
||||
dSprintf(value, 31, "%1.5f ", *(filter->begin()+i) );
|
||||
dStrcat(buffer, value);
|
||||
dSprintf(value, 32, "%1.5f ", *(filter->begin()+i) );
|
||||
dStrcat(buffer, value, 32);
|
||||
}
|
||||
|
||||
return buffer;
|
||||
|
|
@ -239,7 +239,7 @@ void Filter::set(S32 argc, const char *argv[])
|
|||
if (argc == 1)
|
||||
{ // in the form of one string "1.0 1.0 1.0"
|
||||
char list[1024];
|
||||
dStrcpy(list, *argv); // strtok modifies the string so we need to copy it
|
||||
dStrcpy(list, *argv, 1024); // strtok modifies the string so we need to copy it
|
||||
char *value = dStrtok(list, " ");
|
||||
while (value)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -500,7 +500,7 @@ void MessageVector::insertLine(const U32 position,
|
|||
|
||||
U32 len = dStrlen(newMessage) + 1;
|
||||
char* copy = new char[len];
|
||||
dStrcpy(copy, newMessage);
|
||||
dStrcpy(copy, newMessage, len);
|
||||
|
||||
mMessageLines.insert(position);
|
||||
mMessageLines[position].message = copy;
|
||||
|
|
|
|||
|
|
@ -2495,8 +2495,8 @@ DefineConsoleMethod(TerrainEditor, getTerrainBlocksMaterialList, const char *, (
|
|||
ret[0] = 0;
|
||||
for(U32 i = 0; i < list.size(); ++i)
|
||||
{
|
||||
dStrcat( ret, list[i] );
|
||||
dStrcat( ret, "\n" );
|
||||
dStrcat( ret, list[i], size );
|
||||
dStrcat( ret, "\n", size );
|
||||
}
|
||||
|
||||
return ret;
|
||||
|
|
@ -2709,8 +2709,8 @@ DefineConsoleMethod(TerrainEditor, getMaterials, const char *, (), , "() gets th
|
|||
ret[0] = 0;
|
||||
for(U32 i = 0; i < terr->getMaterialCount(); i++)
|
||||
{
|
||||
dStrcat( ret, terr->getMaterialName(i) );
|
||||
dStrcat( ret, "\n" );
|
||||
dStrcat( ret, terr->getMaterialName(i), 4096 );
|
||||
dStrcat( ret, "\n", 4096 );
|
||||
}
|
||||
|
||||
return ret;
|
||||
|
|
|
|||
|
|
@ -42,8 +42,9 @@ LangFile::LangFile(const UTF8 *langName /* = NULL */)
|
|||
|
||||
if(langName)
|
||||
{
|
||||
mLangName = new UTF8 [dStrlen(langName) + 1];
|
||||
dStrcpy(mLangName, langName);
|
||||
dsize_t langNameLen = dStrlen(langName) + 1;
|
||||
mLangName = new UTF8 [langNameLen];
|
||||
dStrcpy(mLangName, langName, langNameLen);
|
||||
}
|
||||
else
|
||||
mLangName = NULL;
|
||||
|
|
@ -136,8 +137,9 @@ const UTF8 * LangFile::getString(U32 id)
|
|||
|
||||
U32 LangFile::addString(const UTF8 *str)
|
||||
{
|
||||
UTF8 *newstr = new UTF8 [dStrlen(str) + 1];
|
||||
dStrcpy(newstr, str);
|
||||
dsize_t newstrLen = dStrlen(str) + 1;
|
||||
UTF8 *newstr = new UTF8 [newstrLen];
|
||||
dStrcpy(newstr, str, newstrLen);
|
||||
mStringTable.push_back(newstr);
|
||||
return mStringTable.size() - 1;
|
||||
}
|
||||
|
|
@ -156,8 +158,9 @@ void LangFile::setString(U32 id, const UTF8 *str)
|
|||
|
||||
SAFE_DELETE_ARRAY(mStringTable[id]);
|
||||
|
||||
UTF8 *newstr = new UTF8 [dStrlen(str) + 1];
|
||||
dStrcpy(newstr, str);
|
||||
dsize_t newstrLen = dStrlen(str) + 1;
|
||||
UTF8 *newstr = new UTF8 [newstrLen];
|
||||
dStrcpy(newstr, str, newstrLen);
|
||||
mStringTable[id] = newstr;
|
||||
}
|
||||
|
||||
|
|
@ -166,8 +169,9 @@ void LangFile::setLangName(const UTF8 *newName)
|
|||
if(mLangName)
|
||||
delete [] mLangName;
|
||||
|
||||
mLangName = new UTF8 [dStrlen(newName) + 1];
|
||||
dStrcpy(mLangName, newName);
|
||||
dsize_t langNameLen = dStrlen(newName) + 1;
|
||||
mLangName = new UTF8 [langNameLen];
|
||||
dStrcpy(mLangName, newName, langNameLen);
|
||||
}
|
||||
|
||||
void LangFile::setLangFile(const UTF8 *langFile)
|
||||
|
|
@ -175,8 +179,9 @@ void LangFile::setLangFile(const UTF8 *langFile)
|
|||
if(mLangFile)
|
||||
delete [] mLangFile;
|
||||
|
||||
mLangFile = new UTF8 [dStrlen(langFile) + 1];
|
||||
dStrcpy(mLangFile, langFile);
|
||||
dsize_t langFileLen = dStrlen(langFile) + 1;
|
||||
mLangFile = new UTF8 [langFileLen];
|
||||
dStrcpy(mLangFile, langFile, langFileLen);
|
||||
}
|
||||
|
||||
bool LangFile::activateLanguage()
|
||||
|
|
@ -349,8 +354,9 @@ DefineConsoleMethod(LangTable, getString, const char *, (U32 id), ,
|
|||
const char * str = (const char*)object->getString(id);
|
||||
if(str != NULL)
|
||||
{
|
||||
char * ret = Con::getReturnBuffer(dStrlen(str) + 1);
|
||||
dStrcpy(ret, str);
|
||||
dsize_t retLen = dStrlen(str) + 1;
|
||||
char * ret = Con::getReturnBuffer(retLen);
|
||||
dStrcpy(ret, str, retLen);
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
|
@ -387,8 +393,9 @@ DefineConsoleMethod(LangTable, getLangName, const char *, (S32 langId), , "(int
|
|||
const char * str = (const char*)object->getLangName(langId);
|
||||
if(str != NULL)
|
||||
{
|
||||
char * ret = Con::getReturnBuffer(dStrlen(str) + 1);
|
||||
dStrcpy(ret, str);
|
||||
dsize_t retLen = dStrlen(str) + 1;
|
||||
char * ret = Con::getReturnBuffer(retLen);
|
||||
dStrcpy(ret, str, retLen);
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
|
@ -414,7 +421,7 @@ UTF8 *sanitiseVarName(const UTF8 *varName, UTF8 *buffer, U32 bufsize)
|
|||
return NULL;
|
||||
}
|
||||
|
||||
dStrcpy(buffer, (const UTF8*)"I18N::");
|
||||
dStrcpy(buffer, (const UTF8*)"I18N::", bufsize);
|
||||
|
||||
UTF8 *dptr = buffer + 6;
|
||||
const UTF8 *sptr = varName;
|
||||
|
|
@ -575,4 +582,4 @@ ConsoleFunction(CompileLanguage, void, 2, 3, "(string inputFile, [bool createMap
|
|||
delete mapStream;
|
||||
}
|
||||
}
|
||||
//end lang_ localization
|
||||
//end lang_ localization
|
||||
|
|
|
|||
|
|
@ -654,35 +654,35 @@ DefineConsoleMethod( Material, getAnimFlags, const char*, (U32 id), , "" )
|
|||
if(object->mAnimFlags[ id ] & Material::Scroll)
|
||||
{
|
||||
if(dStrcmp( animFlags, "" ) == 0)
|
||||
dStrcpy( animFlags, "$Scroll" );
|
||||
dStrcpy( animFlags, "$Scroll", 512 );
|
||||
}
|
||||
if(object->mAnimFlags[ id ] & Material::Rotate)
|
||||
{
|
||||
if(dStrcmp( animFlags, "" ) == 0)
|
||||
dStrcpy( animFlags, "$Rotate" );
|
||||
dStrcpy( animFlags, "$Rotate", 512 );
|
||||
else
|
||||
dStrcat( animFlags, " | $Rotate");
|
||||
dStrcat( animFlags, " | $Rotate", 512);
|
||||
}
|
||||
if(object->mAnimFlags[ id ] & Material::Wave)
|
||||
{
|
||||
if(dStrcmp( animFlags, "" ) == 0)
|
||||
dStrcpy( animFlags, "$Wave" );
|
||||
dStrcpy( animFlags, "$Wave", 512 );
|
||||
else
|
||||
dStrcat( animFlags, " | $Wave");
|
||||
dStrcat( animFlags, " | $Wave", 512);
|
||||
}
|
||||
if(object->mAnimFlags[ id ] & Material::Scale)
|
||||
{
|
||||
if(dStrcmp( animFlags, "" ) == 0)
|
||||
dStrcpy( animFlags, "$Scale" );
|
||||
dStrcpy( animFlags, "$Scale", 512 );
|
||||
else
|
||||
dStrcat( animFlags, " | $Scale");
|
||||
dStrcat( animFlags, " | $Scale", 512);
|
||||
}
|
||||
if(object->mAnimFlags[ id ] & Material::Sequence)
|
||||
{
|
||||
if(dStrcmp( animFlags, "" ) == 0)
|
||||
dStrcpy( animFlags, "$Sequence" );
|
||||
dStrcpy( animFlags, "$Sequence", 512 );
|
||||
else
|
||||
dStrcat( animFlags, " | $Sequence");
|
||||
dStrcat( animFlags, " | $Sequence", 512);
|
||||
}
|
||||
|
||||
return animFlags;
|
||||
|
|
@ -718,4 +718,4 @@ bool Material::_setAccuEnabled( void *object, const char *index, const char *dat
|
|||
AccumulationVolume::refreshVolumes();
|
||||
}
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -254,11 +254,11 @@ protected:
|
|||
for ( U32 dependencyIndex = 0; dependencyIndex < dependencyWordCount; ++dependencyIndex )
|
||||
{
|
||||
// Fetch slot.
|
||||
dStrcpy( slotUnit, StringUnit::getUnit( pDependencyValue, dependencyIndex, "," ) );
|
||||
dStrcpy( slotUnit, StringUnit::getUnit( pDependencyValue, dependencyIndex, "," ), 256 );
|
||||
|
||||
// Fetch slot name and value.
|
||||
dStrcpy( slotName, StringUnit::getUnit( slotUnit, 0, "=" ) );
|
||||
dStrcpy( slotValue, StringUnit::getUnit( slotUnit, 1, "=" ) );
|
||||
dStrcpy( slotName, StringUnit::getUnit( slotUnit, 0, "=" ), 256 );
|
||||
dStrcpy( slotValue, StringUnit::getUnit( slotUnit, 1, "=" ), 256 );
|
||||
|
||||
// Fetch module Id.
|
||||
StringTableEntry moduleId = StringTable->insert( slotName );
|
||||
|
|
|
|||
|
|
@ -74,7 +74,7 @@ ModuleManager::ModuleManager() :
|
|||
mIgnoreLoadedGroups(false)
|
||||
{
|
||||
// Set module extension.
|
||||
dStrcpy( mModuleExtension, MODULE_MANAGER_MODULE_DEFINITION_EXTENSION );
|
||||
dStrcpy( mModuleExtension, MODULE_MANAGER_MODULE_DEFINITION_EXTENSION, 256 );
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
|
|
@ -155,7 +155,7 @@ bool ModuleManager::setModuleExtension( const char* pExtension )
|
|||
}
|
||||
|
||||
// Set module extension.
|
||||
dStrcpy( mModuleExtension, pExtension );
|
||||
dStrcpy( mModuleExtension, pExtension, 256 );
|
||||
|
||||
return true;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -33,7 +33,7 @@ bool fsTiXmlDocument::LoadFile( const char * pFilename, TiXmlEncoding encoding )
|
|||
|
||||
#ifdef TORQUE_OS_ANDROID
|
||||
if (strlen(pFilename) > strlen(filenameBuffer)) {
|
||||
strcpy(filenameBuffer, pFilename);
|
||||
dStrcpy(filenameBuffer, pFilename, 1024);
|
||||
}
|
||||
#endif
|
||||
|
||||
|
|
|
|||
|
|
@ -708,7 +708,7 @@ ImplementEnumType(_TamlFormatMode,
|
|||
|
||||
U32 nBufferSize = dStrlen(pFieldValue) + 1;
|
||||
FrameTemp<char> valueCopy(nBufferSize);
|
||||
dStrcpy((char *)valueCopy, pFieldValue);
|
||||
dStrcpy((char *)valueCopy, pFieldValue, nBufferSize);
|
||||
|
||||
// Skip if field should not be written.
|
||||
if (!pSimObject->writeField(fieldName, valueCopy))
|
||||
|
|
@ -1547,4 +1547,4 @@ ImplementEnumType(_TamlFormatMode,
|
|||
TiXmlElement* pAnyElement = new TiXmlElement("xs:any");
|
||||
pAnyElement->SetAttribute("processContents", "skip");
|
||||
pSequenceElement->LinkEndChild(pAnyElement);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -53,7 +53,7 @@ void TamlCustomField::set( const char* pFieldName, const char* pFieldValue )
|
|||
}
|
||||
#endif
|
||||
// Copy field value.
|
||||
dStrcpy( mFieldValue, pFieldValue );
|
||||
dStrcpy( mFieldValue, pFieldValue, MAX_TAML_NODE_FIELDVALUE_LENGTH );
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
|
|
|
|||
|
|
@ -334,7 +334,7 @@ public:
|
|||
// Sanity!
|
||||
AssertFatal( fieldNameLength < sizeof(fieldNameBuffer), "TamlCustomField: Field name is too long." );
|
||||
|
||||
dStrcpy( fieldNameBuffer, mFieldName );
|
||||
dStrcpy( fieldNameBuffer, mFieldName, 1024 );
|
||||
fieldNameBuffer[fieldNameLength-1] = 0;
|
||||
StringTableEntry fieldName = StringTable->insert( fieldNameBuffer );
|
||||
|
||||
|
|
@ -782,4 +782,4 @@ private:
|
|||
TamlCustomNodeVector mNodes;
|
||||
};
|
||||
|
||||
#endif // _TAML_CUSTOM_H_
|
||||
#endif // _TAML_CUSTOM_H_
|
||||
|
|
|
|||
|
|
@ -53,8 +53,9 @@ public:
|
|||
mName = name;
|
||||
|
||||
// Allocate and copy the value.
|
||||
mpValue = new char[ dStrlen(pValue)+1 ];
|
||||
dStrcpy( (char *)mpValue, pValue );
|
||||
dsize_t valueLen = dStrlen(pValue) + 1;
|
||||
mpValue = new char[ valueLen ];
|
||||
dStrcpy( (char *)mpValue, pValue, valueLen );
|
||||
}
|
||||
|
||||
|
||||
|
|
@ -113,4 +114,4 @@ public:
|
|||
TamlCustomNodes mCustomNodes;
|
||||
};
|
||||
|
||||
#endif // _TAML_WRITE_NODE_H_
|
||||
#endif // _TAML_WRITE_NODE_H_
|
||||
|
|
|
|||
|
|
@ -53,7 +53,7 @@ bool TamlXmlParser::accept( const char* pFilename, TamlVisitor& visitor )
|
|||
|
||||
#ifdef TORQUE_OS_ANDROID
|
||||
if (strlen(pFilename) > strlen(filenameBuffer)) {
|
||||
strcpy(filenameBuffer, pFilename);
|
||||
dStrcpy(filenameBuffer, pFilename, 1024);
|
||||
}
|
||||
#endif
|
||||
|
||||
|
|
|
|||
|
|
@ -82,7 +82,7 @@ U32 LeapMotionDevice::LM_FRAME = 0;
|
|||
LeapMotionDevice::LeapMotionDevice()
|
||||
{
|
||||
// From IInputDevice
|
||||
dStrcpy(mName, "leapmotion");
|
||||
dStrcpy(mName, "leapmotion", 30);
|
||||
mDeviceType = INPUTMGR->getNextDeviceType();
|
||||
|
||||
mController = NULL;
|
||||
|
|
|
|||
|
|
@ -86,7 +86,7 @@ F32 OculusVRDevice::smPositionTrackingScale = 1.0f;
|
|||
OculusVRDevice::OculusVRDevice()
|
||||
{
|
||||
// From IInputDevice
|
||||
dStrcpy(mName, "oculusvr");
|
||||
dStrcpy(mName, "oculusvr", 30);
|
||||
mDeviceType = INPUTMGR->getNextDeviceType();
|
||||
|
||||
//
|
||||
|
|
|
|||
|
|
@ -493,7 +493,7 @@ OpenVRProvider::OpenVRProvider() :
|
|||
mDrawCanvas(NULL),
|
||||
mGameConnection(NULL)
|
||||
{
|
||||
dStrcpy(mName, "openvr");
|
||||
dStrcpy(mName, "openvr", 30);
|
||||
mDeviceType = INPUTMGR->getNextDeviceType();
|
||||
buildInputCodeTable();
|
||||
GFXDevice::getDeviceEventSignal().notify(this, &OpenVRProvider::_handleDeviceEvent);
|
||||
|
|
|
|||
|
|
@ -91,7 +91,7 @@ U32 RazerHydraDevice::RH_FRAME = 0;
|
|||
RazerHydraDevice::RazerHydraDevice()
|
||||
{
|
||||
// From IInputDevice
|
||||
dStrcpy(mName, "razerhydra");
|
||||
dStrcpy(mName, "razerhydra", 30);
|
||||
mDeviceType = INPUTMGR->getNextDeviceType();
|
||||
|
||||
//
|
||||
|
|
|
|||
|
|
@ -433,7 +433,7 @@ bool FileDialog::setDefaultPath(void *object, const char *index, const char *dat
|
|||
|
||||
// Copy and Backslash the path (Windows dialogs are VERY picky about this format)
|
||||
static char szPathValidate[512];
|
||||
dStrcpy(szPathValidate, data);
|
||||
dStrcpy(szPathValidate, data, 512);
|
||||
|
||||
Platform::makeFullPathName(data, szPathValidate, sizeof(szPathValidate));
|
||||
//backslash( szPathValidate );
|
||||
|
|
|
|||
|
|
@ -523,7 +523,7 @@ next:
|
|||
tblPkgID[j] = apicID & PackageIDMask;
|
||||
sprintf(tmp," AffinityMask = %d; Initial APIC = %d; Physical ID = %d, Core ID = %d, SMT ID = %d\n",
|
||||
dwAffinityMask, apicID, tblPkgID[j], tblCoreID[j], tblSMTID[j]);
|
||||
strcat(g_s3Levels, tmp);
|
||||
dStrcat(g_s3Levels, tmp, 2048);
|
||||
|
||||
numLPEnabled ++; // Number of available logical processors in the system.
|
||||
|
||||
|
|
@ -654,4 +654,4 @@ next:
|
|||
} // namespace CPUInfo
|
||||
#endif
|
||||
|
||||
#endif
|
||||
#endif
|
||||
|
|
|
|||
|
|
@ -534,7 +534,7 @@ StringTableEntry Platform::makeRelativePathName(const char *path, const char *to
|
|||
|
||||
// Copy the rest
|
||||
if(*branch)
|
||||
dStrcpy(bufPtr, branch + 1);
|
||||
dStrcpy(bufPtr, branch + 1, temp.size - (bufPtr - temp.ptr));
|
||||
else
|
||||
*--bufPtr = 0;
|
||||
|
||||
|
|
|
|||
|
|
@ -1130,7 +1130,7 @@ static void logFree(const AllocatedHeader* hdr)
|
|||
|
||||
void enableLogging(const char* fileName)
|
||||
{
|
||||
dStrcpy(gLogFilename, fileName);
|
||||
dStrcpy(gLogFilename, fileName, 256);
|
||||
if (!gEnableLogging)
|
||||
{
|
||||
gEnableLogging = true;
|
||||
|
|
|
|||
|
|
@ -280,7 +280,7 @@ namespace PlatformNetState
|
|||
if (addressString[0] == '[')
|
||||
{
|
||||
// Must be ipv6 notation
|
||||
dStrcpy(outAddress, addressString+1);
|
||||
dStrcpy(outAddress, addressString+1, 256);
|
||||
addressString = outAddress;
|
||||
|
||||
portString = dStrchr(outAddress, ']');
|
||||
|
|
@ -305,7 +305,7 @@ namespace PlatformNetState
|
|||
}
|
||||
else
|
||||
{
|
||||
dStrcpy(outAddress, addressString);
|
||||
dStrcpy(outAddress, addressString, 256);
|
||||
addressString = outAddress;
|
||||
|
||||
// Check to see if we have multiple ":" which would indicate this is an ipv6 address
|
||||
|
|
@ -546,7 +546,7 @@ static PolledSocket* addPolledSocket(NetSocket handleFd, SOCKET fd, S32 state,
|
|||
sock->handleFd = handleFd;
|
||||
sock->state = state;
|
||||
if (remoteAddr)
|
||||
dStrcpy(sock->remoteAddr, remoteAddr);
|
||||
dStrcpy(sock->remoteAddr, remoteAddr, 256);
|
||||
if (port != -1)
|
||||
sock->remotePort = port;
|
||||
gPolledSockets.push_back(sock);
|
||||
|
|
|
|||
|
|
@ -94,7 +94,7 @@ void RedBook::setLastError(const char * error)
|
|||
if(!error || dStrlen(error) >= sizeof(smLastError))
|
||||
setLastError("Invalid error string passed");
|
||||
else
|
||||
dStrcpy(smLastError, error);
|
||||
dStrcpy(smLastError, error, 1024);
|
||||
}
|
||||
|
||||
const char * RedBook::getLastError()
|
||||
|
|
|
|||
|
|
@ -328,9 +328,9 @@ const char * Profiler::constructProfilePath(ProfilerData * pd)
|
|||
|
||||
U32 mark = FrameAllocator::getWaterMark();
|
||||
char * buf = (char*)FrameAllocator::alloc(len+1);
|
||||
dStrcpy(buf,pd->mParent->mPath);
|
||||
dStrcat(buf,connector);
|
||||
dStrcat(buf,pd->mRoot->mName);
|
||||
dStrcpy(buf,pd->mParent->mPath,len+1);
|
||||
dStrcat(buf,connector,len+1);
|
||||
dStrcat(buf,pd->mRoot->mName,len+1);
|
||||
const char * ret = StringTable->insert(buf);
|
||||
FrameAllocator::setWaterMark(mark);
|
||||
|
||||
|
|
@ -433,7 +433,7 @@ void Profiler::dumpToFile(const char* fileName)
|
|||
AssertFatal(dStrlen(fileName) < DumpFileNameLength, "Error, dump filename too long");
|
||||
mDumpToFile = true;
|
||||
mDumpToConsole = false;
|
||||
dStrcpy(mDumpFileName, fileName);
|
||||
dStrcpy(mDumpFileName, fileName, DumpFileNameLength);
|
||||
}
|
||||
|
||||
void Profiler::hashPop(ProfilerRootData *expected)
|
||||
|
|
@ -645,11 +645,11 @@ void Profiler::dump()
|
|||
AssertFatal(success, "Cannot write profile dump to specified file!");
|
||||
char buffer[1024];
|
||||
|
||||
dStrcpy(buffer, "Profiler Data Dump:\n");
|
||||
dStrcpy(buffer, "Profiler Data Dump:\n", 1024);
|
||||
fws.write(dStrlen(buffer), buffer);
|
||||
dStrcpy(buffer, "Ordered by non-sub total time -\n");
|
||||
dStrcpy(buffer, "Ordered by non-sub total time -\n", 1024);
|
||||
fws.write(dStrlen(buffer), buffer);
|
||||
dStrcpy(buffer, "%%NSTime %% Time Invoke # Name\n");
|
||||
dStrcpy(buffer, "%%NSTime %% Time Invoke # Name\n", 1024);
|
||||
fws.write(dStrlen(buffer), buffer);
|
||||
|
||||
for(U32 i = 0; i < rootVector.size(); i++)
|
||||
|
|
@ -665,9 +665,9 @@ void Profiler::dump()
|
|||
rootVector[i]->mTotalTime = 0;
|
||||
rootVector[i]->mSubTime = 0;
|
||||
}
|
||||
dStrcpy(buffer, "\nOrdered by non-sub total time -\n");
|
||||
dStrcpy(buffer, "\nOrdered by non-sub total time -\n", 1024);
|
||||
fws.write(dStrlen(buffer), buffer);
|
||||
dStrcpy(buffer, "%%NSTime %% Time Invoke # Name\n");
|
||||
dStrcpy(buffer, "%%NSTime %% Time Invoke # Name\n", 1024);
|
||||
fws.write(dStrlen(buffer), buffer);
|
||||
|
||||
mCurrentProfilerData->mTotalTime = endHighResolutionTimer(mCurrentProfilerData->mStartTime);
|
||||
|
|
|
|||
|
|
@ -27,10 +27,11 @@
|
|||
#define FN_CDECL
|
||||
#define STDCALL
|
||||
|
||||
#include <stddef.h>
|
||||
// size_t is needed to overload new
|
||||
// size_t tends to be OS and compiler specific and may need to
|
||||
// be if/def'ed in the future
|
||||
typedef unsigned long dsize_t;
|
||||
typedef size_t dsize_t;
|
||||
|
||||
|
||||
/** Platform dependent file date-time structure. The defination of this structure
|
||||
|
|
|
|||
|
|
@ -894,7 +894,7 @@ static bool recurseDumpDirectories(const char *basePath, const char *subPath, Ve
|
|||
{
|
||||
char child[1024];
|
||||
if ( (basePath[dStrlen(basePath) - 1]) == '/')
|
||||
dStrcpy (child, d->d_name);
|
||||
dStrcpy (child, d->d_name, 1024);
|
||||
else
|
||||
dSprintf(child, 1024, "/%s", d->d_name);
|
||||
if (currentDepth < recurseDepth || recurseDepth == -1)
|
||||
|
|
|
|||
|
|
@ -1,69 +0,0 @@
|
|||
//-----------------------------------------------------------------------------
|
||||
// Copyright (c) 2012 GarageGames, LLC
|
||||
//
|
||||
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
// of this software and associated documentation files (the "Software"), to
|
||||
// deal in the Software without restriction, including without limitation the
|
||||
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
||||
// sell copies of the Software, and to permit persons to whom the Software is
|
||||
// furnished to do so, subject to the following conditions:
|
||||
//
|
||||
// The above copyright notice and this permission notice shall be included in
|
||||
// all copies or substantial portions of the Software.
|
||||
//
|
||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
||||
// IN THE SOFTWARE.
|
||||
//-----------------------------------------------------------------------------
|
||||
|
||||
#import "platform/platform.h"
|
||||
#import <stdlib.h>
|
||||
#import <stdarg.h>
|
||||
#import <string.h>
|
||||
#import <ctype.h>
|
||||
#import <stdio.h>
|
||||
#import "core/strings/stringFunctions.h"
|
||||
|
||||
char *dStrnew(const char *src)
|
||||
{
|
||||
char *buffer = new char[dStrlen(src) + 1];
|
||||
dStrcpy(buffer, src);
|
||||
return buffer;
|
||||
}
|
||||
|
||||
char* dStrstr(char *str1, char *str2)
|
||||
{
|
||||
return strstr(str1,str2);
|
||||
}
|
||||
|
||||
int dSprintf(char *buffer, dsize_t /*bufferSize*/, const char *format, ...)
|
||||
{
|
||||
va_list args;
|
||||
va_start(args, format);
|
||||
S32 len = vsprintf(buffer, format, args);
|
||||
va_end(args);
|
||||
return (len);
|
||||
}
|
||||
|
||||
|
||||
int dVsprintf(char *buffer, dsize_t /*bufferSize*/, const char *format, va_list arglist)
|
||||
{
|
||||
S32 len = vsprintf(buffer, format, arglist);
|
||||
|
||||
return (len);
|
||||
}
|
||||
|
||||
int dFflushStdout()
|
||||
{
|
||||
return fflush(stdout);
|
||||
}
|
||||
|
||||
int dFflushStderr()
|
||||
{
|
||||
return fflush(stderr);
|
||||
}
|
||||
|
||||
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue