[llvm] [mlir] [mlir][core] Add an MLIR "pattern catalog" generator (PR #146228)

Maksim Levental via llvm-commits llvm-commits at lists.llvm.org
Sat Jun 28 14:17:00 PDT 2025


================
@@ -206,14 +227,38 @@ LogicalResult PatternApplicator::matchAndRewrite(
           } else {
             LLVM_DEBUG(llvm::dbgs() << "Trying to match \""
                                     << bestPattern->getDebugName() << "\"\n");
-
             const auto *pattern =
                 static_cast<const RewritePattern *>(bestPattern);
-            result = pattern->matchAndRewrite(op, rewriter);
 
+#ifdef MLIR_ENABLE_CATALOG_GENERATOR
+            OpBuilder::Listener *oldListener = rewriter.getListener();
+            int status;
+            const char *mangledPatternName = typeid(*pattern).name();
+            char *demangled = abi::__cxa_demangle(mangledPatternName, nullptr,
+                                                  nullptr, &status);
+            std::string demangledPatternName;
+            if (status == 0 && demangled) {
+              demangledPatternName = demangled;
+              free(demangled);
+            } else {
+              // Fallback in case demangling fails.
+              demangledPatternName = mangledPatternName;
+            }
----------------
makslevental wrote:

can't you just do `pattern->getDebugName()`? incidentally that name is set using [llvm::getTypeName](https://github.com/llvm/llvm-project/blob/45ca39d8e1a2b2cc9d67f7a1999e39dc2f77f342/llvm/include/llvm/Support/TypeName.h#L40) (that's how it avoids demangling...).

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


More information about the llvm-commits mailing list