fixity_with_assign.carbon 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  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: {kind: 'FunctionIntroducer', text: 'fn'},
  9. // CHECK:STDOUT: {kind: 'DeclaredName', text: 'F'},
  10. // CHECK:STDOUT: {kind: 'ParameterListStart', text: '('},
  11. // CHECK:STDOUT: {kind: 'ParameterList', text: ')', subtree_size: 2},
  12. // CHECK:STDOUT: {kind: 'FunctionDefinitionStart', text: '{', subtree_size: 5},
  13. // CHECK:STDOUT: {kind: 'NameReference', text: 't'},
  14. // CHECK:STDOUT: {kind: 'NameReference', text: 't'},
  15. // CHECK:STDOUT: {kind: 'PostfixOperator', text: '*', subtree_size: 2},
  16. // CHECK:STDOUT: {kind: 'PostfixOperator', text: '*', subtree_size: 3},
  17. // CHECK:STDOUT: {kind: 'InfixOperator', text: '=', subtree_size: 5},
  18. // CHECK:STDOUT: {kind: 'ExpressionStatement', text: ';', subtree_size: 6},
  19. // CHECK:STDOUT: {kind: 'NameReference', text: 'n'},
  20. // CHECK:STDOUT: {kind: 'NameReference', text: 'n'},
  21. // CHECK:STDOUT: {kind: 'NameReference', text: 'n'},
  22. // CHECK:STDOUT: {kind: 'InfixOperator', text: '*', subtree_size: 3},
  23. // CHECK:STDOUT: {kind: 'InfixOperator', text: '=', subtree_size: 5},
  24. // CHECK:STDOUT: {kind: 'ExpressionStatement', text: ';', subtree_size: 6},
  25. // CHECK:STDOUT: {kind: 'NameReference', text: 'n'},
  26. // CHECK:STDOUT: {kind: 'NameReference', text: 'n'},
  27. // CHECK:STDOUT: {kind: 'NameReference', text: 'p'},
  28. // CHECK:STDOUT: {kind: 'PrefixOperator', text: '*', subtree_size: 2},
  29. // CHECK:STDOUT: {kind: 'InfixOperator', text: '*', subtree_size: 4},
  30. // CHECK:STDOUT: {kind: 'InfixOperator', text: '=', subtree_size: 6},
  31. // CHECK:STDOUT: {kind: 'ExpressionStatement', text: ';', subtree_size: 7},
  32. // CHECK:STDOUT: {kind: 'NameReference', text: 'n'},
  33. // CHECK:STDOUT: {kind: 'NameReference', text: 'n'},
  34. // CHECK:STDOUT: {kind: 'NameReference', text: 'n'},
  35. // CHECK:STDOUT: {kind: 'InfixOperator', text: '*', subtree_size: 3},
  36. // CHECK:STDOUT: {kind: 'InfixOperator', text: '=', subtree_size: 5},
  37. // CHECK:STDOUT: {kind: 'ExpressionStatement', text: ';', subtree_size: 6},
  38. // CHECK:STDOUT: {kind: 'FunctionDefinition', text: '}', subtree_size: 31},
  39. // CHECK:STDOUT: {kind: 'FileEnd', text: ''},
  40. // CHECK:STDOUT: ]
  41. fn F() {
  42. t = t**;
  43. n = n * n;
  44. n = n * *p;
  45. n = n*n;
  46. }