fail_invalid_base.carbon 2.5 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. // TODO: The errors here are in bad locations. We should build a SemIR
  7. // representation for a reference to a name so that we can track the location
  8. // properly.
  9. namespace N;
  10. // CHECK:STDERR: fail_invalid_base.carbon:[[@LINE+3]]:14: ERROR: Expression cannot be used as a value.
  11. // CHECK:STDERR: var a: i32 = N[0];
  12. // CHECK:STDERR: ^
  13. var a: i32 = N[0];
  14. fn F();
  15. // CHECK:STDERR: fail_invalid_base.carbon:[[@LINE+3]]:14: ERROR: Expression cannot be used as a value.
  16. // CHECK:STDERR: var b: i32 = F[1];
  17. // CHECK:STDERR: ^
  18. var b: i32 = F[1];
  19. // CHECK:STDERR: fail_invalid_base.carbon:[[@LINE+3]]:32: ERROR: `{.a: i32, .b: i32}` does not support indexing.
  20. // CHECK:STDERR: var c: i32 = {.a = 1, .b = 2}[0];
  21. // CHECK:STDERR: ^
  22. var c: i32 = {.a = 1, .b = 2}[0];
  23. // CHECK:STDERR: fail_invalid_base.carbon:[[@LINE+3]]:34: ERROR: `type` does not support indexing.
  24. // CHECK:STDERR: var d: i32 = {.a: i32, .b: i32}[0];
  25. // CHECK:STDERR: ^
  26. var d: i32 = {.a: i32, .b: i32}[0];
  27. // CHECK:STDOUT: file "fail_invalid_base.carbon" {
  28. // CHECK:STDOUT: %.loc11: <namespace> = namespace {}
  29. // CHECK:STDOUT: %a: ref i32 = var "a"
  30. // CHECK:STDOUT: %N.ref: <namespace> = name_reference "N", %.loc11
  31. // CHECK:STDOUT: %.loc15: i32 = int_literal 0
  32. // CHECK:STDOUT: assign %a, <error>
  33. // CHECK:STDOUT: %F: <function> = fn_decl @F
  34. // CHECK:STDOUT: %b: ref i32 = var "b"
  35. // CHECK:STDOUT: %F.ref: <function> = name_reference "F", %F
  36. // CHECK:STDOUT: %.loc21: i32 = int_literal 1
  37. // CHECK:STDOUT: assign %b, <error>
  38. // CHECK:STDOUT: %c: ref i32 = var "c"
  39. // CHECK:STDOUT: %.loc26_20: i32 = int_literal 1
  40. // CHECK:STDOUT: %.loc26_28: i32 = int_literal 2
  41. // CHECK:STDOUT: %.loc26_29.1: type = struct_type {.a: i32, .b: i32}
  42. // CHECK:STDOUT: %.loc26_29.2: {.a: i32, .b: i32} = struct_literal (%.loc26_20, %.loc26_28)
  43. // CHECK:STDOUT: %.loc26_31: i32 = int_literal 0
  44. // CHECK:STDOUT: %.loc26_29.3: {.a: i32, .b: i32} = struct_value %.loc26_29.2, (%.loc26_20, %.loc26_28)
  45. // CHECK:STDOUT: assign %c, <error>
  46. // CHECK:STDOUT: %d: ref i32 = var "d"
  47. // CHECK:STDOUT: %.loc31_31: type = struct_type {.a: i32, .b: i32}
  48. // CHECK:STDOUT: %.loc31_33: i32 = int_literal 0
  49. // CHECK:STDOUT: assign %d, <error>
  50. // CHECK:STDOUT: }
  51. // CHECK:STDOUT:
  52. // CHECK:STDOUT: fn @F();