Files
qt-creator/src/plugins/python/pythonscanner.h
Kai Köhne 56baf8c058 Remove GPL-3.0+ from license identifiers
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>
2023-01-06 11:15:13 +00:00

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