LLVM  6.0.0svn
Public Types | Public Member Functions | List of all members
llvm::RNSuccIterator< FlatIt< NodeRef >, BlockT, RegionT > Class Template Reference

Flat RegionNode iterator. More...

#include "llvm/Analysis/RegionIterator.h"

Inheritance diagram for llvm::RNSuccIterator< FlatIt< NodeRef >, BlockT, RegionT >:
Inheritance graph
[legend]
Collaboration diagram for llvm::RNSuccIterator< FlatIt< NodeRef >, BlockT, RegionT >:
Collaboration graph
[legend]

Public Types

using Self = RNSuccIterator< FlatIt< NodeRef >, BlockT, RegionT >
 
using value_type = typename super::value_type
 

Public Member Functions

 RNSuccIterator (NodeRef node)
 Create the iterator from a RegionNode. More...
 
 RNSuccIterator (NodeRef node, bool)
 Create an end iterator. More...
 
bool operator== (const Self &x) const
 
bool operator!= (const Self &x) const
 
value_type operator* () const
 
Selfoperator++ ()
 
Self operator++ (int)
 

Detailed Description

template<class NodeRef, class BlockT, class RegionT>
class llvm::RNSuccIterator< FlatIt< NodeRef >, BlockT, RegionT >

Flat RegionNode iterator.

The Flat Region iterator will iterate over all BasicBlock RegionNodes that are contained in the Region and its subregions. This is close to a virtual control flow graph of the Region.

Definition at line 167 of file RegionIterator.h.

Member Typedef Documentation

◆ Self

template<class NodeRef , class BlockT , class RegionT >
using llvm::RNSuccIterator< FlatIt< NodeRef >, BlockT, RegionT >::Self = RNSuccIterator<FlatIt<NodeRef>, BlockT, RegionT>

Definition at line 177 of file RegionIterator.h.

◆ value_type

template<class NodeRef , class BlockT , class RegionT >
using llvm::RNSuccIterator< FlatIt< NodeRef >, BlockT, RegionT >::value_type = typename super::value_type

Definition at line 178 of file RegionIterator.h.

Constructor & Destructor Documentation

◆ RNSuccIterator() [1/2]

template<class NodeRef , class BlockT , class RegionT >
llvm::RNSuccIterator< FlatIt< NodeRef >, BlockT, RegionT >::RNSuccIterator ( NodeRef  node)
inline

Create the iterator from a RegionNode.

Note that the incoming node must be a bb node, otherwise it will trigger an assertion when we try to get a BasicBlock.

Definition at line 184 of file RegionIterator.h.

References assert().

◆ RNSuccIterator() [2/2]

template<class NodeRef , class BlockT , class RegionT >
llvm::RNSuccIterator< FlatIt< NodeRef >, BlockT, RegionT >::RNSuccIterator ( NodeRef  node,
bool   
)
inline

Create an end iterator.

Definition at line 197 of file RegionIterator.h.

References assert().

Member Function Documentation

◆ operator!=()

template<class NodeRef , class BlockT , class RegionT >
bool llvm::RNSuccIterator< FlatIt< NodeRef >, BlockT, RegionT >::operator!= ( const Self x) const
inline

◆ operator*()

template<class NodeRef , class BlockT , class RegionT >
value_type llvm::RNSuccIterator< FlatIt< NodeRef >, BlockT, RegionT >::operator* ( ) const
inline

Definition at line 212 of file RegionIterator.h.

References assert().

◆ operator++() [1/2]

template<class NodeRef , class BlockT , class RegionT >
Self& llvm::RNSuccIterator< FlatIt< NodeRef >, BlockT, RegionT >::operator++ ( )
inline

Definition at line 225 of file RegionIterator.h.

References llvm::succ_end().

◆ operator++() [2/2]

template<class NodeRef , class BlockT , class RegionT >
Self llvm::RNSuccIterator< FlatIt< NodeRef >, BlockT, RegionT >::operator++ ( int  )
inline

Definition at line 235 of file RegionIterator.h.

◆ operator==()

template<class NodeRef , class BlockT , class RegionT >
bool llvm::RNSuccIterator< FlatIt< NodeRef >, BlockT, RegionT >::operator== ( const Self x) const
inline

Definition at line 203 of file RegionIterator.h.

References assert().


The documentation for this class was generated from the following file: