diff options
author | Daniel Dunbar <daniel@zuster.org> | 2009-07-30 21:15:14 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2009-07-30 21:15:14 +0000 |
commit | a91dd9bf5f7f3042daff2ade1563dcda58a47f8f (patch) | |
tree | fcaac66b19aabb6e66075edb6f1127bfa1e1d473 /llvm/lib/Support/Twine.cpp | |
parent | f4362da1b710a7c29612515daf5b0582ce37302c (diff) | |
download | bcm5719-llvm-a91dd9bf5f7f3042daff2ade1563dcda58a47f8f.tar.gz bcm5719-llvm-a91dd9bf5f7f3042daff2ade1563dcda58a47f8f.zip |
Twine: Directly support int, long, and long long types.
- This should resolve Cygwin gcc ambiguities.
llvm-svn: 77624
Diffstat (limited to 'llvm/lib/Support/Twine.cpp')
-rw-r--r-- | llvm/lib/Support/Twine.cpp | 46 |
1 files changed, 29 insertions, 17 deletions
diff --git a/llvm/lib/Support/Twine.cpp b/llvm/lib/Support/Twine.cpp index 83a3a6180f3..8b8c0f0db80 100644 --- a/llvm/lib/Support/Twine.cpp +++ b/llvm/lib/Support/Twine.cpp @@ -47,17 +47,23 @@ void Twine::printOneChild(raw_ostream &OS, const void *Ptr, case Twine::StringRefKind: OS << *static_cast<const StringRef*>(Ptr); break; - case Twine::UDec32Kind: - OS << *static_cast<const uint32_t*>(Ptr); + case Twine::DecUIKind: + OS << *static_cast<const unsigned int*>(Ptr); break; - case Twine::SDec32Kind: - OS << *static_cast<const int32_t*>(Ptr); + case Twine::DecIKind: + OS << *static_cast<const int*>(Ptr); break; - case Twine::UDec64Kind: - OS << *static_cast<const uint64_t*>(Ptr); + case Twine::DecULKind: + OS << *static_cast<const unsigned long*>(Ptr); break; - case Twine::SDec64Kind: - OS << *static_cast<const int64_t*>(Ptr); + case Twine::DecLKind: + OS << *static_cast<const long*>(Ptr); + break; + case Twine::DecULLKind: + OS << *static_cast<const unsigned long long*>(Ptr); + break; + case Twine::DecLLKind: + OS << *static_cast<const long long*>(Ptr); break; case Twine::UHexKind: OS.write_hex(*static_cast<const uint64_t*>(Ptr)); @@ -88,20 +94,26 @@ void Twine::printOneChildRepr(raw_ostream &OS, const void *Ptr, OS << "stringref:\"" << static_cast<const StringRef*>(Ptr) << "\""; break; - case Twine::UDec32Kind: - OS << "udec32:" << static_cast<const uint64_t*>(Ptr) << "\""; + case Twine::DecUIKind: + OS << "decUI:\"" << *static_cast<const unsigned int*>(Ptr) << "\""; + break; + case Twine::DecIKind: + OS << "decI:\"" << *static_cast<const int*>(Ptr) << "\""; + break; + case Twine::DecULKind: + OS << "decUL:\"" << *static_cast<const unsigned long*>(Ptr) << "\""; break; - case Twine::SDec32Kind: - OS << "sdec32:" << static_cast<const int64_t*>(Ptr) << "\""; + case Twine::DecLKind: + OS << "decL:\"" << *static_cast<const long*>(Ptr) << "\""; break; - case Twine::UDec64Kind: - OS << "udec64:" << static_cast<const uint64_t*>(Ptr) << "\""; + case Twine::DecULLKind: + OS << "decULL:\"" << *static_cast<const unsigned long long*>(Ptr) << "\""; break; - case Twine::SDec64Kind: - OS << "sdec64:" << static_cast<const int64_t*>(Ptr) << "\""; + case Twine::DecLLKind: + OS << "decLL:\"" << *static_cast<const long long*>(Ptr) << "\""; break; case Twine::UHexKind: - OS << "uhex:" << static_cast<const uint64_t*>(Ptr) << "\""; + OS << "uhex:\"" << static_cast<const uint64_t*>(Ptr) << "\""; break; } } |