summaryrefslogtreecommitdiff
path: root/thirdparty/bullet/src/BulletInverseDynamics/IDConfigBuiltin.hpp
blob: 130c19c6d6ff5fb57cf7e89c2b273b5757c9c6f4 (plain)
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
///@file Configuration for Inverse Dynamics Library without external dependencies
#ifndef INVDYNCONFIG_BUILTIN_HPP_
#define INVDYNCONFIG_BUILTIN_HPP_
#define btInverseDynamics btInverseDynamicsBuiltin
#ifdef BT_USE_DOUBLE_PRECISION
// choose double/single precision version
typedef double idScalar;
#else
typedef float idScalar;
#endif
// use std::vector for arrays
#include <vector>
// this is to make it work with C++2003, otherwise we could do this
// template <typename T>
// using idArray = std::vector<T>;
template <typename T>
struct idArray {
	typedef std::vector<T> type;
};
typedef std::vector<int>::size_type idArrayIdx;
// default to standard malloc/free
#include <cstdlib>
#define idMalloc ::malloc
#define idFree ::free
// currently not aligned at all...
#define ID_DECLARE_ALIGNED_ALLOCATOR()															 \
	inline void* operator new(std::size_t sizeInBytes) { return idMalloc(sizeInBytes); }		   \
	inline void operator delete(void* ptr) { idFree(ptr); }										\
	inline void* operator new(std::size_t, void* ptr) { return ptr; }							  \
	inline void operator delete(void*, void*) {}												   \
	inline void* operator new[](std::size_t sizeInBytes) { return idMalloc(sizeInBytes); }		 \
	inline void operator delete[](void* ptr) { idFree(ptr); }									  \
	inline void* operator new[](std::size_t, void* ptr) { return ptr; }							\
	inline void operator delete[](void*, void*) {}

#include "details/IDMatVec.hpp"
#endif