convert_lhs_interface.carbon 881 B

123456789101112131415161718192021222324252627282930313233343536
  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. // RUN: %{explorer} %s 2>&1 | \
  6. // RUN: %{FileCheck} --match-full-lines --allow-unused-prefixes=false %s
  7. // RUN: %{explorer} --parser_debug --trace_file=- %s 2>&1 | \
  8. // RUN: %{FileCheck} --match-full-lines --allow-unused-prefixes %s
  9. // AUTOUPDATE: %{explorer} %s
  10. // CHECK: result: 3
  11. package Foo api;
  12. interface HasF {
  13. fn F[me: Self](o: Self) -> Self;
  14. }
  15. class X {
  16. impl as HasF {
  17. fn F[me: Self](o: Self) -> Self { return {.n = me.n + o.n}; }
  18. }
  19. var n: i32;
  20. }
  21. class Y {
  22. var m: i32;
  23. impl as ImplicitAs(X) {
  24. fn Convert[me: Self]() -> X { return {.n = me.m}; }
  25. }
  26. }
  27. fn Main() -> i32 {
  28. var x: X = {.n = 1};
  29. var y: Y = {.m = 2};
  30. return y.(X.(HasF.F))(x).n;
  31. }