Utility.cpp 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. #include "utils/Utility.h"
  2. #include <stdio.h>
  3. #include <stdlib.h>
  4. #include <string.h>
  5. static Core::ExitHandler exitHandler = nullptr;
  6. static void* exitData = nullptr;
  7. const char* Core::getErrorName(Error e) {
  8. switch(e) {
  9. case Error::NONE: return "NONE";
  10. case Error::NEGATIVE_ARGUMENT: return "NEGATIVE_ARGUMENT";
  11. case Error::CAPACITY_REACHED: return "CAPACITY_REACHED";
  12. case Error::BLOCKED_STDOUT: return "BLOCKED_STDOUT";
  13. case Error::OUT_OF_MEMORY: return "OUT_OF_MEMORY";
  14. case Error::INVALID_CHAR: return "INVALID_CHAR";
  15. case Error::NOT_FOUND: return "NOT_FOUND";
  16. case Error::INVALID_STATE: return "INVALID_STATE";
  17. case Error::INVALID_INDEX: return "INVALID_INDEX";
  18. case Error::TIME_NOT_AVAILABLE: return "TIME_NOT_AVAILABLE";
  19. case Error::SLEEP_INTERRUPTED: return "SLEEP_INTERRUPTED";
  20. case Error::THREAD_ERROR: return "THREAD_ERROR";
  21. case Error::INVALID_ID: return "INVALID_ID";
  22. case Error::EXISTING_KEY: return "EXISTING_KEY";
  23. }
  24. return "?";
  25. }
  26. void* operator new(size_t bytes) noexcept {
  27. return malloc(bytes);
  28. }
  29. void* operator new[](size_t bytes) noexcept {
  30. return malloc(bytes);
  31. }
  32. void operator delete(void* p) noexcept {
  33. free(p);
  34. }
  35. void operator delete[](void* p) noexcept {
  36. free(p);
  37. }
  38. void operator delete(void* p, size_t bytes) noexcept {
  39. (void)bytes;
  40. free(p);
  41. }
  42. void operator delete[](void* p, size_t bytes) noexcept {
  43. (void)bytes;
  44. free(p);
  45. }
  46. void* operator new(size_t bytes, void* p) noexcept {
  47. (void)bytes;
  48. return p;
  49. }
  50. /*void* operator new[](size_t bytes, void* p) noexcept {
  51. (void)bytes;
  52. return p;
  53. }*/
  54. void Core::exitWithHandler(const char* file, int line, int value) {
  55. if(value != 0) {
  56. printf("\33[1;31mExit from %s:%d with value %d\33[39;49m\n", file, line,
  57. value);
  58. }
  59. if(exitHandler != nullptr) {
  60. exitHandler(value, exitData);
  61. }
  62. exit(value);
  63. }
  64. void Core::setExitHandler(ExitHandler eh, void* data) {
  65. exitHandler = eh;
  66. exitData = data;
  67. }
  68. #define CORE_TO_STRING(type, cast, format) \
  69. check_return Core::Error Core::toString(type t, char* buffer, int size) { \
  70. if(size < 0) { \
  71. return Error::NEGATIVE_ARGUMENT; \
  72. } \
  73. return snprintf(buffer, static_cast<unsigned int>(size), format, \
  74. static_cast<cast>(t)) >= size \
  75. ? Error::CAPACITY_REACHED \
  76. : Error::NONE; \
  77. }
  78. CORE_TO_STRING(signed short, signed short, "%hd")
  79. CORE_TO_STRING(unsigned short, unsigned short, "%hu")
  80. CORE_TO_STRING(signed int, signed int, "%d")
  81. CORE_TO_STRING(unsigned int, unsigned int, "%u")
  82. CORE_TO_STRING(signed long, signed long, "%ld")
  83. CORE_TO_STRING(unsigned long, unsigned long, "%lu")
  84. CORE_TO_STRING(signed long long, signed long long, "%lld")
  85. CORE_TO_STRING(unsigned long long, unsigned long long, "%llu")
  86. CORE_TO_STRING(float, double, "%.2f")
  87. CORE_TO_STRING(double, double, "%.2lf")
  88. CORE_TO_STRING(long double, long double, "%.2Lf")
  89. Core::Error Core::putChar(int c) {
  90. return putchar(c) == EOF ? Error::BLOCKED_STDOUT : Error::NONE;
  91. }
  92. void Core::memorySet(void* p, int c, int n) {
  93. if(n <= 0) {
  94. return;
  95. }
  96. memset(p, c, static_cast<unsigned int>(n));
  97. }
  98. void Core::memoryCopy(void* dest, const void* src, int n) {
  99. if(n <= 0) {
  100. return;
  101. }
  102. memcpy(dest, src, static_cast<unsigned int>(n));
  103. }
  104. bool Core::memoryCompare(const void* a, const void* b, int n) {
  105. return n <= 0 ? true : memcmp(a, b, static_cast<unsigned int>(n)) == 0;
  106. }
  107. Core::Error Core::reallocate(char*& p, int n) {
  108. if(n <= 0) {
  109. free(p);
  110. p = nullptr;
  111. return Error::NONE;
  112. }
  113. char* newP = static_cast<char*>(realloc(p, static_cast<unsigned int>(n)));
  114. if(newP == nullptr) {
  115. return Error::OUT_OF_MEMORY;
  116. }
  117. p = newP;
  118. return Error::NONE;
  119. }
  120. void Core::free(void* p) {
  121. ::free(p);
  122. }
  123. const char* Core::getFileName(const char* path) {
  124. int end = 0;
  125. while(path[end] != '\0') {
  126. end++;
  127. }
  128. while(end > 0 && path[end - 1] != '/') {
  129. end--;
  130. }
  131. return path + end;
  132. }