mirror of
https://github.com/TorqueGameEngines/Torque3D.git
synced 2026-01-20 12:44:46 +00:00
182 lines
4.6 KiB
C++
182 lines
4.6 KiB
C++
//-----------------------------------------------------------------------------
|
|
// 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.
|
|
//-----------------------------------------------------------------------------
|
|
|
|
#include <stdio.h>
|
|
#include "console/consoleInternal.h"
|
|
#include "console/stringStack.h"
|
|
|
|
StringStack::StringStack()
|
|
{
|
|
mBufferSize = 0;
|
|
mBuffer = NULL;
|
|
mArgBufferSize = 0;
|
|
mArgBuffer = NULL;
|
|
for (U32 i = 0; i < MaxArgs; i++)
|
|
mArgV[i] = "";
|
|
dMemset(mFrameOffsets, 0, sizeof(mFrameOffsets));
|
|
dMemset(mStartOffsets, 0, sizeof(mStartOffsets));
|
|
mNumFrames = 0;
|
|
mArgc = 0;
|
|
mStart = 0;
|
|
mLen = 0;
|
|
mStartStackSize = 0;
|
|
validateBufferSize(8192);
|
|
validateArgBufferSize(2048);
|
|
dMemset(mBuffer, '\0', mBufferSize);
|
|
dMemset(mArgBuffer, '\0', mArgBufferSize);
|
|
}
|
|
|
|
StringStack::~StringStack()
|
|
{
|
|
if( mBuffer )
|
|
dFree( mBuffer );
|
|
if( mArgBuffer )
|
|
dFree( mArgBuffer );
|
|
}
|
|
|
|
void StringStack::validateBufferSize(U32 size)
|
|
{
|
|
if(size > mBufferSize)
|
|
{
|
|
mBufferSize = size + 2048;
|
|
mBuffer = (char *) dRealloc(mBuffer, mBufferSize);
|
|
}
|
|
}
|
|
|
|
void StringStack::validateArgBufferSize(U32 size)
|
|
{
|
|
if(size > mArgBufferSize)
|
|
{
|
|
mArgBufferSize = size + 2048;
|
|
mArgBuffer = (char *) dRealloc(mArgBuffer, mArgBufferSize);
|
|
}
|
|
}
|
|
|
|
void StringStack::setIntValue(U32 i)
|
|
{
|
|
validateBufferSize(mStart + 32);
|
|
dSprintf(mBuffer + mStart, 32, "%d", i);
|
|
mLen = dStrlen(mBuffer + mStart);
|
|
}
|
|
|
|
void StringStack::setFloatValue(F64 v)
|
|
{
|
|
validateBufferSize(mStart + 32);
|
|
dSprintf(mBuffer + mStart, 32, "%.9g", v);
|
|
mLen = dStrlen(mBuffer + mStart);
|
|
}
|
|
|
|
char *StringStack::getReturnBuffer(U32 size)
|
|
{
|
|
if(size > ReturnBufferSpace)
|
|
{
|
|
AssertFatal(Con::isMainThread(), "Manipulating return buffer from a secondary thread!");
|
|
validateArgBufferSize(size);
|
|
return mArgBuffer;
|
|
}
|
|
else
|
|
{
|
|
validateBufferSize(mStart + size);
|
|
return mBuffer + mStart;
|
|
}
|
|
}
|
|
|
|
char *StringStack::getArgBuffer(U32 size)
|
|
{
|
|
AssertFatal(Con::isMainThread(), "Manipulating console arg buffer from a secondary thread!");
|
|
validateBufferSize(mStart + mFunctionOffset + size);
|
|
char *ret = mBuffer + mStart + mFunctionOffset;
|
|
mFunctionOffset += size;
|
|
return ret;
|
|
}
|
|
|
|
void StringStack::clearFunctionOffset()
|
|
{
|
|
//Con::printf("StringStack mFunctionOffset = 0 (from %i)", mFunctionOffset);
|
|
mFunctionOffset = 0;
|
|
}
|
|
|
|
void StringStack::setStringValue(const char *s)
|
|
{
|
|
if(!s)
|
|
{
|
|
mLen = 0;
|
|
mBuffer[mStart] = 0;
|
|
return;
|
|
}
|
|
mLen = dStrlen(s);
|
|
|
|
validateBufferSize(mStart + mLen + 2);
|
|
dStrcpy(mBuffer + mStart, s, mBufferSize - mStart);
|
|
}
|
|
|
|
void StringStack::advance()
|
|
{
|
|
mStartOffsets[mStartStackSize++] = mStart;
|
|
mStart += mLen;
|
|
mLen = 0;
|
|
}
|
|
|
|
void StringStack::advanceChar(char c)
|
|
{
|
|
mStartOffsets[mStartStackSize++] = mStart;
|
|
mStart += mLen;
|
|
mBuffer[mStart] = c;
|
|
mBuffer[mStart+1] = 0;
|
|
mStart += 1;
|
|
mLen = 0;
|
|
}
|
|
|
|
void StringStack::push()
|
|
{
|
|
advanceChar(0);
|
|
}
|
|
|
|
void StringStack::rewind()
|
|
{
|
|
mStart = mStartOffsets[--mStartStackSize];
|
|
mLen = dStrlen(mBuffer + mStart);
|
|
}
|
|
|
|
void StringStack::rewindTerminate()
|
|
{
|
|
mBuffer[mStart] = 0;
|
|
mStart = mStartOffsets[--mStartStackSize];
|
|
mLen = dStrlen(mBuffer + mStart);
|
|
}
|
|
|
|
U32 StringStack::compare()
|
|
{
|
|
// Figure out the 1st and 2nd item offsets.
|
|
U32 oldStart = mStart;
|
|
mStart = mStartOffsets[--mStartStackSize];
|
|
|
|
// Compare current and previous strings.
|
|
U32 ret = !dStricmp(mBuffer + mStart, mBuffer + oldStart);
|
|
|
|
// Put an empty string on the top of the stack.
|
|
mLen = 0;
|
|
mBuffer[mStart] = 0;
|
|
|
|
return ret;
|
|
}
|