dump.cpp 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  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. // This library contains functions to assist dumping objects to stderr during
  5. // interactive debugging. Functions named `Dump` are intended for direct use by
  6. // developers, and should use overload resolution to determine which will be
  7. // invoked. The debugger should do namespace resolution automatically. For
  8. // example:
  9. //
  10. // - lldb: `expr Dump(context, id)`
  11. // - gdb: `call Dump(context, id)`
  12. #ifndef NDEBUG
  13. #include "toolchain/lex/dump.h"
  14. #include "common/check.h"
  15. #include "common/raw_string_ostream.h"
  16. #include "toolchain/check/context.h"
  17. #include "toolchain/lex/tokenized_buffer.h"
  18. #include "toolchain/parse/dump.h"
  19. #include "toolchain/parse/tree.h"
  20. #include "toolchain/sem_ir/dump.h"
  21. #include "toolchain/sem_ir/file.h"
  22. namespace Carbon::Check {
  23. static auto Dump(const Context& context, SemIR::LocId loc_id) -> std::string;
  24. LLVM_DUMP_METHOD static auto Dump(const Context& context, Lex::TokenIndex token)
  25. -> std::string {
  26. return Parse::Dump(context.parse_tree(), token);
  27. }
  28. LLVM_DUMP_METHOD static auto Dump(const Context& context, Parse::NodeId node_id)
  29. -> std::string {
  30. return Parse::Dump(context.parse_tree(), node_id);
  31. }
  32. LLVM_DUMP_METHOD static auto Dump(const Context& context,
  33. SemIR::ClassId class_id) -> std::string {
  34. return SemIR::Dump(context.sem_ir(), class_id);
  35. }
  36. LLVM_DUMP_METHOD static auto Dump(const Context& context,
  37. SemIR::ConstantId const_id) -> std::string {
  38. return SemIR::Dump(context.sem_ir(), const_id);
  39. }
  40. LLVM_DUMP_METHOD static auto Dump(const Context& context,
  41. SemIR::EntityNameId entity_name_id)
  42. -> std::string {
  43. return SemIR::Dump(context.sem_ir(), entity_name_id);
  44. }
  45. LLVM_DUMP_METHOD static auto Dump(const Context& context,
  46. SemIR::FacetTypeId facet_type_id)
  47. -> std::string {
  48. return SemIR::Dump(context.sem_ir(), facet_type_id);
  49. }
  50. LLVM_DUMP_METHOD static auto Dump(const Context& context,
  51. SemIR::FunctionId function_id)
  52. -> std::string {
  53. return SemIR::Dump(context.sem_ir(), function_id);
  54. }
  55. LLVM_DUMP_METHOD static auto Dump(const Context& context,
  56. SemIR::GenericId generic_id) -> std::string {
  57. return SemIR::Dump(context.sem_ir(), generic_id);
  58. }
  59. LLVM_DUMP_METHOD static auto Dump(const Context& context, SemIR::ImplId impl_id)
  60. -> std::string {
  61. RawStringOstream out;
  62. out << SemIR::Dump(context.sem_ir(), impl_id);
  63. if (!impl_id.has_value()) {
  64. return out.TakeStr();
  65. }
  66. const auto& impl = context.sem_ir().impls().Get(impl_id);
  67. auto loc_id = context.sem_ir().insts().GetLocId(impl.witness_id);
  68. out << "\nwitness loc: " << Dump(context, loc_id);
  69. return out.TakeStr();
  70. }
  71. LLVM_DUMP_METHOD static auto Dump(const Context& context,
  72. SemIR::InstBlockId inst_block_id)
  73. -> std::string {
  74. return SemIR::Dump(context.sem_ir(), inst_block_id);
  75. }
  76. LLVM_DUMP_METHOD static auto Dump(const Context& context, SemIR::InstId inst_id)
  77. -> std::string {
  78. RawStringOstream out;
  79. auto loc_id = context.sem_ir().insts().GetLocId(inst_id);
  80. out << SemIR::Dump(context.sem_ir(), inst_id) << '\n'
  81. << " - " << Dump(context, loc_id);
  82. return out.TakeStr();
  83. }
  84. LLVM_DUMP_METHOD static auto Dump(const Context& context,
  85. SemIR::InterfaceId interface_id)
  86. -> std::string {
  87. return SemIR::Dump(context.sem_ir(), interface_id);
  88. }
  89. LLVM_DUMP_METHOD static auto Dump(const Context& context, SemIR::LocId loc_id)
  90. -> std::string {
  91. RawStringOstream out;
  92. switch (loc_id.kind()) {
  93. case SemIR::LocId::Kind::None: {
  94. out << "LocId(<none>)";
  95. break;
  96. }
  97. case SemIR::LocId::Kind::ImportIRInstId: {
  98. auto import_ir_id = context.sem_ir()
  99. .import_ir_insts()
  100. .Get(loc_id.import_ir_inst_id())
  101. .ir_id;
  102. const auto* import_file =
  103. context.sem_ir().import_irs().Get(import_ir_id).sem_ir;
  104. out << "LocId(import from \"" << FormatEscaped(import_file->filename())
  105. << "\")";
  106. break;
  107. }
  108. case SemIR::LocId::Kind::InstId: {
  109. out << "LocId(" << SemIR::Dump(context.sem_ir(), loc_id.inst_id()) << ")";
  110. break;
  111. }
  112. case SemIR::LocId::Kind::NodeId: {
  113. auto token = context.parse_tree().node_token(loc_id.node_id());
  114. auto line = context.tokens().GetLineNumber(token);
  115. auto col = context.tokens().GetColumnNumber(token);
  116. const char* implicit = loc_id.is_implicit() ? " implicit" : "";
  117. out << "LocId(" << FormatEscaped(context.sem_ir().filename()) << ":"
  118. << line << ":" << col << implicit << ")";
  119. break;
  120. }
  121. }
  122. return out.TakeStr();
  123. }
  124. LLVM_DUMP_METHOD static auto Dump(const Context& context, SemIR::NameId name_id)
  125. -> std::string {
  126. return SemIR::Dump(context.sem_ir(), name_id);
  127. }
  128. LLVM_DUMP_METHOD static auto Dump(const Context& context,
  129. SemIR::NameScopeId name_scope_id)
  130. -> std::string {
  131. return SemIR::Dump(context.sem_ir(), name_scope_id);
  132. }
  133. LLVM_DUMP_METHOD static auto Dump(
  134. const Context& context,
  135. SemIR::IdentifiedFacetTypeId identified_facet_type_id) -> std::string {
  136. return SemIR::Dump(context.sem_ir(), identified_facet_type_id);
  137. }
  138. LLVM_DUMP_METHOD static auto Dump(const Context& context,
  139. SemIR::SpecificId specific_id)
  140. -> std::string {
  141. return SemIR::Dump(context.sem_ir(), specific_id);
  142. }
  143. LLVM_DUMP_METHOD static auto Dump(
  144. const Context& context, SemIR::SpecificInterfaceId specific_interface_id)
  145. -> std::string {
  146. return SemIR::Dump(context.sem_ir(), specific_interface_id);
  147. }
  148. LLVM_DUMP_METHOD static auto Dump(
  149. const Context& context, SemIR::StructTypeFieldsId struct_type_fields_id)
  150. -> std::string {
  151. return SemIR::Dump(context.sem_ir(), struct_type_fields_id);
  152. }
  153. LLVM_DUMP_METHOD static auto Dump(const Context& context, SemIR::TypeId type_id)
  154. -> std::string {
  155. return SemIR::Dump(context.sem_ir(), type_id);
  156. }
  157. } // namespace Carbon::Check
  158. #endif // NDEBUG