summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSlávek Banko <slavek.banko@axis.cz>2012-09-26 14:54:22 +0200
committerSlávek Banko <slavek.banko@axis.cz>2012-09-26 17:45:52 +0200
commit9dc91538a908afdd21be11ea3a2b5b3619b0513b (patch)
treeec2a89c8387226dcb929139d8a5c521bc925d20e
parente3cb7a61df6fd3f219445033a42bccf110b0bbf8 (diff)
downloadtdepim-9dc91538a908afdd21be11ea3a2b5b3619b0513b.tar.gz
tdepim-9dc91538a908afdd21be11ea3a2b5b3619b0513b.zip
Fix more SEGV in imapparser
Thanks to Francois Andriot for the patch This resolves Bug 1235 (cherry picked from commit 590161fd805b5d9c397a5dc192996d13acdbaff6)
-rw-r--r--kioslaves/imap4/imapparser.cc9
1 files changed, 7 insertions, 2 deletions
diff --git a/kioslaves/imap4/imapparser.cc b/kioslaves/imap4/imapparser.cc
index da1052a1..08fd69f6 100644
--- a/kioslaves/imap4/imapparser.cc
+++ b/kioslaves/imap4/imapparser.cc
@@ -345,6 +345,7 @@ imapParser::parseUntagged (parseString & result)
parseOneWordC(result); // *
TQByteArray what = parseLiteral (result); // see whats coming next
+ if(!what.isEmpty ()) {
switch (what[0])
{
//the status responses
@@ -482,6 +483,7 @@ imapParser::parseUntagged (parseString & result)
if (valid)
{
what = parseLiteral (result);
+ if(!what.isEmpty ()) {
switch (what[0])
{
case 'E':
@@ -520,10 +522,12 @@ imapParser::parseUntagged (parseString & result)
default:
break;
}
+ }
}
}
break;
} //switch
+ }
} //func
@@ -1915,9 +1919,10 @@ TQCString imapParser::parseLiteralC(parseString & inWords, bool relay, bool stop
if (!inWords.isEmpty() && inWords[0] == '{')
{
TQCString retVal;
- ulong runLen = inWords.find ('}', 1);
- if (runLen > 0)
+ long srunLen = inWords.find ('}', 1); // Can return -1, so use a signed long
+ if (srunLen > 0)
{
+ ulong runLen = (ulong)srunLen;
bool proper;
ulong runLenSave = runLen + 1;
TQCString tmpstr(runLen);