Utility.cpp 4.5 KB

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