precedence_as.carbon 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  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. fn F(n: i32) {
  7. // Type operators and unary operators are lower precedence than `as`.
  8. -n as const i32;
  9. &n as i32*;
  10. // `as` is lower precedence than relational comparisons and logical operators.
  11. if (1 as i32 < 2 as i32 and true as bool and false as bool) {}
  12. }
  13. // CHECK:STDOUT: - filename: precedence_as.carbon
  14. // CHECK:STDOUT: parse_tree: [
  15. // CHECK:STDOUT: {kind: 'FileStart', text: ''},
  16. // CHECK:STDOUT: {kind: 'FunctionIntroducer', text: 'fn'},
  17. // CHECK:STDOUT: {kind: 'Name', text: 'F'},
  18. // CHECK:STDOUT: {kind: 'ParamListStart', text: '('},
  19. // CHECK:STDOUT: {kind: 'Name', text: 'n'},
  20. // CHECK:STDOUT: {kind: 'IntegerTypeLiteral', text: 'i32'},
  21. // CHECK:STDOUT: {kind: 'PatternBinding', text: ':', subtree_size: 3},
  22. // CHECK:STDOUT: {kind: 'ParamList', text: ')', subtree_size: 5},
  23. // CHECK:STDOUT: {kind: 'FunctionDefinitionStart', text: '{', subtree_size: 8},
  24. // CHECK:STDOUT: {kind: 'NameExpr', text: 'n'},
  25. // CHECK:STDOUT: {kind: 'PrefixOperator', text: '-', subtree_size: 2},
  26. // CHECK:STDOUT: {kind: 'IntegerTypeLiteral', text: 'i32'},
  27. // CHECK:STDOUT: {kind: 'PrefixOperator', text: 'const', subtree_size: 2},
  28. // CHECK:STDOUT: {kind: 'InfixOperator', text: 'as', subtree_size: 5},
  29. // CHECK:STDOUT: {kind: 'ExprStatement', text: ';', subtree_size: 6},
  30. // CHECK:STDOUT: {kind: 'NameExpr', text: 'n'},
  31. // CHECK:STDOUT: {kind: 'PrefixOperator', text: '&', subtree_size: 2},
  32. // CHECK:STDOUT: {kind: 'IntegerTypeLiteral', text: 'i32'},
  33. // CHECK:STDOUT: {kind: 'PostfixOperator', text: '*', subtree_size: 2},
  34. // CHECK:STDOUT: {kind: 'InfixOperator', text: 'as', subtree_size: 5},
  35. // CHECK:STDOUT: {kind: 'ExprStatement', text: ';', subtree_size: 6},
  36. // CHECK:STDOUT: {kind: 'IfConditionStart', text: '('},
  37. // CHECK:STDOUT: {kind: 'IntegerLiteral', text: '1'},
  38. // CHECK:STDOUT: {kind: 'IntegerTypeLiteral', text: 'i32'},
  39. // CHECK:STDOUT: {kind: 'InfixOperator', text: 'as', subtree_size: 3},
  40. // CHECK:STDOUT: {kind: 'IntegerLiteral', text: '2'},
  41. // CHECK:STDOUT: {kind: 'IntegerTypeLiteral', text: 'i32'},
  42. // CHECK:STDOUT: {kind: 'InfixOperator', text: 'as', subtree_size: 3},
  43. // CHECK:STDOUT: {kind: 'InfixOperator', text: '<', subtree_size: 7},
  44. // CHECK:STDOUT: {kind: 'ShortCircuitOperand', text: 'and', subtree_size: 8},
  45. // CHECK:STDOUT: {kind: 'BoolLiteralTrue', text: 'true'},
  46. // CHECK:STDOUT: {kind: 'BoolTypeLiteral', text: 'bool'},
  47. // CHECK:STDOUT: {kind: 'InfixOperator', text: 'as', subtree_size: 3},
  48. // CHECK:STDOUT: {kind: 'InfixOperator', text: 'and', subtree_size: 12},
  49. // CHECK:STDOUT: {kind: 'ShortCircuitOperand', text: 'and', subtree_size: 13},
  50. // CHECK:STDOUT: {kind: 'BoolLiteralFalse', text: 'false'},
  51. // CHECK:STDOUT: {kind: 'BoolTypeLiteral', text: 'bool'},
  52. // CHECK:STDOUT: {kind: 'InfixOperator', text: 'as', subtree_size: 3},
  53. // CHECK:STDOUT: {kind: 'InfixOperator', text: 'and', subtree_size: 17},
  54. // CHECK:STDOUT: {kind: 'IfCondition', text: ')', subtree_size: 19},
  55. // CHECK:STDOUT: {kind: 'CodeBlockStart', text: '{'},
  56. // CHECK:STDOUT: {kind: 'CodeBlock', text: '}', subtree_size: 2},
  57. // CHECK:STDOUT: {kind: 'IfStatement', text: 'if', subtree_size: 22},
  58. // CHECK:STDOUT: {kind: 'FunctionDefinition', text: '}', subtree_size: 43},
  59. // CHECK:STDOUT: {kind: 'FileEnd', text: ''},
  60. // CHECK:STDOUT: ]