
* The API is a bit more verbose than I feel like it needs to be. In a follow-up I'd like to abbreviate some things and look in to creating aliases for common accessors. * There is a lingering lifetime hazard between the module and newly added operations. We have the facilities now to solve for this but I will do that in a follow-up. * We may need to craft a more limited API for safely referencing successors when creating operations. We need more facilities to really prove that out and should defer for now. Differential Revision: https://reviews.llvm.org/D87996
39 lines
1.2 KiB
C++
39 lines
1.2 KiB
C++
//===- PybindUtils.h - Utilities for interop with pybind11 ------*- C++ -*-===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef MLIR_BINDINGS_PYTHON_PYBINDUTILS_H
|
|
#define MLIR_BINDINGS_PYTHON_PYBINDUTILS_H
|
|
|
|
#include <pybind11/pybind11.h>
|
|
#include <pybind11/stl.h>
|
|
|
|
#include "llvm/ADT/Optional.h"
|
|
#include "llvm/ADT/Twine.h"
|
|
|
|
namespace pybind11 {
|
|
namespace detail {
|
|
template <typename T>
|
|
struct type_caster<llvm::Optional<T>> : optional_caster<llvm::Optional<T>> {};
|
|
} // namespace detail
|
|
} // namespace pybind11
|
|
|
|
namespace mlir {
|
|
namespace python {
|
|
|
|
// Sets a python error, ready to be thrown to return control back to the
|
|
// python runtime.
|
|
// Correct usage:
|
|
// throw SetPyError(PyExc_ValueError, "Foobar'd");
|
|
pybind11::error_already_set SetPyError(PyObject *excClass,
|
|
const llvm::Twine &message);
|
|
|
|
} // namespace python
|
|
} // namespace mlir
|
|
|
|
#endif // MLIR_BINDINGS_PYTHON_PYBINDUTILS_H
|