diff options
| -rw-r--r-- | llvm/include/llvm/Support/ManagedStatic.h | 7 | ||||
| -rw-r--r-- | llvm/unittests/Support/ManagedStatic.cpp | 42 |
2 files changed, 46 insertions, 3 deletions
diff --git a/llvm/include/llvm/Support/ManagedStatic.h b/llvm/include/llvm/Support/ManagedStatic.h index 7ce86eee95d..26e20115441 100644 --- a/llvm/include/llvm/Support/ManagedStatic.h +++ b/llvm/include/llvm/Support/ManagedStatic.h @@ -59,14 +59,15 @@ public: /// libraries that link in LLVM components) and for making destruction be /// explicit through the llvm_shutdown() function call. /// -template<class C> +template <class C, void *(*Creator)() = object_creator<C>, + void (*Deleter)(void *) = object_deleter<C>::call> class ManagedStatic : public ManagedStaticBase { public: // Accessors. C &operator*() { void *Tmp = Ptr.load(std::memory_order_acquire); if (!Tmp) - RegisterManagedStatic(object_creator<C>, object_deleter<C>::call); + RegisterManagedStatic(Creator, Deleter); return *static_cast<C *>(Ptr.load(std::memory_order_relaxed)); } @@ -76,7 +77,7 @@ public: const C &operator*() const { void *Tmp = Ptr.load(std::memory_order_acquire); if (!Tmp) - RegisterManagedStatic(object_creator<C>, object_deleter<C>::call); + RegisterManagedStatic(Creator, Deleter); return *static_cast<C *>(Ptr.load(std::memory_order_relaxed)); } diff --git a/llvm/unittests/Support/ManagedStatic.cpp b/llvm/unittests/Support/ManagedStatic.cpp index 153884ba429..9c84ce8cb51 100644 --- a/llvm/unittests/Support/ManagedStatic.cpp +++ b/llvm/unittests/Support/ManagedStatic.cpp @@ -57,4 +57,46 @@ TEST(Initialize, MultipleThreads) { } #endif +namespace NestedStatics { +static ManagedStatic<int> Ms1; +struct Nest { + Nest() { + ++(*Ms1); + } + + ~Nest() { + assert(Ms1.isConstructed()); + ++(*Ms1); + } +}; +static ManagedStatic<Nest> Ms2; + +TEST(ManagedStaticTest, NestedStatics) { + EXPECT_FALSE(Ms1.isConstructed()); + EXPECT_FALSE(Ms2.isConstructed()); + + *Ms2; + EXPECT_TRUE(Ms1.isConstructed()); + EXPECT_TRUE(Ms2.isConstructed()); + + llvm_shutdown(); + EXPECT_FALSE(Ms1.isConstructed()); + EXPECT_FALSE(Ms2.isConstructed()); +} +} // namespace NestedStatics + +namespace CustomCreatorDeletor { +static void *CustomCreate() { + void *Mem = std::malloc(sizeof(int)); + *((int *)Mem) = 42; + return Mem; +} +static ManagedStatic<int, CustomCreate, std::free> Custom; +TEST(ManagedStaticTest, CustomCreatorDeletor) { + EXPECT_EQ(42, *Custom); + llvm_shutdown(); + EXPECT_FALSE(Custom.isConstructed()); +} +} // namespace CustomCreatorDeletor + } // anonymous namespace |

