jack2 codebase
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.

255 lines
6.8KB

  1. /* JACK server control API */
  2. /* SPDX-FileCopyrightText: Copyright © 2008-2023 Nedko Arnaudov */
  3. /* SPDX-FileCopyrightText: Copyright © 2008-2023 Grame */
  4. /* SPDX-License-Identifier: ( GPL-2.0-or-later OR LGPL-2.1-or-later OR MIT OR AFL-2.1 ) */
  5. #ifndef __JackControlAPI__
  6. #define __JackControlAPI__
  7. #include "jslist.h"
  8. #include "JackCompilerDeps.h"
  9. /** Parameter types, intentionally similar to jack_driver_param_type_t */
  10. typedef enum
  11. {
  12. JackParamInt = 1, /**< @brief value type is a signed integer */
  13. JackParamUInt, /**< @brief value type is an unsigned integer */
  14. JackParamChar, /**< @brief value type is a char */
  15. JackParamString, /**< @brief value type is a string with max size of ::JACK_PARAM_STRING_MAX+1 chars */
  16. JackParamBool, /**< @brief value type is a boolean */
  17. } jackctl_param_type_t;
  18. /** Driver types, intentionally similar to jack_driver_type_t */
  19. typedef enum
  20. {
  21. JackMaster = 1, /**< @brief master driver */
  22. JackSlave, /**< @brief slave driver */
  23. } jackctl_driver_type_t;
  24. /** @brief Max value that jackctl_param_type_t type can have */
  25. #define JACK_PARAM_MAX (JackParamBool + 1)
  26. /** @brief Max length of string parameter value, excluding terminating nul char */
  27. #define JACK_PARAM_STRING_MAX 127
  28. /** @brief Type for parameter value */
  29. /* intentionally similar to jack_driver_param_value_t */
  30. union jackctl_parameter_value
  31. {
  32. uint32_t ui; /**< @brief member used for ::JackParamUInt */
  33. int32_t i; /**< @brief member used for ::JackParamInt */
  34. char c; /**< @brief member used for ::JackParamChar */
  35. char str[JACK_PARAM_STRING_MAX + 1]; /**< @brief member used for ::JackParamString */
  36. bool b; /**< @brief member used for ::JackParamBool */
  37. };
  38. /** opaque type for server object */
  39. typedef struct jackctl_server jackctl_server_t;
  40. /** opaque type for driver object */
  41. typedef struct jackctl_driver jackctl_driver_t;
  42. /** opaque type for internal client object */
  43. typedef struct jackctl_internal jackctl_internal_t;
  44. /** opaque type for parameter object */
  45. typedef struct jackctl_parameter jackctl_parameter_t;
  46. /** opaque type for sigmask object */
  47. typedef struct jackctl_sigmask jackctl_sigmask_t;
  48. #ifdef __cplusplus
  49. extern "C" {
  50. #endif
  51. #if 0
  52. } /* Adjust editor indent */
  53. #endif
  54. SERVER_EXPORT jackctl_sigmask_t *
  55. jackctl_setup_signals(
  56. unsigned int flags);
  57. SERVER_EXPORT void
  58. jackctl_wait_signals(
  59. jackctl_sigmask_t * signals);
  60. SERVER_EXPORT jackctl_server_t *
  61. jackctl_server_create(
  62. bool (* on_device_acquire)(const char * device_name),
  63. void (* on_device_release)(const char * device_name));
  64. SERVER_EXPORT jackctl_server_t *
  65. jackctl_server_create2(
  66. bool (* on_device_acquire)(const char * device_name),
  67. void (* on_device_release)(const char * device_name),
  68. void (* on_device_reservation_loop)(void));
  69. SERVER_EXPORT void
  70. jackctl_server_destroy(
  71. jackctl_server_t * server);
  72. SERVER_EXPORT const JSList *
  73. jackctl_server_get_drivers_list(
  74. jackctl_server_t * server);
  75. SERVER_EXPORT bool
  76. jackctl_server_open(
  77. jackctl_server_t * server,
  78. jackctl_driver_t * driver);
  79. SERVER_EXPORT bool
  80. jackctl_server_start(
  81. jackctl_server_t * server);
  82. SERVER_EXPORT bool
  83. jackctl_server_stop(
  84. jackctl_server_t * server);
  85. SERVER_EXPORT bool
  86. jackctl_server_close(
  87. jackctl_server_t * server);
  88. SERVER_EXPORT const JSList *
  89. jackctl_server_get_parameters(
  90. jackctl_server_t * server);
  91. SERVER_EXPORT const char *
  92. jackctl_driver_get_name(
  93. jackctl_driver_t * driver);
  94. SERVER_EXPORT jackctl_driver_type_t
  95. jackctl_driver_get_type(
  96. jackctl_driver_t * driver);
  97. SERVER_EXPORT const JSList *
  98. jackctl_driver_get_parameters(
  99. jackctl_driver_t * driver);
  100. SERVER_EXPORT const char *
  101. jackctl_parameter_get_name(
  102. jackctl_parameter_t * parameter);
  103. SERVER_EXPORT const char *
  104. jackctl_parameter_get_short_description(
  105. jackctl_parameter_t * parameter);
  106. SERVER_EXPORT const char *
  107. jackctl_parameter_get_long_description(
  108. jackctl_parameter_t * parameter);
  109. SERVER_EXPORT jackctl_param_type_t
  110. jackctl_parameter_get_type(
  111. jackctl_parameter_t * parameter);
  112. SERVER_EXPORT char
  113. jackctl_parameter_get_id(
  114. jackctl_parameter_t * parameter);
  115. SERVER_EXPORT bool
  116. jackctl_parameter_is_set(
  117. jackctl_parameter_t * parameter);
  118. SERVER_EXPORT bool
  119. jackctl_parameter_reset(
  120. jackctl_parameter_t * parameter);
  121. SERVER_EXPORT union jackctl_parameter_value
  122. jackctl_parameter_get_value(
  123. jackctl_parameter_t * parameter);
  124. SERVER_EXPORT bool
  125. jackctl_parameter_set_value(
  126. jackctl_parameter_t * parameter,
  127. const union jackctl_parameter_value * value_ptr);
  128. SERVER_EXPORT union jackctl_parameter_value
  129. jackctl_parameter_get_default_value(
  130. jackctl_parameter_t * parameter);
  131. SERVER_EXPORT union jackctl_parameter_value
  132. jackctl_parameter_get_default_value(
  133. jackctl_parameter *parameter_ptr);
  134. SERVER_EXPORT bool
  135. jackctl_parameter_has_range_constraint(
  136. jackctl_parameter_t * parameter_ptr);
  137. SERVER_EXPORT bool
  138. jackctl_parameter_has_enum_constraint(
  139. jackctl_parameter_t * parameter_ptr);
  140. SERVER_EXPORT uint32_t
  141. jackctl_parameter_get_enum_constraints_count(
  142. jackctl_parameter_t * parameter_ptr);
  143. SERVER_EXPORT union jackctl_parameter_value
  144. jackctl_parameter_get_enum_constraint_value(
  145. jackctl_parameter_t * parameter_ptr,
  146. uint32_t index);
  147. SERVER_EXPORT const char *
  148. jackctl_parameter_get_enum_constraint_description(
  149. jackctl_parameter_t * parameter_ptr,
  150. uint32_t index);
  151. SERVER_EXPORT void
  152. jackctl_parameter_get_range_constraint(
  153. jackctl_parameter_t * parameter_ptr,
  154. union jackctl_parameter_value * min_ptr,
  155. union jackctl_parameter_value * max_ptr);
  156. SERVER_EXPORT bool
  157. jackctl_parameter_constraint_is_strict(
  158. jackctl_parameter_t * parameter_ptr);
  159. SERVER_EXPORT bool
  160. jackctl_parameter_constraint_is_fake_value(
  161. jackctl_parameter_t * parameter_ptr);
  162. SERVER_EXPORT const JSList *
  163. jackctl_server_get_internals_list(
  164. jackctl_server *server_ptr);
  165. SERVER_EXPORT const char *
  166. jackctl_internal_get_name(
  167. jackctl_internal *internal_ptr);
  168. SERVER_EXPORT const JSList *
  169. jackctl_internal_get_parameters(
  170. jackctl_internal *internal_ptr);
  171. SERVER_EXPORT bool jackctl_server_load_internal(
  172. jackctl_server * server,
  173. jackctl_internal * internal);
  174. SERVER_EXPORT bool jackctl_server_unload_internal(
  175. jackctl_server * server,
  176. jackctl_internal * internal);
  177. SERVER_EXPORT bool jackctl_server_load_session_file(
  178. jackctl_server * server_ptr,
  179. const char * file);
  180. SERVER_EXPORT bool jackctl_server_add_slave(jackctl_server_t * server,
  181. jackctl_driver_t * driver);
  182. SERVER_EXPORT bool jackctl_server_remove_slave(jackctl_server_t * server,
  183. jackctl_driver_t * driver);
  184. SERVER_EXPORT bool
  185. jackctl_server_switch_master(jackctl_server_t * server,
  186. jackctl_driver_t * driver);
  187. SERVER_EXPORT int
  188. jackctl_parse_driver_params(jackctl_driver * driver_ptr, int argc, char* argv[]);
  189. #if 0
  190. { /* Adjust editor indent */
  191. #endif
  192. #ifdef __cplusplus
  193. } /* extern "C" */
  194. #endif
  195. #endif