include.hpp 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. /**
  2. * Copyright (c) 2019 Paul-Louis Ageneau
  3. *
  4. * This library is free software; you can redistribute it and/or
  5. * modify it under the terms of the GNU Lesser General Public
  6. * License as published by the Free Software Foundation; either
  7. * version 2.1 of the License, or (at your option) any later version.
  8. *
  9. * This library is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  12. * Lesser General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU Lesser General Public
  15. * License along with this library; if not, write to the Free Software
  16. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  17. */
  18. #ifndef RTC_INCLUDE_H
  19. #define RTC_INCLUDE_H
  20. #ifndef RTC_ENABLE_MEDIA
  21. #define RTC_ENABLE_MEDIA 1
  22. #endif
  23. #ifndef RTC_ENABLE_WEBSOCKET
  24. #define RTC_ENABLE_WEBSOCKET 1
  25. #endif
  26. #ifdef _WIN32
  27. #define RTC_CPP_EXPORT __declspec(dllexport)
  28. #ifndef _WIN32_WINNT
  29. #define _WIN32_WINNT 0x0602 // Windows 8
  30. #endif
  31. #else
  32. #define RTC_CPP_EXPORT
  33. #endif
  34. #include "log.hpp"
  35. #include <cstddef>
  36. #include <functional>
  37. #include <memory>
  38. #include <mutex>
  39. #include <optional>
  40. #include <string>
  41. #include <string_view>
  42. #include <vector>
  43. namespace rtc {
  44. using std::byte;
  45. using std::string;
  46. using std::string_view;
  47. using binary = std::vector<byte>;
  48. using std::nullopt;
  49. using std::size_t;
  50. using std::uint16_t;
  51. using std::uint32_t;
  52. using std::uint64_t;
  53. using std::uint8_t;
  54. const size_t MAX_NUMERICNODE_LEN = 48; // Max IPv6 string representation length
  55. const size_t MAX_NUMERICSERV_LEN = 6; // Max port string representation length
  56. const uint16_t DEFAULT_SCTP_PORT = 5000; // SCTP port to use by default
  57. const size_t DEFAULT_MAX_MESSAGE_SIZE = 65536; // Remote max message size if not specified in SDP
  58. const size_t LOCAL_MAX_MESSAGE_SIZE = 256 * 1024; // Local max message size
  59. const size_t RECV_QUEUE_LIMIT = 1024 * 1024; // Max per-channel queue size
  60. const int THREADPOOL_SIZE = 4; // Number of threads in the global thread pool
  61. // overloaded helper
  62. template <class... Ts> struct overloaded : Ts... { using Ts::operator()...; };
  63. template <class... Ts> overloaded(Ts...) -> overloaded<Ts...>;
  64. // weak_ptr bind helper
  65. template <typename F, typename T, typename... Args> auto weak_bind(F &&f, T *t, Args &&... _args) {
  66. return [bound = std::bind(f, t, _args...), weak_this = t->weak_from_this()](auto &&... args) {
  67. using result_type = typename decltype(bound)::result_type;
  68. if (auto shared_this = weak_this.lock())
  69. return bound(args...);
  70. else
  71. return static_cast<result_type>(false);
  72. };
  73. }
  74. // scope_guard helper
  75. class scope_guard {
  76. public:
  77. scope_guard(std::function<void()> func) : function(std::move(func)) {}
  78. scope_guard(scope_guard &&other) = delete;
  79. scope_guard(const scope_guard &) = delete;
  80. void operator=(const scope_guard &) = delete;
  81. ~scope_guard() {
  82. if (function)
  83. function();
  84. }
  85. private:
  86. std::function<void()> function;
  87. };
  88. template <typename... Args> class synchronized_callback {
  89. public:
  90. synchronized_callback() = default;
  91. synchronized_callback(synchronized_callback &&cb) { *this = std::move(cb); }
  92. synchronized_callback(const synchronized_callback &cb) { *this = cb; }
  93. synchronized_callback(std::function<void(Args...)> func) { *this = std::move(func); }
  94. ~synchronized_callback() { *this = nullptr; }
  95. synchronized_callback &operator=(synchronized_callback &&cb) {
  96. std::scoped_lock lock(mutex, cb.mutex);
  97. callback = std::move(cb.callback);
  98. cb.callback = nullptr;
  99. return *this;
  100. }
  101. synchronized_callback &operator=(const synchronized_callback &cb) {
  102. std::scoped_lock lock(mutex, cb.mutex);
  103. callback = cb.callback;
  104. return *this;
  105. }
  106. synchronized_callback &operator=(std::function<void(Args...)> func) {
  107. std::lock_guard lock(mutex);
  108. callback = std::move(func);
  109. return *this;
  110. }
  111. void operator()(Args... args) const {
  112. std::lock_guard lock(mutex);
  113. if (callback)
  114. callback(std::move(args)...);
  115. }
  116. operator bool() const {
  117. std::lock_guard lock(mutex);
  118. return callback ? true : false;
  119. }
  120. std::function<void(Args...)> wrap() const {
  121. return [this](Args... args) { (*this)(std::move(args)...); };
  122. }
  123. private:
  124. std::function<void(Args...)> callback;
  125. mutable std::recursive_mutex mutex;
  126. };
  127. } // namespace rtc
  128. #endif