kde-extraapps/kdevplatform/language/checks/controlflownode.h

85 lines
3.3 KiB
C
Raw Normal View History

/* This file is part of KDevelop
Copyright 2010-2011 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 KDEVPLATFORM_CONTROLFLOWNODE_H
#define KDEVPLATFORM_CONTROLFLOWNODE_H
#include <language/editor/rangeinrevision.h>
#include <language/languageexport.h>
namespace KDevelop
{
/** @brief Class that represents a node in the control flow graph
This class will provide us the information to know how to navigate in a ControlFlowGraph.
It has two methods (next and alternative) that will tell us what are the next nodes and
nodeRange and conditionRange that will tell us the code ranges that this nodes is located at.
*/
class KDEVPLATFORMLANGUAGE_EXPORT ControlFlowNode
{
public:
/** Defines the type of the node in terms of what's on the next and alternative method */
enum Type {
Conditional, /**< It's a conditional node. alternative and next are available, also conditionRange returns a valid range. */
Sequential, /**< It's a node where we just have a next node, we always know where it's going to go as a next step. */
Exit /**< It's the end node, it will either return to the caller or finish execution depending on the context. */
};
/** Constructs an empty node with no next or alternative nodes */
ControlFlowNode();
/** @returns the node type by checking the node's next and alternative value */
Type type() const;
/** Sets where is this range going to start to @p cursor*/
void setStartCursor(const CursorInRevision& cursor);
/** Sets where is this range going to end to @p cursor*/
void setEndCursor(const CursorInRevision& cursor);
/** Sets the condition range to @p range */
void setConditionRange(const KDevelop::RangeInRevision& range);
/** Sets @p next to be the node that will be executed after this one */
void setNext(ControlFlowNode* next);
/** Sets @p alt to be the alternative to next. Converts this node into a conditional node */
void setAlternative(ControlFlowNode* alt);
/** @returns the node to be executed next */
ControlFlowNode* next() const;
/** @returns the node to be executed next alternatively */
ControlFlowNode* alternative() const;
/** @returns the node range as in what range area does the node affect. */
KDevelop::RangeInRevision nodeRange() const;
/** @returns the node range as in what range does its condition affect. */
KDevelop::RangeInRevision conditionRange() const;
private:
KDevelop::RangeInRevision m_nodeRange;
KDevelop::RangeInRevision m_conditionRange;
ControlFlowNode* m_next;
ControlFlowNode* m_alternative;
};
}
#endif // KDEVPLATFORM_FLUXNODE_H