mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-03-12 17:37:13 +00:00
now that Type::getDescription() is dead, the TypePrinting class can move from Assembly/Writer.h to being
a private class in AsmWriter.cpp. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@133361 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
0cd0d88160
commit
fb78b33018
@ -17,46 +17,12 @@
|
|||||||
#ifndef LLVM_ASSEMBLY_WRITER_H
|
#ifndef LLVM_ASSEMBLY_WRITER_H
|
||||||
#define LLVM_ASSEMBLY_WRITER_H
|
#define LLVM_ASSEMBLY_WRITER_H
|
||||||
|
|
||||||
#include <string>
|
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
|
|
||||||
class Type;
|
class Type;
|
||||||
class Module;
|
class Module;
|
||||||
class Value;
|
class Value;
|
||||||
class raw_ostream;
|
class raw_ostream;
|
||||||
template <typename T> class SmallVectorImpl;
|
|
||||||
|
|
||||||
/// TypePrinting - Type printing machinery.
|
|
||||||
class TypePrinting {
|
|
||||||
void *TypeNames; // A map to remember type names.
|
|
||||||
TypePrinting(const TypePrinting &); // DO NOT IMPLEMENT
|
|
||||||
void operator=(const TypePrinting&); // DO NOT IMPLEMENT
|
|
||||||
public:
|
|
||||||
TypePrinting();
|
|
||||||
~TypePrinting();
|
|
||||||
|
|
||||||
void clear();
|
|
||||||
|
|
||||||
void print(const Type *Ty, raw_ostream &OS, bool IgnoreTopLevelName = false);
|
|
||||||
|
|
||||||
void printAtLeastOneLevel(const Type *Ty, raw_ostream &OS) {
|
|
||||||
print(Ty, OS, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// hasTypeName - Return true if the type has a name in TypeNames, false
|
|
||||||
/// otherwise.
|
|
||||||
bool hasTypeName(const Type *Ty) const;
|
|
||||||
|
|
||||||
/// addTypeName - Add a name for the specified type if it doesn't already have
|
|
||||||
/// one. This name will be printed instead of the structural version of the
|
|
||||||
/// type in order to make the output more concise.
|
|
||||||
void addTypeName(const Type *Ty, const std::string &N);
|
|
||||||
|
|
||||||
private:
|
|
||||||
void CalcTypeName(const Type *Ty, SmallVectorImpl<const Type *> &TypeStack,
|
|
||||||
raw_ostream &OS, bool IgnoreTopLevelName = false);
|
|
||||||
};
|
|
||||||
|
|
||||||
// WriteTypeSymbolic - This attempts to write the specified type as a symbolic
|
// WriteTypeSymbolic - This attempts to write the specified type as a symbolic
|
||||||
// type, if there is an entry in the Module's symbol table for the specified
|
// type, if there is an entry in the Module's symbol table for the specified
|
||||||
|
@ -17,7 +17,6 @@
|
|||||||
|
|
||||||
#include "llvm/AbstractTypeUser.h"
|
#include "llvm/AbstractTypeUser.h"
|
||||||
#include "llvm/Support/Casting.h"
|
#include "llvm/Support/Casting.h"
|
||||||
#include <string>
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
|
@ -140,30 +140,45 @@ static void PrintLLVMName(raw_ostream &OS, const Value *V) {
|
|||||||
// TypePrinting Class: Type printing machinery
|
// TypePrinting Class: Type printing machinery
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
static DenseMap<const Type *, std::string> &getTypeNamesMap(void *M) {
|
/// TypePrinting - Type printing machinery.
|
||||||
return *static_cast<DenseMap<const Type *, std::string>*>(M);
|
namespace {
|
||||||
}
|
class TypePrinting {
|
||||||
|
DenseMap<const Type *, std::string> TypeNames;
|
||||||
|
TypePrinting(const TypePrinting &); // DO NOT IMPLEMENT
|
||||||
|
void operator=(const TypePrinting&); // DO NOT IMPLEMENT
|
||||||
|
public:
|
||||||
|
TypePrinting() {}
|
||||||
|
~TypePrinting() {}
|
||||||
|
|
||||||
|
void clear() {
|
||||||
|
TypeNames.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
void print(const Type *Ty, raw_ostream &OS, bool IgnoreTopLevelName = false);
|
||||||
|
|
||||||
|
void printAtLeastOneLevel(const Type *Ty, raw_ostream &OS) {
|
||||||
|
print(Ty, OS, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// hasTypeName - Return true if the type has a name in TypeNames, false
|
||||||
|
/// otherwise.
|
||||||
|
bool hasTypeName(const Type *Ty) const {
|
||||||
|
return TypeNames.count(Ty);
|
||||||
|
}
|
||||||
|
|
||||||
void TypePrinting::clear() {
|
|
||||||
getTypeNamesMap(TypeNames).clear();
|
/// addTypeName - Add a name for the specified type if it doesn't already have
|
||||||
}
|
/// one. This name will be printed instead of the structural version of the
|
||||||
|
/// type in order to make the output more concise.
|
||||||
bool TypePrinting::hasTypeName(const Type *Ty) const {
|
void addTypeName(const Type *Ty, const std::string &N) {
|
||||||
return getTypeNamesMap(TypeNames).count(Ty);
|
TypeNames.insert(std::make_pair(Ty, N));
|
||||||
}
|
}
|
||||||
|
|
||||||
void TypePrinting::addTypeName(const Type *Ty, const std::string &N) {
|
private:
|
||||||
getTypeNamesMap(TypeNames).insert(std::make_pair(Ty, N));
|
void CalcTypeName(const Type *Ty, SmallVectorImpl<const Type *> &TypeStack,
|
||||||
}
|
raw_ostream &OS, bool IgnoreTopLevelName = false);
|
||||||
|
};
|
||||||
|
} // end anonymous namespace.
|
||||||
TypePrinting::TypePrinting() {
|
|
||||||
TypeNames = new DenseMap<const Type *, std::string>();
|
|
||||||
}
|
|
||||||
|
|
||||||
TypePrinting::~TypePrinting() {
|
|
||||||
delete &getTypeNamesMap(TypeNames);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// CalcTypeName - Write the specified type to the specified raw_ostream, making
|
/// CalcTypeName - Write the specified type to the specified raw_ostream, making
|
||||||
/// use of type names or up references to shorten the type name where possible.
|
/// use of type names or up references to shorten the type name where possible.
|
||||||
@ -172,7 +187,7 @@ void TypePrinting::CalcTypeName(const Type *Ty,
|
|||||||
raw_ostream &OS, bool IgnoreTopLevelName) {
|
raw_ostream &OS, bool IgnoreTopLevelName) {
|
||||||
// Check to see if the type is named.
|
// Check to see if the type is named.
|
||||||
if (!IgnoreTopLevelName) {
|
if (!IgnoreTopLevelName) {
|
||||||
DenseMap<const Type *, std::string> &TM = getTypeNamesMap(TypeNames);
|
DenseMap<const Type *, std::string> &TM = TypeNames;
|
||||||
DenseMap<const Type *, std::string>::iterator I = TM.find(Ty);
|
DenseMap<const Type *, std::string>::iterator I = TM.find(Ty);
|
||||||
if (I != TM.end()) {
|
if (I != TM.end()) {
|
||||||
OS << I->second;
|
OS << I->second;
|
||||||
@ -283,10 +298,9 @@ void TypePrinting::CalcTypeName(const Type *Ty,
|
|||||||
void TypePrinting::print(const Type *Ty, raw_ostream &OS,
|
void TypePrinting::print(const Type *Ty, raw_ostream &OS,
|
||||||
bool IgnoreTopLevelName) {
|
bool IgnoreTopLevelName) {
|
||||||
// Check to see if the type is named.
|
// Check to see if the type is named.
|
||||||
DenseMap<const Type*, std::string> &TM = getTypeNamesMap(TypeNames);
|
|
||||||
if (!IgnoreTopLevelName) {
|
if (!IgnoreTopLevelName) {
|
||||||
DenseMap<const Type*, std::string>::iterator I = TM.find(Ty);
|
DenseMap<const Type*, std::string>::iterator I = TypeNames.find(Ty);
|
||||||
if (I != TM.end()) {
|
if (I != TypeNames.end()) {
|
||||||
OS << I->second;
|
OS << I->second;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -304,7 +318,7 @@ void TypePrinting::print(const Type *Ty, raw_ostream &OS,
|
|||||||
|
|
||||||
// Cache type name for later use.
|
// Cache type name for later use.
|
||||||
if (!IgnoreTopLevelName)
|
if (!IgnoreTopLevelName)
|
||||||
TM.insert(std::make_pair(Ty, TypeOS.str()));
|
TypeNames.insert(std::make_pair(Ty, TypeOS.str()));
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user