mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-26 07:34:06 +00:00
Fix the way parens are printed around "*ptrName" so that
no parens are printed around *, **, ... alone, except if it is a pointer type for which no name should be printed, as in the result of a cast. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@3506 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
df3fe55e57
commit
969c4ad65d
@ -42,7 +42,7 @@ namespace {
|
|||||||
inline void write(Module *M) { printModule(M); }
|
inline void write(Module *M) { printModule(M); }
|
||||||
|
|
||||||
ostream &printType(const Type *Ty, const string &VariableName = "",
|
ostream &printType(const Type *Ty, const string &VariableName = "",
|
||||||
bool IgnoreName = false);
|
bool IgnoreName = false, bool namedContext = true);
|
||||||
|
|
||||||
void writeOperand(Value *Operand);
|
void writeOperand(Value *Operand);
|
||||||
void writeOperandInternal(Value *Operand);
|
void writeOperandInternal(Value *Operand);
|
||||||
@ -142,11 +142,16 @@ string CWriter::getValueName(const Value *V) {
|
|||||||
return "ltmp_" + itostr(Slot) + "_" + utostr(V->getType()->getUniqueID());
|
return "ltmp_" + itostr(Slot) + "_" + utostr(V->getType()->getUniqueID());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// A pointer type should not use parens around *'s alone, e.g., (**)
|
||||||
|
inline bool ptrTypeNameNeedsParens(const string &NameSoFar) {
|
||||||
|
return (NameSoFar.find_last_not_of('*') != std::string::npos);
|
||||||
|
}
|
||||||
|
|
||||||
// Pass the Type* and the variable name and this prints out the variable
|
// Pass the Type* and the variable name and this prints out the variable
|
||||||
// declaration.
|
// declaration.
|
||||||
//
|
//
|
||||||
ostream &CWriter::printType(const Type *Ty, const string &NameSoFar,
|
ostream &CWriter::printType(const Type *Ty, const string &NameSoFar,
|
||||||
bool IgnoreName) {
|
bool IgnoreName, bool namedContext) {
|
||||||
if (Ty->isPrimitiveType())
|
if (Ty->isPrimitiveType())
|
||||||
switch (Ty->getPrimitiveID()) {
|
switch (Ty->getPrimitiveID()) {
|
||||||
case Type::VoidTyID: return Out << "void " << NameSoFar;
|
case Type::VoidTyID: return Out << "void " << NameSoFar;
|
||||||
@ -210,7 +215,14 @@ ostream &CWriter::printType(const Type *Ty, const string &NameSoFar,
|
|||||||
|
|
||||||
case Type::PointerTyID: {
|
case Type::PointerTyID: {
|
||||||
const PointerType *PTy = cast<PointerType>(Ty);
|
const PointerType *PTy = cast<PointerType>(Ty);
|
||||||
std::string ptrName = NameSoFar.length()? "(*"+NameSoFar+")" : string("*");
|
std::string ptrName = "*" + NameSoFar;
|
||||||
|
|
||||||
|
// Do not need parens around "* NameSoFar" if NameSoFar consists only
|
||||||
|
// of zero or more '*' chars *and* this is not an unnamed pointer type
|
||||||
|
// such as the result type in a cast statement. Otherwise, enclose in ( ).
|
||||||
|
if (ptrTypeNameNeedsParens(NameSoFar) || !namedContext)
|
||||||
|
ptrName = "(" + ptrName + ")"; //
|
||||||
|
|
||||||
return printType(PTy->getElementType(), ptrName);
|
return printType(PTy->getElementType(), ptrName);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -439,9 +451,10 @@ void CWriter::printModule(Module *M) {
|
|||||||
<< "#include <malloc.h>\n"
|
<< "#include <malloc.h>\n"
|
||||||
<< "#include <alloca.h>\n\n"
|
<< "#include <alloca.h>\n\n"
|
||||||
|
|
||||||
// Provide a definition for null if one does not already exist.
|
// Provide a definition for null if one does not already exist,
|
||||||
|
// and for `bool' if not compiling with a C++ compiler.
|
||||||
<< "#ifndef NULL\n#define NULL 0\n#endif\n\n"
|
<< "#ifndef NULL\n#define NULL 0\n#endif\n\n"
|
||||||
<< "typedef unsigned char bool;\n"
|
<< "#ifndef __cplusplus\ntypedef unsigned char bool;\n#endif\n"
|
||||||
|
|
||||||
<< "\n\n/* Global Declarations */\n";
|
<< "\n\n/* Global Declarations */\n";
|
||||||
|
|
||||||
@ -755,7 +768,7 @@ void CWriter::visitBinaryOperator(Instruction &I) {
|
|||||||
|
|
||||||
void CWriter::visitCastInst(CastInst &I) {
|
void CWriter::visitCastInst(CastInst &I) {
|
||||||
Out << "(";
|
Out << "(";
|
||||||
printType(I.getType());
|
printType(I.getType(), string(""),/*ignoreName*/false, /*namedContext*/false);
|
||||||
Out << ")";
|
Out << ")";
|
||||||
writeOperand(I.getOperand(0));
|
writeOperand(I.getOperand(0));
|
||||||
}
|
}
|
||||||
|
@ -42,7 +42,7 @@ namespace {
|
|||||||
inline void write(Module *M) { printModule(M); }
|
inline void write(Module *M) { printModule(M); }
|
||||||
|
|
||||||
ostream &printType(const Type *Ty, const string &VariableName = "",
|
ostream &printType(const Type *Ty, const string &VariableName = "",
|
||||||
bool IgnoreName = false);
|
bool IgnoreName = false, bool namedContext = true);
|
||||||
|
|
||||||
void writeOperand(Value *Operand);
|
void writeOperand(Value *Operand);
|
||||||
void writeOperandInternal(Value *Operand);
|
void writeOperandInternal(Value *Operand);
|
||||||
@ -142,11 +142,16 @@ string CWriter::getValueName(const Value *V) {
|
|||||||
return "ltmp_" + itostr(Slot) + "_" + utostr(V->getType()->getUniqueID());
|
return "ltmp_" + itostr(Slot) + "_" + utostr(V->getType()->getUniqueID());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// A pointer type should not use parens around *'s alone, e.g., (**)
|
||||||
|
inline bool ptrTypeNameNeedsParens(const string &NameSoFar) {
|
||||||
|
return (NameSoFar.find_last_not_of('*') != std::string::npos);
|
||||||
|
}
|
||||||
|
|
||||||
// Pass the Type* and the variable name and this prints out the variable
|
// Pass the Type* and the variable name and this prints out the variable
|
||||||
// declaration.
|
// declaration.
|
||||||
//
|
//
|
||||||
ostream &CWriter::printType(const Type *Ty, const string &NameSoFar,
|
ostream &CWriter::printType(const Type *Ty, const string &NameSoFar,
|
||||||
bool IgnoreName) {
|
bool IgnoreName, bool namedContext) {
|
||||||
if (Ty->isPrimitiveType())
|
if (Ty->isPrimitiveType())
|
||||||
switch (Ty->getPrimitiveID()) {
|
switch (Ty->getPrimitiveID()) {
|
||||||
case Type::VoidTyID: return Out << "void " << NameSoFar;
|
case Type::VoidTyID: return Out << "void " << NameSoFar;
|
||||||
@ -210,7 +215,14 @@ ostream &CWriter::printType(const Type *Ty, const string &NameSoFar,
|
|||||||
|
|
||||||
case Type::PointerTyID: {
|
case Type::PointerTyID: {
|
||||||
const PointerType *PTy = cast<PointerType>(Ty);
|
const PointerType *PTy = cast<PointerType>(Ty);
|
||||||
std::string ptrName = NameSoFar.length()? "(*"+NameSoFar+")" : string("*");
|
std::string ptrName = "*" + NameSoFar;
|
||||||
|
|
||||||
|
// Do not need parens around "* NameSoFar" if NameSoFar consists only
|
||||||
|
// of zero or more '*' chars *and* this is not an unnamed pointer type
|
||||||
|
// such as the result type in a cast statement. Otherwise, enclose in ( ).
|
||||||
|
if (ptrTypeNameNeedsParens(NameSoFar) || !namedContext)
|
||||||
|
ptrName = "(" + ptrName + ")"; //
|
||||||
|
|
||||||
return printType(PTy->getElementType(), ptrName);
|
return printType(PTy->getElementType(), ptrName);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -439,9 +451,10 @@ void CWriter::printModule(Module *M) {
|
|||||||
<< "#include <malloc.h>\n"
|
<< "#include <malloc.h>\n"
|
||||||
<< "#include <alloca.h>\n\n"
|
<< "#include <alloca.h>\n\n"
|
||||||
|
|
||||||
// Provide a definition for null if one does not already exist.
|
// Provide a definition for null if one does not already exist,
|
||||||
|
// and for `bool' if not compiling with a C++ compiler.
|
||||||
<< "#ifndef NULL\n#define NULL 0\n#endif\n\n"
|
<< "#ifndef NULL\n#define NULL 0\n#endif\n\n"
|
||||||
<< "typedef unsigned char bool;\n"
|
<< "#ifndef __cplusplus\ntypedef unsigned char bool;\n#endif\n"
|
||||||
|
|
||||||
<< "\n\n/* Global Declarations */\n";
|
<< "\n\n/* Global Declarations */\n";
|
||||||
|
|
||||||
@ -755,7 +768,7 @@ void CWriter::visitBinaryOperator(Instruction &I) {
|
|||||||
|
|
||||||
void CWriter::visitCastInst(CastInst &I) {
|
void CWriter::visitCastInst(CastInst &I) {
|
||||||
Out << "(";
|
Out << "(";
|
||||||
printType(I.getType());
|
printType(I.getType(), string(""),/*ignoreName*/false, /*namedContext*/false);
|
||||||
Out << ")";
|
Out << ")";
|
||||||
writeOperand(I.getOperand(0));
|
writeOperand(I.getOperand(0));
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user