aboutsummaryrefslogtreecommitdiff
path: root/lib/Target/CBackend/CBackend.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2002-05-09 03:56:52 +0000
committerChris Lattner <sabre@nondot.org>2002-05-09 03:56:52 +0000
commit2f5eb4e9a55b06cec0516a2e6a371afd46f0fd12 (patch)
tree1e8c880afedafed2533d170cc0c8239ac7d5c089 /lib/Target/CBackend/CBackend.cpp
parent4440826cae4b22e98105b2e9f69e864e23e3d390 (diff)
* Remove dead function
* Print C strings correctly * Expand C escape sequences nicely (ie \n \t, etc get generated instead of hex escapes) git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2572 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/CBackend/CBackend.cpp')
-rw-r--r--lib/Target/CBackend/CBackend.cpp29
1 files changed, 20 insertions, 9 deletions
diff --git a/lib/Target/CBackend/CBackend.cpp b/lib/Target/CBackend/CBackend.cpp
index bb5f75de3e..630abecbd0 100644
--- a/lib/Target/CBackend/CBackend.cpp
+++ b/lib/Target/CBackend/CBackend.cpp
@@ -72,11 +72,6 @@ static string makeNameProper(string x) {
return tmp;
}
-static string getConstantName(const Constant *CPV) {
- return CPV->getName();
-}
-
-
static std::string getConstArrayStrValue(const Constant* CPV) {
std::string Result;
@@ -94,10 +89,17 @@ static std::string getConstArrayStrValue(const Constant* CPV) {
break;
}
}
+ if (isString) {
+ // Make sure the last character is a null char, as automatically added by C
+ if (CPV->getNumOperands() == 0 ||
+ !cast<Constant>(*(CPV->op_end()-1))->isNullValue())
+ isString = false;
+ }
if (isString) {
Result = "\"";
- for (unsigned i = 0; i < CPV->getNumOperands(); ++i) {
+ // Do not include the last character, which we know is null
+ for (unsigned i = 0, e = CPV->getNumOperands()-1; i != e; ++i) {
unsigned char C = (ETy == Type::SByteTy) ?
(unsigned char)cast<ConstantSInt>(CPV->getOperand(i))->getValue() :
(unsigned char)cast<ConstantUInt>(CPV->getOperand(i))->getValue();
@@ -105,9 +107,18 @@ static std::string getConstArrayStrValue(const Constant* CPV) {
if (isprint(C)) {
Result += C;
} else {
- Result += "\\x";
- Result += ( C/16 < 10) ? ( C/16 +'0') : ( C/16 -10+'A');
- Result += ((C&15) < 10) ? ((C&15)+'0') : ((C&15)-10+'A');
+ switch (C) {
+ case '\n': Result += "\\n"; break;
+ case '\t': Result += "\\t"; break;
+ case '\r': Result += "\\r"; break;
+ case '\v': Result += "\\v"; break;
+ case '\a': Result += "\\a"; break;
+ default:
+ Result += "\\x";
+ Result += ( C/16 < 10) ? ( C/16 +'0') : ( C/16 -10+'A');
+ Result += ((C&15) < 10) ? ((C&15)+'0') : ((C&15)-10+'A');
+ break;
+ }
}
}
Result += "\"";