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.

264 lines
6.9KB

  1. /*
  2. JACK control API
  3. Copyright (C) 2008 Nedko Arnaudov
  4. Copyright (C) 2008 Grame
  5. This program is free software; you can redistribute it and/or modify
  6. it under the terms of the GNU General Public License as published by
  7. the Free Software Foundation; version 2 of the License.
  8. This program is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. GNU General Public License for more details.
  12. You should have received a copy of the GNU General Public License
  13. along with this program; if not, write to the Free Software
  14. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  15. */
  16. #ifndef __JackControlAPI__
  17. #define __JackControlAPI__
  18. #include "jslist.h"
  19. #include "JackCompilerDeps.h"
  20. #ifdef WIN32
  21. #ifdef __MINGW32__
  22. #include <sys/types.h>
  23. typedef _sigset_t sigset_t;
  24. #else
  25. typedef HANDLE sigset_t;
  26. #endif
  27. #endif
  28. /** Parameter types, intentionally similar to jack_driver_param_type_t */
  29. typedef enum
  30. {
  31. JackParamInt = 1, /**< @brief value type is a signed integer */
  32. JackParamUInt, /**< @brief value type is an unsigned integer */
  33. JackParamChar, /**< @brief value type is a char */
  34. JackParamString, /**< @brief value type is a string with max size of ::JACK_PARAM_STRING_MAX+1 chars */
  35. JackParamBool, /**< @brief value type is a boolean */
  36. } jackctl_param_type_t;
  37. /** Driver types, intentionally similar to jack_driver_type_t */
  38. typedef enum
  39. {
  40. JackMaster = 1, /**< @brief master driver */
  41. JackSlave, /**< @brief slave driver */
  42. } jackctl_driver_type_t;
  43. /** @brief Max value that jackctl_param_type_t type can have */
  44. #define JACK_PARAM_MAX (JackParamBool + 1)
  45. /** @brief Max length of string parameter value, excluding terminating nul char */
  46. #define JACK_PARAM_STRING_MAX 127
  47. /** @brief Type for parameter value */
  48. /* intentionally similar to jack_driver_param_value_t */
  49. union jackctl_parameter_value
  50. {
  51. uint32_t ui; /**< @brief member used for ::JackParamUInt */
  52. int32_t i; /**< @brief member used for ::JackParamInt */
  53. char c; /**< @brief member used for ::JackParamChar */
  54. char str[JACK_PARAM_STRING_MAX + 1]; /**< @brief member used for ::JackParamString */
  55. bool b; /**< @brief member used for ::JackParamBool */
  56. };
  57. /** opaque type for server object */
  58. typedef struct jackctl_server jackctl_server_t;
  59. /** opaque type for driver object */
  60. typedef struct jackctl_driver jackctl_driver_t;
  61. /** opaque type for internal client object */
  62. typedef struct jackctl_internal jackctl_internal_t;
  63. /** opaque type for parameter object */
  64. typedef struct jackctl_parameter jackctl_parameter_t;
  65. #ifdef __cplusplus
  66. extern "C" {
  67. #endif
  68. #if 0
  69. } /* Adjust editor indent */
  70. #endif
  71. SERVER_EXPORT sigset_t
  72. jackctl_setup_signals(
  73. unsigned int flags);
  74. SERVER_EXPORT void
  75. jackctl_wait_signals(
  76. sigset_t signals);
  77. SERVER_EXPORT jackctl_server_t *
  78. jackctl_server_create(
  79. bool (* on_device_acquire)(const char * device_name),
  80. void (* on_device_release)(const char * device_name));
  81. SERVER_EXPORT void
  82. jackctl_server_destroy(
  83. jackctl_server_t * server);
  84. SERVER_EXPORT const JSList *
  85. jackctl_server_get_drivers_list(
  86. jackctl_server_t * server);
  87. SERVER_EXPORT bool
  88. jackctl_server_open(
  89. jackctl_server_t * server,
  90. jackctl_driver_t * driver);
  91. SERVER_EXPORT bool
  92. jackctl_server_start(
  93. jackctl_server_t * server);
  94. SERVER_EXPORT bool
  95. jackctl_server_stop(
  96. jackctl_server_t * server);
  97. SERVER_EXPORT bool
  98. jackctl_server_close(
  99. jackctl_server_t * server);
  100. SERVER_EXPORT const JSList *
  101. jackctl_server_get_parameters(
  102. jackctl_server_t * server);
  103. SERVER_EXPORT const char *
  104. jackctl_driver_get_name(
  105. jackctl_driver_t * driver);
  106. SERVER_EXPORT jackctl_driver_type_t
  107. jackctl_driver_get_type(
  108. jackctl_driver_t * driver);
  109. SERVER_EXPORT const JSList *
  110. jackctl_driver_get_parameters(
  111. jackctl_driver_t * driver);
  112. SERVER_EXPORT const char *
  113. jackctl_parameter_get_name(
  114. jackctl_parameter_t * parameter);
  115. SERVER_EXPORT const char *
  116. jackctl_parameter_get_short_description(
  117. jackctl_parameter_t * parameter);
  118. SERVER_EXPORT const char *
  119. jackctl_parameter_get_long_description(
  120. jackctl_parameter_t * parameter);
  121. SERVER_EXPORT jackctl_param_type_t
  122. jackctl_parameter_get_type(
  123. jackctl_parameter_t * parameter);
  124. SERVER_EXPORT char
  125. jackctl_parameter_get_id(
  126. jackctl_parameter_t * parameter);
  127. SERVER_EXPORT bool
  128. jackctl_parameter_is_set(
  129. jackctl_parameter_t * parameter);
  130. SERVER_EXPORT bool
  131. jackctl_parameter_reset(
  132. jackctl_parameter_t * parameter);
  133. SERVER_EXPORT union jackctl_parameter_value
  134. jackctl_parameter_get_value(
  135. jackctl_parameter_t * parameter);
  136. SERVER_EXPORT bool
  137. jackctl_parameter_set_value(
  138. jackctl_parameter_t * parameter,
  139. const union jackctl_parameter_value * value_ptr);
  140. SERVER_EXPORT union jackctl_parameter_value
  141. jackctl_parameter_get_default_value(
  142. jackctl_parameter_t * parameter);
  143. SERVER_EXPORT union jackctl_parameter_value
  144. jackctl_parameter_get_default_value(
  145. jackctl_parameter *parameter_ptr);
  146. SERVER_EXPORT bool
  147. jackctl_parameter_has_range_constraint(
  148. jackctl_parameter_t * parameter_ptr);
  149. SERVER_EXPORT bool
  150. jackctl_parameter_has_enum_constraint(
  151. jackctl_parameter_t * parameter_ptr);
  152. SERVER_EXPORT uint32_t
  153. jackctl_parameter_get_enum_constraints_count(
  154. jackctl_parameter_t * parameter_ptr);
  155. SERVER_EXPORT union jackctl_parameter_value
  156. jackctl_parameter_get_enum_constraint_value(
  157. jackctl_parameter_t * parameter_ptr,
  158. uint32_t index);
  159. SERVER_EXPORT const char *
  160. jackctl_parameter_get_enum_constraint_description(
  161. jackctl_parameter_t * parameter_ptr,
  162. uint32_t index);
  163. SERVER_EXPORT void
  164. jackctl_parameter_get_range_constraint(
  165. jackctl_parameter_t * parameter_ptr,
  166. union jackctl_parameter_value * min_ptr,
  167. union jackctl_parameter_value * max_ptr);
  168. SERVER_EXPORT bool
  169. jackctl_parameter_constraint_is_strict(
  170. jackctl_parameter_t * parameter_ptr);
  171. SERVER_EXPORT bool
  172. jackctl_parameter_constraint_is_fake_value(
  173. jackctl_parameter_t * parameter_ptr);
  174. SERVER_EXPORT const JSList *
  175. jackctl_server_get_internals_list(
  176. jackctl_server *server_ptr);
  177. SERVER_EXPORT const char *
  178. jackctl_internal_get_name(
  179. jackctl_internal *internal_ptr);
  180. SERVER_EXPORT const JSList *
  181. jackctl_internal_get_parameters(
  182. jackctl_internal *internal_ptr);
  183. SERVER_EXPORT bool jackctl_server_load_internal(
  184. jackctl_server * server,
  185. jackctl_internal * internal);
  186. SERVER_EXPORT bool jackctl_server_unload_internal(
  187. jackctl_server * server,
  188. jackctl_internal * internal);
  189. SERVER_EXPORT bool jackctl_server_add_slave(jackctl_server_t * server,
  190. jackctl_driver_t * driver);
  191. SERVER_EXPORT bool jackctl_server_remove_slave(jackctl_server_t * server,
  192. jackctl_driver_t * driver);
  193. SERVER_EXPORT bool
  194. jackctl_server_switch_master(jackctl_server_t * server,
  195. jackctl_driver_t * driver);
  196. #if 0
  197. { /* Adjust editor indent */
  198. #endif
  199. #ifdef __cplusplus
  200. } /* extern "C" */
  201. #endif
  202. #endif