Red error, ensure residual actiondata is not read for RichLabel

This commit is contained in:
Simon Robertshaw
2012-08-17 17:02:02 +01:00
parent b835861519
commit d24e439a1e
2 changed files with 101 additions and 90 deletions

View File

@@ -58,7 +58,8 @@ extern "C"
Client::Client():
authUser(0, ""),
updateAvailable(false),
versionCheckRequest(NULL)
versionCheckRequest(NULL),
messageOfTheDay("")
{
int i = 0;
for(i = 0; i < THUMB_CACHE_SIZE; i++)

View File

@@ -22,7 +22,8 @@ public:
RichLabel::RichLabel(Point position, Point size, std::string labelText):
Component(position, size),
textSource(labelText)
textSource(labelText),
displayText("")
{
updateRichText();
}
@@ -35,15 +36,21 @@ RichLabel::~RichLabel()
void RichLabel::updateRichText()
{
regions.clear();
displayText = "";
if(textSource.length())
{
enum State { ReadText, ReadData, ReadRegion, ReadDataStart };
State state = ReadText;
int currentDataPos = 0;
char * currentData = new char[textSource.length()+1];
std::fill(currentData, currentData+textSource.length()+1, 0);
int finalTextPos = 0;
char * finalText = new char[textSource.length()+1];
std::fill(finalText, finalText+textSource.length()+1, 0);
int originalTextPos = 0;
char * originalText = new char[textSource.length()+1];
@@ -86,6 +93,7 @@ void RichLabel::updateRichText()
else
{
finalText[finalTextPos++] = current;
finalText[finalTextPos] = 0;
if(stackPos >= 0)
{
regionsStack[stackPos].finish = finalTextPos;
@@ -101,6 +109,7 @@ void RichLabel::updateRichText()
else
{
currentData[currentDataPos++] = current;
currentData[currentDataPos] = 0;
}
}
else if(state == ReadDataStart)
@@ -136,13 +145,14 @@ void RichLabel::updateRichText()
}
catch (const RichTextParseException & e)
{
displayText = "[Parse exception: " + std::string(e.what()) + "]";
displayText = "\br[Parse exception: " + std::string(e.what()) + "]";
regions.clear();
}
delete[] currentData;
delete[] finalText;
delete[] originalText;
delete[] regionsStack;
}
TextPosition(displayText);
}