+struct CYData {
+ apr_pool_t *pool_;
+ unsigned count_;
+
+ CYData() :
+ count_(1)
+ {
+ }
+
+ virtual ~CYData() {
+ }
+
+ static void *operator new(size_t size, apr_pool_t *pool) {
+ void *data(apr_palloc(pool, size));
+ reinterpret_cast<CYData *>(data)->pool_ = pool;
+ return data;
+ }
+
+ static void *operator new(size_t size) {
+ apr_pool_t *pool;
+ _aprcall(apr_pool_create(&pool, NULL));
+ return operator new(size, pool);
+ }
+
+ static void operator delete(void *data) {
+ apr_pool_destroy(reinterpret_cast<CYData *>(data)->pool_);
+ }
+};
+
+template <typename Type_>
+struct CYPoolAllocator {
+ apr_pool_t *pool_;
+
+ typedef Type_ value_type;
+ typedef value_type *pointer;
+ typedef const value_type *const_pointer;
+ typedef value_type &reference;
+ typedef const value_type &const_reference;
+ typedef std::size_t size_type;
+ typedef std::ptrdiff_t difference_type;
+
+ CYPoolAllocator() :
+ pool_(NULL)
+ {
+ }
+
+ template <typename Right_>
+ CYPoolAllocator(const CYPoolAllocator<Right_> &rhs) :
+ pool_(rhs.pool_)
+ {
+ }
+
+ pointer allocate(size_type size, const void *hint = 0) {
+ return reinterpret_cast<pointer>(apr_palloc(pool_, size));
+ }
+
+ void deallocate(pointer data, size_type size) {
+ }
+
+ void construct(pointer address, const Type_ &rhs) {
+ new(address) Type_(rhs);
+ }
+
+ void destroy(pointer address) {
+ address->~Type_();
+ }
+
+ template <typename Right_>
+ inline bool operator==(const CYPoolAllocator<Right_> &rhs) {
+ return pool_ == rhs.pool_;
+ }
+
+ template <typename Right_>
+ inline bool operator!=(const CYPoolAllocator<Right_> &rhs) {
+ return !operator==(rhs);
+ }
+
+ template <typename Right_>
+ struct rebind {
+ typedef CYPoolAllocator<Right_> other;
+ };
+};
+
+class CYLocalPool :
+ public CYPool
+{
+ private:
+ CYLocal<apr_pool_t> local_;
+
+ public:
+ CYLocalPool() :
+ CYPool(),
+ local_(operator apr_pool_t *())
+ {
+ }
+};
+
+#define $pool \
+ CYLocal<apr_pool_t>::Get()
+
+#endif/*CYCRIPT_POOLING_HPP*/