obs-encoder.c 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  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_properties_t obs_encoder_properties(const char *id, const char *locale)
  72. {
  73. const struct obs_encoder_info *ei = get_encoder_info(id);
  74. if (ei && ei->get_properties)
  75. return ei->get_properties(locale);
  76. return NULL;
  77. }
  78. void obs_encoder_update(obs_encoder_t encoder, obs_data_t settings)
  79. {
  80. if (!encoder) return;
  81. obs_data_apply(encoder->settings, settings);
  82. encoder->info.update(encoder->data, encoder->settings);
  83. }
  84. bool obs_encoder_reset(obs_encoder_t encoder, obs_data_t settings)
  85. {
  86. if (!encoder) return false;
  87. return encoder->info.reset(encoder->data, settings);
  88. }
  89. bool obs_encoder_encode(obs_encoder_t encoder,
  90. const struct encoder_frame *frame,
  91. struct encoder_packet *packet, bool *received_packet)
  92. {
  93. if (!encoder) return false;
  94. return encoder->info.encode(encoder->data, frame, packet,
  95. received_packet);
  96. }
  97. bool obs_encoder_get_extra_data(obs_encoder_t encoder, uint8_t **extra_data,
  98. size_t *size)
  99. {
  100. if (!encoder) return false;
  101. if (encoder->info.get_extra_data)
  102. return encoder->info.get_extra_data(encoder, extra_data, size);
  103. return false;
  104. }
  105. obs_data_t obs_encoder_get_settings(obs_encoder_t encoder)
  106. {
  107. if (!encoder) return NULL;
  108. obs_data_addref(encoder->settings);
  109. return encoder->settings;
  110. }
  111. bool obs_encoder_start(obs_encoder_t encoder,
  112. void (*new_packet)(void *param, struct encoder_packet *packet),
  113. void *param)
  114. {
  115. #pragma message ("TODO: implement obs_encoder_start")
  116. UNUSED_PARAMETER(encoder);
  117. UNUSED_PARAMETER(new_packet);
  118. UNUSED_PARAMETER(param);
  119. return false;
  120. }
  121. void obs_encoder_stop(obs_encoder_t encoder,
  122. void (*new_packet)(void *param, struct encoder_packet *packet),
  123. void *param)
  124. {
  125. #pragma message ("TODO: implement obs_encoder_stop")
  126. UNUSED_PARAMETER(encoder);
  127. UNUSED_PARAMETER(new_packet);
  128. UNUSED_PARAMETER(param);
  129. return;
  130. }