aboutsummaryrefslogtreecommitdiffstats
path: root/SQLiteStudio3/coreSQLiteStudio/parser/parsercontext.cpp
diff options
context:
space:
mode:
authorLibravatarUnit 193 <unit193@unit193.net>2023-04-30 18:30:36 -0400
committerLibravatarUnit 193 <unit193@unit193.net>2023-04-30 18:30:36 -0400
commit3565aad630864ecdbe53fdaa501ea708555b3c7c (patch)
treec743e4ad0bad39ebdb2f514c7cc52d34a257ebbe /SQLiteStudio3/coreSQLiteStudio/parser/parsercontext.cpp
parent1fdc150116cad39aae5c5da407c3312b47a59e3a (diff)
New upstream version 3.4.4+dfsg.upstream/3.4.4+dfsg
Diffstat (limited to 'SQLiteStudio3/coreSQLiteStudio/parser/parsercontext.cpp')
-rw-r--r--SQLiteStudio3/coreSQLiteStudio/parser/parsercontext.cpp14
1 files changed, 8 insertions, 6 deletions
diff --git a/SQLiteStudio3/coreSQLiteStudio/parser/parsercontext.cpp b/SQLiteStudio3/coreSQLiteStudio/parser/parsercontext.cpp
index a9eae82..a275882 100644
--- a/SQLiteStudio3/coreSQLiteStudio/parser/parsercontext.cpp
+++ b/SQLiteStudio3/coreSQLiteStudio/parser/parsercontext.cpp
@@ -167,9 +167,9 @@ const QList<ParserError *> &ParserContext::getErrors()
QVariant *ParserContext::handleNumberToken(const QString &tokenValue)
{
recentNumberIsCandidateForMaxNegative = false;
+ bool ok;
if (tokenValue.startsWith("0x", Qt::CaseInsensitive))
{
- bool ok;
qint64 i64 = tokenValue.toLongLong(&ok, 16);
if (!ok)
{
@@ -183,10 +183,12 @@ QVariant *ParserContext::handleNumberToken(const QString &tokenValue)
recentNumberIsCandidateForMaxNegative = true;
return new QVariant(static_cast<qint64>(0L));
}
- else
- {
- return new QVariant(QVariant(tokenValue).toLongLong());
- }
+
+ QVariant varLong = QVariant(tokenValue).toLongLong(&ok);
+ if (!ok)
+ varLong = QVariant(tokenValue).toDouble();
+
+ return new QVariant(varLong);
}
bool ParserContext::isCandidateForMaxNegativeNumber() const
@@ -196,7 +198,7 @@ bool ParserContext::isCandidateForMaxNegativeNumber() const
void ParserContext::cleanUp()
{
- for (ParserError* err : errors)
+ for (ParserError*& err : errors)
delete err;
parsedQueries.clear();