Bump version to 4.3-4
[LibreOffice.git] / sc / inc / stlalgorithm.hxx
blob3c7014446fa41afe55ee528a9de318436fa0931c
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8 */
10 #ifndef INCLUDED_SC_INC_STLALGORITHM_HXX
11 #define INCLUDED_SC_INC_STLALGORITHM_HXX
13 #include <functional>
14 #include <limits>
16 #include <rtl/alloc.h>
18 namespace sc {
20 /**
21 * Custom allocator for STL container to ensure that the base address of
22 * allocated storage is aligned to a specified boundary.
24 template<typename T, size_t _Alignment>
25 class AlignedAllocator
27 public:
28 typedef T value_type;
29 typedef size_t size_type;
30 typedef std::ptrdiff_t difference_type;
32 typedef T* pointer;
33 typedef const T* const_pointer;
34 typedef T* void_pointer;
36 typedef T& reference;
37 typedef const T& const_reference;
39 template<typename _Type2>
40 struct rebind
42 typedef AlignedAllocator<_Type2,_Alignment> other;
45 AlignedAllocator() {}
46 ~AlignedAllocator() {}
48 template<typename _Type2>
49 AlignedAllocator(const AlignedAllocator<_Type2,_Alignment>&) {}
51 void construct(T* p, const value_type& val) { new(p) value_type(val); }
52 void destroy(T* p)
54 p->~value_type();
55 (void)p; // avoid bogus MSVC '12 "unreferenced formal parameter" warning
58 size_type max_size() const
60 return std::numeric_limits<size_type>::max() / sizeof(value_type);
63 bool operator== (const AlignedAllocator&) const { return true; }
64 bool operator!= (const AlignedAllocator&) const { return false; }
66 pointer allocate(size_type n)
68 return (pointer)rtl_allocateAlignedMemory(_Alignment, n*sizeof(value_type));
71 void deallocate(pointer p, size_type)
73 rtl_freeAlignedMemory(p);
79 #endif
81 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */