summaryrefslogtreecommitdiff
path: root/include/llvm/ADT/APSInt.h
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2008-08-17 07:19:36 +0000
committerChris Lattner <sabre@nondot.org>2008-08-17 07:19:36 +0000
commitfad86b003a839cef40ec8ce8408322f4913368ca (patch)
tree4049a1355d17df35e86a6806d300f0c894bb3fd9 /include/llvm/ADT/APSInt.h
parentb6c8a4098fd23c21d6cda33b09b99b5a0ac1e13f (diff)
downloadllvm-fad86b003a839cef40ec8ce8408322f4913368ca.tar.gz
llvm-fad86b003a839cef40ec8ce8408322f4913368ca.tar.bz2
llvm-fad86b003a839cef40ec8ce8408322f4913368ca.tar.xz
Rework the routines that convert AP[S]Int into a string. Now, instead of
returning an std::string by value, it fills in a SmallString/SmallVector passed in. This significantly reduces string thrashing in some cases. More specifically, this: - Adds an operator<< and a print method for APInt that allows you to directly send them to an ostream. - Reimplements APInt::toString to be much simpler and more efficient algorithmically in addition to not thrashing strings quite as much. This speeds up llvm-dis on kc++ by 7%, and may also slightly speed up the asmprinter. This also fixes a bug I introduced into the asmwriter in a previous patch w.r.t. alias printing. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@54873 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/ADT/APSInt.h')
-rw-r--r--include/llvm/ADT/APSInt.h18
1 files changed, 14 insertions, 4 deletions
diff --git a/include/llvm/ADT/APSInt.h b/include/llvm/ADT/APSInt.h
index edb36bafe4..00bece62ad 100644
--- a/include/llvm/ADT/APSInt.h
+++ b/include/llvm/ADT/APSInt.h
@@ -19,7 +19,6 @@
namespace llvm {
-
class APSInt : public APInt {
bool IsUnsigned;
public:
@@ -58,11 +57,16 @@ public:
void setIsUnsigned(bool Val) { IsUnsigned = Val; }
void setIsSigned(bool Val) { IsUnsigned = !Val; }
- /// This is used internally to convert an APInt to a string.
- /// @brief Converts an APInt to a std::string
- std::string toString(uint8_t Radix = 10) const {
+ /// toString - Append this APSInt to the specified SmallString.
+ void toString(SmallVectorImpl<char> &Str, unsigned Radix = 10) const {
+ return APInt::toString(Str, Radix, isSigned());
+ }
+ /// toString - Converts an APInt to a std::string. This is an inefficient
+ /// method, your should prefer passing in a SmallString instead.
+ std::string toString(unsigned Radix) const {
return APInt::toString(Radix, isSigned());
}
+ using APInt::toString;
APSInt& extend(uint32_t width) {
if (IsUnsigned)
@@ -235,6 +239,12 @@ public:
void Profile(FoldingSetNodeID& ID) const;
};
+inline std::ostream &operator<<(std::ostream &OS, const APSInt &I) {
+ I.print(OS, I.isSigned());
+ return OS;
+}
+
+
} // end namespace llvm
#endif