MLIR 22.0.0git
mlir::python::MLIR_BINDINGS_PYTHON_DOMAIN::PyBlockArgumentList Class Reference

A list of block arguments. More...

#include "mlir/Bindings/Python/IRCore.h"

Inheritance diagram for mlir::python::MLIR_BINDINGS_PYTHON_DOMAIN::PyBlockArgumentList:

Public Types

using SliceableT = Sliceable<PyBlockArgumentList, PyBlockArgument>

Public Member Functions

 PyBlockArgumentList (PyOperationRef operation, MlirBlock block, intptr_t startIndex=0, intptr_t length=-1, intptr_t step=1)
Public Member Functions inherited from mlir::Sliceable< PyBlockArgumentList, PyBlockArgument >
 Sliceable (intptr_t startIndex, intptr_t length, intptr_t step)
PyBlockArgument 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< PyBlockArgument > dunderAdd (PyBlockArgumentList &other)
 Returns a new vector (mapped to Python list) containing elements from two slices.

Static Public Member Functions

static void bindDerived (ClassTy &c)
Static Public Member Functions inherited from mlir::Sliceable< PyBlockArgumentList, PyBlockArgument >
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.

Static Public Attributes

static constexpr const char * pyClassName = "BlockArgumentList"

Friends

class Sliceable< PyBlockArgumentList, PyBlockArgument >
 Give the parent CRTP class access to hook implementations below.

Additional Inherited Members

Public Attributes inherited from mlir::Sliceable< PyBlockArgumentList, PyBlockArgument >
intptr_t startIndex
intptr_t length
intptr_t step
Protected Types inherited from mlir::Sliceable< PyBlockArgumentList, PyBlockArgument >
using ClassTy
using has_maybe_downcast
 Trait to check if T provides a maybeDownCast method.
Protected Member Functions inherited from mlir::Sliceable< PyBlockArgumentList, PyBlockArgument >
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.

Detailed Description

A list of block arguments.

Internally, these are stored as consecutive elements, random access is cheap. The argument list is associated with the operation that contains the block (detached blocks are not allowed in Python bindings) and extends its lifetime.

Definition at line 1642 of file IRCore.h.

Member Typedef Documentation

◆ SliceableT

Constructor & Destructor Documentation

◆ PyBlockArgumentList()

mlir::python::MLIR_BINDINGS_PYTHON_DOMAIN::PyBlockArgumentList::PyBlockArgumentList ( PyOperationRef operation,
MlirBlock block,
intptr_t startIndex = 0,
intptr_t length = -1,
intptr_t step = 1 )

Member Function Documentation

◆ bindDerived()

◆ Sliceable< PyBlockArgumentList, PyBlockArgument >

Member Data Documentation

◆ pyClassName

const char* mlir::python::MLIR_BINDINGS_PYTHON_DOMAIN::PyBlockArgumentList::pyClassName = "BlockArgumentList"
staticconstexpr

Definition at line 1645 of file IRCore.h.


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