diff options
| author | Chris Lattner <sabre@nondot.org> | 2008-08-17 07:19:36 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2008-08-17 07:19:36 +0000 |
| commit | 17f7165f849c17004b37b6db02b91d80cecb1855 (patch) | |
| tree | 43fb323d6789a0fd64e0ced1d40b3177fb355b2a /llvm/lib/Support/ConstantRange.cpp | |
| parent | 286e5e6c611f492dccba12988c851510bfbb2f63 (diff) | |
| download | llvm-17f7165f849c17004b37b6db02b91d80cecb1855.zip llvm-17f7165f849c17004b37b6db02b91d80cecb1855.tar.gz llvm-17f7165f849c17004b37b6db02b91d80cecb1855.tar.bz2 | |
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.
llvm-svn: 54873
Diffstat (limited to 'llvm/lib/Support/ConstantRange.cpp')
| -rw-r--r-- | llvm/lib/Support/ConstantRange.cpp | 3 |
1 files changed, 1 insertions, 2 deletions
diff --git a/llvm/lib/Support/ConstantRange.cpp b/llvm/lib/Support/ConstantRange.cpp index 0d22b32..9c83b7c 100644 --- a/llvm/lib/Support/ConstantRange.cpp +++ b/llvm/lib/Support/ConstantRange.cpp @@ -463,8 +463,7 @@ ConstantRange ConstantRange::truncate(uint32_t DstTySize) const { /// print - Print out the bounds to a stream... /// void ConstantRange::print(std::ostream &OS) const { - OS << "[" << Lower.toStringSigned(10) << "," - << Upper.toStringSigned(10) << ")"; + OS << "[" << Lower << "," << Upper << ")"; } /// dump - Allow printing from a debugger easily... |
