DART 6.13.2
Loading...
Searching...
No Matches
MemoryManager-impl.hpp
Go to the documentation of this file.
1/*
2 * Copyright (c) 2011-2022, The DART development contributors
3 * All rights reserved.
4 *
5 * The list of contributors can be found at:
6 * https://github.com/dartsim/dart/blob/master/LICENSE
7 *
8 * This file is provided under the following "BSD-style" License:
9 * Redistribution and use in source and binary forms, with or
10 * without modification, are permitted provided that the following
11 * conditions are met:
12 * * Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
14 * * Redistributions in binary form must reproduce the above
15 * copyright notice, this list of conditions and the following
16 * disclaimer in the documentation and/or other materials provided
17 * with the distribution.
18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
19 * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
20 * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
21 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
22 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
23 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
26 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
27 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
29 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30 * POSSIBILITY OF SUCH DAMAGE.
31 */
32
33#ifndef DART_COMMON_DETAIL_MEMORYMANAGER_IMPL_HPP_
34#define DART_COMMON_DETAIL_MEMORYMANAGER_IMPL_HPP_
35
37
38namespace dart::common {
39
40//==============================================================================
41template <typename T, typename... Args>
42T* MemoryManager::construct(Type type, Args&&... args) noexcept
43{
44 // Allocate new memory for a new object (without calling the constructor)
45 void* object = allocate(type, sizeof(T));
46 if (!object)
47 {
48 return nullptr;
49 }
50
51 // Call constructor. Return nullptr if failed.
52 try
53 {
54 new (object) T(std::forward<Args>(args)...);
55 }
56 catch (...)
57 {
58 deallocate(type, object, sizeof(T));
59 return nullptr;
60 }
61
62 return reinterpret_cast<T*>(object);
63}
64
65//==============================================================================
66template <typename T, typename... Args>
67T* MemoryManager::constructUsingFree(Args&&... args) noexcept
68{
69 return construct<T, Args...>(Type::Free, std::forward<Args>(args)...);
70}
71
72//==============================================================================
73template <typename T, typename... Args>
74T* MemoryManager::constructUsingPool(Args&&... args) noexcept
75{
76 return construct<T, Args...>(Type::Pool, std::forward<Args>(args)...);
77}
78
79//==============================================================================
80template <typename T>
81void MemoryManager::destroy(Type type, T* object) noexcept
82{
83 if (!object)
84 {
85 return;
86 }
87 object->~T();
88 deallocate(type, object, sizeof(T));
89}
90
91//==============================================================================
92template <typename T>
93void MemoryManager::destroyUsingFree(T* pointer) noexcept
94{
95 destroy(Type::Free, pointer);
96}
97
98//==============================================================================
99template <typename T>
100void MemoryManager::destroyUsingPool(T* pointer) noexcept
101{
102 destroy(Type::Pool, pointer);
103}
104
105} // namespace dart::common
106
107#endif // DART_COMMON_DETAIL_MEMORYMANAGER_IMPL_HPP_
std::string type
Definition SdfParser.cpp:82
T * constructUsingPool(Args &&... args) noexcept
Allocates uninitialized storage using PoolAllocator and constructs an object of type T to the allocat...
Definition MemoryManager-impl.hpp:74
void destroyUsingPool(T *pointer) noexcept
Calls the destructor of the object and deallocate the storage using PoolAllocator.
Definition MemoryManager-impl.hpp:100
T * construct(Type type, Args &&... args) noexcept
Allocates uninitialized storage and constructs an object of type T to the allocated storage.
Definition MemoryManager-impl.hpp:42
Type
Type of the memory allocators.
Definition MemoryManager.hpp:53
void destroy(Type type, T *object) noexcept
Calls the destructor of the object and deallocate the storage.
Definition MemoryManager-impl.hpp:81
void destroyUsingFree(T *pointer) noexcept
Calls the destructor of the object and deallocate the storage using FreeListAllocator.
Definition MemoryManager-impl.hpp:93
T * constructUsingFree(Args &&... args) noexcept
Allocates uninitialized storage using FreeListAllocator and constructs an object of type T to the all...
Definition MemoryManager-impl.hpp:67
Definition Aspect.cpp:42