File: mallocator.hpp

package info (click to toggle)
libtorrent-rasterbar 2.0.11-1
  • links: PTS
  • area: main
  • in suites: forky, trixie
  • size: 18,304 kB
  • sloc: cpp: 190,670; python: 7,142; makefile: 1,374; ansic: 574; sh: 317; xml: 104
file content (69 lines) | stat: -rw-r--r-- 1,866 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
/*

Copyright (c) 2017, Arvid Norberg
All rights reserved.

    This program is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.
    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.
    You should have received a copy of the GNU General Public License
    along with this program.  If not, see <http://www.gnu.org/licenses/>.

*/

#ifndef SIMULATOR_MALLOCATOR_HPP_INCLUDED
#define SIMULATOR_MALLOCATOR_HPP_INCLUDED

namespace sim
{
namespace aux
{
	struct channel;
	struct packet;
	struct pcap;

	template <typename T>
	struct mallocator
	{
		template <typename U>
		friend struct mallocator;

		using value_type = T;
		using pointer = T*;
		using const_pointer = T const*;
		using reference = T&;
		using const_reference = T const&;
		using size_type = std::size_t;
		using difference_type = std::ptrdiff_t;

		template <class U>
		struct rebind {
			using other = mallocator<U>;
		};

		mallocator() = default;
		template <typename U>
		mallocator(mallocator<U> const&) {}

		T* allocate(std::size_t size)
		{ return reinterpret_cast<T*>(std::malloc(size * sizeof(T))); }

		void deallocate(T* ptr) { std::free(ptr); }
		void deallocate(T* ptr, std::size_t) { std::free(ptr); }

		void destroy(pointer p) { p->~T(); }
		void construct(pointer p, T&& value) { new (p) T(std::move(value)); }

		bool operator==(mallocator const&) const { return true; }
		bool operator!=(mallocator const&) const { return false; }
	};
} // aux
} // sim

#endif // SIMULATOR_MALLOCATOR_HPP_INCLUDED