py::arg("enable_debug_info") = false,
py::arg("pretty_debug_info") = false,
py::arg("print_generic_op_form") = false,
- py::arg("use_local_scope") = false, kOperationGetAsmDocstring);
+ py::arg("use_local_scope") = false, kOperationGetAsmDocstring)
+ .def(
+ "verify",
+ [](PyOperationBase &self) {
+ return mlirOperationVerify(self.getOperation());
+ },
+ "Verify the operation and return true if it passes, false if it "
+ "fails.");
py::class_<PyOperation, PyOperationBase>(m, "Operation")
.def_static("create", &PyOperation::create, py::arg("name"),
# CHECK: MODULE REGIONS=1 BLOCKS=1
print(f"MODULE REGIONS={len(regions)} BLOCKS={len(blocks)}")
+ # Should verify.
+ # CHECK: .verify = True
+ print(f".verify = {module.operation.verify()}")
+
# Get the regions and blocks from the default collections.
default_regions = list(op)
default_blocks = list(default_regions[0])
# This block does not have a terminator, it may crash the custom printer.
# Verify that we fallback to the generic printer for safety.
block = module.regions[0].blocks.append()
- print(module)
# CHECK: // Verification failed, printing generic form
# CHECK: "module"() ( {
# CHECK: }) : () -> ()
+ print(module)
+ # CHECK: .verify = False
+ print(f".verify = {module.operation.verify()}")
run(testPrintInvalidOperation)