[clang-tools-extra] [clang-tidy] Add MLIR check for old op builder usage. (PR #149148)

Jacques Pienaar via cfe-commits cfe-commits at lists.llvm.org
Thu Jul 24 01:15:05 PDT 2025


================
@@ -0,0 +1,51 @@
+// RUN: %check_clang_tidy --match-partial-fixes %s llvm-mlir-op-builder %t
+
+namespace mlir {
+class Location {};
+class OpBuilder {
+public:
+  template <typename OpTy, typename... Args>
+  OpTy create(Location location, Args &&...args) {
+    return OpTy(args...);
+  }
+  Location getUnknownLoc() { return Location(); }
+};
+class ImplicitLocOpBuilder : public OpBuilder {
+public:
+  template <typename OpTy, typename... Args>
+  OpTy create(Args &&...args) {
+    return OpTy(args...);
+  }
+};
+struct ModuleOp {
+  ModuleOp() {}
+  static ModuleOp create(OpBuilder &builder, Location location) {
+    return ModuleOp();
+  }
+};
+struct NamedOp {
+  NamedOp(const char* name) {}
+  static NamedOp create(OpBuilder &builder, Location location, const char* name) {
+    return NamedOp(name);
+  }
+};
+} // namespace mlir
+
+void f() {
----------------
jpienaar wrote:

SGTM, yes it turned out if I redo it as an EditGenerator rather than ASTEdit, I can at least warn about macros, so that's all I do when encountering.

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


More information about the cfe-commits mailing list