From 35518848a8e40f9bc337dfb73b52d7dd2eb5bde0 Mon Sep 17 00:00:00 2001 From: Richard Smith Date: Wed, 11 Dec 2024 01:39:55 +0000 Subject: [PATCH] Support stringifying tuple values. --- toolchain/check/testdata/tuple/import.carbon | 4 ++-- toolchain/sem_ir/stringify_type.cpp | 22 +++++++++++++++++++- 2 files changed, 23 insertions(+), 3 deletions(-) diff --git a/toolchain/check/testdata/tuple/import.carbon b/toolchain/check/testdata/tuple/import.carbon index 2ea5c9c50ac38..2d1bc24a85ec3 100644 --- a/toolchain/check/testdata/tuple/import.carbon +++ b/toolchain/check/testdata/tuple/import.carbon @@ -45,10 +45,10 @@ var c_bad: C((1, 2, 3)) = F(); impl package Implicit; -// CHECK:STDERR: fail_bad_value.impl.carbon:[[@LINE+6]]:1: error: cannot implicitly convert from `C()` to `C()` [ImplicitAsConversionFailure] +// CHECK:STDERR: fail_bad_value.impl.carbon:[[@LINE+6]]:1: error: cannot implicitly convert from `C((1, 2))` to `C((3, 4))` [ImplicitAsConversionFailure] // CHECK:STDERR: var c_bad: C((3, 4)) = F(); // CHECK:STDERR: ^~~~~~~~~~~~~~~~~~~~~~~~~~~ -// CHECK:STDERR: fail_bad_value.impl.carbon:[[@LINE+3]]:1: note: type `C()` does not implement interface `ImplicitAs(C())` [MissingImplInMemberAccessNote] +// CHECK:STDERR: fail_bad_value.impl.carbon:[[@LINE+3]]:1: note: type `C((1, 2))` does not implement interface `ImplicitAs(C((3, 4)))` [MissingImplInMemberAccessNote] // CHECK:STDERR: var c_bad: C((3, 4)) = F(); // CHECK:STDERR: ^~~~~~~~~~~~~~~~~~~~~~~~~~~ var c_bad: C((3, 4)) = F(); diff --git a/toolchain/sem_ir/stringify_type.cpp b/toolchain/sem_ir/stringify_type.cpp index 9429bc3767659..93286958a8721 100644 --- a/toolchain/sem_ir/stringify_type.cpp +++ b/toolchain/sem_ir/stringify_type.cpp @@ -423,6 +423,27 @@ auto StringifyTypeExpr(const SemIR::File& sem_ir, InstId outer_inst_id) } break; } + case CARBON_KIND(TupleValue inst): { + auto refs = sem_ir.inst_blocks().Get(inst.elements_id); + if (refs.empty()) { + out << "()"; + break; + } + out << "("; + step_stack.PushString(")"); + // A tuple of one element has a comma to disambiguate from an + // expression. + if (refs.size() == 1) { + step_stack.PushString(","); + } + for (auto i : llvm::reverse(llvm::seq(refs.size()))) { + step_stack.PushInstId(refs[i]); + if (i > 0) { + step_stack.PushString(", "); + } + } + break; + } case CARBON_KIND(UnboundElementType inst): { out << ""); @@ -492,7 +513,6 @@ auto StringifyTypeExpr(const SemIR::File& sem_ir, InstId outer_inst_id) case TupleAccess::Kind: case TupleInit::Kind: case TupleLiteral::Kind: - case TupleValue::Kind: case UnaryOperatorNot::Kind: case ValueAsRef::Kind: case ValueOfInitializer::Kind: