From abff3aa8217049cffe6da77c91e510c66b8c2313 Mon Sep 17 00:00:00 2001 From: Manuel Klimek Date: Mon, 3 Jun 2013 13:03:05 +0000 Subject: [PATCH] Introduce needsCleanup() for APFloat and APInt. This is needed in clang so one can check if the object needs the destructor called after its memory was freed. This is useful when creating many APInt/APFloat objects with placement new, where the overhead of tracking the pointers for cleanup is significant. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@183100 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/ADT/APFloat.h | 3 +++ include/llvm/ADT/APInt.h | 5 ++++- lib/Support/APFloat.cpp | 2 +- 3 files changed, 8 insertions(+), 2 deletions(-) diff --git a/include/llvm/ADT/APFloat.h b/include/llvm/ADT/APFloat.h index 64e56a0ef6a..33f997e1734 100644 --- a/include/llvm/ADT/APFloat.h +++ b/include/llvm/ADT/APFloat.h @@ -201,6 +201,9 @@ public: /// @} + /// \brief Returns whether this instance allocated memory. + bool needsCleanup() const { return partCount() > 1; } + /// \name Convenience "constructors" /// @{ diff --git a/include/llvm/ADT/APInt.h b/include/llvm/ADT/APInt.h index a9df4036be2..e5797b8be23 100644 --- a/include/llvm/ADT/APInt.h +++ b/include/llvm/ADT/APInt.h @@ -293,7 +293,7 @@ public: /// \brief Destructor. ~APInt() { - if (!isSingleWord()) + if (needsCleanup()) delete[] pVal; } @@ -303,6 +303,9 @@ public: /// method Read). explicit APInt() : BitWidth(1) {} + /// \brief Returns whether this instance allocated memory. + bool needsCleanup() const { return !isSingleWord(); } + /// Used to insert APInt objects, or objects that contain APInt objects, into /// FoldingSets. void Profile(FoldingSetNodeID &id) const; diff --git a/lib/Support/APFloat.cpp b/lib/Support/APFloat.cpp index 16586fbc9e8..2ad66c5687c 100644 --- a/lib/Support/APFloat.cpp +++ b/lib/Support/APFloat.cpp @@ -580,7 +580,7 @@ APFloat::initialize(const fltSemantics *ourSemantics) void APFloat::freeSignificand() { - if (partCount() > 1) + if (needsCleanup()) delete [] significand.parts; }