Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / lib / DebugInfo / LogicalView / Core / LVObject.cpp
blob75acbf3225e08a3f9bdef115e9a6c78c5b38a553
1 //===-- LVObject.cpp ------------------------------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 //
9 // This implements the LVObject class.
11 //===----------------------------------------------------------------------===//
13 #include "llvm/DebugInfo/LogicalView/Core/LVObject.h"
14 #include "llvm/DebugInfo/LogicalView/Core/LVReader.h"
15 #include "llvm/DebugInfo/LogicalView/Core/LVScope.h"
16 #include "llvm/DebugInfo/LogicalView/Core/LVSymbol.h"
17 #include <iomanip>
19 using namespace llvm;
20 using namespace llvm::logicalview;
22 #define DEBUG_TYPE "Object"
24 #ifndef NDEBUG
25 uint64_t LVObject::GID = 0;
26 #endif
28 StringRef llvm::logicalview::typeNone() { return StringRef(); }
29 StringRef llvm::logicalview::typeVoid() { return "void"; }
30 StringRef llvm::logicalview::typeInt() { return "int"; }
31 StringRef llvm::logicalview::typeUnknown() { return "?"; }
32 StringRef llvm::logicalview::emptyString() { return StringRef(); }
34 // Get a string representing the indentation level.
35 std::string LVObject::indentAsString(LVLevel Level) const {
36 return std::string(Level * 2, ' ');
39 // Get a string representing the indentation level.
40 std::string LVObject::indentAsString() const {
41 return (options().getPrintFormatting() || options().getPrintOffset())
42 ? indentAsString(ScopeLevel)
43 : "";
46 // String used as padding for printing objects with no line number.
47 std::string LVObject::noLineAsString(bool ShowZero) const {
48 return std::string(8, ' ');
51 // Get a string representation for the given number and discriminator.
52 std::string LVObject::lineAsString(uint32_t LineNumber, LVHalf Discriminator,
53 bool ShowZero) const {
54 // The representation is formatted as:
55 // a) line number (xxxxx) and discriminator (yy): 'xxxxx,yy'
56 // b) Only line number (xxxxx): 'xxxxx '
57 // c) No line number: ' '
58 std::stringstream Stream;
59 if (LineNumber) {
60 if (Discriminator && options().getAttributeDiscriminator())
61 Stream << std::setw(5) << LineNumber << "," << std::left << std::setw(2)
62 << Discriminator;
63 else
64 Stream << std::setw(5) << LineNumber << " ";
65 } else
66 Stream << noLineAsString(ShowZero);
68 if (options().getInternalNone())
69 Stream.str(noLineAsString(ShowZero));
71 return Stream.str();
74 // Same as 'LineString' but with stripped whitespaces.
75 std::string LVObject::lineNumberAsStringStripped(bool ShowZero) const {
76 return std::string(StringRef(lineNumberAsString(ShowZero)).trim());
79 std::string LVObject::referenceAsString(uint32_t LineNumber,
80 bool Spaces) const {
81 std::string String;
82 raw_string_ostream Stream(String);
83 if (LineNumber)
84 Stream << "@" << LineNumber << (Spaces ? " " : "");
86 return String;
89 void LVObject::setParent(LVScope *Scope) {
90 Parent.Scope = Scope;
91 setLevel(Scope->getLevel() + 1);
93 void LVObject::setParent(LVSymbol *Symbol) {
94 Parent.Symbol = Symbol;
95 setLevel(Symbol->getLevel() + 1);
98 void LVObject::markBranchAsMissing() {
99 // Mark the current object as 'missing'; then traverse the parents chain
100 // marking them as 'special missing' to indicate a missing branch. They
101 // can not be marked as missing, because will generate incorrect reports.
102 LVObject *Parent = this;
103 Parent->setIsMissing();
104 while (Parent) {
105 Parent->setIsMissingLink();
106 Parent = Parent->getParent();
110 Error LVObject::doPrint(bool Split, bool Match, bool Print, raw_ostream &OS,
111 bool Full) const {
112 print(OS, Full);
113 return Error::success();
116 void LVObject::printAttributes(raw_ostream &OS, bool Full, StringRef Name,
117 LVObject *Parent, StringRef Value,
118 bool UseQuotes, bool PrintRef) const {
119 // The current object will be the enclosing scope, use its offset and level.
120 LVObject Object(*Parent);
121 Object.setLevel(Parent->getLevel() + 1);
122 Object.setLineNumber(0);
123 Object.printAttributes(OS, Full);
125 // Print the line.
126 std::string TheLineNumber(Object.lineNumberAsString());
127 std::string TheIndentation(Object.indentAsString());
128 OS << format(" %5s %s ", TheLineNumber.c_str(), TheIndentation.c_str());
130 OS << Name;
131 if (PrintRef && options().getAttributeOffset())
132 OS << hexSquareString(getOffset());
133 if (UseQuotes)
134 OS << formattedName(Value) << "\n";
135 else
136 OS << Value << "\n";
139 void LVObject::printAttributes(raw_ostream &OS, bool Full) const {
140 #ifndef NDEBUG
141 if (options().getInternalID())
142 OS << hexSquareString(getID());
143 #endif
144 if (options().getCompareExecute() &&
145 (options().getAttributeAdded() || options().getAttributeMissing()))
146 OS << (getIsAdded() ? '+' : getIsMissing() ? '-' : ' ');
147 if (options().getAttributeOffset())
148 OS << hexSquareString(getOffset());
149 if (options().getAttributeLevel()) {
150 std::stringstream Stream;
151 Stream.str(std::string());
152 Stream << "[" << std::setfill('0') << std::setw(3) << getLevel() << "]";
153 std::string TheLevel(Stream.str());
154 OS << TheLevel;
156 if (options().getAttributeGlobal())
157 OS << (getIsGlobalReference() ? 'X' : ' ');
160 void LVObject::print(raw_ostream &OS, bool Full) const {
161 printFileIndex(OS, Full);
162 printAttributes(OS, Full);
164 // Print the line and any discriminator.
165 std::stringstream Stream;
166 Stream << " " << std::setw(5) << lineNumberAsString() << " "
167 << indentAsString() << " ";
168 OS << Stream.str();