diff options
author | Daniel Dunbar <daniel@zuster.org> | 2009-08-19 18:09:47 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2009-08-19 18:09:47 +0000 |
commit | ea579e3d297371f45e97277c89cc7353f5607d9e (patch) | |
tree | 6c5631affd2088b99b961a9504da602def6c3fa4 /llvm/lib/Support/Twine.cpp | |
parent | a7c2dfbca1142aa120ba1350b415a463dddb04a4 (diff) | |
download | bcm5719-llvm-ea579e3d297371f45e97277c89cc7353f5607d9e.tar.gz bcm5719-llvm-ea579e3d297371f45e97277c89cc7353f5607d9e.zip |
Switch Twine::str() to use toVector(), which is now efficient.
llvm-svn: 79437
Diffstat (limited to 'llvm/lib/Support/Twine.cpp')
-rw-r--r-- | llvm/lib/Support/Twine.cpp | 18 |
1 files changed, 4 insertions, 14 deletions
diff --git a/llvm/lib/Support/Twine.cpp b/llvm/lib/Support/Twine.cpp index 611af8c5ae0..292c0c2b9e5 100644 --- a/llvm/lib/Support/Twine.cpp +++ b/llvm/lib/Support/Twine.cpp @@ -8,27 +8,17 @@ //===----------------------------------------------------------------------===// #include "llvm/ADT/Twine.h" +#include "llvm/ADT/SmallString.h" #include "llvm/Support/raw_ostream.h" using namespace llvm; std::string Twine::str() const { - // FIXME: This should probably use the toVector implementation, once that is - // efficient. - std::string Res; - raw_string_ostream OS(Res); - print(OS); - OS.flush(); - return Res; + SmallString<256> Vec; + toVector(Vec); + return std::string(Vec.begin(), Vec.end()); } void Twine::toVector(SmallVectorImpl<char> &Out) const { - // FIXME: This is very inefficient, since we are creating a large raw_ostream - // buffer -- hitting malloc, which we were supposed to avoid -- all when we - // have this pretty little small vector available. - // - // The best way to fix this is to make raw_svector_ostream do the right thing - // and be efficient, by augmenting the base raw_ostream with the ability to - // have the buffer managed by a concrete implementation. raw_svector_ostream OS(Out); print(OS); } |