fail_rewrite.carbon 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. // Part of the Carbon Language project, under the Apache License v2.0 with LLVM
  2. // Exceptions. See /LICENSE for license information.
  3. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  4. //
  5. // AUTOUPDATE
  6. // TIP: To test this file alone, run:
  7. // TIP: bazel test //toolchain/testing:file_test --test_arg=--file_tests=toolchain/parse/testdata/where_expr/fail_rewrite.carbon
  8. // TIP: To dump output, run:
  9. // TIP: bazel run //toolchain/testing:file_test -- --dump_output --file_tests=toolchain/parse/testdata/where_expr/fail_rewrite.carbon
  10. // Tests for reporting errors when a rewrite requirement doesn't follow
  11. // `where .designator = rewrite`.
  12. // --- fail_not_designator.carbon
  13. // CHECK:STDERR: fail_not_designator.carbon:[[@LINE+4]]:37: error: requirement can only use `=` after `.member` designator [RequirementEqualAfterNonDesignator]
  14. // CHECK:STDERR: fn NotDesignator(T:! type where i32 = .U);
  15. // CHECK:STDERR: ^
  16. // CHECK:STDERR:
  17. fn NotDesignator(T:! type where i32 = .U);
  18. // --- fail_designator_in_parens.carbon
  19. // CHECK:STDERR: fail_designator_in_parens.carbon:[[@LINE+4]]:40: error: requirement can only use `=` after `.member` designator [RequirementEqualAfterNonDesignator]
  20. // CHECK:STDERR: fn DesignatorInParens(V:! I where (.J) = bool);
  21. // CHECK:STDERR: ^
  22. // CHECK:STDERR:
  23. fn DesignatorInParens(V:! I where (.J) = bool);
  24. // --- fail_dot_self.carbon
  25. // CHECK:STDERR: fail_dot_self.carbon:[[@LINE+4]]:30: error: requirement can only use `=` after `.member` designator [RequirementEqualAfterNonDesignator]
  26. // CHECK:STDERR: fn DotSelf(W:! K where .Self = f32);
  27. // CHECK:STDERR: ^
  28. // CHECK:STDERR:
  29. fn DotSelf(W:! K where .Self = f32);
  30. // --- fail_dot_keyword.carbon
  31. // CHECK:STDERR: fail_dot_keyword.carbon:[[@LINE+4]]:28: error: expected identifier or `Self` after `.` [ExpectedIdentifierOrSelfAfterPeriod]
  32. // CHECK:STDERR: fn DotKeyword(W:! K where .and = u8);
  33. // CHECK:STDERR: ^~~
  34. // CHECK:STDERR:
  35. fn DotKeyword(W:! K where .and = u8);
  36. // --- fail_postfix_after_designator.carbon
  37. // CHECK:STDERR: fail_postfix_after_designator.carbon:[[@LINE+4]]:43: error: requirement can only use `=` after `.member` designator [RequirementEqualAfterNonDesignator]
  38. // CHECK:STDERR: fn PostfixAfterDesignator(X:! L where .M* = u64*);
  39. // CHECK:STDERR: ^
  40. // CHECK:STDERR:
  41. fn PostfixAfterDesignator(X:! L where .M* = u64*);
  42. // --- fail_binary_op_after_designator.carbon
  43. // CHECK:STDERR: fail_binary_op_after_designator.carbon:[[@LINE+4]]:48: error: requirement can only use `=` after `.member` designator [RequirementEqualAfterNonDesignator]
  44. // CHECK:STDERR: fn BinaryOpAfterDesignator(Y:! N where .O + .P = {});
  45. // CHECK:STDERR: ^
  46. // CHECK:STDERR:
  47. fn BinaryOpAfterDesignator(Y:! N where .O + .P = {});
  48. // --- fail_after_and.carbon
  49. // CHECK:STDERR: fail_after_and.carbon:[[@LINE+4]]:43: error: requirement can only use `=` after `.member` designator [RequirementEqualAfterNonDesignator]
  50. // CHECK:STDERR: fn AfterAnd(Z:! Q where .R impls S and () = .A);
  51. // CHECK:STDERR: ^
  52. // CHECK:STDERR:
  53. fn AfterAnd(Z:! Q where .R impls S and () = .A);
  54. // CHECK:STDOUT: - filename: fail_not_designator.carbon
  55. // CHECK:STDOUT: parse_tree: [
  56. // CHECK:STDOUT: {kind: 'FileStart', text: ''},
  57. // CHECK:STDOUT: {kind: 'FunctionIntroducer', text: 'fn'},
  58. // CHECK:STDOUT: {kind: 'IdentifierNameBeforeParams', text: 'NotDesignator'},
  59. // CHECK:STDOUT: {kind: 'ExplicitParamListStart', text: '('},
  60. // CHECK:STDOUT: {kind: 'IdentifierNameNotBeforeParams', text: 'T'},
  61. // CHECK:STDOUT: {kind: 'TypeTypeLiteral', text: 'type'},
  62. // CHECK:STDOUT: {kind: 'WhereOperand', text: 'where', subtree_size: 2},
  63. // CHECK:STDOUT: {kind: 'IntTypeLiteral', text: 'i32'},
  64. // CHECK:STDOUT: {kind: 'WhereExpr', text: 'where', has_error: yes, subtree_size: 4},
  65. // CHECK:STDOUT: {kind: 'CompileTimeBindingPattern', text: ':!', has_error: yes, subtree_size: 6},
  66. // CHECK:STDOUT: {kind: 'ExplicitParamList', text: ')', has_error: yes, subtree_size: 8},
  67. // CHECK:STDOUT: {kind: 'FunctionDecl', text: ';', subtree_size: 11},
  68. // CHECK:STDOUT: {kind: 'FileEnd', text: ''},
  69. // CHECK:STDOUT: ]
  70. // CHECK:STDOUT: - filename: fail_designator_in_parens.carbon
  71. // CHECK:STDOUT: parse_tree: [
  72. // CHECK:STDOUT: {kind: 'FileStart', text: ''},
  73. // CHECK:STDOUT: {kind: 'FunctionIntroducer', text: 'fn'},
  74. // CHECK:STDOUT: {kind: 'IdentifierNameBeforeParams', text: 'DesignatorInParens'},
  75. // CHECK:STDOUT: {kind: 'ExplicitParamListStart', text: '('},
  76. // CHECK:STDOUT: {kind: 'IdentifierNameNotBeforeParams', text: 'V'},
  77. // CHECK:STDOUT: {kind: 'IdentifierNameExpr', text: 'I'},
  78. // CHECK:STDOUT: {kind: 'WhereOperand', text: 'where', subtree_size: 2},
  79. // CHECK:STDOUT: {kind: 'ParenExprStart', text: '('},
  80. // CHECK:STDOUT: {kind: 'IdentifierNameNotBeforeParams', text: 'J'},
  81. // CHECK:STDOUT: {kind: 'DesignatorExpr', text: '.', subtree_size: 2},
  82. // CHECK:STDOUT: {kind: 'ParenExpr', text: ')', subtree_size: 4},
  83. // CHECK:STDOUT: {kind: 'WhereExpr', text: 'where', has_error: yes, subtree_size: 7},
  84. // CHECK:STDOUT: {kind: 'CompileTimeBindingPattern', text: ':!', has_error: yes, subtree_size: 9},
  85. // CHECK:STDOUT: {kind: 'ExplicitParamList', text: ')', has_error: yes, subtree_size: 11},
  86. // CHECK:STDOUT: {kind: 'FunctionDecl', text: ';', subtree_size: 14},
  87. // CHECK:STDOUT: {kind: 'FileEnd', text: ''},
  88. // CHECK:STDOUT: ]
  89. // CHECK:STDOUT: - filename: fail_dot_self.carbon
  90. // CHECK:STDOUT: parse_tree: [
  91. // CHECK:STDOUT: {kind: 'FileStart', text: ''},
  92. // CHECK:STDOUT: {kind: 'FunctionIntroducer', text: 'fn'},
  93. // CHECK:STDOUT: {kind: 'IdentifierNameBeforeParams', text: 'DotSelf'},
  94. // CHECK:STDOUT: {kind: 'ExplicitParamListStart', text: '('},
  95. // CHECK:STDOUT: {kind: 'IdentifierNameNotBeforeParams', text: 'W'},
  96. // CHECK:STDOUT: {kind: 'IdentifierNameExpr', text: 'K'},
  97. // CHECK:STDOUT: {kind: 'WhereOperand', text: 'where', subtree_size: 2},
  98. // CHECK:STDOUT: {kind: 'SelfTypeName', text: 'Self'},
  99. // CHECK:STDOUT: {kind: 'DesignatorExpr', text: '.', subtree_size: 2},
  100. // CHECK:STDOUT: {kind: 'WhereExpr', text: 'where', has_error: yes, subtree_size: 5},
  101. // CHECK:STDOUT: {kind: 'CompileTimeBindingPattern', text: ':!', has_error: yes, subtree_size: 7},
  102. // CHECK:STDOUT: {kind: 'ExplicitParamList', text: ')', has_error: yes, subtree_size: 9},
  103. // CHECK:STDOUT: {kind: 'FunctionDecl', text: ';', subtree_size: 12},
  104. // CHECK:STDOUT: {kind: 'FileEnd', text: ''},
  105. // CHECK:STDOUT: ]
  106. // CHECK:STDOUT: - filename: fail_dot_keyword.carbon
  107. // CHECK:STDOUT: parse_tree: [
  108. // CHECK:STDOUT: {kind: 'FileStart', text: ''},
  109. // CHECK:STDOUT: {kind: 'FunctionIntroducer', text: 'fn'},
  110. // CHECK:STDOUT: {kind: 'IdentifierNameBeforeParams', text: 'DotKeyword'},
  111. // CHECK:STDOUT: {kind: 'ExplicitParamListStart', text: '('},
  112. // CHECK:STDOUT: {kind: 'IdentifierNameNotBeforeParams', text: 'W'},
  113. // CHECK:STDOUT: {kind: 'IdentifierNameExpr', text: 'K'},
  114. // CHECK:STDOUT: {kind: 'WhereOperand', text: 'where', subtree_size: 2},
  115. // CHECK:STDOUT: {kind: 'IdentifierNameNotBeforeParams', text: 'and', has_error: yes},
  116. // CHECK:STDOUT: {kind: 'DesignatorExpr', text: '.', has_error: yes, subtree_size: 2},
  117. // CHECK:STDOUT: {kind: 'WhereExpr', text: 'where', has_error: yes, subtree_size: 5},
  118. // CHECK:STDOUT: {kind: 'CompileTimeBindingPattern', text: ':!', has_error: yes, subtree_size: 7},
  119. // CHECK:STDOUT: {kind: 'ExplicitParamList', text: ')', has_error: yes, subtree_size: 9},
  120. // CHECK:STDOUT: {kind: 'FunctionDecl', text: ';', subtree_size: 12},
  121. // CHECK:STDOUT: {kind: 'FileEnd', text: ''},
  122. // CHECK:STDOUT: ]
  123. // CHECK:STDOUT: - filename: fail_postfix_after_designator.carbon
  124. // CHECK:STDOUT: parse_tree: [
  125. // CHECK:STDOUT: {kind: 'FileStart', text: ''},
  126. // CHECK:STDOUT: {kind: 'FunctionIntroducer', text: 'fn'},
  127. // CHECK:STDOUT: {kind: 'IdentifierNameBeforeParams', text: 'PostfixAfterDesignator'},
  128. // CHECK:STDOUT: {kind: 'ExplicitParamListStart', text: '('},
  129. // CHECK:STDOUT: {kind: 'IdentifierNameNotBeforeParams', text: 'X'},
  130. // CHECK:STDOUT: {kind: 'IdentifierNameExpr', text: 'L'},
  131. // CHECK:STDOUT: {kind: 'WhereOperand', text: 'where', subtree_size: 2},
  132. // CHECK:STDOUT: {kind: 'IdentifierNameNotBeforeParams', text: 'M'},
  133. // CHECK:STDOUT: {kind: 'DesignatorExpr', text: '.', subtree_size: 2},
  134. // CHECK:STDOUT: {kind: 'PostfixOperatorStar', text: '*', subtree_size: 3},
  135. // CHECK:STDOUT: {kind: 'WhereExpr', text: 'where', has_error: yes, subtree_size: 6},
  136. // CHECK:STDOUT: {kind: 'CompileTimeBindingPattern', text: ':!', has_error: yes, subtree_size: 8},
  137. // CHECK:STDOUT: {kind: 'ExplicitParamList', text: ')', has_error: yes, subtree_size: 10},
  138. // CHECK:STDOUT: {kind: 'FunctionDecl', text: ';', subtree_size: 13},
  139. // CHECK:STDOUT: {kind: 'FileEnd', text: ''},
  140. // CHECK:STDOUT: ]
  141. // CHECK:STDOUT: - filename: fail_binary_op_after_designator.carbon
  142. // CHECK:STDOUT: parse_tree: [
  143. // CHECK:STDOUT: {kind: 'FileStart', text: ''},
  144. // CHECK:STDOUT: {kind: 'FunctionIntroducer', text: 'fn'},
  145. // CHECK:STDOUT: {kind: 'IdentifierNameBeforeParams', text: 'BinaryOpAfterDesignator'},
  146. // CHECK:STDOUT: {kind: 'ExplicitParamListStart', text: '('},
  147. // CHECK:STDOUT: {kind: 'IdentifierNameNotBeforeParams', text: 'Y'},
  148. // CHECK:STDOUT: {kind: 'IdentifierNameExpr', text: 'N'},
  149. // CHECK:STDOUT: {kind: 'WhereOperand', text: 'where', subtree_size: 2},
  150. // CHECK:STDOUT: {kind: 'IdentifierNameNotBeforeParams', text: 'O'},
  151. // CHECK:STDOUT: {kind: 'DesignatorExpr', text: '.', subtree_size: 2},
  152. // CHECK:STDOUT: {kind: 'IdentifierNameNotBeforeParams', text: 'P'},
  153. // CHECK:STDOUT: {kind: 'DesignatorExpr', text: '.', subtree_size: 2},
  154. // CHECK:STDOUT: {kind: 'InfixOperatorPlus', text: '+', subtree_size: 5},
  155. // CHECK:STDOUT: {kind: 'WhereExpr', text: 'where', has_error: yes, subtree_size: 8},
  156. // CHECK:STDOUT: {kind: 'CompileTimeBindingPattern', text: ':!', has_error: yes, subtree_size: 10},
  157. // CHECK:STDOUT: {kind: 'ExplicitParamList', text: ')', has_error: yes, subtree_size: 12},
  158. // CHECK:STDOUT: {kind: 'FunctionDecl', text: ';', subtree_size: 15},
  159. // CHECK:STDOUT: {kind: 'FileEnd', text: ''},
  160. // CHECK:STDOUT: ]
  161. // CHECK:STDOUT: - filename: fail_after_and.carbon
  162. // CHECK:STDOUT: parse_tree: [
  163. // CHECK:STDOUT: {kind: 'FileStart', text: ''},
  164. // CHECK:STDOUT: {kind: 'FunctionIntroducer', text: 'fn'},
  165. // CHECK:STDOUT: {kind: 'IdentifierNameBeforeParams', text: 'AfterAnd'},
  166. // CHECK:STDOUT: {kind: 'ExplicitParamListStart', text: '('},
  167. // CHECK:STDOUT: {kind: 'IdentifierNameNotBeforeParams', text: 'Z'},
  168. // CHECK:STDOUT: {kind: 'IdentifierNameExpr', text: 'Q'},
  169. // CHECK:STDOUT: {kind: 'WhereOperand', text: 'where', subtree_size: 2},
  170. // CHECK:STDOUT: {kind: 'IdentifierNameNotBeforeParams', text: 'R'},
  171. // CHECK:STDOUT: {kind: 'DesignatorExpr', text: '.', subtree_size: 2},
  172. // CHECK:STDOUT: {kind: 'IdentifierNameExpr', text: 'S'},
  173. // CHECK:STDOUT: {kind: 'RequirementImpls', text: 'impls', subtree_size: 4},
  174. // CHECK:STDOUT: {kind: 'RequirementAnd', text: 'and'},
  175. // CHECK:STDOUT: {kind: 'TupleLiteralStart', text: '('},
  176. // CHECK:STDOUT: {kind: 'TupleLiteral', text: ')', subtree_size: 2},
  177. // CHECK:STDOUT: {kind: 'WhereExpr', text: 'where', has_error: yes, subtree_size: 10},
  178. // CHECK:STDOUT: {kind: 'CompileTimeBindingPattern', text: ':!', has_error: yes, subtree_size: 12},
  179. // CHECK:STDOUT: {kind: 'ExplicitParamList', text: ')', has_error: yes, subtree_size: 14},
  180. // CHECK:STDOUT: {kind: 'FunctionDecl', text: ';', subtree_size: 17},
  181. // CHECK:STDOUT: {kind: 'FileEnd', text: ''},
  182. // CHECK:STDOUT: ]