summaryrefslogtreecommitdiffstats
path: root/contrib/libs/antlr3_cpp_runtime/include/antlr3memory.hpp
diff options
context:
space:
mode:
authorisiv <[email protected]>2022-02-10 16:47:54 +0300
committerDaniil Cherednik <[email protected]>2022-02-10 16:47:54 +0300
commitf20e3f1949626df2ef9d81d7618ec367b0c34f6b (patch)
tree36465c9262a386743fc483efb848be6d76c5ac04 /contrib/libs/antlr3_cpp_runtime/include/antlr3memory.hpp
parent7a839432184dcd989efaeccf678e4238d71bd9b0 (diff)
Restoring authorship annotation for <[email protected]>. Commit 1 of 2.
Diffstat (limited to 'contrib/libs/antlr3_cpp_runtime/include/antlr3memory.hpp')
-rw-r--r--contrib/libs/antlr3_cpp_runtime/include/antlr3memory.hpp266
1 files changed, 133 insertions, 133 deletions
diff --git a/contrib/libs/antlr3_cpp_runtime/include/antlr3memory.hpp b/contrib/libs/antlr3_cpp_runtime/include/antlr3memory.hpp
index 7b85f67545d..6a3d6d38ccc 100644
--- a/contrib/libs/antlr3_cpp_runtime/include/antlr3memory.hpp
+++ b/contrib/libs/antlr3_cpp_runtime/include/antlr3memory.hpp
@@ -1,5 +1,5 @@
-#ifndef _ANTLR3MEMORY_HPP
-#define _ANTLR3MEMORY_HPP
+#ifndef _ANTLR3MEMORY_HPP
+#define _ANTLR3MEMORY_HPP
// [The "BSD licence"]
// Copyright (c) 2005-2009 Gokulakannan Somasundaram, ElectronDB
@@ -29,146 +29,146 @@
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
// THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-namespace antlr3 {
+namespace antlr3 {
class DefaultAllocPolicy
{
public:
- //limitation of c++. unable to write a typedef
- template <class TYPE>
- class AllocatorType : public std::allocator<TYPE>
- {
- public:
- 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 size_t size_type;
- typedef ptrdiff_t difference_type;
- template<class U> struct rebind {
- typedef AllocatorType<U> other;
- };
+ //limitation of c++. unable to write a typedef
+ template <class TYPE>
+ class AllocatorType : public std::allocator<TYPE>
+ {
+ public:
+ 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 size_t size_type;
+ typedef ptrdiff_t difference_type;
+ template<class U> struct rebind {
+ typedef AllocatorType<U> other;
+ };
AllocatorType() noexcept {}
AllocatorType( const AllocatorType& ) noexcept {}
template<typename U> AllocatorType(const AllocatorType<U>& ) noexcept{}
- };
-
- template<class TYPE>
- class VectorType : public std::vector< TYPE, AllocatorType<TYPE> >
- {
- };
-
- template<class TYPE>
- class ListType : public std::deque< TYPE, AllocatorType<TYPE> >
- {
- };
-
- template<class TYPE>
- class StackType : public std::deque< TYPE, AllocatorType<TYPE> >
- {
- public:
- void push( const TYPE& elem ) { this->push_back(elem); }
- void pop() { this->pop_back(); }
- TYPE& peek() { return this->back(); }
- TYPE& top() { return this->back(); }
- const TYPE& peek() const { return this->back(); }
- const TYPE& top() const { return this->back(); }
- };
-
-
- template<class TYPE>
- class OrderedSetType : public std::set< TYPE, std::less<TYPE>, AllocatorType<TYPE> >
- {
- };
-
- template<class TYPE>
- class UnOrderedSetType : public std::set< TYPE, std::less<TYPE>, AllocatorType<TYPE> >
- {
- };
-
- template<class KeyType, class ValueType>
- class UnOrderedMapType : public std::map< KeyType, ValueType, std::less<KeyType>,
- AllocatorType<std::pair<const KeyType, ValueType> > >
- {
- };
-
- template<class KeyType, class ValueType>
- class OrderedMapType : public std::map< KeyType, ValueType, std::less<KeyType>,
- AllocatorType<std::pair<KeyType, ValueType> > >
- {
- };
-
- template<class TYPE>
- class SmartPtrType : public std::unique_ptr<TYPE, std::default_delete<TYPE> >
- {
- typedef typename std::unique_ptr<TYPE, std::default_delete<TYPE> > BaseType;
- public:
- SmartPtrType() {};
- SmartPtrType( SmartPtrType&& other )
- : BaseType(other)
- {};
- SmartPtrType & operator=(SmartPtrType&& other) //= default;
- {
- BaseType::swap(other);
- //return std::move((BaseType&)other);
- return *this;
- }
- private:
- SmartPtrType & operator=(const SmartPtrType&) /*= delete*/;
- SmartPtrType(const SmartPtrType&) /*= delete*/;
- };
-
- ANTLR_INLINE static void* operator new (std::size_t bytes)
- {
- void* p = alloc(bytes);
- return p;
- }
- ANTLR_INLINE static void* operator new (std::size_t , void* p) { return p; }
- ANTLR_INLINE static void* operator new[]( std::size_t bytes)
- {
+ };
+
+ template<class TYPE>
+ class VectorType : public std::vector< TYPE, AllocatorType<TYPE> >
+ {
+ };
+
+ template<class TYPE>
+ class ListType : public std::deque< TYPE, AllocatorType<TYPE> >
+ {
+ };
+
+ template<class TYPE>
+ class StackType : public std::deque< TYPE, AllocatorType<TYPE> >
+ {
+ public:
+ void push( const TYPE& elem ) { this->push_back(elem); }
+ void pop() { this->pop_back(); }
+ TYPE& peek() { return this->back(); }
+ TYPE& top() { return this->back(); }
+ const TYPE& peek() const { return this->back(); }
+ const TYPE& top() const { return this->back(); }
+ };
+
+
+ template<class TYPE>
+ class OrderedSetType : public std::set< TYPE, std::less<TYPE>, AllocatorType<TYPE> >
+ {
+ };
+
+ template<class TYPE>
+ class UnOrderedSetType : public std::set< TYPE, std::less<TYPE>, AllocatorType<TYPE> >
+ {
+ };
+
+ template<class KeyType, class ValueType>
+ class UnOrderedMapType : public std::map< KeyType, ValueType, std::less<KeyType>,
+ AllocatorType<std::pair<const KeyType, ValueType> > >
+ {
+ };
+
+ template<class KeyType, class ValueType>
+ class OrderedMapType : public std::map< KeyType, ValueType, std::less<KeyType>,
+ AllocatorType<std::pair<KeyType, ValueType> > >
+ {
+ };
+
+ template<class TYPE>
+ class SmartPtrType : public std::unique_ptr<TYPE, std::default_delete<TYPE> >
+ {
+ typedef typename std::unique_ptr<TYPE, std::default_delete<TYPE> > BaseType;
+ public:
+ SmartPtrType() {};
+ SmartPtrType( SmartPtrType&& other )
+ : BaseType(other)
+ {};
+ SmartPtrType & operator=(SmartPtrType&& other) //= default;
+ {
+ BaseType::swap(other);
+ //return std::move((BaseType&)other);
+ return *this;
+ }
+ private:
+ SmartPtrType & operator=(const SmartPtrType&) /*= delete*/;
+ SmartPtrType(const SmartPtrType&) /*= delete*/;
+ };
+
+ ANTLR_INLINE static void* operator new (std::size_t bytes)
+ {
void* p = alloc(bytes);
- return p;
- }
- ANTLR_INLINE static void operator delete(void* p)
- {
- DefaultAllocPolicy::free(p);
- }
- ANTLR_INLINE static void operator delete(void* , void* ) {} //placement delete
-
- ANTLR_INLINE static void operator delete[](void* p)
- {
- DefaultAllocPolicy::free(p);
- }
-
- ANTLR_INLINE static void* alloc( std::size_t bytes )
- {
- void* p = malloc(bytes);
- if( p== NULL )
- throw std::bad_alloc();
- return p;
- }
-
- ANTLR_INLINE static void* alloc0( std::size_t bytes )
- {
- void* p = calloc(1, bytes);
- if( p== NULL )
- throw std::bad_alloc();
- return p;
- }
-
- ANTLR_INLINE static void free( void* p )
- {
- return ::free(p);
- }
-
- ANTLR_INLINE static void* realloc(void *ptr, size_t size)
- {
- return ::realloc( ptr, size );
- }
+ return p;
+ }
+ ANTLR_INLINE static void* operator new (std::size_t , void* p) { return p; }
+ ANTLR_INLINE static void* operator new[]( std::size_t bytes)
+ {
+ void* p = alloc(bytes);
+ return p;
+ }
+ ANTLR_INLINE static void operator delete(void* p)
+ {
+ DefaultAllocPolicy::free(p);
+ }
+ ANTLR_INLINE static void operator delete(void* , void* ) {} //placement delete
+
+ ANTLR_INLINE static void operator delete[](void* p)
+ {
+ DefaultAllocPolicy::free(p);
+ }
+
+ ANTLR_INLINE static void* alloc( std::size_t bytes )
+ {
+ void* p = malloc(bytes);
+ if( p== NULL )
+ throw std::bad_alloc();
+ return p;
+ }
+
+ ANTLR_INLINE static void* alloc0( std::size_t bytes )
+ {
+ void* p = calloc(1, bytes);
+ if( p== NULL )
+ throw std::bad_alloc();
+ return p;
+ }
+
+ ANTLR_INLINE static void free( void* p )
+ {
+ return ::free(p);
+ }
+
+ ANTLR_INLINE static void* realloc(void *ptr, size_t size)
+ {
+ return ::realloc( ptr, size );
+ }
};
-}
+}
-#endif /* _ANTLR3MEMORY_H */
+#endif /* _ANTLR3MEMORY_H */