diff options
| -rw-r--r-- | lib/Analysis/ConstantRange.cpp | 2 | ||||
| -rw-r--r-- | lib/Support/ConstantRange.cpp | 2 | ||||
| -rw-r--r-- | lib/Support/LeakDetector.cpp | 22 | ||||
| -rw-r--r-- | lib/VMCore/ConstantRange.cpp | 2 | ||||
| -rw-r--r-- | lib/VMCore/LeakDetector.cpp | 22 | 
5 files changed, 39 insertions, 11 deletions
| diff --git a/lib/Analysis/ConstantRange.cpp b/lib/Analysis/ConstantRange.cpp index 580ca01..3b91c5b 100644 --- a/lib/Analysis/ConstantRange.cpp +++ b/lib/Analysis/ConstantRange.cpp @@ -322,7 +322,7 @@ ConstantRange ConstantRange::truncate(const Type *Ty) const {  /// print - Print out the bounds to a stream...  ///  void ConstantRange::print(std::ostream &OS) const { -  OS << "[" << Lower << "," << Upper << " )"; +  OS << "[" << *Lower << "," << *Upper << " )";  }  /// dump - Allow printing from a debugger easily... diff --git a/lib/Support/ConstantRange.cpp b/lib/Support/ConstantRange.cpp index 580ca01..3b91c5b 100644 --- a/lib/Support/ConstantRange.cpp +++ b/lib/Support/ConstantRange.cpp @@ -322,7 +322,7 @@ ConstantRange ConstantRange::truncate(const Type *Ty) const {  /// print - Print out the bounds to a stream...  ///  void ConstantRange::print(std::ostream &OS) const { -  OS << "[" << Lower << "," << Upper << " )"; +  OS << "[" << *Lower << "," << *Upper << " )";  }  /// dump - Allow printing from a debugger easily... diff --git a/lib/Support/LeakDetector.cpp b/lib/Support/LeakDetector.cpp index 919f7a9..dbdb7dd 100644 --- a/lib/Support/LeakDetector.cpp +++ b/lib/Support/LeakDetector.cpp @@ -18,6 +18,16 @@  using namespace llvm;  namespace { +  template <class T> +  struct PrinterTrait { +    static void print(const T* P) { std::cerr << P; } +  }; + +  template<> +  struct PrinterTrait<Value> { +    static void print(const Value* P) { std::cerr << *P; } +  }; +    template <typename T>    struct LeakDetectorImpl {      LeakDetectorImpl(const char* const name) : Cache(0), Name(name) { } @@ -39,7 +49,7 @@ namespace {        if (o == Cache)          Cache = 0; // Cache hit        else -          Ts.erase(o); +        Ts.erase(o);      }      bool hasGarbage(const std::string& Message) { @@ -49,9 +59,13 @@ namespace {        if (!Ts.empty()) {          std::cerr -            << "Leaked " << Name << " objects found: " << Message << ":\n\t"; -        std::copy(Ts.begin(), Ts.end(), -                  std::ostream_iterator<const T*>(std::cerr, " ")); +            << "Leaked " << Name << " objects found: " << Message << ":\n"; +        for (typename std::set<const T*>::iterator I = Ts.begin(), +               E = Ts.end(); I != E; ++I) { +          std::cerr << "\t"; +          PrinterTrait<T>::print(*I); +          std::cerr << "\n"; +        }          std::cerr << '\n';          // Clear out results so we don't get duplicate warnings on diff --git a/lib/VMCore/ConstantRange.cpp b/lib/VMCore/ConstantRange.cpp index 580ca01..3b91c5b 100644 --- a/lib/VMCore/ConstantRange.cpp +++ b/lib/VMCore/ConstantRange.cpp @@ -322,7 +322,7 @@ ConstantRange ConstantRange::truncate(const Type *Ty) const {  /// print - Print out the bounds to a stream...  ///  void ConstantRange::print(std::ostream &OS) const { -  OS << "[" << Lower << "," << Upper << " )"; +  OS << "[" << *Lower << "," << *Upper << " )";  }  /// dump - Allow printing from a debugger easily... diff --git a/lib/VMCore/LeakDetector.cpp b/lib/VMCore/LeakDetector.cpp index 919f7a9..dbdb7dd 100644 --- a/lib/VMCore/LeakDetector.cpp +++ b/lib/VMCore/LeakDetector.cpp @@ -18,6 +18,16 @@  using namespace llvm;  namespace { +  template <class T> +  struct PrinterTrait { +    static void print(const T* P) { std::cerr << P; } +  }; + +  template<> +  struct PrinterTrait<Value> { +    static void print(const Value* P) { std::cerr << *P; } +  }; +    template <typename T>    struct LeakDetectorImpl {      LeakDetectorImpl(const char* const name) : Cache(0), Name(name) { } @@ -39,7 +49,7 @@ namespace {        if (o == Cache)          Cache = 0; // Cache hit        else -          Ts.erase(o); +        Ts.erase(o);      }      bool hasGarbage(const std::string& Message) { @@ -49,9 +59,13 @@ namespace {        if (!Ts.empty()) {          std::cerr -            << "Leaked " << Name << " objects found: " << Message << ":\n\t"; -        std::copy(Ts.begin(), Ts.end(), -                  std::ostream_iterator<const T*>(std::cerr, " ")); +            << "Leaked " << Name << " objects found: " << Message << ":\n"; +        for (typename std::set<const T*>::iterator I = Ts.begin(), +               E = Ts.end(); I != E; ++I) { +          std::cerr << "\t"; +          PrinterTrait<T>::print(*I); +          std::cerr << "\n"; +        }          std::cerr << '\n';          // Clear out results so we don't get duplicate warnings on | 
