Audio plugin host https://kx.studio/carla
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

CarlaUtils.hpp 9.2KB

10 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
11 years ago
10 years ago
11 years ago
11 years ago
10 years ago
11 years ago
11 years ago
11 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
10 years ago
11 years ago
10 years ago
11 years ago
10 years ago
10 years ago
11 years ago
11 years ago
10 years ago
10 years ago
10 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
10 years ago
10 years ago
11 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392
  1. /*
  2. * Carla common utils
  3. * Copyright (C) 2011-2014 Filipe Coelho <falktx@falktx.com>
  4. *
  5. * This program is free software; you can redistribute it and/or
  6. * modify it under the terms of the GNU General Public License as
  7. * published by the Free Software Foundation; either version 2 of
  8. * the License, or any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * For a full copy of the GNU General Public License see the doc/GPL.txt file.
  16. */
  17. #ifndef CARLA_UTILS_HPP_INCLUDED
  18. #define CARLA_UTILS_HPP_INCLUDED
  19. #include "CarlaDefines.h"
  20. #include <cassert>
  21. #include <cstdarg>
  22. #include <cstdio>
  23. #include <cstdlib>
  24. #include <cstring>
  25. #ifdef CARLA_PROPER_CPP11_SUPPORT
  26. # include <cstdint>
  27. #else
  28. # include <stdint.h>
  29. #endif
  30. #ifdef CARLA_OS_WIN
  31. # include <winsock2.h>
  32. # include <windows.h>
  33. #else
  34. # include <unistd.h>
  35. #endif
  36. // -----------------------------------------------------------------------
  37. // misc functions
  38. /*
  39. * Return "true" or "false" according to yesNo.
  40. */
  41. static inline
  42. const char* bool2str(const bool yesNo) noexcept
  43. {
  44. return yesNo ? "true" : "false";
  45. }
  46. /*
  47. * Dummy function.
  48. */
  49. static inline
  50. void pass() noexcept {}
  51. // -----------------------------------------------------------------------
  52. // string print functions
  53. /*
  54. * Print a string to stdout with newline (gray color).
  55. * Does nothing if DEBUG is not defined.
  56. */
  57. #ifndef DEBUG
  58. # define carla_debug(...)
  59. #else
  60. static inline
  61. void carla_debug(const char* const fmt, ...) noexcept
  62. {
  63. try {
  64. ::va_list args;
  65. ::va_start(args, fmt);
  66. std::fprintf(stdout, "\x1b[30;1m");
  67. std::vfprintf(stdout, fmt, args);
  68. std::fprintf(stdout, "\x1b[0m\n");
  69. ::va_end(args);
  70. } catch (...) {}
  71. }
  72. #endif
  73. /*
  74. * Print a string to stdout with newline.
  75. */
  76. static inline
  77. void carla_stdout(const char* const fmt, ...) noexcept
  78. {
  79. try {
  80. ::va_list args;
  81. ::va_start(args, fmt);
  82. std::vfprintf(stdout, fmt, args);
  83. std::fprintf(stdout, "\n");
  84. ::va_end(args);
  85. } catch (...) {}
  86. }
  87. /*
  88. * Print a string to stderr with newline.
  89. */
  90. static inline
  91. void carla_stderr(const char* const fmt, ...) noexcept
  92. {
  93. try {
  94. ::va_list args;
  95. ::va_start(args, fmt);
  96. std::vfprintf(stderr, fmt, args);
  97. std::fprintf(stderr, "\n");
  98. ::va_end(args);
  99. } catch (...) {}
  100. }
  101. /*
  102. * Print a string to stderr with newline (red color).
  103. */
  104. static inline
  105. void carla_stderr2(const char* const fmt, ...) noexcept
  106. {
  107. try {
  108. ::va_list args;
  109. ::va_start(args, fmt);
  110. std::fprintf(stderr, "\x1b[31m");
  111. std::vfprintf(stderr, fmt, args);
  112. std::fprintf(stderr, "\x1b[0m\n");
  113. ::va_end(args);
  114. } catch (...) {}
  115. }
  116. // -----------------------------------------------------------------------
  117. // carla_safe_assert*
  118. /*
  119. * Print a safe assertion error message.
  120. */
  121. static inline
  122. void carla_safe_assert(const char* const assertion, const char* const file, const int line) noexcept
  123. {
  124. carla_stderr2("Carla assertion failure: \"%s\" in file %s, line %i", assertion, file, line);
  125. }
  126. /*
  127. * Print a safe assertion error message, with 1 extra integer value.
  128. */
  129. static inline
  130. void carla_safe_assert_int(const char* const assertion, const char* const file, const int line, const int value) noexcept
  131. {
  132. carla_stderr2("Carla assertion failure: \"%s\" in file %s, line %i, value %i", assertion, file, line, value);
  133. }
  134. static inline
  135. void carla_safe_assert_uint(const char* const assertion, const char* const file, const int line, const uint value) noexcept
  136. {
  137. carla_stderr2("Carla assertion failure: \"%s\" in file %s, line %i, value %u", assertion, file, line, value);
  138. }
  139. /*
  140. * Print a safe assertion error message, with 2 extra integer values.
  141. */
  142. static inline
  143. void carla_safe_assert_int2(const char* const assertion, const char* const file, const int line, const int v1, const int v2) noexcept
  144. {
  145. carla_stderr2("Carla assertion failure: \"%s\" in file %s, line %i, v1 %i, v2 %i", assertion, file, line, v1, v2);
  146. }
  147. static inline
  148. void carla_safe_assert_uint2(const char* const assertion, const char* const file, const int line, const uint v1, const uint v2) noexcept
  149. {
  150. carla_stderr2("Carla assertion failure: \"%s\" in file %s, line %i, v1 %u, v2 %u", assertion, file, line, v1, v2);
  151. }
  152. // -----------------------------------------------------------------------
  153. // carla_*sleep
  154. /*
  155. * Sleep for 'secs' seconds.
  156. */
  157. static inline
  158. void carla_sleep(const uint secs) noexcept
  159. {
  160. CARLA_SAFE_ASSERT_RETURN(secs > 0,);
  161. try {
  162. #ifdef CARLA_OS_WIN
  163. ::Sleep(secs * 1000);
  164. #else
  165. ::sleep(secs);
  166. #endif
  167. } catch(...) {}
  168. }
  169. /*
  170. * Sleep for 'msecs' milliseconds.
  171. */
  172. static inline
  173. void carla_msleep(const uint msecs) noexcept
  174. {
  175. CARLA_SAFE_ASSERT_RETURN(msecs > 0,);
  176. try {
  177. #ifdef CARLA_OS_WIN
  178. ::Sleep(msecs);
  179. #else
  180. ::usleep(msecs * 1000);
  181. #endif
  182. } catch(...) {}
  183. }
  184. // -----------------------------------------------------------------------
  185. // carla_setenv
  186. /*
  187. * Set environment variable 'key' to 'value'.
  188. */
  189. static inline
  190. void carla_setenv(const char* const key, const char* const value) noexcept
  191. {
  192. CARLA_SAFE_ASSERT_RETURN(key != nullptr && key[0] != '\0',);
  193. CARLA_SAFE_ASSERT_RETURN(value != nullptr,);
  194. #ifdef CARLA_OS_WIN
  195. try {
  196. ::SetEnvironmentVariableA(key, value);
  197. } catch(...) {}
  198. #else
  199. ::setenv(key, value, 1);
  200. #endif
  201. }
  202. // -----------------------------------------------------------------------
  203. // carla_strdup
  204. /*
  205. * Custom 'strdup' function.
  206. * Returned value is always valid, and must be freed with "delete[] var".
  207. * May throw.
  208. */
  209. static inline
  210. const char* carla_strdup(const char* const strBuf)
  211. {
  212. CARLA_SAFE_ASSERT(strBuf != nullptr);
  213. const size_t bufferLen = (strBuf != nullptr) ? std::strlen(strBuf) : 0;
  214. char* const buffer = new char[bufferLen+1];
  215. if (strBuf != nullptr && bufferLen > 0)
  216. std::strncpy(buffer, strBuf, bufferLen);
  217. buffer[bufferLen] = '\0';
  218. return buffer;
  219. }
  220. /*
  221. * Custom 'strdup' function.
  222. * Calls "std::free(strBuf)".
  223. * Returned value is always valid, and must be freed with "delete[] var".
  224. * May throw.
  225. */
  226. static inline
  227. const char* carla_strdup_free(char* const strBuf)
  228. {
  229. const char* const buffer(carla_strdup(strBuf));
  230. std::free(strBuf);
  231. return buffer;
  232. }
  233. // -----------------------------------------------------------------------
  234. // memory functions
  235. /*
  236. * Add array values to another array.
  237. */
  238. template<typename T>
  239. static inline
  240. void carla_add(T* dataDst, const T* dataSrc, const size_t size) noexcept
  241. {
  242. CARLA_SAFE_ASSERT_RETURN(dataDst != nullptr,);
  243. CARLA_SAFE_ASSERT_RETURN(dataSrc != nullptr,);
  244. CARLA_SAFE_ASSERT_RETURN(size > 0,);
  245. for (size_t i=0; i < size; ++i)
  246. *dataDst++ += *dataSrc++;
  247. }
  248. /*
  249. * Copy array values to another array.
  250. */
  251. template<typename T>
  252. static inline
  253. void carla_copy(T* const dataDst, const T* const dataSrc, const size_t size) noexcept
  254. {
  255. CARLA_SAFE_ASSERT_RETURN(dataDst != nullptr,);
  256. CARLA_SAFE_ASSERT_RETURN(dataSrc != nullptr,);
  257. CARLA_SAFE_ASSERT_RETURN(size > 0,);
  258. std::memcpy(dataDst, dataSrc, size*sizeof(T));
  259. }
  260. /*
  261. * Fill an array with a fixed value.
  262. */
  263. template<typename T>
  264. static inline
  265. void carla_fill(T* data, const size_t size, const T v) noexcept
  266. {
  267. CARLA_SAFE_ASSERT_RETURN(data != nullptr,);
  268. CARLA_SAFE_ASSERT_RETURN(size > 0,);
  269. if (v == 0)
  270. {
  271. std::memset(data, 0, size*sizeof(T));
  272. }
  273. else
  274. {
  275. for (size_t i=0; i < size; ++i)
  276. *data++ = v;
  277. }
  278. }
  279. /*
  280. * Clear a char array.
  281. */
  282. static inline
  283. void carla_zeroChar(char* const data, const size_t numChars) noexcept
  284. {
  285. CARLA_SAFE_ASSERT_RETURN(data != nullptr,);
  286. CARLA_SAFE_ASSERT_RETURN(numChars > 0,);
  287. std::memset(data, 0, numChars*sizeof(char));
  288. }
  289. /*
  290. * Clear a memory location.
  291. */
  292. static inline
  293. void carla_zeroMem(void* const memory, const size_t numBytes) noexcept
  294. {
  295. CARLA_SAFE_ASSERT_RETURN(memory != nullptr,);
  296. CARLA_SAFE_ASSERT_RETURN(numBytes > 0,);
  297. std::memset(memory, 0, numBytes);
  298. }
  299. /*
  300. * Clear a single struct/class.
  301. */
  302. template <typename T>
  303. static inline
  304. void carla_zeroStruct(T& structure) noexcept
  305. {
  306. std::memset(&structure, 0, sizeof(T));
  307. }
  308. /*
  309. * Clear an array of struct/classes.
  310. */
  311. template <typename T>
  312. static inline
  313. void carla_zeroStruct(T* const structure, const size_t count) noexcept
  314. {
  315. CARLA_SAFE_ASSERT_RETURN(structure != nullptr,);
  316. CARLA_SAFE_ASSERT_RETURN(count > 0,);
  317. std::memset(structure, 0, count*sizeof(T));
  318. }
  319. /*
  320. * Copy a single struct/class.
  321. */
  322. template <typename T>
  323. static inline
  324. void carla_copyStruct(T& struct1, const T& struct2) noexcept
  325. {
  326. std::memcpy(&struct1, &struct2, sizeof(T));
  327. }
  328. /*
  329. * Copy an array of struct/classes.
  330. */
  331. template <typename T>
  332. static inline
  333. void carla_copyStruct(T* const struct1, const T* const struct2, const size_t count) noexcept
  334. {
  335. CARLA_SAFE_ASSERT_RETURN(struct1 != nullptr,);
  336. CARLA_SAFE_ASSERT_RETURN(struct2 != nullptr,);
  337. CARLA_SAFE_ASSERT_RETURN(count > 0,);
  338. std::memcpy(struct1, struct2, count*sizeof(T));
  339. }
  340. // -----------------------------------------------------------------------
  341. #endif // CARLA_UTILS_HPP_INCLUDED