|
MLIR 22.0.0git
|
A list of block successors. More...
#include "mlir/Bindings/Python/IRCore.h"
Public Member Functions | |
| PyBlockSuccessors (PyBlock block, PyOperationRef operation, intptr_t startIndex=0, intptr_t length=-1, intptr_t step=1) | |
| Public Member Functions inherited from mlir::Sliceable< PyBlockSuccessors, PyBlock > | |
| Sliceable (intptr_t startIndex, intptr_t length, intptr_t step) | |
| PyBlock | getElement (intptr_t index) |
| Returns the index-th element in the slice, supports negative indices. | |
| intptr_t | size () |
| Returns the size of slice. | |
| std::vector< PyBlock > | dunderAdd (PyBlockSuccessors &other) |
| Returns a new vector (mapped to Python list) containing elements from two slices. | |
Static Public Attributes | |
| static constexpr const char * | pyClassName = "BlockSuccessors" |
Friends | |
| class | Sliceable< PyBlockSuccessors, PyBlock > |
| Give the parent CRTP class access to hook implementations below. | |
Additional Inherited Members | |
| Static Public Member Functions inherited from mlir::Sliceable< PyBlockSuccessors, PyBlock > | |
| static void | bind (nanobind::module_ &m) |
| Binds the indexing and length methods in the Python class. | |
| static void | bindDerived (ClassTy &) |
| Hook for derived classes willing to bind more methods. | |
| Public Attributes inherited from mlir::Sliceable< PyBlockSuccessors, PyBlock > | |
| intptr_t | startIndex |
| intptr_t | length |
| intptr_t | step |
| Protected Types inherited from mlir::Sliceable< PyBlockSuccessors, PyBlock > | |
| using | ClassTy |
| using | has_maybe_downcast |
| Trait to check if T provides a maybeDownCast method. | |
| Protected Member Functions inherited from mlir::Sliceable< PyBlockSuccessors, PyBlock > | |
| intptr_t | wrapIndex (intptr_t index) |
| Transforms index into a legal value to access the underlying sequence. | |
| intptr_t | linearizeIndex (intptr_t index) |
| Computes the linear index given the current slice properties. | |
| nanobind::object | getItem (intptr_t index) |
| Returns the element at the given slice index. | |
| nanobind::object | getItemSlice (PyObject *slice) |
| Returns a new instance of the pseudo-container restricted to the given slice. | |
A list of block successors.
Internally, these are stored as consecutive elements, random access is cheap. The (returned) successor list is associated with the operation and block whose successors these are, and thus extends the lifetime of this operation and block.
| mlir::python::MLIR_BINDINGS_PYTHON_DOMAIN::PyBlockSuccessors::PyBlockSuccessors | ( | PyBlock | block, |
| PyOperationRef | operation, | ||
| intptr_t | startIndex = 0, | ||
| intptr_t | length = -1, | ||
| intptr_t | step = 1 ) |
Definition at line 2327 of file IRCore.cpp.
References mlir::Sliceable< PyBlockSuccessors, PyBlock >::length, mlir::python::MLIR_BINDINGS_PYTHON_DOMAIN::PyOpSuccessors::PyOpSuccessors(), mlir::Sliceable< PyBlockSuccessors, PyBlock >::startIndex, and mlir::Sliceable< PyBlockSuccessors, PyBlock >::step.
Referenced by mlir::python::MLIR_BINDINGS_PYTHON_DOMAIN::PyBlockPredecessors::PyBlockPredecessors(), and Sliceable< PyBlockSuccessors, PyBlock >.
|
friend |
Give the parent CRTP class access to hook implementations below.
Definition at line 1742 of file IRCore.h.
References mlir::Sliceable< PyBlockSuccessors, PyBlock >::length, PyBlockSuccessors(), mlir::Sliceable< PyBlockSuccessors, PyBlock >::Sliceable(), mlir::Sliceable< PyBlockSuccessors, PyBlock >::startIndex, and mlir::Sliceable< PyBlockSuccessors, PyBlock >::step.
|
staticconstexpr |