tuple_as_element.carbon 3.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  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. var x: {.a: i32, .b: (i32,)} = {.a = 1, .b = (2,)};
  7. var y: {.a: i32, .b: (i32,)} = x;
  8. // CHECK:STDOUT: --- tuple_as_element.carbon
  9. // CHECK:STDOUT:
  10. // CHECK:STDOUT: constants {
  11. // CHECK:STDOUT: %.loc7_27.1: type = tuple_type (type)
  12. // CHECK:STDOUT: %.loc7_27.2: type = tuple_type (i32)
  13. // CHECK:STDOUT: %.loc7_28: type = ptr_type {.a: i32, .b: (i32,)}
  14. // CHECK:STDOUT: }
  15. // CHECK:STDOUT:
  16. // CHECK:STDOUT: file {
  17. // CHECK:STDOUT: %.loc7_27.1: (type,) = tuple_literal (i32)
  18. // CHECK:STDOUT: %.loc7_27.2: type = converted %.loc7_27.1, constants.%.loc7_27.2
  19. // CHECK:STDOUT: %.loc7_28: type = struct_type {.a: i32, .b: (i32,)}
  20. // CHECK:STDOUT: %x.var: ref {.a: i32, .b: (i32,)} = var x
  21. // CHECK:STDOUT: %x: ref {.a: i32, .b: (i32,)} = bind_name x, %x.var
  22. // CHECK:STDOUT: %.loc7_38: i32 = int_literal 1
  23. // CHECK:STDOUT: %.loc7_47: i32 = int_literal 2
  24. // CHECK:STDOUT: %.loc7_49.1: (i32,) = tuple_literal (%.loc7_47)
  25. // CHECK:STDOUT: %.loc7_50.1: {.a: i32, .b: (i32,)} = struct_literal (%.loc7_38, %.loc7_49.1)
  26. // CHECK:STDOUT: %.loc7_50.2: ref i32 = struct_access %x.var, element0
  27. // CHECK:STDOUT: %.loc7_50.3: init i32 = initialize_from %.loc7_38 to %.loc7_50.2
  28. // CHECK:STDOUT: %.loc7_50.4: ref (i32,) = struct_access %x.var, element1
  29. // CHECK:STDOUT: %.loc7_49.2: init (i32,) = tuple_init (%.loc7_47) to %.loc7_50.4
  30. // CHECK:STDOUT: %.loc7_49.3: init (i32,) = converted %.loc7_49.1, %.loc7_49.2
  31. // CHECK:STDOUT: %.loc7_50.5: init (i32,) = initialize_from %.loc7_49.3 to %.loc7_50.4
  32. // CHECK:STDOUT: %.loc7_50.6: init {.a: i32, .b: (i32,)} = struct_init (%.loc7_50.3, %.loc7_50.5) to %x.var
  33. // CHECK:STDOUT: %.loc7_50.7: init {.a: i32, .b: (i32,)} = converted %.loc7_50.1, %.loc7_50.6
  34. // CHECK:STDOUT: assign %x.var, %.loc7_50.7
  35. // CHECK:STDOUT: %.loc8_27: (type,) = tuple_literal (i32)
  36. // CHECK:STDOUT: %.loc7_27.3: type = converted %.loc8_27, constants.%.loc7_27.2
  37. // CHECK:STDOUT: %.loc8_28: type = struct_type {.a: i32, .b: (i32,)}
  38. // CHECK:STDOUT: %y.var: ref {.a: i32, .b: (i32,)} = var y
  39. // CHECK:STDOUT: %y: ref {.a: i32, .b: (i32,)} = bind_name y, %y.var
  40. // CHECK:STDOUT: %x.ref: ref {.a: i32, .b: (i32,)} = name_ref x, %x
  41. // CHECK:STDOUT: %.loc8_32.1: ref i32 = struct_access %x.ref, element0
  42. // CHECK:STDOUT: %.loc8_32.2: i32 = bind_value %.loc8_32.1
  43. // CHECK:STDOUT: %.loc8_32.3: ref i32 = struct_access %y.var, element0
  44. // CHECK:STDOUT: %.loc8_32.4: init i32 = initialize_from %.loc8_32.2 to %.loc8_32.3
  45. // CHECK:STDOUT: %.loc8_32.5: ref (i32,) = struct_access %x.ref, element1
  46. // CHECK:STDOUT: %.loc8_32.6: ref i32 = tuple_access %.loc8_32.5, element0
  47. // CHECK:STDOUT: %.loc8_32.7: i32 = bind_value %.loc8_32.6
  48. // CHECK:STDOUT: %.loc8_32.8: ref (i32,) = struct_access %y.var, element1
  49. // CHECK:STDOUT: %.loc8_32.9: init (i32,) = tuple_init (%.loc8_32.7) to %.loc8_32.8
  50. // CHECK:STDOUT: %.loc8_32.10: init (i32,) = converted %.loc8_32.5, %.loc8_32.9
  51. // CHECK:STDOUT: %.loc8_32.11: init (i32,) = initialize_from %.loc8_32.10 to %.loc8_32.8
  52. // CHECK:STDOUT: %.loc8_32.12: init {.a: i32, .b: (i32,)} = struct_init (%.loc8_32.4, %.loc8_32.11) to %y.var
  53. // CHECK:STDOUT: %.loc8_32.13: init {.a: i32, .b: (i32,)} = converted %x.ref, %.loc8_32.12
  54. // CHECK:STDOUT: assign %y.var, %.loc8_32.13
  55. // CHECK:STDOUT: }
  56. // CHECK:STDOUT: