Mercurial > hg > Members > tobaru > cbc > CbC_llvm
view include/llvm/Support/RecyclingAllocator.h @ 125:56c5119fbcd2
fix
author | mir3636 |
---|---|
date | Sun, 03 Dec 2017 20:09:16 +0900 |
parents | 1172e4bd9c6f |
children |
line wrap: on
line source
//==- llvm/Support/RecyclingAllocator.h - Recycling Allocator ----*- C++ -*-==// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // This file defines the RecyclingAllocator class. See the doxygen comment for // RecyclingAllocator for more details on the implementation. // //===----------------------------------------------------------------------===// #ifndef LLVM_SUPPORT_RECYCLINGALLOCATOR_H #define LLVM_SUPPORT_RECYCLINGALLOCATOR_H #include "llvm/Support/Recycler.h" namespace llvm { /// RecyclingAllocator - This class wraps an Allocator, adding the /// functionality of recycling deleted objects. /// template <class AllocatorType, class T, size_t Size = sizeof(T), size_t Align = alignof(T)> class RecyclingAllocator { private: /// Base - Implementation details. /// Recycler<T, Size, Align> Base; /// Allocator - The wrapped allocator. /// AllocatorType Allocator; public: ~RecyclingAllocator() { Base.clear(Allocator); } /// Allocate - Return a pointer to storage for an object of type /// SubClass. The storage may be either newly allocated or recycled. /// template<class SubClass> SubClass *Allocate() { return Base.template Allocate<SubClass>(Allocator); } T *Allocate() { return Base.Allocate(Allocator); } /// Deallocate - Release storage for the pointed-to object. The /// storage will be kept track of and may be recycled. /// template<class SubClass> void Deallocate(SubClass* E) { return Base.Deallocate(Allocator, E); } void PrintStats() { Allocator.PrintStats(); Base.PrintStats(); } }; } template<class AllocatorType, class T, size_t Size, size_t Align> inline void *operator new(size_t size, llvm::RecyclingAllocator<AllocatorType, T, Size, Align> &Allocator) { assert(size <= Size && "allocation size exceeded"); return Allocator.Allocate(); } template<class AllocatorType, class T, size_t Size, size_t Align> inline void operator delete(void *E, llvm::RecyclingAllocator<AllocatorType, T, Size, Align> &A) { A.Deallocate(E); } #endif