else.carbon 5.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  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: 60, kind: 'FunctionDefinition', text: '}', subtree_size: 61, children: [
  9. // CHECK:STDOUT: {node_index: 4, kind: 'FunctionDefinitionStart', text: '{', subtree_size: 5, 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: 3, kind: 'ParameterList', text: '(', subtree_size: 2, children: [
  13. // CHECK:STDOUT: {node_index: 2, kind: 'ParameterListEnd', text: ')'}]}]},
  14. // CHECK:STDOUT: {node_index: 28, kind: 'IfStatement', text: 'if', subtree_size: 24, children: [
  15. // CHECK:STDOUT: {node_index: 7, kind: 'Condition', text: '(', subtree_size: 3, children: [
  16. // CHECK:STDOUT: {node_index: 5, kind: 'NameReference', text: 'a'},
  17. // CHECK:STDOUT: {node_index: 6, kind: 'ConditionEnd', text: ')'}]},
  18. // CHECK:STDOUT: {node_index: 22, kind: 'CodeBlock', text: '}', subtree_size: 15, children: [
  19. // CHECK:STDOUT: {node_index: 8, kind: 'CodeBlockStart', text: '{'},
  20. // CHECK:STDOUT: {node_index: 21, kind: 'IfStatement', text: 'if', subtree_size: 13, children: [
  21. // CHECK:STDOUT: {node_index: 11, kind: 'Condition', text: '(', subtree_size: 3, children: [
  22. // CHECK:STDOUT: {node_index: 9, kind: 'NameReference', text: 'b'},
  23. // CHECK:STDOUT: {node_index: 10, kind: 'ConditionEnd', text: ')'}]},
  24. // CHECK:STDOUT: {node_index: 15, kind: 'CodeBlock', text: '}', subtree_size: 4, children: [
  25. // CHECK:STDOUT: {node_index: 12, kind: 'CodeBlockStart', text: '{'},
  26. // CHECK:STDOUT: {node_index: 14, kind: 'ExpressionStatement', text: ';', subtree_size: 2, children: [
  27. // CHECK:STDOUT: {node_index: 13, kind: 'NameReference', text: 'c'}]}]},
  28. // CHECK:STDOUT: {node_index: 16, kind: 'IfStatementElse', text: 'else'},
  29. // CHECK:STDOUT: {node_index: 20, kind: 'CodeBlock', text: '}', subtree_size: 4, children: [
  30. // CHECK:STDOUT: {node_index: 17, kind: 'CodeBlockStart', text: '{'},
  31. // CHECK:STDOUT: {node_index: 19, kind: 'ExpressionStatement', text: ';', subtree_size: 2, children: [
  32. // CHECK:STDOUT: {node_index: 18, kind: 'NameReference', text: 'd'}]}]}]}]},
  33. // CHECK:STDOUT: {node_index: 23, kind: 'IfStatementElse', text: 'else'},
  34. // CHECK:STDOUT: {node_index: 27, kind: 'CodeBlock', text: '}', subtree_size: 4, children: [
  35. // CHECK:STDOUT: {node_index: 24, kind: 'CodeBlockStart', text: '{'},
  36. // CHECK:STDOUT: {node_index: 26, kind: 'ExpressionStatement', text: ';', subtree_size: 2, children: [
  37. // CHECK:STDOUT: {node_index: 25, kind: 'NameReference', text: 'e'}]}]}]},
  38. // CHECK:STDOUT: {node_index: 59, kind: 'IfStatement', text: 'if', subtree_size: 31, children: [
  39. // CHECK:STDOUT: {node_index: 31, kind: 'Condition', text: '(', subtree_size: 3, children: [
  40. // CHECK:STDOUT: {node_index: 29, kind: 'NameReference', text: 'x'},
  41. // CHECK:STDOUT: {node_index: 30, kind: 'ConditionEnd', text: ')'}]},
  42. // CHECK:STDOUT: {node_index: 38, kind: 'CodeBlock', text: '}', subtree_size: 7, children: [
  43. // CHECK:STDOUT: {node_index: 32, kind: 'CodeBlockStart', text: '{'},
  44. // CHECK:STDOUT: {node_index: 37, kind: 'ExpressionStatement', text: ';', subtree_size: 5, children: [
  45. // CHECK:STDOUT: {node_index: 36, kind: 'CallExpression', text: '(', subtree_size: 4, children: [
  46. // CHECK:STDOUT: {node_index: 33, kind: 'NameReference', text: 'G'},
  47. // CHECK:STDOUT: {node_index: 34, kind: 'Literal', text: '1'},
  48. // CHECK:STDOUT: {node_index: 35, kind: 'CallExpressionEnd', text: ')'}]}]}]},
  49. // CHECK:STDOUT: {node_index: 39, kind: 'IfStatementElse', text: 'else'},
  50. // CHECK:STDOUT: {node_index: 58, kind: 'IfStatement', text: 'if', subtree_size: 19, children: [
  51. // CHECK:STDOUT: {node_index: 42, kind: 'Condition', text: '(', subtree_size: 3, children: [
  52. // CHECK:STDOUT: {node_index: 40, kind: 'NameReference', text: 'x'},
  53. // CHECK:STDOUT: {node_index: 41, kind: 'ConditionEnd', text: ')'}]},
  54. // CHECK:STDOUT: {node_index: 49, kind: 'CodeBlock', text: '}', subtree_size: 7, children: [
  55. // CHECK:STDOUT: {node_index: 43, kind: 'CodeBlockStart', text: '{'},
  56. // CHECK:STDOUT: {node_index: 48, kind: 'ExpressionStatement', text: ';', subtree_size: 5, children: [
  57. // CHECK:STDOUT: {node_index: 47, kind: 'CallExpression', text: '(', subtree_size: 4, children: [
  58. // CHECK:STDOUT: {node_index: 44, kind: 'NameReference', text: 'G'},
  59. // CHECK:STDOUT: {node_index: 45, kind: 'Literal', text: '2'},
  60. // CHECK:STDOUT: {node_index: 46, kind: 'CallExpressionEnd', text: ')'}]}]}]},
  61. // CHECK:STDOUT: {node_index: 50, kind: 'IfStatementElse', text: 'else'},
  62. // CHECK:STDOUT: {node_index: 57, kind: 'CodeBlock', text: '}', subtree_size: 7, children: [
  63. // CHECK:STDOUT: {node_index: 51, kind: 'CodeBlockStart', text: '{'},
  64. // CHECK:STDOUT: {node_index: 56, kind: 'ExpressionStatement', text: ';', subtree_size: 5, children: [
  65. // CHECK:STDOUT: {node_index: 55, kind: 'CallExpression', text: '(', subtree_size: 4, children: [
  66. // CHECK:STDOUT: {node_index: 52, kind: 'NameReference', text: 'G'},
  67. // CHECK:STDOUT: {node_index: 53, kind: 'Literal', text: '3'},
  68. // CHECK:STDOUT: {node_index: 54, kind: 'CallExpressionEnd', text: ')'}]}]}]}]}]}]},
  69. // CHECK:STDOUT: {node_index: 61, kind: 'FileEnd', text: ''},
  70. // CHECK:STDOUT: ]
  71. fn F() {
  72. if (a) {
  73. if (b) {
  74. c;
  75. } else {
  76. d;
  77. }
  78. } else {
  79. e;
  80. }
  81. if (x) { G(1); }
  82. else if (x) { G(2); }
  83. else { G(3); }
  84. }