fixity.carbon 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  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. // RUN: %{carbon-run-parser}
  7. // CHECK:STDOUT: [
  8. // CHECK:STDOUT: {node_index: 64, kind: 'FunctionDefinition', text: '}', subtree_size: 65, children: [
  9. // CHECK:STDOUT: {node_index: 12, kind: 'FunctionDefinitionStart', text: '{', subtree_size: 13, children: [
  10. // CHECK:STDOUT: {node_index: 0, kind: 'FunctionIntroducer', text: 'fn'},
  11. // CHECK:STDOUT: {node_index: 1, kind: 'DeclaredName', text: 'F'},
  12. // CHECK:STDOUT: {node_index: 11, kind: 'ParameterList', text: '(', subtree_size: 10, children: [
  13. // CHECK:STDOUT: {node_index: 5, kind: 'PatternBinding', text: ':', subtree_size: 4, children: [
  14. // CHECK:STDOUT: {node_index: 2, kind: 'DeclaredName', text: 'p'},
  15. // CHECK:STDOUT: {node_index: 4, kind: 'PostfixOperator', text: '*', subtree_size: 2, children: [
  16. // CHECK:STDOUT: {node_index: 3, kind: 'Literal', text: 'i32'}]}]},
  17. // CHECK:STDOUT: {node_index: 6, kind: 'ParameterListComma', text: ','},
  18. // CHECK:STDOUT: {node_index: 9, kind: 'PatternBinding', text: ':', subtree_size: 3, children: [
  19. // CHECK:STDOUT: {node_index: 7, kind: 'DeclaredName', text: 'n'},
  20. // CHECK:STDOUT: {node_index: 8, kind: 'Literal', text: 'i32'}]},
  21. // CHECK:STDOUT: {node_index: 10, kind: 'ParameterListEnd', text: ')'}]}]},
  22. // CHECK:STDOUT: {node_index: 20, kind: 'VariableDeclaration', text: 'var', subtree_size: 8, children: [
  23. // CHECK:STDOUT: {node_index: 16, kind: 'PatternBinding', text: ':', subtree_size: 4, children: [
  24. // CHECK:STDOUT: {node_index: 13, kind: 'DeclaredName', text: 'q'},
  25. // CHECK:STDOUT: {node_index: 15, kind: 'PostfixOperator', text: '*', subtree_size: 2, children: [
  26. // CHECK:STDOUT: {node_index: 14, kind: 'Literal', text: 'i32'}]}]},
  27. // CHECK:STDOUT: {node_index: 18, kind: 'VariableInitializer', text: '=', subtree_size: 2, children: [
  28. // CHECK:STDOUT: {node_index: 17, kind: 'NameReference', text: 'p'}]},
  29. // CHECK:STDOUT: {node_index: 19, kind: 'DeclarationEnd', text: ';'}]},
  30. // CHECK:STDOUT: {node_index: 28, kind: 'VariableDeclaration', text: 'var', subtree_size: 8, children: [
  31. // CHECK:STDOUT: {node_index: 23, kind: 'PatternBinding', text: ':', subtree_size: 3, children: [
  32. // CHECK:STDOUT: {node_index: 21, kind: 'DeclaredName', text: 't'},
  33. // CHECK:STDOUT: {node_index: 22, kind: 'NameReference', text: 'Type'}]},
  34. // CHECK:STDOUT: {node_index: 26, kind: 'VariableInitializer', text: '=', subtree_size: 3, children: [
  35. // CHECK:STDOUT: {node_index: 25, kind: 'PostfixOperator', text: '*', subtree_size: 2, children: [
  36. // CHECK:STDOUT: {node_index: 24, kind: 'Literal', text: 'i32'}]}]},
  37. // CHECK:STDOUT: {node_index: 27, kind: 'DeclarationEnd', text: ';'}]},
  38. // CHECK:STDOUT: {node_index: 34, kind: 'ExpressionStatement', text: ';', subtree_size: 6, children: [
  39. // CHECK:STDOUT: {node_index: 33, kind: 'InfixOperator', text: '=', subtree_size: 5, children: [
  40. // CHECK:STDOUT: {node_index: 29, kind: 'NameReference', text: 't'},
  41. // CHECK:STDOUT: {node_index: 32, kind: 'PostfixOperator', text: '*', subtree_size: 3, children: [
  42. // CHECK:STDOUT: {node_index: 31, kind: 'PostfixOperator', text: '*', subtree_size: 2, children: [
  43. // CHECK:STDOUT: {node_index: 30, kind: 'NameReference', text: 't'}]}]}]}]},
  44. // CHECK:STDOUT: {node_index: 40, kind: 'ExpressionStatement', text: ';', subtree_size: 6, children: [
  45. // CHECK:STDOUT: {node_index: 39, kind: 'InfixOperator', text: '=', subtree_size: 5, children: [
  46. // CHECK:STDOUT: {node_index: 35, kind: 'NameReference', text: 'n'},
  47. // CHECK:STDOUT: {node_index: 38, kind: 'InfixOperator', text: '*', subtree_size: 3, children: [
  48. // CHECK:STDOUT: {node_index: 36, kind: 'NameReference', text: 'n'},
  49. // CHECK:STDOUT: {node_index: 37, kind: 'NameReference', text: 'n'}]}]}]},
  50. // CHECK:STDOUT: {node_index: 47, kind: 'ExpressionStatement', text: ';', subtree_size: 7, children: [
  51. // CHECK:STDOUT: {node_index: 46, kind: 'InfixOperator', text: '=', subtree_size: 6, children: [
  52. // CHECK:STDOUT: {node_index: 41, kind: 'NameReference', text: 'n'},
  53. // CHECK:STDOUT: {node_index: 45, kind: 'InfixOperator', text: '*', subtree_size: 4, children: [
  54. // CHECK:STDOUT: {node_index: 42, kind: 'NameReference', text: 'n'},
  55. // CHECK:STDOUT: {node_index: 44, kind: 'PrefixOperator', text: '*', subtree_size: 2, children: [
  56. // CHECK:STDOUT: {node_index: 43, kind: 'NameReference', text: 'p'}]}]}]}]},
  57. // CHECK:STDOUT: {node_index: 53, kind: 'ExpressionStatement', text: ';', subtree_size: 6, children: [
  58. // CHECK:STDOUT: {node_index: 52, kind: 'InfixOperator', text: '=', subtree_size: 5, children: [
  59. // CHECK:STDOUT: {node_index: 48, kind: 'NameReference', text: 'n'},
  60. // CHECK:STDOUT: {node_index: 51, kind: 'InfixOperator', text: '*', subtree_size: 3, children: [
  61. // CHECK:STDOUT: {node_index: 49, kind: 'NameReference', text: 'n'},
  62. // CHECK:STDOUT: {node_index: 50, kind: 'NameReference', text: 'n'}]}]}]},
  63. // CHECK:STDOUT: {node_index: 63, kind: 'ExpressionStatement', text: ';', subtree_size: 10, children: [
  64. // CHECK:STDOUT: {node_index: 62, kind: 'CallExpression', text: '(', subtree_size: 9, children: [
  65. // CHECK:STDOUT: {node_index: 54, kind: 'NameReference', text: 'G'},
  66. // CHECK:STDOUT: {node_index: 56, kind: 'PostfixOperator', text: '*', subtree_size: 2, children: [
  67. // CHECK:STDOUT: {node_index: 55, kind: 'Literal', text: 'i32'}]},
  68. // CHECK:STDOUT: {node_index: 57, kind: 'CallExpressionComma', text: ','},
  69. // CHECK:STDOUT: {node_index: 60, kind: 'InfixOperator', text: '*', subtree_size: 3, children: [
  70. // CHECK:STDOUT: {node_index: 58, kind: 'NameReference', text: 'n'},
  71. // CHECK:STDOUT: {node_index: 59, kind: 'NameReference', text: 'n'}]},
  72. // CHECK:STDOUT: {node_index: 61, kind: 'CallExpressionEnd', text: ')'}]}]}]},
  73. // CHECK:STDOUT: {node_index: 65, kind: 'FileEnd', text: ''},
  74. // CHECK:STDOUT: ]
  75. fn F(p: i32*, n: i32) {
  76. var q: i32* = p;
  77. var t: Type = i32*;
  78. t = t**;
  79. n = n * n;
  80. n = n * *p;
  81. n = n*n;
  82. G(i32*, n * n);
  83. }