aboutsummaryrefslogtreecommitdiffstats
path: root/SQLiteStudio3/coreSQLiteStudio/parser/parsercontext.cpp
diff options
context:
space:
mode:
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();