Utility.h 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. #ifndef CORE_UTILITY_H
  2. #define CORE_UTILITY_H
  3. #include <string.h>
  4. #include "core/Types.h"
  5. size_t popCount(u64 u);
  6. #define interpolate(a, b, factor) ((a) * (1.0f - (factor)) + (b) * (factor))
  7. #define PI 3.14159265358979323846f
  8. #define radianToDegree(radians) ((radians) * (180.0f / PI))
  9. #define degreeToRadian(degrees) ((degrees) * (PI / 180.0f))
  10. inline size_t maxSize(size_t a, size_t b) {
  11. return a > b ? a : b;
  12. }
  13. inline size_t minSize(size_t a, size_t b) {
  14. return a < b ? a : b;
  15. }
  16. typedef void (*ExitHandler)(int, void*);
  17. [[noreturn]] void exitWithHandler(const char* file, int line, int value);
  18. void setExitHandler(ExitHandler h, void* data);
  19. #define EXIT(exitValue) exitWithHandler(__FILE__, __LINE__, exitValue)
  20. typedef void (*OutOfMemoryHandler)(void*);
  21. void setOutOfMemoryHandler(OutOfMemoryHandler h, void* data);
  22. #ifdef CHECK_MEMORY
  23. void* coreDebugAllocate(const char* file, int line, size_t n);
  24. void* coreDebugZeroAllocate(const char* file, int line, size_t n);
  25. void* coreDebugReallocate(const char* file, int line, void* p, size_t n);
  26. void coreFreeDebug(const char* file, int line, void* p);
  27. void printMemoryReport(void);
  28. #define coreAllocate(n) coreDebugAllocate(__FILE__, __LINE__, n)
  29. #define coreZeroAllocate(n) coreDebugZeroAllocate(__FILE__, __LINE__, n)
  30. #define coreReallocate(p, n) coreDebugReallocate(__FILE__, __LINE__, p, n)
  31. #define coreFree(p) coreFreeDebug(__FILE__, __LINE__, p)
  32. #else
  33. void* coreAllocate(size_t n);
  34. void* coreZeroAllocate(size_t n);
  35. void* coreReallocate(void* p, size_t n);
  36. void coreFree(void* p);
  37. #define printMemoryReport()
  38. #endif
  39. bool sleepNanos(i64 nanos);
  40. i64 getNanos(void);
  41. #define swap(a, b) \
  42. do { \
  43. auto aPointer = (a); \
  44. auto bPointer = (b); \
  45. auto tmp = *aPointer; \
  46. *aPointer = *bPointer; \
  47. *bPointer = tmp; \
  48. } while(0)
  49. #define BUBBLE_SORT(type, Type) void bubbleSort##Type(type* data, size_t n);
  50. #define BUBBLE_SORT_SOURCE(type, Type, greaterThan) \
  51. void bubbleSort##Type(type* data, size_t n) { \
  52. bool swapped = true; \
  53. while(swapped && n > 0) { \
  54. swapped = false; \
  55. n--; \
  56. for(size_t i = 0; i < n; i++) { \
  57. if(greaterThan(data[i], data[i + 1])) { \
  58. swap(data + i, data + i + 1); \
  59. swapped = true; \
  60. } \
  61. } \
  62. } \
  63. }
  64. #endif