Add MCSymbol::{print, dump}

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@78983 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Daniel Dunbar
2009-08-14 03:41:23 +00:00
parent 2c11624b65
commit 1689e0cf55
3 changed files with 63 additions and 3 deletions

View File

@@ -20,6 +20,7 @@
namespace llvm {
class MCSection;
class MCContext;
class raw_ostream;
/// MCSymbol - Instances of this class represent a symbol name in the MC file,
/// and MCSymbols are created and unique'd by the MCContext class.
@@ -61,6 +62,12 @@ namespace llvm {
void setExternal(bool Value) { IsExternal = Value; }
const std::string &getName() const { return Name; }
/// print - Print the value to the stream \arg OS.
void print(raw_ostream &OS) const;
/// dump - Print the value to stderr.
void dump() const;
};
} // end namespace llvm

49
lib/MC/MCSymbol.cpp Normal file
View File

@@ -0,0 +1,49 @@
//===- lib/MC/MCSymbol.cpp - MCSymbol implementation ----------------------===//
//
// The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
#include "llvm/MC/MCSymbol.h"
#include "llvm/Support/raw_ostream.h"
using namespace llvm;
/// NeedsQuoting - Return true if the string \arg Str needs quoting, i.e., it
/// does not match [a-zA-Z_.][a-zA-Z0-9_.]*.
//
// FIXME: This could be more permissive, do we care?
static inline bool NeedsQuoting(const StringRef &Str) {
if (Str.empty())
return true;
// Check that first character is in [a-zA-Z_.].
if (!((Str[0] >= 'a' && Str[0] <= 'z') ||
(Str[0] >= 'A' && Str[0] <= 'Z') ||
(Str[0] == '_' || Str[0] == '.')))
return true;
// Check subsequent characters are in [a-zA-Z0-9_.].
for (unsigned i = 1, e = Str.size(); i != e; ++i)
if (!((Str[i] >= 'a' && Str[i] <= 'z') ||
(Str[i] >= 'A' && Str[i] <= 'Z') ||
(Str[i] >= '0' && Str[i] <= '9') ||
(Str[i] == '_' || Str[i] == '.')))
return true;
return false;
}
void MCSymbol::print(raw_ostream &OS) const {
if (NeedsQuoting(getName()))
OS << '"' << getName() << '"';
else
OS << getName();
}
void MCSymbol::dump() const {
print(errs());
}

View File

@@ -18,9 +18,13 @@ void MCValue::print(raw_ostream &OS) const {
return;
}
OS << getSymA();
if (getSymB())
OS << " - " << getSymB();
getSymA()->print(OS);
if (getSymB()) {
OS << " - ";
getSymB()->print(OS);
}
if (getConstant())
OS << " + " << getConstant();
}