Files
qt-creator/src/libs/cplusplus/findcdbbreakpoint.cpp
hjk 386ca7c8dd Adjust license headers
Change-Id: Ice592c6de9951ee3b2c4cb52ed0bb3b6770e0825
Reviewed-by: Eike Ziller <eike.ziller@digia.com>
2012-10-05 17:12:56 +02:00

249 lines
5.9 KiB
C++

/****************************************************************************
**
** Copyright (C) 2012 Digia Plc and/or its subsidiary(-ies).
** Contact: http://www.qt-project.org/legal
**
** This file is part of Qt Creator.
**
** 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 Digia. For licensing terms and
** conditions see http://qt.digia.com/licensing. For further information
** use the contact form at http://qt.digia.com/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 as published by the Free Software
** Foundation and appearing in the file LICENSE.LGPL included in the
** packaging of this file. Please review the following information to
** ensure the GNU Lesser General Public License version 2.1 requirements
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
**
** In addition, as a special exception, Digia gives you certain additional
** rights. These rights are described in the Digia Qt LGPL Exception
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
**
****************************************************************************/
#include "findcdbbreakpoint.h"
#include <AST.h>
#include <TranslationUnit.h>
#include <typeinfo>
#include <QDebug>
using namespace CPlusPlus;
FindCdbBreakpoint::FindCdbBreakpoint(TranslationUnit *unit)
: ASTVisitor(unit)
{
}
unsigned FindCdbBreakpoint::searchFrom(unsigned line)
{
m_initialLine = line;
m_breakpointLine = NO_LINE_FOUND;
accept(translationUnit()->ast());
return m_breakpointLine;
}
void FindCdbBreakpoint::foundLine(unsigned tokenIndex)
{
unsigned dummy = 0;
getTokenStartPosition(tokenIndex, &m_breakpointLine, &dummy);
}
unsigned FindCdbBreakpoint::endLine(unsigned tokenIndex) const
{
unsigned line = 0, column = 0;
getTokenEndPosition(tokenIndex, &line, &column);
return line;
}
unsigned FindCdbBreakpoint::endLine(AST *ast) const
{
if (ast)
return endLine(ast->lastToken() - 1);
else
return NO_LINE_FOUND;
}
bool FindCdbBreakpoint::preVisit(AST *ast)
{
if (m_breakpointLine)
return false;
if (endLine(ast) < m_initialLine)
return false;
return true;
}
bool FindCdbBreakpoint::visit(FunctionDefinitionAST *ast)
{
if (ast->function_body) {
if (CompoundStatementAST *stmt = ast->function_body->asCompoundStatement()) {
accept(stmt);
if (!m_breakpointLine)
foundLine(ast->function_body->firstToken());
return false;
}
}
return true;
}
bool FindCdbBreakpoint::visit(QtMemberDeclarationAST *ast)
{
foundLine(ast->lastToken() - 1);
return false;
}
bool FindCdbBreakpoint::visit(CompoundStatementAST *ast)
{
accept(ast->statement_list);
return false;
}
bool FindCdbBreakpoint::visit(DeclarationStatementAST *ast)
{
foundLine(ast->lastToken() - 1);
return m_breakpointLine == NO_LINE_FOUND;
}
bool FindCdbBreakpoint::visit(DoStatementAST *ast)
{
accept(ast->statement);
if (m_breakpointLine == NO_LINE_FOUND)
foundLine(ast->rparen_token);
return false;
}
bool FindCdbBreakpoint::visit(ExpressionStatementAST *ast)
{
if (ast->expression)
foundLine(ast->semicolon_token);
return false;
}
bool FindCdbBreakpoint::visit(ForeachStatementAST *ast)
{
if (m_initialLine <= endLine(ast->rparen_token))
foundLine(ast->rparen_token);
accept(ast->statement);
return false;
}
bool FindCdbBreakpoint::visit(RangeBasedForStatementAST *ast)
{
if (m_initialLine <= endLine(ast->rparen_token))
foundLine(ast->rparen_token);
accept(ast->statement);
return false;
}
bool FindCdbBreakpoint::visit(ForStatementAST *ast)
{
if (m_initialLine <= endLine(ast->rparen_token))
foundLine(ast->rparen_token);
accept(ast->statement);
return false;
}
bool FindCdbBreakpoint::visit(IfStatementAST *ast)
{
if (m_initialLine <= endLine(ast->rparen_token))
foundLine(ast->rparen_token);
accept(ast->statement);
accept(ast->else_statement);
return false;
}
bool FindCdbBreakpoint::visit(LabeledStatementAST *ast)
{
foundLine(ast->lastToken() - 1);
return false;
}
bool FindCdbBreakpoint::visit(BreakStatementAST *ast)
{
foundLine(ast->lastToken() - 1);
return false;
}
bool FindCdbBreakpoint::visit(ContinueStatementAST *ast)
{
foundLine(ast->lastToken() - 1);
return false;
}
bool FindCdbBreakpoint::visit(GotoStatementAST *ast)
{
foundLine(ast->lastToken() - 1);
return false;
}
bool FindCdbBreakpoint::visit(ReturnStatementAST *ast)
{
foundLine(ast->lastToken() - 1);
return false;
}
bool FindCdbBreakpoint::visit(SwitchStatementAST *ast)
{
if (m_initialLine <= endLine(ast->rparen_token))
foundLine(ast->rparen_token);
accept(ast->statement);
return false;
}
bool FindCdbBreakpoint::visit(TryBlockStatementAST *ast)
{
accept(ast->statement);
return false;
}
bool FindCdbBreakpoint::visit(CatchClauseAST *ast)
{
accept(ast->statement);
return false;
}
bool FindCdbBreakpoint::visit(WhileStatementAST *ast)
{
if (m_initialLine <= endLine(ast->rparen_token))
foundLine(ast->rparen_token);
accept(ast->statement);
return false;
}
bool FindCdbBreakpoint::visit(ObjCFastEnumerationAST *ast)
{
if (m_initialLine <= endLine(ast->rparen_token))
foundLine(ast->rparen_token);
accept(ast->statement);
return false;
}
bool FindCdbBreakpoint::visit(ObjCSynchronizedStatementAST *ast)
{
if (m_initialLine <= endLine(ast->rparen_token))
foundLine(ast->rparen_token);
accept(ast->statement);
return false;
}