forked from qt-creator/qt-creator
Since we also license under GPL-3.0 WITH Qt-GPL-exception-1.0,
this applies only to a hypothetical newer version of GPL, that doesn't
exist yet. If such a version emerges, we can still decide to relicense...
While at it, replace (deprecated) GPL-3.0 with more explicit GPL-3.0-only
Change was done by running
find . -type f -exec perl -pi -e "s/LicenseRef-Qt-Commercial OR GPL-3.0\+ OR GPL-3.0 WITH Qt-GPL-exception-1.0/LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0/g" {} \;
Change-Id: I5097e6ce8d10233993ee30d7e25120e2659eb10b
Reviewed-by: Eike Ziller <eike.ziller@qt.io>
76 lines
1.9 KiB
C++
76 lines
1.9 KiB
C++
// Copyright (C) 2016 The Qt Company Ltd.
|
|
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
|
|
|
|
#pragma once
|
|
|
|
#include "pythonformattoken.h"
|
|
|
|
#include <QString>
|
|
|
|
namespace Python::Internal {
|
|
|
|
/**
|
|
* @brief The Scanner class - scans source code for highlighting only
|
|
*/
|
|
class Scanner
|
|
{
|
|
public:
|
|
Scanner(const Scanner &other) = delete;
|
|
void operator=(const Scanner &other) = delete;
|
|
|
|
enum State {
|
|
State_Default,
|
|
State_String,
|
|
State_MultiLineString
|
|
};
|
|
|
|
Scanner(const QChar *text, const int length);
|
|
|
|
void setState(int state);
|
|
int state() const;
|
|
FormatToken read();
|
|
QString value(const FormatToken& tk) const;
|
|
|
|
private:
|
|
FormatToken onDefaultState();
|
|
|
|
void checkEscapeSequence(QChar quoteChar);
|
|
FormatToken readStringLiteral(QChar quoteChar);
|
|
FormatToken readMultiLineStringLiteral(QChar quoteChar);
|
|
FormatToken readIdentifier();
|
|
FormatToken readNumber();
|
|
FormatToken readFloatNumber();
|
|
FormatToken readComment();
|
|
FormatToken readDoxygenComment();
|
|
FormatToken readWhiteSpace();
|
|
FormatToken readOperator();
|
|
FormatToken readBrace(bool isOpening);
|
|
|
|
void clearState();
|
|
void saveState(State state, QChar savedData);
|
|
void parseState(State &state, QChar &savedData) const;
|
|
|
|
void setAnchor() { m_markedPosition = m_position; }
|
|
void move() { ++m_position; }
|
|
int length() const { return m_position - m_markedPosition; }
|
|
int anchor() const { return m_markedPosition; }
|
|
bool isEnd() const { return m_position >= m_textLength; }
|
|
|
|
QChar peek(int offset = 0) const
|
|
{
|
|
int pos = m_position + offset;
|
|
if (pos >= m_textLength)
|
|
return QLatin1Char('\0');
|
|
return m_text[pos];
|
|
}
|
|
|
|
const QChar *m_text;
|
|
const int m_textLength;
|
|
int m_position = 0;
|
|
int m_markedPosition = 0;
|
|
|
|
int m_state;
|
|
};
|
|
|
|
} // Python::Internal
|