|
|
@@ -6,324 +6,330 @@
|
|
|
|
|
|
#include "toolchain/sem_ir/dump.h"
|
|
|
|
|
|
-#include "common/ostream.h"
|
|
|
+#include "common/raw_string_ostream.h"
|
|
|
#include "toolchain/sem_ir/stringify_type.h"
|
|
|
|
|
|
namespace Carbon::SemIR {
|
|
|
|
|
|
-static auto DumpNameIfValid(const File& file, NameId name_id) -> void {
|
|
|
+static auto DumpNameIfValid(const File& file, NameId name_id) -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
if (name_id.has_value()) {
|
|
|
- llvm::errs() << " `" << file.names().GetFormatted(name_id) << "`";
|
|
|
+ out << " `" << file.names().GetFormatted(name_id) << "`";
|
|
|
}
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
-static auto DumpNoNewline(const File& file, ConstantId const_id) -> void {
|
|
|
- llvm::errs() << const_id;
|
|
|
- if (!const_id.has_value()) {
|
|
|
- return;
|
|
|
- }
|
|
|
- if (const_id.is_symbolic()) {
|
|
|
- llvm::errs() << ": "
|
|
|
- << file.constant_values().GetSymbolicConstant(const_id);
|
|
|
- } else if (const_id.is_concrete()) {
|
|
|
- llvm::errs() << ": "
|
|
|
- << file.insts().Get(
|
|
|
- file.constant_values().GetInstId(const_id));
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-static auto DumpNoNewline(const File& file, InstId inst_id) -> void {
|
|
|
- llvm::errs() << inst_id;
|
|
|
+static auto DumpInstSummary(const File& file, InstId inst_id) -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << inst_id;
|
|
|
if (inst_id.has_value()) {
|
|
|
- llvm::errs() << ": " << file.insts().Get(inst_id);
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-static auto DumpNoNewline(const File& file, InterfaceId interface_id) -> void {
|
|
|
- llvm::errs() << interface_id;
|
|
|
- if (interface_id.has_value()) {
|
|
|
- const auto& interface = file.interfaces().Get(interface_id);
|
|
|
- llvm::errs() << ": " << interface;
|
|
|
- DumpNameIfValid(file, interface.name_id);
|
|
|
+ out << ": " << file.insts().Get(inst_id);
|
|
|
}
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
-static auto DumpNoNewline(const File& file, SpecificId specific_id) -> void {
|
|
|
- llvm::errs() << specific_id;
|
|
|
+static auto DumpSpecificSummary(const File& file, SpecificId specific_id)
|
|
|
+ -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << specific_id;
|
|
|
if (specific_id.has_value()) {
|
|
|
- llvm::errs() << ": " << file.specifics().Get(specific_id);
|
|
|
+ out << ": " << file.specifics().Get(specific_id);
|
|
|
}
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
-LLVM_DUMP_METHOD auto Dump(const File& file, ClassId class_id) -> void {
|
|
|
- llvm::errs() << class_id;
|
|
|
+LLVM_DUMP_METHOD auto Dump(const File& file, ClassId class_id) -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << class_id;
|
|
|
if (class_id.has_value()) {
|
|
|
const auto& class_obj = file.classes().Get(class_id);
|
|
|
- llvm::errs() << ": " << class_obj;
|
|
|
- DumpNameIfValid(file, class_obj.name_id);
|
|
|
+ out << ": " << class_obj << DumpNameIfValid(file, class_obj.name_id);
|
|
|
}
|
|
|
- llvm::errs() << '\n';
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
-LLVM_DUMP_METHOD auto Dump(const File& file, ConstantId const_id) -> void {
|
|
|
- DumpNoNewline(file, const_id);
|
|
|
- llvm::errs() << '\n';
|
|
|
+LLVM_DUMP_METHOD auto Dump(const File& file, ConstantId const_id)
|
|
|
+ -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << const_id;
|
|
|
+ if (!const_id.has_value()) {
|
|
|
+ return out.TakeStr();
|
|
|
+ }
|
|
|
+ if (const_id.is_symbolic()) {
|
|
|
+ out << ": " << file.constant_values().GetSymbolicConstant(const_id);
|
|
|
+ } else if (const_id.is_concrete()) {
|
|
|
+ out << ": " << file.insts().Get(file.constant_values().GetInstId(const_id));
|
|
|
+ }
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
LLVM_DUMP_METHOD auto Dump(const File& file, EntityNameId entity_name_id)
|
|
|
- -> void {
|
|
|
- llvm::errs() << entity_name_id;
|
|
|
+ -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << entity_name_id;
|
|
|
if (entity_name_id.has_value()) {
|
|
|
auto entity_name = file.entity_names().Get(entity_name_id);
|
|
|
- llvm::errs() << ": " << entity_name;
|
|
|
- DumpNameIfValid(file, entity_name.name_id);
|
|
|
+ out << ": " << entity_name << DumpNameIfValid(file, entity_name.name_id);
|
|
|
}
|
|
|
- llvm::errs() << '\n';
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
LLVM_DUMP_METHOD auto Dump(const File& file, FacetTypeId facet_type_id)
|
|
|
- -> void {
|
|
|
- llvm::errs() << facet_type_id;
|
|
|
- if (facet_type_id.has_value()) {
|
|
|
- const auto& facet_type = file.facet_types().Get(facet_type_id);
|
|
|
- llvm::errs() << ": " << facet_type << '\n';
|
|
|
- for (auto impls : facet_type.impls_constraints) {
|
|
|
- llvm::errs() << " - ";
|
|
|
- DumpNoNewline(file, impls.interface_id);
|
|
|
- if (impls.specific_id.has_value()) {
|
|
|
- llvm::errs() << "; ";
|
|
|
- DumpNoNewline(file, impls.specific_id);
|
|
|
- }
|
|
|
- llvm::errs() << '\n';
|
|
|
- }
|
|
|
- for (auto rewrite : facet_type.rewrite_constraints) {
|
|
|
- llvm::errs() << " - ";
|
|
|
- Dump(file, rewrite.lhs_const_id);
|
|
|
- llvm::errs() << " - ";
|
|
|
- Dump(file, rewrite.rhs_const_id);
|
|
|
- }
|
|
|
- if (auto complete_id = file.complete_facet_types().TryGetId(facet_type_id);
|
|
|
- complete_id.has_value()) {
|
|
|
- llvm::errs() << "complete: ";
|
|
|
- Dump(file, complete_id);
|
|
|
+ -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << facet_type_id;
|
|
|
+ if (!facet_type_id.has_value()) {
|
|
|
+ return out.TakeStr();
|
|
|
+ }
|
|
|
+
|
|
|
+ const auto& facet_type = file.facet_types().Get(facet_type_id);
|
|
|
+ out << ": " << facet_type;
|
|
|
+ for (auto impls : facet_type.impls_constraints) {
|
|
|
+ out << "\n - " << Dump(file, impls.interface_id);
|
|
|
+ if (impls.specific_id.has_value()) {
|
|
|
+ out << "; " << DumpSpecificSummary(file, impls.specific_id);
|
|
|
}
|
|
|
- } else {
|
|
|
- llvm::errs() << '\n';
|
|
|
}
|
|
|
+ for (auto rewrite : facet_type.rewrite_constraints) {
|
|
|
+ out << "\n"
|
|
|
+ << " - " << Dump(file, rewrite.lhs_const_id) << "\n"
|
|
|
+ << " - " << Dump(file, rewrite.rhs_const_id);
|
|
|
+ }
|
|
|
+ if (auto complete_id = file.complete_facet_types().TryGetId(facet_type_id);
|
|
|
+ complete_id.has_value()) {
|
|
|
+ out << "\ncomplete: " << Dump(file, complete_id);
|
|
|
+ }
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
-LLVM_DUMP_METHOD auto Dump(const File& file, FunctionId function_id) -> void {
|
|
|
- llvm::errs() << function_id;
|
|
|
+LLVM_DUMP_METHOD auto Dump(const File& file, FunctionId function_id)
|
|
|
+ -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << function_id;
|
|
|
if (function_id.has_value()) {
|
|
|
const auto& function = file.functions().Get(function_id);
|
|
|
- llvm::errs() << ": " << function;
|
|
|
- DumpNameIfValid(file, function.name_id);
|
|
|
+ out << ": " << function << DumpNameIfValid(file, function.name_id);
|
|
|
}
|
|
|
- llvm::errs() << '\n';
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
-LLVM_DUMP_METHOD auto Dump(const File& file, GenericId generic_id) -> void {
|
|
|
- llvm::errs() << generic_id;
|
|
|
+LLVM_DUMP_METHOD auto Dump(const File& file, GenericId generic_id)
|
|
|
+ -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << generic_id;
|
|
|
if (!generic_id.has_value()) {
|
|
|
- llvm::errs() << '\n';
|
|
|
- return;
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
- llvm::errs() << ": " << file.generics().Get(generic_id) << '\n';
|
|
|
- Dump(file, file.generics().Get(generic_id).bindings_id);
|
|
|
+ out << ": " << file.generics().Get(generic_id) << '\n'
|
|
|
+ << Dump(file, file.generics().Get(generic_id).bindings_id);
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
-LLVM_DUMP_METHOD auto Dump(const File& file, ImplId impl_id) -> void {
|
|
|
- llvm::errs() << impl_id;
|
|
|
+LLVM_DUMP_METHOD auto Dump(const File& file, ImplId impl_id) -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << impl_id;
|
|
|
if (!impl_id.has_value()) {
|
|
|
- llvm::errs() << '\n';
|
|
|
- return;
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
-
|
|
|
const auto& impl = file.impls().Get(impl_id);
|
|
|
- llvm::errs() << ": " << impl << '\n';
|
|
|
- llvm::errs() << " - interface_id: ";
|
|
|
- DumpNoNewline(file, impl.interface.interface_id);
|
|
|
- llvm::errs() << '\n';
|
|
|
- llvm::errs() << " - specific_id: ";
|
|
|
- DumpNoNewline(file, impl.interface.specific_id);
|
|
|
- llvm::errs() << '\n';
|
|
|
+ out << ": " << impl << '\n'
|
|
|
+ << " - interface_id: " << Dump(file, impl.interface.interface_id) << '\n'
|
|
|
+ << " - specific_id: "
|
|
|
+ << DumpSpecificSummary(file, impl.interface.specific_id);
|
|
|
if (impl.interface.specific_id.has_value()) {
|
|
|
auto inst_block_id =
|
|
|
file.specifics().Get(impl.interface.specific_id).args_id;
|
|
|
- Dump(file, inst_block_id);
|
|
|
+ out << '\n' << Dump(file, inst_block_id);
|
|
|
}
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
LLVM_DUMP_METHOD auto Dump(const File& file, InstBlockId inst_block_id)
|
|
|
- -> void {
|
|
|
- llvm::errs() << inst_block_id;
|
|
|
+ -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << inst_block_id;
|
|
|
if (inst_block_id.has_value()) {
|
|
|
- llvm::errs() << ":";
|
|
|
+ out << ":";
|
|
|
auto inst_block = file.inst_blocks().Get(inst_block_id);
|
|
|
for (auto inst_id : inst_block) {
|
|
|
- llvm::errs() << "\n - ";
|
|
|
- DumpNoNewline(file, inst_id);
|
|
|
+ out << "\n - " << DumpInstSummary(file, inst_id);
|
|
|
}
|
|
|
}
|
|
|
- llvm::errs() << '\n';
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
-LLVM_DUMP_METHOD auto Dump(const File& file, InstId inst_id) -> void {
|
|
|
- DumpNoNewline(file, inst_id);
|
|
|
- llvm::errs() << '\n';
|
|
|
- if (inst_id.has_value()) {
|
|
|
- Inst inst = file.insts().Get(inst_id);
|
|
|
- if (inst.type_id().has_value()) {
|
|
|
- llvm::errs() << " - type ";
|
|
|
- Dump(file, inst.type_id());
|
|
|
- }
|
|
|
- ConstantId const_id = file.constant_values().Get(inst_id);
|
|
|
- if (const_id.has_value()) {
|
|
|
- InstId const_inst_id = file.constant_values().GetInstId(const_id);
|
|
|
- llvm::errs() << " - value ";
|
|
|
- if (const_inst_id == inst_id) {
|
|
|
- llvm::errs() << const_id << '\n';
|
|
|
- } else {
|
|
|
- Dump(file, const_id);
|
|
|
- }
|
|
|
+LLVM_DUMP_METHOD auto Dump(const File& file, InstId inst_id) -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << DumpInstSummary(file, inst_id);
|
|
|
+ if (!inst_id.has_value()) {
|
|
|
+ return out.TakeStr();
|
|
|
+ }
|
|
|
+
|
|
|
+ Inst inst = file.insts().Get(inst_id);
|
|
|
+ if (inst.type_id().has_value()) {
|
|
|
+ out << "\n - type: " << Dump(file, inst.type_id());
|
|
|
+ }
|
|
|
+ ConstantId const_id = file.constant_values().Get(inst_id);
|
|
|
+ if (const_id.has_value()) {
|
|
|
+ InstId const_inst_id = file.constant_values().GetInstId(const_id);
|
|
|
+ out << "\n - value: ";
|
|
|
+ if (const_inst_id == inst_id) {
|
|
|
+ out << const_id;
|
|
|
+ } else {
|
|
|
+ out << Dump(file, const_id);
|
|
|
}
|
|
|
}
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
-LLVM_DUMP_METHOD auto Dump(const File& file, InterfaceId interface_id) -> void {
|
|
|
- DumpNoNewline(file, interface_id);
|
|
|
- llvm::errs() << '\n';
|
|
|
+LLVM_DUMP_METHOD auto Dump(const File& file, InterfaceId interface_id)
|
|
|
+ -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << interface_id;
|
|
|
+ if (interface_id.has_value()) {
|
|
|
+ const auto& interface = file.interfaces().Get(interface_id);
|
|
|
+ out << ": " << interface << DumpNameIfValid(file, interface.name_id);
|
|
|
+ }
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
-LLVM_DUMP_METHOD auto Dump(const File& file, NameId name_id) -> void {
|
|
|
- llvm::errs() << name_id;
|
|
|
- DumpNameIfValid(file, name_id);
|
|
|
- llvm::errs() << '\n';
|
|
|
+LLVM_DUMP_METHOD auto Dump(const File& file, NameId name_id) -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << name_id << DumpNameIfValid(file, name_id);
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
LLVM_DUMP_METHOD auto Dump(const File& file, NameScopeId name_scope_id)
|
|
|
- -> void {
|
|
|
- llvm::errs() << name_scope_id;
|
|
|
- if (name_scope_id.has_value()) {
|
|
|
- const auto& name_scope = file.name_scopes().Get(name_scope_id);
|
|
|
- llvm::errs() << ": " << name_scope;
|
|
|
- if (name_scope.inst_id().has_value()) {
|
|
|
- llvm::errs() << " " << file.insts().Get(name_scope.inst_id());
|
|
|
- }
|
|
|
- DumpNameIfValid(file, name_scope.name_id());
|
|
|
- llvm::errs() << '\n';
|
|
|
- for (const auto& entry : name_scope.entries()) {
|
|
|
- llvm::errs() << " - " << entry.name_id;
|
|
|
- DumpNameIfValid(file, entry.name_id);
|
|
|
- llvm::errs() << ": ";
|
|
|
- if (entry.result.is_poisoned()) {
|
|
|
- llvm::errs() << "<poisoned>\n";
|
|
|
- } else if (entry.result.is_found()) {
|
|
|
- switch (entry.result.access_kind()) {
|
|
|
- case AccessKind::Public:
|
|
|
- llvm::errs() << "public ";
|
|
|
- break;
|
|
|
- case AccessKind::Protected:
|
|
|
- llvm::errs() << "protected ";
|
|
|
- break;
|
|
|
- case AccessKind::Private:
|
|
|
- llvm::errs() << "private ";
|
|
|
- break;
|
|
|
- }
|
|
|
- DumpNoNewline(file, entry.result.target_inst_id());
|
|
|
- llvm::errs() << "\n";
|
|
|
- } else {
|
|
|
- llvm::errs() << "<not-found>\n";
|
|
|
+ -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << name_scope_id;
|
|
|
+ if (!name_scope_id.has_value()) {
|
|
|
+ return out.TakeStr();
|
|
|
+ }
|
|
|
+
|
|
|
+ const auto& name_scope = file.name_scopes().Get(name_scope_id);
|
|
|
+ out << ": " << name_scope;
|
|
|
+ if (name_scope.inst_id().has_value()) {
|
|
|
+ out << " " << file.insts().Get(name_scope.inst_id());
|
|
|
+ }
|
|
|
+ out << DumpNameIfValid(file, name_scope.name_id());
|
|
|
+ for (const auto& entry : name_scope.entries()) {
|
|
|
+ out << "\n - " << entry.name_id << DumpNameIfValid(file, entry.name_id)
|
|
|
+ << ": ";
|
|
|
+ if (entry.result.is_poisoned()) {
|
|
|
+ out << "<poisoned>";
|
|
|
+ } else if (entry.result.is_found()) {
|
|
|
+ switch (entry.result.access_kind()) {
|
|
|
+ case AccessKind::Public:
|
|
|
+ out << "public ";
|
|
|
+ break;
|
|
|
+ case AccessKind::Protected:
|
|
|
+ out << "protected ";
|
|
|
+ break;
|
|
|
+ case AccessKind::Private:
|
|
|
+ out << "private ";
|
|
|
+ break;
|
|
|
}
|
|
|
+ out << DumpInstSummary(file, entry.result.target_inst_id());
|
|
|
+ } else {
|
|
|
+ out << "<not-found>";
|
|
|
}
|
|
|
- } else {
|
|
|
- llvm::errs() << '\n';
|
|
|
}
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
LLVM_DUMP_METHOD auto Dump(const File& file,
|
|
|
- CompleteFacetTypeId complete_facet_type_id) -> void {
|
|
|
- llvm::errs() << complete_facet_type_id << "\n";
|
|
|
- if (complete_facet_type_id.has_value()) {
|
|
|
- const auto& complete_facet_type =
|
|
|
- file.complete_facet_types().Get(complete_facet_type_id);
|
|
|
- for (auto [i, req_interface] :
|
|
|
- llvm::enumerate(complete_facet_type.required_interfaces)) {
|
|
|
- llvm::errs() << " - ";
|
|
|
- DumpNoNewline(file, req_interface.interface_id);
|
|
|
- if (req_interface.specific_id.has_value()) {
|
|
|
- llvm::errs() << "; ";
|
|
|
- DumpNoNewline(file, req_interface.specific_id);
|
|
|
- }
|
|
|
- if (static_cast<int>(i) < complete_facet_type.num_to_impl) {
|
|
|
- llvm::errs() << " (to impl)";
|
|
|
- }
|
|
|
- llvm::errs() << '\n';
|
|
|
+ CompleteFacetTypeId complete_facet_type_id)
|
|
|
+ -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << complete_facet_type_id;
|
|
|
+ if (!complete_facet_type_id.has_value()) {
|
|
|
+ return out.TakeStr();
|
|
|
+ }
|
|
|
+
|
|
|
+ const auto& complete_facet_type =
|
|
|
+ file.complete_facet_types().Get(complete_facet_type_id);
|
|
|
+ for (auto [i, req_interface] :
|
|
|
+ llvm::enumerate(complete_facet_type.required_interfaces)) {
|
|
|
+ out << "\n - " << Dump(file, req_interface.interface_id);
|
|
|
+ if (req_interface.specific_id.has_value()) {
|
|
|
+ out << "; " << DumpSpecificSummary(file, req_interface.specific_id);
|
|
|
+ }
|
|
|
+ if (static_cast<int>(i) < complete_facet_type.num_to_impl) {
|
|
|
+ out << " (to impl)";
|
|
|
}
|
|
|
}
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
-LLVM_DUMP_METHOD auto Dump(const File& file, SpecificId specific_id) -> void {
|
|
|
- DumpNoNewline(file, specific_id);
|
|
|
- llvm::errs() << '\n';
|
|
|
+LLVM_DUMP_METHOD auto Dump(const File& file, SpecificId specific_id)
|
|
|
+ -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << DumpSpecificSummary(file, specific_id);
|
|
|
if (specific_id.has_value()) {
|
|
|
- Dump(file, file.specifics().Get(specific_id).args_id);
|
|
|
+ out << "\n" << Dump(file, file.specifics().Get(specific_id).args_id);
|
|
|
}
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
LLVM_DUMP_METHOD auto Dump(const File& file,
|
|
|
- SpecificInterfaceId specific_interface_id) -> void {
|
|
|
+ SpecificInterfaceId specific_interface_id)
|
|
|
+ -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
const auto& interface = file.specific_interfaces().Get(specific_interface_id);
|
|
|
- llvm::errs() << specific_interface_id << '\n';
|
|
|
- llvm::errs() << " - interface: ";
|
|
|
- DumpNoNewline(file, interface.interface_id);
|
|
|
- llvm::errs() << '\n';
|
|
|
- llvm::errs() << " - specific_id: ";
|
|
|
- Dump(file, interface.specific_id);
|
|
|
+ out << specific_interface_id << "\n"
|
|
|
+ << " - interface: " << Dump(file, interface.interface_id) << "\n"
|
|
|
+ << " - specific_id: " << Dump(file, interface.specific_id);
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
LLVM_DUMP_METHOD auto Dump(const File& file,
|
|
|
- StructTypeFieldsId struct_type_fields_id) -> void {
|
|
|
- llvm::errs() << struct_type_fields_id;
|
|
|
+ StructTypeFieldsId struct_type_fields_id)
|
|
|
+ -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << struct_type_fields_id;
|
|
|
if (struct_type_fields_id.has_value()) {
|
|
|
- llvm::errs() << ":";
|
|
|
+ out << ":";
|
|
|
auto block = file.struct_type_fields().Get(struct_type_fields_id);
|
|
|
for (auto field : block) {
|
|
|
- llvm::errs() << "\n - " << field;
|
|
|
- DumpNameIfValid(file, field.name_id);
|
|
|
+ out << "\n - " << field << DumpNameIfValid(file, field.name_id);
|
|
|
if (field.type_id.has_value()) {
|
|
|
InstId inst_id =
|
|
|
file.constant_values().GetInstId(field.type_id.AsConstantId());
|
|
|
- llvm::errs() << ": " << StringifyTypeExpr(file, inst_id);
|
|
|
+ out << ": " << StringifyTypeExpr(file, inst_id);
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
- llvm::errs() << '\n';
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
LLVM_DUMP_METHOD auto Dump(const File& file, TypeBlockId type_block_id)
|
|
|
- -> void {
|
|
|
- llvm::errs() << type_block_id;
|
|
|
- if (type_block_id.has_value()) {
|
|
|
- llvm::errs() << ":\n";
|
|
|
- auto type_block = file.type_blocks().Get(type_block_id);
|
|
|
- for (auto type_id : type_block) {
|
|
|
- llvm::errs() << " - ";
|
|
|
- Dump(file, type_id);
|
|
|
- }
|
|
|
- } else {
|
|
|
- llvm::errs() << '\n';
|
|
|
+ -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << type_block_id;
|
|
|
+ if (!type_block_id.has_value()) {
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
+
|
|
|
+ out << ":";
|
|
|
+ auto type_block = file.type_blocks().Get(type_block_id);
|
|
|
+ for (auto type_id : type_block) {
|
|
|
+ out << "\n - " << Dump(file, type_id);
|
|
|
+ }
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
-LLVM_DUMP_METHOD auto Dump(const File& file, TypeId type_id) -> void {
|
|
|
- llvm::errs() << type_id;
|
|
|
- if (type_id.has_value()) {
|
|
|
- InstId inst_id = file.constant_values().GetInstId(type_id.AsConstantId());
|
|
|
- llvm::errs() << ": " << StringifyTypeExpr(file, inst_id) << "; "
|
|
|
- << file.insts().Get(inst_id);
|
|
|
+LLVM_DUMP_METHOD auto Dump(const File& file, TypeId type_id) -> std::string {
|
|
|
+ RawStringOstream out;
|
|
|
+ out << type_id;
|
|
|
+ if (!type_id.has_value()) {
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
- llvm::errs() << '\n';
|
|
|
+
|
|
|
+ InstId inst_id = file.constant_values().GetInstId(type_id.AsConstantId());
|
|
|
+ out << ": " << StringifyTypeExpr(file, inst_id) << "; "
|
|
|
+ << file.insts().Get(inst_id);
|
|
|
+ return out.TakeStr();
|
|
|
}
|
|
|
|
|
|
// Functions that can be used instead of the corresponding constructor, which is
|