import.carbon 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  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. // TODO: Add ranges and switch to "--dump-sem-ir-ranges=only".
  6. // EXTRA-ARGS: --no-prelude-import --dump-sem-ir-ranges=if-present
  7. //
  8. // AUTOUPDATE
  9. // TIP: To test this file alone, run:
  10. // TIP: bazel test //toolchain/testing:file_test --test_arg=--file_tests=toolchain/check/testdata/var/import.carbon
  11. // TIP: To dump output, run:
  12. // TIP: bazel run //toolchain/testing:file_test -- --dump_output --file_tests=toolchain/check/testdata/var/import.carbon
  13. // --- implicit.carbon
  14. package Implicit;
  15. var a_ref: () = ();
  16. // --- implicit.impl.carbon
  17. impl package Implicit;
  18. var a: () = a_ref;
  19. // CHECK:STDOUT: --- implicit.carbon
  20. // CHECK:STDOUT:
  21. // CHECK:STDOUT: constants {
  22. // CHECK:STDOUT: %empty_tuple.type: type = tuple_type () [concrete]
  23. // CHECK:STDOUT: %pattern_type: type = pattern_type %empty_tuple.type [concrete]
  24. // CHECK:STDOUT: %empty_tuple: %empty_tuple.type = tuple_value () [concrete]
  25. // CHECK:STDOUT: }
  26. // CHECK:STDOUT:
  27. // CHECK:STDOUT: file {
  28. // CHECK:STDOUT: package: <namespace> = namespace [concrete] {
  29. // CHECK:STDOUT: .a_ref = %a_ref
  30. // CHECK:STDOUT: }
  31. // CHECK:STDOUT: name_binding_decl {
  32. // CHECK:STDOUT: %a_ref.patt: %pattern_type = binding_pattern a_ref [concrete]
  33. // CHECK:STDOUT: %a_ref.var_patt: %pattern_type = var_pattern %a_ref.patt [concrete]
  34. // CHECK:STDOUT: }
  35. // CHECK:STDOUT: %a_ref.var: ref %empty_tuple.type = var %a_ref.var_patt [concrete]
  36. // CHECK:STDOUT: %.loc4_13.1: type = splice_block %.loc4_13.3 [concrete = constants.%empty_tuple.type] {
  37. // CHECK:STDOUT: %.loc4_13.2: %empty_tuple.type = tuple_literal ()
  38. // CHECK:STDOUT: %.loc4_13.3: type = converted %.loc4_13.2, constants.%empty_tuple.type [concrete = constants.%empty_tuple.type]
  39. // CHECK:STDOUT: }
  40. // CHECK:STDOUT: %a_ref: ref %empty_tuple.type = bind_name a_ref, %a_ref.var [concrete = %a_ref.var]
  41. // CHECK:STDOUT: }
  42. // CHECK:STDOUT:
  43. // CHECK:STDOUT: fn @__global_init() {
  44. // CHECK:STDOUT: !entry:
  45. // CHECK:STDOUT: %.loc4_18.1: %empty_tuple.type = tuple_literal ()
  46. // CHECK:STDOUT: %.loc4_18.2: init %empty_tuple.type = tuple_init () to file.%a_ref.var [concrete = constants.%empty_tuple]
  47. // CHECK:STDOUT: %.loc4_1: init %empty_tuple.type = converted %.loc4_18.1, %.loc4_18.2 [concrete = constants.%empty_tuple]
  48. // CHECK:STDOUT: assign file.%a_ref.var, %.loc4_1
  49. // CHECK:STDOUT: return
  50. // CHECK:STDOUT: }
  51. // CHECK:STDOUT:
  52. // CHECK:STDOUT: --- implicit.impl.carbon
  53. // CHECK:STDOUT:
  54. // CHECK:STDOUT: constants {
  55. // CHECK:STDOUT: %empty_tuple.type: type = tuple_type () [concrete]
  56. // CHECK:STDOUT: %pattern_type: type = pattern_type %empty_tuple.type [concrete]
  57. // CHECK:STDOUT: %empty_tuple: %empty_tuple.type = tuple_value () [concrete]
  58. // CHECK:STDOUT: }
  59. // CHECK:STDOUT:
  60. // CHECK:STDOUT: imports {
  61. // CHECK:STDOUT: %Implicit.a_ref: ref %empty_tuple.type = import_ref Implicit//default, a_ref, loaded [concrete = %a_ref.var]
  62. // CHECK:STDOUT: %a_ref.patt: %pattern_type = binding_pattern a_ref [concrete]
  63. // CHECK:STDOUT: %a_ref.var_patt: %pattern_type = var_pattern %a_ref.patt [concrete]
  64. // CHECK:STDOUT: %a_ref.var: ref %empty_tuple.type = var %a_ref.var_patt [concrete]
  65. // CHECK:STDOUT: }
  66. // CHECK:STDOUT:
  67. // CHECK:STDOUT: file {
  68. // CHECK:STDOUT: package: <namespace> = namespace [concrete] {
  69. // CHECK:STDOUT: .a_ref = imports.%Implicit.a_ref
  70. // CHECK:STDOUT: .a = %a
  71. // CHECK:STDOUT: }
  72. // CHECK:STDOUT: %Implicit.import = import Implicit
  73. // CHECK:STDOUT: %default.import = import <none>
  74. // CHECK:STDOUT: name_binding_decl {
  75. // CHECK:STDOUT: %a.patt: %pattern_type = binding_pattern a [concrete]
  76. // CHECK:STDOUT: %a.var_patt: %pattern_type = var_pattern %a.patt [concrete]
  77. // CHECK:STDOUT: }
  78. // CHECK:STDOUT: %a.var: ref %empty_tuple.type = var %a.var_patt [concrete]
  79. // CHECK:STDOUT: %.loc4_9.1: type = splice_block %.loc4_9.3 [concrete = constants.%empty_tuple.type] {
  80. // CHECK:STDOUT: %.loc4_9.2: %empty_tuple.type = tuple_literal ()
  81. // CHECK:STDOUT: %.loc4_9.3: type = converted %.loc4_9.2, constants.%empty_tuple.type [concrete = constants.%empty_tuple.type]
  82. // CHECK:STDOUT: }
  83. // CHECK:STDOUT: %a: ref %empty_tuple.type = bind_name a, %a.var [concrete = %a.var]
  84. // CHECK:STDOUT: }
  85. // CHECK:STDOUT:
  86. // CHECK:STDOUT: fn @__global_init() {
  87. // CHECK:STDOUT: !entry:
  88. // CHECK:STDOUT: %a_ref.ref: ref %empty_tuple.type = name_ref a_ref, imports.%Implicit.a_ref [concrete = imports.%a_ref.var]
  89. // CHECK:STDOUT: %.loc4_13: init %empty_tuple.type = tuple_init () to file.%a.var [concrete = constants.%empty_tuple]
  90. // CHECK:STDOUT: %.loc4_1: init %empty_tuple.type = converted %a_ref.ref, %.loc4_13 [concrete = constants.%empty_tuple]
  91. // CHECK:STDOUT: assign file.%a.var, %.loc4_1
  92. // CHECK:STDOUT: return
  93. // CHECK:STDOUT: }
  94. // CHECK:STDOUT: