[Mlir-commits] [mlir] [MLIR][Python] Add a DSL for defining IRDL dialects in Python bindings (PR #169045)

Rolf Morel llvmlistbot at llvm.org
Sat Dec 13 09:15:36 PST 2025


================
@@ -0,0 +1,300 @@
+# RUN: %PYTHON %s 2>&1 | FileCheck %s
+
+from mlir.ir import *
+from mlir.dialects.irdl import dsl as irdsl
+from mlir.dialects import arith
+import sys
+
+
+def run(f):
+    print("\nTEST:", f.__name__, file=sys.stderr)
+    with Context():
+        f()
+
+
+# CHECK: TEST: testMyInt
+ at run
+def testMyInt():
+    myint = irdsl.Dialect("myint")
+    iattr = irdsl.BaseName("#builtin.integer")
+    i32 = irdsl.Is(IntegerType.get_signless(32))
+
+    class ConstantOp(myint.Operation, name="constant"):
----------------
rolfmorel wrote:

And returning to this a day later: I am now doubting we will be able make the definition of ops "static" (i.e. not needing to occur in the context of a `mlir.ir.Context`) as the `i32` that occurs in the examples above is actually `i32 = irdsl.Is(IntegerType.get_signless(32))` where `IntegerType.get_signless(32)` does (implicitly) require a `mlir.ir.Context` to be active. 😞 

https://github.com/llvm/llvm-project/pull/169045


More information about the Mlir-commits mailing list