obs-encoder.c 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. /******************************************************************************
  2. Copyright (C) 2013 by Hugh Bailey <[email protected]>
  3. This program is free software: you can redistribute it and/or modify
  4. it under the terms of the GNU General Public License as published by
  5. the Free Software Foundation, either version 2 of the License, or
  6. (at your option) any later version.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU General Public License for more details.
  11. You should have received a copy of the GNU General Public License
  12. along with this program. If not, see <http://www.gnu.org/licenses/>.
  13. ******************************************************************************/
  14. #include "obs.h"
  15. #include "obs-internal.h"
  16. static inline struct obs_encoder_info *get_encoder_info(const char *id)
  17. {
  18. for (size_t i = 0; i < obs->encoder_types.num; i++) {
  19. struct obs_encoder_info *info = obs->encoder_types.array+i;
  20. if (strcmp(info->id, id) == 0)
  21. return info;
  22. }
  23. return NULL;
  24. }
  25. const char *obs_encoder_getdisplayname(const char *id, const char *locale)
  26. {
  27. struct obs_encoder_info *ei = get_encoder_info(id);
  28. if (!ei)
  29. return NULL;
  30. return ei->getname(locale);
  31. }
  32. obs_encoder_t obs_encoder_create(const char *id, const char *name,
  33. obs_data_t settings)
  34. {
  35. struct obs_encoder *encoder;
  36. struct obs_encoder_info *ei = get_encoder_info(id);
  37. if (!ei)
  38. return NULL;
  39. encoder = bzalloc(sizeof(struct obs_encoder));
  40. encoder->info = *ei;
  41. if (pthread_mutex_init(&encoder->data_callbacks_mutex, NULL) != 0) {
  42. bfree(encoder);
  43. return NULL;
  44. }
  45. encoder->settings = obs_data_newref(settings);
  46. encoder->data = ei->create(encoder->settings, encoder);
  47. if (!encoder->data) {
  48. pthread_mutex_destroy(&encoder->data_callbacks_mutex);
  49. obs_data_release(encoder->settings);
  50. bfree(encoder);
  51. return NULL;
  52. }
  53. pthread_mutex_lock(&obs->data.encoders_mutex);
  54. da_push_back(obs->data.encoders, &encoder);
  55. pthread_mutex_unlock(&obs->data.encoders_mutex);
  56. encoder->name = bstrdup(name);
  57. return encoder;
  58. }
  59. void obs_encoder_destroy(obs_encoder_t encoder)
  60. {
  61. if (encoder) {
  62. pthread_mutex_lock(&obs->data.encoders_mutex);
  63. da_erase_item(obs->data.encoders, &encoder);
  64. pthread_mutex_unlock(&obs->data.encoders_mutex);
  65. encoder->info.destroy(encoder->data);
  66. obs_data_release(encoder->settings);
  67. bfree(encoder->name);
  68. bfree(encoder);
  69. }
  70. }
  71. obs_data_t obs_encoder_defaults(const char *id)
  72. {
  73. const struct obs_encoder_info *info = get_encoder_info(id);
  74. if (info) {
  75. obs_data_t settings = obs_data_create();
  76. if (info->defaults)
  77. info->defaults(settings);
  78. return settings;
  79. }
  80. return NULL;
  81. }
  82. obs_properties_t obs_encoder_properties(const char *id, const char *locale)
  83. {
  84. const struct obs_encoder_info *ei = get_encoder_info(id);
  85. if (ei && ei->properties)
  86. return ei->properties(locale);
  87. return NULL;
  88. }
  89. void obs_encoder_update(obs_encoder_t encoder, obs_data_t settings)
  90. {
  91. if (!encoder) return;
  92. obs_data_apply(encoder->settings, settings);
  93. encoder->info.update(encoder->data, encoder->settings);
  94. }
  95. bool obs_encoder_reset(obs_encoder_t encoder, obs_data_t settings)
  96. {
  97. if (!encoder) return false;
  98. return encoder->info.reset(encoder->data, settings);
  99. }
  100. bool obs_encoder_encode(obs_encoder_t encoder,
  101. const struct encoder_frame *frame,
  102. struct encoder_packet *packet, bool *received_packet)
  103. {
  104. if (!encoder) return false;
  105. return encoder->info.encode(encoder->data, frame, packet,
  106. received_packet);
  107. }
  108. bool obs_encoder_get_extra_data(obs_encoder_t encoder, uint8_t **extra_data,
  109. size_t *size)
  110. {
  111. if (!encoder) return false;
  112. if (encoder->info.get_extra_data)
  113. return encoder->info.get_extra_data(encoder, extra_data, size);
  114. return false;
  115. }
  116. obs_data_t obs_encoder_get_settings(obs_encoder_t encoder)
  117. {
  118. if (!encoder) return NULL;
  119. obs_data_addref(encoder->settings);
  120. return encoder->settings;
  121. }
  122. bool obs_encoder_start(obs_encoder_t encoder,
  123. void (*new_packet)(void *param, struct encoder_packet *packet),
  124. void *param)
  125. {
  126. /* TODO: implement */
  127. UNUSED_PARAMETER(encoder);
  128. UNUSED_PARAMETER(new_packet);
  129. UNUSED_PARAMETER(param);
  130. return false;
  131. }
  132. void obs_encoder_stop(obs_encoder_t encoder,
  133. void (*new_packet)(void *param, struct encoder_packet *packet),
  134. void *param)
  135. {
  136. /* TODO: implement */
  137. UNUSED_PARAMETER(encoder);
  138. UNUSED_PARAMETER(new_packet);
  139. UNUSED_PARAMETER(param);
  140. return;
  141. }