fail_abstract.carbon 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  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. abstract class Abstract {
  7. var a: i32;
  8. }
  9. class Derived {
  10. extend base: Abstract;
  11. var d: i32;
  12. }
  13. fn Make() -> Derived {
  14. // TODO: This should be valid, and should construct an instance of `partial Abstract` as the base.
  15. // CHECK:STDERR: fail_abstract.carbon:[[@LINE+3]]:19: ERROR: Cannot construct instance of abstract class. Consider using `partial Abstract` instead.
  16. // CHECK:STDERR: return {.base = {.a = 1}, .d = 7};
  17. // CHECK:STDERR: ^~~~~~~~
  18. return {.base = {.a = 1}, .d = 7};
  19. }
  20. fn Access(d: Derived) -> (i32, i32) {
  21. return (d.d, d.base.a);
  22. }
  23. // CHECK:STDOUT: --- fail_abstract.carbon
  24. // CHECK:STDOUT:
  25. // CHECK:STDOUT: constants {
  26. // CHECK:STDOUT: %.loc9: type = struct_type {.a: i32}
  27. // CHECK:STDOUT: %.loc7: type = ptr_type {.a: i32}
  28. // CHECK:STDOUT: %.loc15_1.1: type = struct_type {.base: Abstract, .d: i32}
  29. // CHECK:STDOUT: %.loc15_1.2: type = struct_type {.base: {.a: i32}*, .d: i32}
  30. // CHECK:STDOUT: %.loc15_1.3: type = ptr_type {.base: {.a: i32}*, .d: i32}
  31. // CHECK:STDOUT: %.loc11: type = ptr_type {.base: Abstract, .d: i32}
  32. // CHECK:STDOUT: %.loc22: type = struct_type {.base: {.a: i32}, .d: i32}
  33. // CHECK:STDOUT: %.loc25_35.1: type = tuple_type (type, type)
  34. // CHECK:STDOUT: %.loc25_35.2: type = tuple_type (i32, i32)
  35. // CHECK:STDOUT: %.loc25_35.3: type = ptr_type (i32, i32)
  36. // CHECK:STDOUT: }
  37. // CHECK:STDOUT:
  38. // CHECK:STDOUT: file {
  39. // CHECK:STDOUT: package: <namespace> = namespace {.Abstract = %Abstract.decl, .Derived = %Derived.decl, .Make = %Make, .Access = %Access}
  40. // CHECK:STDOUT: %Abstract.decl = class_decl @Abstract, ()
  41. // CHECK:STDOUT: %Abstract: type = class_type @Abstract
  42. // CHECK:STDOUT: %Derived.decl = class_decl @Derived, ()
  43. // CHECK:STDOUT: %Derived: type = class_type @Derived
  44. // CHECK:STDOUT: %Make: <function> = fn_decl @Make
  45. // CHECK:STDOUT: %Access: <function> = fn_decl @Access
  46. // CHECK:STDOUT: }
  47. // CHECK:STDOUT:
  48. // CHECK:STDOUT: class @Abstract {
  49. // CHECK:STDOUT: %.loc8_8.1: type = unbound_element_type Abstract, i32
  50. // CHECK:STDOUT: %.loc8_8.2: <unbound element of class Abstract> = field_decl a, element0
  51. // CHECK:STDOUT: %a: <unbound element of class Abstract> = bind_name a, %.loc8_8.2
  52. // CHECK:STDOUT:
  53. // CHECK:STDOUT: !members:
  54. // CHECK:STDOUT: .a = %a
  55. // CHECK:STDOUT: }
  56. // CHECK:STDOUT:
  57. // CHECK:STDOUT: class @Derived {
  58. // CHECK:STDOUT: %Abstract.ref: type = name_ref Abstract, file.%Abstract
  59. // CHECK:STDOUT: %.loc12_24.1: type = unbound_element_type Derived, Abstract
  60. // CHECK:STDOUT: %.loc12_24.2: <unbound element of class Derived> = base_decl Abstract, element0
  61. // CHECK:STDOUT: %.loc14_8.1: type = unbound_element_type Derived, i32
  62. // CHECK:STDOUT: %.loc14_8.2: <unbound element of class Derived> = field_decl d, element1
  63. // CHECK:STDOUT: %d: <unbound element of class Derived> = bind_name d, %.loc14_8.2
  64. // CHECK:STDOUT:
  65. // CHECK:STDOUT: !members:
  66. // CHECK:STDOUT: .base = %.loc12_24.2
  67. // CHECK:STDOUT: .d = %d
  68. // CHECK:STDOUT: }
  69. // CHECK:STDOUT:
  70. // CHECK:STDOUT: fn @Make() -> %return: Derived {
  71. // CHECK:STDOUT: !entry:
  72. // CHECK:STDOUT: %.loc22_25: i32 = int_literal 1
  73. // CHECK:STDOUT: %.loc22_26: {.a: i32} = struct_literal (%.loc22_25)
  74. // CHECK:STDOUT: %.loc22_34: i32 = int_literal 7
  75. // CHECK:STDOUT: %.loc22_35: {.base: {.a: i32}, .d: i32} = struct_literal (%.loc22_26, %.loc22_34)
  76. // CHECK:STDOUT: return <error>
  77. // CHECK:STDOUT: }
  78. // CHECK:STDOUT:
  79. // CHECK:STDOUT: fn @Access(%d: Derived) -> %return: (i32, i32) {
  80. // CHECK:STDOUT: !entry:
  81. // CHECK:STDOUT: %d.ref.loc26_11: Derived = name_ref d, %d
  82. // CHECK:STDOUT: %.loc26_12.1: ref i32 = class_element_access %d.ref.loc26_11, element1
  83. // CHECK:STDOUT: %.loc26_12.2: i32 = bind_value %.loc26_12.1
  84. // CHECK:STDOUT: %d.ref.loc26_16: Derived = name_ref d, %d
  85. // CHECK:STDOUT: %.loc26_17.1: ref Abstract = class_element_access %d.ref.loc26_16, element0
  86. // CHECK:STDOUT: %.loc26_17.2: Abstract = bind_value %.loc26_17.1
  87. // CHECK:STDOUT: %.loc26_22.1: ref i32 = class_element_access %.loc26_17.2, element0
  88. // CHECK:STDOUT: %.loc26_22.2: i32 = bind_value %.loc26_22.1
  89. // CHECK:STDOUT: %.loc26_24.1: (i32, i32) = tuple_literal (%.loc26_12.2, %.loc26_22.2)
  90. // CHECK:STDOUT: %.loc26_24.2: ref i32 = tuple_access %return, element0
  91. // CHECK:STDOUT: %.loc26_24.3: init i32 = initialize_from %.loc26_12.2 to %.loc26_24.2
  92. // CHECK:STDOUT: %.loc26_24.4: ref i32 = tuple_access %return, element1
  93. // CHECK:STDOUT: %.loc26_24.5: init i32 = initialize_from %.loc26_22.2 to %.loc26_24.4
  94. // CHECK:STDOUT: %.loc26_24.6: init (i32, i32) = tuple_init (%.loc26_24.3, %.loc26_24.5) to %return
  95. // CHECK:STDOUT: %.loc26_24.7: init (i32, i32) = converted %.loc26_24.1, %.loc26_24.6
  96. // CHECK:STDOUT: return %.loc26_24.7
  97. // CHECK:STDOUT: }
  98. // CHECK:STDOUT: