fail_expr_category.carbon 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  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. fn F() -> [i32; 3];
  7. fn G(b: [i32; 3]) {
  8. // Indexing an array value gives a value.
  9. // CHECK:STDERR: fail_expr_category.carbon:[[@LINE+4]]:18: ERROR: Cannot take the address of non-reference expression.
  10. // CHECK:STDERR: var pb: i32* = &b[0];
  11. // CHECK:STDERR: ^
  12. // CHECK:STDERR:
  13. var pb: i32* = &b[0];
  14. // CHECK:STDERR: fail_expr_category.carbon:[[@LINE+4]]:3: ERROR: Expression is not assignable.
  15. // CHECK:STDERR: b[0] = 4;
  16. // CHECK:STDERR: ^~~~
  17. // CHECK:STDERR:
  18. b[0] = 4;
  19. // Indexing an ephemeral reference (materialized from an initializing
  20. // expression) gives a value.
  21. // CHECK:STDERR: fail_expr_category.carbon:[[@LINE+4]]:18: ERROR: Cannot take the address of non-reference expression.
  22. // CHECK:STDERR: var pf: i32* = &F()[0];
  23. // CHECK:STDERR: ^
  24. // CHECK:STDERR:
  25. var pf: i32* = &F()[0];
  26. // CHECK:STDERR: fail_expr_category.carbon:[[@LINE+3]]:3: ERROR: Expression is not assignable.
  27. // CHECK:STDERR: F()[0] = 4;
  28. // CHECK:STDERR: ^~~~~~
  29. F()[0] = 4;
  30. }
  31. // CHECK:STDOUT: --- fail_expr_category.carbon
  32. // CHECK:STDOUT:
  33. // CHECK:STDOUT: constants {
  34. // CHECK:STDOUT: %.1: i32 = int_literal 3 [template]
  35. // CHECK:STDOUT: %.2: type = array_type %.1, i32 [template]
  36. // CHECK:STDOUT: %.3: type = ptr_type [i32; 3] [template]
  37. // CHECK:STDOUT: %.4: type = ptr_type i32 [template]
  38. // CHECK:STDOUT: %.5: i32 = int_literal 0 [template]
  39. // CHECK:STDOUT: %.6: i32 = int_literal 4 [template]
  40. // CHECK:STDOUT: }
  41. // CHECK:STDOUT:
  42. // CHECK:STDOUT: file {
  43. // CHECK:STDOUT: package: <namespace> = namespace [template] {
  44. // CHECK:STDOUT: .F = %F
  45. // CHECK:STDOUT: .G = %G
  46. // CHECK:STDOUT: }
  47. // CHECK:STDOUT: %F: <function> = fn_decl @F [template] {
  48. // CHECK:STDOUT: %.loc7_17: i32 = int_literal 3 [template = constants.%.1]
  49. // CHECK:STDOUT: %.loc7_18: type = array_type %.loc7_17, i32 [template = constants.%.2]
  50. // CHECK:STDOUT: @F.%return: ref [i32; 3] = var <return slot>
  51. // CHECK:STDOUT: }
  52. // CHECK:STDOUT: %G: <function> = fn_decl @G [template] {
  53. // CHECK:STDOUT: %.loc9_15: i32 = int_literal 3 [template = constants.%.1]
  54. // CHECK:STDOUT: %.loc9_16: type = array_type %.loc9_15, i32 [template = constants.%.2]
  55. // CHECK:STDOUT: %b.loc9_6.1: [i32; 3] = param b
  56. // CHECK:STDOUT: @G.%b: [i32; 3] = bind_name b, %b.loc9_6.1
  57. // CHECK:STDOUT: }
  58. // CHECK:STDOUT: }
  59. // CHECK:STDOUT:
  60. // CHECK:STDOUT: fn @F() -> %return: [i32; 3];
  61. // CHECK:STDOUT:
  62. // CHECK:STDOUT: fn @G(%b: [i32; 3]) {
  63. // CHECK:STDOUT: !entry:
  64. // CHECK:STDOUT: %.loc15_14: type = ptr_type i32 [template = constants.%.4]
  65. // CHECK:STDOUT: %pb.var: ref i32* = var pb
  66. // CHECK:STDOUT: %pb: ref i32* = bind_name pb, %pb.var
  67. // CHECK:STDOUT: %b.ref.loc15: [i32; 3] = name_ref b, %b
  68. // CHECK:STDOUT: %.loc15_21: i32 = int_literal 0 [template = constants.%.5]
  69. // CHECK:STDOUT: %.loc15_22.1: ref [i32; 3] = value_as_ref %b.ref.loc15
  70. // CHECK:STDOUT: %.loc15_22.2: ref i32 = array_index %.loc15_22.1, %.loc15_21
  71. // CHECK:STDOUT: %.loc15_22.3: i32 = bind_value %.loc15_22.2
  72. // CHECK:STDOUT: %.loc15_18: i32* = addr_of <error> [template = <error>]
  73. // CHECK:STDOUT: assign %pb.var, %.loc15_18
  74. // CHECK:STDOUT: %b.ref.loc20: [i32; 3] = name_ref b, %b
  75. // CHECK:STDOUT: %.loc20_5: i32 = int_literal 0 [template = constants.%.5]
  76. // CHECK:STDOUT: %.loc20_6.1: ref [i32; 3] = value_as_ref %b.ref.loc20
  77. // CHECK:STDOUT: %.loc20_6.2: ref i32 = array_index %.loc20_6.1, %.loc20_5
  78. // CHECK:STDOUT: %.loc20_6.3: i32 = bind_value %.loc20_6.2
  79. // CHECK:STDOUT: %.loc20_10: i32 = int_literal 4 [template = constants.%.6]
  80. // CHECK:STDOUT: assign %.loc20_6.3, %.loc20_10
  81. // CHECK:STDOUT: %.loc28_14: type = ptr_type i32 [template = constants.%.4]
  82. // CHECK:STDOUT: %pf.var: ref i32* = var pf
  83. // CHECK:STDOUT: %pf: ref i32* = bind_name pf, %pf.var
  84. // CHECK:STDOUT: %F.ref.loc28: <function> = name_ref F, file.%F [template = file.%F]
  85. // CHECK:STDOUT: %.loc28_20.1: ref [i32; 3] = temporary_storage
  86. // CHECK:STDOUT: %.loc28_20.2: init [i32; 3] = call %F.ref.loc28() to %.loc28_20.1
  87. // CHECK:STDOUT: %.loc28_23: i32 = int_literal 0 [template = constants.%.5]
  88. // CHECK:STDOUT: %.loc28_20.3: ref [i32; 3] = temporary %.loc28_20.1, %.loc28_20.2
  89. // CHECK:STDOUT: %.loc28_24.1: ref i32 = array_index %.loc28_20.3, %.loc28_23
  90. // CHECK:STDOUT: %.loc28_24.2: i32 = bind_value %.loc28_24.1
  91. // CHECK:STDOUT: %.loc28_18: i32* = addr_of <error> [template = <error>]
  92. // CHECK:STDOUT: assign %pf.var, %.loc28_18
  93. // CHECK:STDOUT: %F.ref.loc32: <function> = name_ref F, file.%F [template = file.%F]
  94. // CHECK:STDOUT: %.loc32_4.1: ref [i32; 3] = temporary_storage
  95. // CHECK:STDOUT: %.loc32_4.2: init [i32; 3] = call %F.ref.loc32() to %.loc32_4.1
  96. // CHECK:STDOUT: %.loc32_7: i32 = int_literal 0 [template = constants.%.5]
  97. // CHECK:STDOUT: %.loc32_4.3: ref [i32; 3] = temporary %.loc32_4.1, %.loc32_4.2
  98. // CHECK:STDOUT: %.loc32_8.1: ref i32 = array_index %.loc32_4.3, %.loc32_7
  99. // CHECK:STDOUT: %.loc32_8.2: i32 = bind_value %.loc32_8.1
  100. // CHECK:STDOUT: %.loc32_12: i32 = int_literal 4 [template = constants.%.6]
  101. // CHECK:STDOUT: assign %.loc32_8.2, %.loc32_12
  102. // CHECK:STDOUT: return
  103. // CHECK:STDOUT: }
  104. // CHECK:STDOUT: