deDefs.hpp revision 93df37596ea66700965094b3aa2830cf4f2ca5aa
1#ifndef _DEDEFS_HPP 2#define _DEDEFS_HPP 3/*------------------------------------------------------------------------- 4 * drawElements C++ Base Library 5 * ----------------------------- 6 * 7 * Copyright 2014 The Android Open Source Project 8 * 9 * Licensed under the Apache License, Version 2.0 (the "License"); 10 * you may not use this file except in compliance with the License. 11 * You may obtain a copy of the License at 12 * 13 * http://www.apache.org/licenses/LICENSE-2.0 14 * 15 * Unless required by applicable law or agreed to in writing, software 16 * distributed under the License is distributed on an "AS IS" BASIS, 17 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 18 * See the License for the specific language governing permissions and 19 * limitations under the License. 20 * 21 *//*! 22 * \file 23 * \brief Basic definitions. 24 *//*--------------------------------------------------------------------*/ 25 26#include "deDefs.h" 27 28#if !defined(__cplusplus) 29# error "C++ is required" 30#endif 31 32namespace de 33{ 34 35//!< Compute absolute value of x. 36template<typename T> inline T abs (T x) { return x < T(0) ? -x : x; } 37 38//!< Get minimum of x and y. 39template<typename T> inline T min (T x, T y) { return x <= y ? x : y; } 40 41//!< Get maximum of x and y. 42template<typename T> inline T max (T x, T y) { return x >= y ? x : y; } 43 44//!< Clamp x in range a <= x <= b. 45template<typename T> inline T clamp (T x, T a, T b) { DE_ASSERT(a <= b); return x < a ? a : (x > b ? b : x); } 46 47//!< Test if x is in bounds a <= x < b. 48template<typename T> inline bool inBounds (T x, T a, T b) { return a <= x && x < b; } 49 50//!< Test if x is in range a <= x <= b. 51template<typename T> inline bool inRange (T x, T a, T b) { return a <= x && x <= b; } 52 53//! Helper for DE_CHECK() macros. 54void throwRuntimeError (const char* message, const char* expr, const char* file, int line); 55 56//! Default deleter. 57template<typename T> struct DefaultDeleter 58{ 59 inline DefaultDeleter (void) {} 60 template<typename U> inline DefaultDeleter (const DefaultDeleter<U>&) {} 61 template<typename U> inline DefaultDeleter<T>& operator= (const DefaultDeleter<U>&) { return *this; } 62 inline void operator() (T* ptr) const { delete ptr; } 63}; 64 65//! A deleter for arrays 66template<typename T> struct ArrayDeleter 67{ 68 inline ArrayDeleter (void) {} 69 template<typename U> inline ArrayDeleter (const ArrayDeleter<U>&) {} 70 template<typename U> inline ArrayDeleter<T>& operator= (const ArrayDeleter<U>&) { return *this; } 71 inline void operator() (T* ptr) const { delete[] ptr; } 72}; 73 74template <typename T, bool Cond> 75struct EnableIf 76{ 77}; 78 79 80template <typename T> 81struct EnableIf<T, true> 82{ 83 typedef T Type; 84}; 85 86//! Get an element of an array with a specified size. 87template <int LastElementIndex, int Size, typename Elem> 88const Elem& getSizedArrayElement (const Elem (&array)[Size], typename de::EnableIf<int, LastElementIndex==Size>::Type offset) 89{ 90 DE_ASSERT(inBounds(offset, 0, Size)); 91 return array[offset]; 92} 93 94//! Get an element of an array with a compile-time constant size. 95template <int Size, typename Elem> 96const Elem& getArrayElement (const Elem (&array)[Size], int offset) 97{ 98 DE_ASSERT(inBounds(offset, 0, Size)); 99 return array[offset]; 100} 101 102} // de 103 104/*--------------------------------------------------------------------*//*! 105 * \brief Throw runtime error if condition is not met. 106 * \param X Condition to check. 107 * 108 * This macro throws std::runtime_error if condition X is not met. 109 *//*--------------------------------------------------------------------*/ 110#define DE_CHECK_RUNTIME_ERR(X) do { if ((!deGetFalse() && (X)) ? DE_FALSE : DE_TRUE) ::de::throwRuntimeError(DE_NULL, #X, __FILE__, __LINE__); } while(deGetFalse()) 111 112/*--------------------------------------------------------------------*//*! 113 * \brief Throw runtime error if condition is not met. 114 * \param X Condition to check. 115 * \param MSG Additional message to include in the exception. 116 * 117 * This macro throws std::runtime_error with message MSG if condition X is 118 * not met. 119 *//*--------------------------------------------------------------------*/ 120#define DE_CHECK_RUNTIME_ERR_MSG(X, MSG) do { if ((!deGetFalse() && (X)) ? DE_FALSE : DE_TRUE) ::de::throwRuntimeError(MSG, #X, __FILE__, __LINE__); } while(deGetFalse()) 121 122//! Get array start pointer. 123#define DE_ARRAY_BEGIN(ARR) (&(ARR)[0]) 124 125//! Get array end pointer. 126#define DE_ARRAY_END(ARR) (DE_ARRAY_BEGIN(ARR) + DE_LENGTH_OF_ARRAY(ARR)) 127 128//! Empty C++ compilation unit silencing. 129#if (DE_COMPILER == DE_COMPILER_MSC) 130# define DE_EMPTY_CPP_FILE namespace { deUint8 unused; } 131#else 132# define DE_EMPTY_CPP_FILE 133#endif 134 135// Warn if type is constructed, but left unused 136// 137// Used in types with non-trivial ctor/dtor but with ctor-dtor pair causing no (observable) 138// side-effects. 139// 140// \todo add attribute for GCC 141#if (DE_COMPILER == DE_COMPILER_CLANG) && defined(__has_attribute) 142# if __has_attribute(warn_unused) 143# define DE_WARN_UNUSED_TYPE __attribute__((warn_unused)) 144# else 145# define DE_WARN_UNUSED_TYPE 146# endif 147#else 148# define DE_WARN_UNUSED_TYPE 149#endif 150 151#endif // _DEDEFS_HPP 152