// RUN: mlir-opt %s -transform-interpreter -verify-diagnostics -split-input-file
// expected-note @below {{associated payload op}}
module attributes {transform.with_named_sequence} {
transform.named_sequence @__transform_main(%arg0: !transform.any_op) {
// expected-remark @below {{extension absent}}
transform.test_check_if_test_extension_present %arg0 : !transform.any_op
transform.test_add_test_extension "A"
// expected-remark @below {{extension present, A}}
transform.test_check_if_test_extension_present %arg0 : !transform.any_op
transform.test_remove_test_extension
// expected-remark @below {{extension absent}}
transform.test_check_if_test_extension_present %arg0 : !transform.any_op
transform.yield
}
}
// -----
// expected-note @below {{associated payload op}}
module attributes {transform.with_named_sequence} {
transform.named_sequence @__transform_main(%arg0: !transform.any_op) {
transform.test_add_test_extension "A"
transform.test_remove_test_extension
transform.test_add_test_extension "B"
// expected-remark @below {{extension present, B}}
transform.test_check_if_test_extension_present %arg0 : !transform.any_op
transform.yield
}
}
// -----
// expected-note @below {{associated payload op}}
module attributes {transform.with_named_sequence} {
transform.named_sequence @__transform_main(%arg0: !transform.any_op) {
transform.test_add_test_extension "A"
// expected-remark @below {{extension present, A}}
transform.test_check_if_test_extension_present %arg0 : !transform.any_op
// expected-note @below {{associated payload op}}
transform.test_remap_operand_to_self %arg0 : (!transform.any_op) -> !transform.any_op
// expected-remark @below {{extension present, A}}
transform.test_check_if_test_extension_present %arg0 : !transform.any_op
transform.yield
}
}
// -----
module attributes {transform.with_named_sequence} {
transform.named_sequence @__transform_main(%arg0: !transform.any_op) {
transform.test_add_test_extension "A"
// This is okay because we are replacing the top-level module operation
// (0 results) with this operation that has _more_ (1) results.
%dummy = transform.test_remap_operand_to_self %arg0 : (!transform.any_op) -> !transform.any_op
transform.yield
}
}
// -----
module attributes {transform.with_named_sequence} {
transform.named_sequence @__transform_main(%arg0: !transform.any_op) {
transform.test_add_test_extension "A"
%dummy = transform.test_remap_operand_to_self %arg0 : (!transform.any_op) -> !transform.any_op
// This is still okay. Even though we are replacing the previous
// operation with (1 result) with this operation that has less (0) results,
// there is no handle to the result, hence no issue with value handle update.
transform.test_remap_operand_to_self %dummy : (!transform.any_op) -> !transform.any_op
transform.yield
}
}
// -----
module attributes {transform.with_named_sequence} {
transform.named_sequence @__transform_main(%arg0: !transform.any_op) {
transform.test_add_test_extension "A"
// expected-error @below {{cannot replace an op with another op producing fewer results while tracking handles}}
%dummy = transform.test_remap_operand_to_self %arg0 : (!transform.any_op) -> !transform.any_op
%valuehandle = transform.get_result %dummy[0] : (!transform.any_op) -> !transform.any_value
transform.test_remap_operand_to_self %dummy : (!transform.any_op) -> ()
transform.yield
}
}
// -----
module attributes {transform.with_named_sequence} {
transform.named_sequence @__transform_main(%arg0: !transform.any_op) {
// expected-error @below {{TestTransformStateExtension missing}}
transform.test_remap_operand_to_self %arg0 : (!transform.any_op) -> !transform.any_op
transform.yield
}
}