[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