Files correlati : cg0.exe cg0700a.msk cg0700b.msk cg3.exe cg4.exe Bug : Commento: Merge 1.0 libraries
871 lines
28 KiB
C++
871 lines
28 KiB
C++
/****************************************************************************
|
|
**
|
|
** Copyright (C) 2015 The Qt Company Ltd.
|
|
** Contact: http://www.qt.io/licensing/
|
|
**
|
|
** This file is part of the tools applications of the Qt Toolkit.
|
|
**
|
|
** $QT_BEGIN_LICENSE:LGPL$
|
|
** Commercial License Usage
|
|
** Licensees holding valid commercial Qt licenses may use this file in
|
|
** accordance with the commercial license agreement provided with the
|
|
** Software or, alternatively, in accordance with the terms contained in
|
|
** a written agreement between you and The Qt Company. For licensing terms
|
|
** and conditions see http://www.qt.io/terms-conditions. For further
|
|
** information use the contact form at http://www.qt.io/contact-us.
|
|
**
|
|
** GNU Lesser General Public License Usage
|
|
** Alternatively, this file may be used under the terms of the GNU Lesser
|
|
** General Public License version 2.1 or version 3 as published by the Free
|
|
** Software Foundation and appearing in the file LICENSE.LGPLv21 and
|
|
** LICENSE.LGPLv3 included in the packaging of this file. Please review the
|
|
** following information to ensure the GNU Lesser General Public License
|
|
** requirements will be met: https://www.gnu.org/licenses/lgpl.html and
|
|
** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
|
|
**
|
|
** As a special exception, The Qt Company gives you certain additional
|
|
** rights. These rights are described in The Qt Company LGPL Exception
|
|
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
|
|
**
|
|
** GNU General Public License Usage
|
|
** Alternatively, this file may be used under the terms of the GNU
|
|
** General Public License version 3.0 as published by the Free Software
|
|
** Foundation and appearing in the file LICENSE.GPL included in the
|
|
** packaging of this file. Please review the following information to
|
|
** ensure the GNU General Public License version 3.0 requirements will be
|
|
** met: http://www.gnu.org/copyleft/gpl.html.
|
|
**
|
|
** $QT_END_LICENSE$
|
|
**
|
|
****************************************************************************/
|
|
|
|
#include <QStringList>
|
|
#include <QtGlobal>
|
|
#include "declarativeparser/qdeclarativejsast_p.h"
|
|
#include "declarativeparser/qdeclarativejsastfwd_p.h"
|
|
#include "declarativeparser/qdeclarativejsengine_p.h"
|
|
|
|
#include "qmlmarkupvisitor.h"
|
|
|
|
QT_BEGIN_NAMESPACE
|
|
|
|
QmlMarkupVisitor::QmlMarkupVisitor(const QString &source,
|
|
const QList<QDeclarativeJS::AST::SourceLocation> &pragmas,
|
|
QDeclarativeJS::Engine *engine)
|
|
{
|
|
this->source = source;
|
|
this->engine = engine;
|
|
|
|
cursor = 0;
|
|
extraIndex = 0;
|
|
|
|
// Merge the lists of locations of pragmas and comments in the source code.
|
|
int i = 0;
|
|
int j = 0;
|
|
while (i < engine->comments().length() && j < pragmas.length()) {
|
|
if (engine->comments()[i].offset < pragmas[j].offset) {
|
|
extraTypes.append(Comment);
|
|
extraLocations.append(engine->comments()[i]);
|
|
++i;
|
|
} else {
|
|
extraTypes.append(Pragma);
|
|
extraLocations.append(engine->comments()[j]);
|
|
++j;
|
|
}
|
|
}
|
|
|
|
while (i < engine->comments().length()) {
|
|
extraTypes.append(Comment);
|
|
extraLocations.append(engine->comments()[i]);
|
|
++i;
|
|
}
|
|
|
|
while (j < pragmas.length()) {
|
|
extraTypes.append(Pragma);
|
|
extraLocations.append(pragmas[j]);
|
|
++j;
|
|
}
|
|
}
|
|
|
|
QmlMarkupVisitor::~QmlMarkupVisitor()
|
|
{
|
|
}
|
|
|
|
// The protect() function is a copy of the one from CppCodeMarker.
|
|
|
|
static const QString samp = QLatin1String("&");
|
|
static const QString slt = QLatin1String("<");
|
|
static const QString sgt = QLatin1String(">");
|
|
static const QString squot = QLatin1String(""");
|
|
|
|
QString QmlMarkupVisitor::protect(const QString& str)
|
|
{
|
|
int n = str.length();
|
|
QString marked;
|
|
marked.reserve(n * 2 + 30);
|
|
const QChar *data = str.constData();
|
|
for (int i = 0; i != n; ++i) {
|
|
switch (data[i].unicode()) {
|
|
case '&': marked += samp; break;
|
|
case '<': marked += slt; break;
|
|
case '>': marked += sgt; break;
|
|
case '"': marked += squot; break;
|
|
default : marked += data[i];
|
|
}
|
|
}
|
|
return marked;
|
|
}
|
|
|
|
QString QmlMarkupVisitor::markedUpCode()
|
|
{
|
|
if (int(cursor) < source.length())
|
|
addExtra(cursor, source.length());
|
|
|
|
return output;
|
|
}
|
|
|
|
void QmlMarkupVisitor::addExtra(quint32 start, quint32 finish)
|
|
{
|
|
if (extraIndex >= extraLocations.length()) {
|
|
QString extra = source.mid(start, finish - start);
|
|
if (extra.trimmed().isEmpty())
|
|
output += extra;
|
|
else
|
|
output += protect(extra); // text that should probably have been caught by the parser
|
|
|
|
cursor = finish;
|
|
return;
|
|
}
|
|
|
|
while (extraIndex < extraLocations.length()) {
|
|
if (extraTypes[extraIndex] == Comment) {
|
|
if (extraLocations[extraIndex].offset - 2 >= start)
|
|
break;
|
|
} else {
|
|
if (extraLocations[extraIndex].offset >= start)
|
|
break;
|
|
}
|
|
extraIndex++;
|
|
}
|
|
|
|
quint32 i = start;
|
|
while (i < finish && extraIndex < extraLocations.length()) {
|
|
quint32 j = extraLocations[extraIndex].offset - 2;
|
|
if (i <= j && j < finish) {
|
|
if (i < j)
|
|
output += protect(source.mid(i, j - i));
|
|
|
|
quint32 l = extraLocations[extraIndex].length;
|
|
if (extraTypes[extraIndex] == Comment) {
|
|
if (source.mid(j, 2) == QLatin1String("/*"))
|
|
l += 4;
|
|
else
|
|
l += 2;
|
|
output += QLatin1String("<@comment>");
|
|
output += protect(source.mid(j, l));
|
|
output += QLatin1String("</@comment>");
|
|
} else
|
|
output += protect(source.mid(j, l));
|
|
|
|
extraIndex++;
|
|
i = j + l;
|
|
} else
|
|
break;
|
|
}
|
|
|
|
QString extra = source.mid(i, finish - i);
|
|
if (extra.trimmed().isEmpty())
|
|
output += extra;
|
|
else
|
|
output += protect(extra); // text that should probably have been caught by the parser
|
|
|
|
cursor = finish;
|
|
}
|
|
|
|
void QmlMarkupVisitor::addMarkedUpToken(
|
|
QDeclarativeJS::AST::SourceLocation &location, const QString &tagName,
|
|
const QHash<QString, QString> &attributes)
|
|
{
|
|
if (!location.isValid())
|
|
return;
|
|
|
|
if (cursor < location.offset)
|
|
addExtra(cursor, location.offset);
|
|
else if (cursor > location.offset)
|
|
return;
|
|
|
|
output += QString(QLatin1String("<@%1")).arg(tagName);
|
|
foreach (const QString &key, attributes)
|
|
output += QString(QLatin1String(" %1=\"%2\"")).arg(key).arg(attributes[key]);
|
|
output += QString(QLatin1String(">%2</@%3>")).arg(protect(sourceText(location)), tagName);
|
|
cursor += location.length;
|
|
}
|
|
|
|
QString QmlMarkupVisitor::sourceText(QDeclarativeJS::AST::SourceLocation &location)
|
|
{
|
|
return source.mid(location.offset, location.length);
|
|
}
|
|
|
|
void QmlMarkupVisitor::addVerbatim(QDeclarativeJS::AST::SourceLocation first,
|
|
QDeclarativeJS::AST::SourceLocation last)
|
|
{
|
|
if (!first.isValid())
|
|
return;
|
|
|
|
quint32 start = first.begin();
|
|
quint32 finish;
|
|
if (last.isValid())
|
|
finish = last.end();
|
|
else
|
|
finish = first.end();
|
|
|
|
if (cursor < start)
|
|
addExtra(cursor, start);
|
|
else if (cursor > start)
|
|
return;
|
|
|
|
QString text = source.mid(start, finish - start);
|
|
output += protect(text);
|
|
cursor = finish;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::UiImport *uiimport)
|
|
{
|
|
addVerbatim(uiimport->importToken);
|
|
if (!uiimport->importUri)
|
|
addMarkedUpToken(uiimport->fileNameToken, QLatin1String("headerfile"));
|
|
return false;
|
|
}
|
|
|
|
void QmlMarkupVisitor::endVisit(QDeclarativeJS::AST::UiImport *uiimport)
|
|
{
|
|
addVerbatim(uiimport->versionToken);
|
|
addVerbatim(uiimport->asToken);
|
|
addMarkedUpToken(uiimport->importIdToken, QLatin1String("headerfile"));
|
|
addVerbatim(uiimport->semicolonToken);
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::UiPublicMember *member)
|
|
{
|
|
if (member->type == QDeclarativeJS::AST::UiPublicMember::Property) {
|
|
addVerbatim(member->defaultToken);
|
|
addVerbatim(member->readonlyToken);
|
|
addVerbatim(member->propertyToken);
|
|
addVerbatim(member->typeModifierToken);
|
|
addMarkedUpToken(member->typeToken, QLatin1String("type"));
|
|
addMarkedUpToken(member->identifierToken, QLatin1String("name"));
|
|
addVerbatim(member->colonToken);
|
|
if (member->binding)
|
|
QDeclarativeJS::AST::Node::accept(member->binding, this);
|
|
else if (member->expression)
|
|
QDeclarativeJS::AST::Node::accept(member->expression, this);
|
|
} else {
|
|
addVerbatim(member->propertyToken);
|
|
addVerbatim(member->typeModifierToken);
|
|
addMarkedUpToken(member->typeToken, QLatin1String("type"));
|
|
//addVerbatim(member->identifierToken);
|
|
QDeclarativeJS::AST::Node::accept(member->parameters, this);
|
|
}
|
|
addVerbatim(member->semicolonToken);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::UiObjectInitializer *initializer)
|
|
{
|
|
addVerbatim(initializer->lbraceToken, initializer->lbraceToken);
|
|
return true;
|
|
}
|
|
|
|
void QmlMarkupVisitor::endVisit(QDeclarativeJS::AST::UiObjectInitializer *initializer)
|
|
{
|
|
addVerbatim(initializer->rbraceToken, initializer->rbraceToken);
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::UiObjectBinding *binding)
|
|
{
|
|
QDeclarativeJS::AST::Node::accept(binding->qualifiedId, this);
|
|
addVerbatim(binding->colonToken);
|
|
QDeclarativeJS::AST::Node::accept(binding->qualifiedTypeNameId, this);
|
|
QDeclarativeJS::AST::Node::accept(binding->initializer, this);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::UiScriptBinding *binding)
|
|
{
|
|
QDeclarativeJS::AST::Node::accept(binding->qualifiedId, this);
|
|
addVerbatim(binding->colonToken);
|
|
QDeclarativeJS::AST::Node::accept(binding->statement, this);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::UiArrayBinding *binding)
|
|
{
|
|
QDeclarativeJS::AST::Node::accept(binding->qualifiedId, this);
|
|
addVerbatim(binding->colonToken);
|
|
addVerbatim(binding->lbracketToken);
|
|
QDeclarativeJS::AST::Node::accept(binding->members, this);
|
|
addVerbatim(binding->rbracketToken);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::UiArrayMemberList *list)
|
|
{
|
|
for (QDeclarativeJS::AST::UiArrayMemberList *it = list; it; it = it->next) {
|
|
QDeclarativeJS::AST::Node::accept(it->member, this);
|
|
//addVerbatim(it->commaToken);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::UiQualifiedId *id)
|
|
{
|
|
addMarkedUpToken(id->identifierToken, QLatin1String("name"));
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::UiSignature *signature)
|
|
{
|
|
addVerbatim(signature->lparenToken);
|
|
return true;
|
|
}
|
|
|
|
void QmlMarkupVisitor::endVisit(QDeclarativeJS::AST::UiSignature *signature)
|
|
{
|
|
addVerbatim(signature->rparenToken);
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::UiFormal *formal)
|
|
{
|
|
addMarkedUpToken(formal->identifierToken, QLatin1String("name"));
|
|
addVerbatim(formal->asToken);
|
|
addVerbatim(formal->aliasToken);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::ThisExpression *expression)
|
|
{
|
|
addVerbatim(expression->thisToken);
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::IdentifierExpression *identifier)
|
|
{
|
|
addMarkedUpToken(identifier->identifierToken, QLatin1String("name"));
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::NullExpression *null)
|
|
{
|
|
addMarkedUpToken(null->nullToken, QLatin1String("number"));
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::TrueLiteral *literal)
|
|
{
|
|
addMarkedUpToken(literal->trueToken, QLatin1String("number"));
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::FalseLiteral *literal)
|
|
{
|
|
addMarkedUpToken(literal->falseToken, QLatin1String("number"));
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::NumericLiteral *literal)
|
|
{
|
|
addMarkedUpToken(literal->literalToken, QLatin1String("number"));
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::StringLiteral *literal)
|
|
{
|
|
addMarkedUpToken(literal->literalToken, QLatin1String("string"));
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::RegExpLiteral *literal)
|
|
{
|
|
addVerbatim(literal->literalToken);
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::ArrayLiteral *literal)
|
|
{
|
|
addVerbatim(literal->lbracketToken);
|
|
QDeclarativeJS::AST::Node::accept(literal->elements, this);
|
|
addVerbatim(literal->rbracketToken);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::ObjectLiteral *literal)
|
|
{
|
|
addVerbatim(literal->lbraceToken);
|
|
return true;
|
|
}
|
|
|
|
void QmlMarkupVisitor::endVisit(QDeclarativeJS::AST::ObjectLiteral *literal)
|
|
{
|
|
addVerbatim(literal->rbraceToken);
|
|
}
|
|
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::ElementList *list)
|
|
{
|
|
for (QDeclarativeJS::AST::ElementList *it = list; it; it = it->next) {
|
|
QDeclarativeJS::AST::Node::accept(it->expression, this);
|
|
//addVerbatim(it->commaToken);
|
|
}
|
|
QDeclarativeJS::AST::Node::accept(list->elision, this);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::Elision *elision)
|
|
{
|
|
addVerbatim(elision->commaToken, elision->commaToken);
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::PropertyNameAndValueList *list)
|
|
{
|
|
QDeclarativeJS::AST::Node::accept(list->name, this);
|
|
addVerbatim(list->colonToken, list->colonToken);
|
|
QDeclarativeJS::AST::Node::accept(list->value, this);
|
|
addVerbatim(list->commaToken, list->commaToken);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::ArrayMemberExpression *expression)
|
|
{
|
|
QDeclarativeJS::AST::Node::accept(expression->base, this);
|
|
addVerbatim(expression->lbracketToken);
|
|
QDeclarativeJS::AST::Node::accept(expression->expression, this);
|
|
addVerbatim(expression->rbracketToken);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::FieldMemberExpression *expression)
|
|
{
|
|
QDeclarativeJS::AST::Node::accept(expression->base, this);
|
|
addVerbatim(expression->dotToken);
|
|
addMarkedUpToken(expression->identifierToken, QLatin1String("name"));
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::NewMemberExpression *expression)
|
|
{
|
|
addVerbatim(expression->newToken);
|
|
QDeclarativeJS::AST::Node::accept(expression->base, this);
|
|
addVerbatim(expression->lparenToken);
|
|
QDeclarativeJS::AST::Node::accept(expression->arguments, this);
|
|
addVerbatim(expression->rparenToken);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::NewExpression *expression)
|
|
{
|
|
addVerbatim(expression->newToken);
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::ArgumentList *list)
|
|
{
|
|
addVerbatim(list->commaToken, list->commaToken);
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::PostIncrementExpression *expression)
|
|
{
|
|
addVerbatim(expression->incrementToken);
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::PostDecrementExpression *expression)
|
|
{
|
|
addVerbatim(expression->decrementToken);
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::DeleteExpression *expression)
|
|
{
|
|
addVerbatim(expression->deleteToken);
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::VoidExpression *expression)
|
|
{
|
|
addVerbatim(expression->voidToken);
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::TypeOfExpression *expression)
|
|
{
|
|
addVerbatim(expression->typeofToken);
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::PreIncrementExpression *expression)
|
|
{
|
|
addVerbatim(expression->incrementToken);
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::PreDecrementExpression *expression)
|
|
{
|
|
addVerbatim(expression->decrementToken);
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::UnaryPlusExpression *expression)
|
|
{
|
|
addVerbatim(expression->plusToken);
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::UnaryMinusExpression *expression)
|
|
{
|
|
addVerbatim(expression->minusToken);
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::TildeExpression *expression)
|
|
{
|
|
addVerbatim(expression->tildeToken);
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::NotExpression *expression)
|
|
{
|
|
addVerbatim(expression->notToken);
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::BinaryExpression *expression)
|
|
{
|
|
QDeclarativeJS::AST::Node::accept(expression->left, this);
|
|
addMarkedUpToken(expression->operatorToken, QLatin1String("op"));
|
|
QDeclarativeJS::AST::Node::accept(expression->right, this);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::ConditionalExpression *expression)
|
|
{
|
|
QDeclarativeJS::AST::Node::accept(expression->expression, this);
|
|
addVerbatim(expression->questionToken);
|
|
QDeclarativeJS::AST::Node::accept(expression->ok, this);
|
|
addVerbatim(expression->colonToken);
|
|
QDeclarativeJS::AST::Node::accept(expression->ko, this);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::Expression *expression)
|
|
{
|
|
QDeclarativeJS::AST::Node::accept(expression->left, this);
|
|
addVerbatim(expression->commaToken);
|
|
QDeclarativeJS::AST::Node::accept(expression->right, this);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::Block *block)
|
|
{
|
|
addVerbatim(block->lbraceToken);
|
|
return true;
|
|
}
|
|
|
|
void QmlMarkupVisitor::endVisit(QDeclarativeJS::AST::Block *block)
|
|
{
|
|
addVerbatim(block->rbraceToken);
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::VariableStatement *statement)
|
|
{
|
|
addVerbatim(statement->declarationKindToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->declarations, this);
|
|
addVerbatim(statement->semicolonToken);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::VariableDeclarationList *list)
|
|
{
|
|
for (QDeclarativeJS::AST::VariableDeclarationList *it = list; it; it = it->next) {
|
|
QDeclarativeJS::AST::Node::accept(it->declaration, this);
|
|
addVerbatim(it->commaToken);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::VariableDeclaration *declaration)
|
|
{
|
|
addMarkedUpToken(declaration->identifierToken, QLatin1String("name"));
|
|
QDeclarativeJS::AST::Node::accept(declaration->expression, this);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::EmptyStatement *statement)
|
|
{
|
|
addVerbatim(statement->semicolonToken);
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::ExpressionStatement *statement)
|
|
{
|
|
QDeclarativeJS::AST::Node::accept(statement->expression, this);
|
|
addVerbatim(statement->semicolonToken);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::IfStatement *statement)
|
|
{
|
|
addMarkedUpToken(statement->ifToken, QLatin1String("keyword"));
|
|
addVerbatim(statement->lparenToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->expression, this);
|
|
addVerbatim(statement->rparenToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->ok, this);
|
|
if (statement->ko) {
|
|
addMarkedUpToken(statement->elseToken, QLatin1String("keyword"));
|
|
QDeclarativeJS::AST::Node::accept(statement->ko, this);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::DoWhileStatement *statement)
|
|
{
|
|
addMarkedUpToken(statement->doToken, QLatin1String("keyword"));
|
|
QDeclarativeJS::AST::Node::accept(statement->statement, this);
|
|
addMarkedUpToken(statement->whileToken, QLatin1String("keyword"));
|
|
addVerbatim(statement->lparenToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->expression, this);
|
|
addVerbatim(statement->rparenToken);
|
|
addVerbatim(statement->semicolonToken);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::WhileStatement *statement)
|
|
{
|
|
addMarkedUpToken(statement->whileToken, QLatin1String("keyword"));
|
|
addVerbatim(statement->lparenToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->expression, this);
|
|
addVerbatim(statement->rparenToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->statement, this);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::ForStatement *statement)
|
|
{
|
|
addMarkedUpToken(statement->forToken, QLatin1String("keyword"));
|
|
addVerbatim(statement->lparenToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->initialiser, this);
|
|
addVerbatim(statement->firstSemicolonToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->condition, this);
|
|
addVerbatim(statement->secondSemicolonToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->expression, this);
|
|
addVerbatim(statement->rparenToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->statement, this);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::LocalForStatement *statement)
|
|
{
|
|
addMarkedUpToken(statement->forToken, QLatin1String("keyword"));
|
|
addVerbatim(statement->lparenToken);
|
|
addMarkedUpToken(statement->varToken, QLatin1String("keyword"));
|
|
QDeclarativeJS::AST::Node::accept(statement->declarations, this);
|
|
addVerbatim(statement->firstSemicolonToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->condition, this);
|
|
addVerbatim(statement->secondSemicolonToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->expression, this);
|
|
addVerbatim(statement->rparenToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->statement, this);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::ForEachStatement *statement)
|
|
{
|
|
addMarkedUpToken(statement->forToken, QLatin1String("keyword"));
|
|
addVerbatim(statement->lparenToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->initialiser, this);
|
|
addVerbatim(statement->inToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->expression, this);
|
|
addVerbatim(statement->rparenToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->statement, this);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::LocalForEachStatement *statement)
|
|
{
|
|
addMarkedUpToken(statement->forToken, QLatin1String("keyword"));
|
|
addVerbatim(statement->lparenToken);
|
|
addMarkedUpToken(statement->varToken, QLatin1String("keyword"));
|
|
QDeclarativeJS::AST::Node::accept(statement->declaration, this);
|
|
addVerbatim(statement->inToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->expression, this);
|
|
addVerbatim(statement->rparenToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->statement, this);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::ContinueStatement *statement)
|
|
{
|
|
addMarkedUpToken(statement->continueToken, QLatin1String("keyword"));
|
|
addMarkedUpToken(statement->identifierToken, QLatin1String("name"));
|
|
addVerbatim(statement->semicolonToken);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::BreakStatement *statement)
|
|
{
|
|
addMarkedUpToken(statement->breakToken, QLatin1String("keyword"));
|
|
addMarkedUpToken(statement->identifierToken, QLatin1String("name"));
|
|
addVerbatim(statement->semicolonToken);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::ReturnStatement *statement)
|
|
{
|
|
addMarkedUpToken(statement->returnToken, QLatin1String("keyword"));
|
|
QDeclarativeJS::AST::Node::accept(statement->expression, this);
|
|
addVerbatim(statement->semicolonToken);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::WithStatement *statement)
|
|
{
|
|
addMarkedUpToken(statement->withToken, QLatin1String("keyword"));
|
|
addVerbatim(statement->lparenToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->expression, this);
|
|
addVerbatim(statement->rparenToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->statement, this);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::CaseBlock *block)
|
|
{
|
|
addVerbatim(block->lbraceToken);
|
|
return true;
|
|
}
|
|
|
|
void QmlMarkupVisitor::endVisit(QDeclarativeJS::AST::CaseBlock *block)
|
|
{
|
|
addVerbatim(block->rbraceToken, block->rbraceToken);
|
|
}
|
|
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::SwitchStatement *statement)
|
|
{
|
|
addMarkedUpToken(statement->switchToken, QLatin1String("keyword"));
|
|
addVerbatim(statement->lparenToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->expression, this);
|
|
addVerbatim(statement->rparenToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->block, this);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::CaseClause *clause)
|
|
{
|
|
addMarkedUpToken(clause->caseToken, QLatin1String("keyword"));
|
|
QDeclarativeJS::AST::Node::accept(clause->expression, this);
|
|
addVerbatim(clause->colonToken);
|
|
QDeclarativeJS::AST::Node::accept(clause->statements, this);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::DefaultClause *clause)
|
|
{
|
|
addMarkedUpToken(clause->defaultToken, QLatin1String("keyword"));
|
|
addVerbatim(clause->colonToken, clause->colonToken);
|
|
return true;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::LabelledStatement *statement)
|
|
{
|
|
addMarkedUpToken(statement->identifierToken, QLatin1String("name"));
|
|
addVerbatim(statement->colonToken);
|
|
QDeclarativeJS::AST::Node::accept(statement->statement, this);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::ThrowStatement *statement)
|
|
{
|
|
addMarkedUpToken(statement->throwToken, QLatin1String("keyword"));
|
|
QDeclarativeJS::AST::Node::accept(statement->expression, this);
|
|
addVerbatim(statement->semicolonToken);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::Catch *c)
|
|
{
|
|
addMarkedUpToken(c->catchToken, QLatin1String("keyword"));
|
|
addVerbatim(c->lparenToken);
|
|
addMarkedUpToken(c->identifierToken, QLatin1String("name"));
|
|
addVerbatim(c->rparenToken);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::Finally *f)
|
|
{
|
|
addMarkedUpToken(f->finallyToken, QLatin1String("keyword"));
|
|
QDeclarativeJS::AST::Node::accept(f->statement, this);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::TryStatement *statement)
|
|
{
|
|
addMarkedUpToken(statement->tryToken, QLatin1String("keyword"));
|
|
QDeclarativeJS::AST::Node::accept(statement->statement, this);
|
|
QDeclarativeJS::AST::Node::accept(statement->catchExpression, this);
|
|
QDeclarativeJS::AST::Node::accept(statement->finallyExpression, this);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::FunctionExpression *expression)
|
|
{
|
|
addMarkedUpToken(expression->functionToken, QLatin1String("keyword"));
|
|
addMarkedUpToken(expression->identifierToken, QLatin1String("name"));
|
|
addVerbatim(expression->lparenToken);
|
|
QDeclarativeJS::AST::Node::accept(expression->formals, this);
|
|
addVerbatim(expression->rparenToken);
|
|
addVerbatim(expression->lbraceToken);
|
|
QDeclarativeJS::AST::Node::accept(expression->body, this);
|
|
addVerbatim(expression->rbraceToken);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::FunctionDeclaration *declaration)
|
|
{
|
|
addMarkedUpToken(declaration->functionToken, QLatin1String("keyword"));
|
|
addMarkedUpToken(declaration->identifierToken, QLatin1String("name"));
|
|
addVerbatim(declaration->lparenToken);
|
|
QDeclarativeJS::AST::Node::accept(declaration->formals, this);
|
|
addVerbatim(declaration->rparenToken);
|
|
addVerbatim(declaration->lbraceToken);
|
|
QDeclarativeJS::AST::Node::accept(declaration->body, this);
|
|
addVerbatim(declaration->rbraceToken);
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::FormalParameterList *list)
|
|
{
|
|
addVerbatim(list->commaToken);
|
|
addMarkedUpToken(list->identifierToken, QLatin1String("name"));
|
|
return false;
|
|
}
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::DebuggerStatement *statement)
|
|
{
|
|
addVerbatim(statement->debuggerToken);
|
|
addVerbatim(statement->semicolonToken);
|
|
return true;
|
|
}
|
|
|
|
// Elements and items are represented by UiObjectDefinition nodes.
|
|
|
|
bool QmlMarkupVisitor::visit(QDeclarativeJS::AST::UiObjectDefinition *definition)
|
|
{
|
|
QHash<QString, QString> attributes;
|
|
addMarkedUpToken(definition->qualifiedTypeNameId->identifierToken, QLatin1String("type"));
|
|
QDeclarativeJS::AST::Node::accept(definition->initializer, this);
|
|
return false;
|
|
}
|
|
|
|
QT_END_NAMESPACE
|