mirror of
https://bitbucket.org/smil3y/kde-extraapps.git
synced 2025-02-26 11:52:54 +00:00
80 lines
3 KiB
C
80 lines
3 KiB
C
![]() |
/* This file is part of KDevelop
|
||
|
Copyright 2010 Aleix Pol Gonzalez <aleixpol@kde.org>
|
||
|
|
||
|
This library is free software; you can redistribute it and/or
|
||
|
modify it under the terms of the GNU Library General Public
|
||
|
License version 2 as published by the Free Software Foundation.
|
||
|
|
||
|
This library is distributed in the hope that it will be useful,
|
||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||
|
Library General Public License for more details.
|
||
|
|
||
|
You should have received a copy of the GNU Library General Public License
|
||
|
along with this library; see the file COPYING.LIB. If not, write to
|
||
|
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
||
|
Boston, MA 02110-1301, USA.
|
||
|
*/
|
||
|
|
||
|
#ifndef CONTROLFLOWGRAPHBUILDER_H
|
||
|
#define CONTROLFLOWGRAPHBUILDER_H
|
||
|
|
||
|
#include <cppduchainexport.h>
|
||
|
#include <parser/default_visitor.h>
|
||
|
#include <language/duchain/topducontext.h>
|
||
|
|
||
|
namespace KDevelop
|
||
|
{
|
||
|
class ControlFlowGraph;
|
||
|
class ControlFlowNode;
|
||
|
class CursorInRevision;
|
||
|
class IndexedString;
|
||
|
}
|
||
|
|
||
|
class KDEVCPPDUCHAIN_EXPORT ControlFlowGraphBuilder : public DefaultVisitor
|
||
|
{
|
||
|
public:
|
||
|
ControlFlowGraphBuilder(const KDevelop::ReferencedTopDUContext& top, const ParseSession* session, KDevelop::ControlFlowGraph* graph);
|
||
|
virtual ~ControlFlowGraphBuilder();
|
||
|
|
||
|
void run(AST* node);
|
||
|
|
||
|
protected:
|
||
|
virtual void visitFunctionDefinition(FunctionDefinitionAST* node);
|
||
|
virtual void visitEnumerator(EnumeratorAST* node);
|
||
|
|
||
|
virtual void visitIfStatement(IfStatementAST* node);
|
||
|
virtual void visitWhileStatement(WhileStatementAST* node);
|
||
|
virtual void visitForStatement(ForStatementAST* node);
|
||
|
virtual void visitConditionalExpression(ConditionalExpressionAST* node);
|
||
|
virtual void visitDoStatement(DoStatementAST* node);
|
||
|
|
||
|
virtual void visitReturnStatement(ReturnStatementAST* node);
|
||
|
virtual void visitJumpStatement(JumpStatementAST* node);
|
||
|
virtual void visitSwitchStatement(SwitchStatementAST* node);
|
||
|
virtual void visitLabeledStatement(LabeledStatementAST* node);
|
||
|
|
||
|
private:
|
||
|
KDevelop::ControlFlowNode* createCompoundStatement(AST* node, KDevelop::ControlFlowNode* next);
|
||
|
void createCompoundStatementFrom(KDevelop::ControlFlowNode* curr, AST* node, KDevelop::ControlFlowNode* next);
|
||
|
KDevelop::CursorInRevision cursorForToken(uint token);
|
||
|
KDevelop::RangeInRevision nodeRange(AST* node);
|
||
|
|
||
|
const ParseSession* m_session;
|
||
|
KDevelop::ControlFlowGraph* m_graph;
|
||
|
KDevelop::ControlFlowNode* m_currentNode;
|
||
|
|
||
|
KDevelop::ControlFlowNode* m_returnNode;
|
||
|
KDevelop::ControlFlowNode* m_breakNode;
|
||
|
KDevelop::ControlFlowNode* m_continueNode;
|
||
|
|
||
|
KDevelop::ControlFlowNode* m_defaultNode;
|
||
|
QList<QPair<KDevelop::ControlFlowNode*, KDevelop::ControlFlowNode*> > m_caseNodes;
|
||
|
QMap<KDevelop::IndexedString, KDevelop::ControlFlowNode*> m_taggedNodes;
|
||
|
QMap<KDevelop::IndexedString, QList<KDevelop::ControlFlowNode*> > m_pendingGotoNodes;
|
||
|
|
||
|
KDevelop::ReferencedTopDUContext m_top;
|
||
|
};
|
||
|
|
||
|
#endif // CONTROLFLOWGRAPHBUILDER_H
|