set(MLIR_BINARY_DIR ${CMAKE_BINARY_DIR})

set(LLVM_TARGET_DEFINITIONS ProtonOps.td)
mlir_tablegen(Dialect.h.inc -gen-dialect-decls -dialect=proton)
mlir_tablegen(Dialect.cpp.inc -gen-dialect-defs -dialect=proton)
mlir_tablegen(OpsConversions.inc -gen-llvmir-conversions)
mlir_tablegen(Ops.h.inc -gen-op-decls)
mlir_tablegen(Ops.cpp.inc -gen-op-defs)
mlir_tablegen(OpsEnums.h.inc -gen-enum-decls)
mlir_tablegen(OpsEnums.cpp.inc -gen-enum-defs)
add_mlir_doc(ProtonDialect ProtonDialect dialects/ -gen-dialect-doc)
add_mlir_doc(ProtonOps ProtonOps dialects/ -gen-op-doc)
add_public_tablegen_target(ProtonTableGen)

set(LLVM_TARGET_DEFINITIONS ProtonAttrDefs.td)
mlir_tablegen(ProtonAttrDefs.h.inc -gen-attrdef-decls)
mlir_tablegen(ProtonAttrDefs.cpp.inc -gen-attrdef-defs)
add_public_tablegen_target(ProtonAttrDefsIncGen)
