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.

167 lines
4.1KB

  1. /*
  2. JACK control API
  3. Copyright (C) 2008 Nedko Arnaudov
  4. This program is free software; you can redistribute it and/or modify
  5. it under the terms of the GNU General Public License as published by
  6. the Free Software Foundation; version 2 of the License.
  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, write to the Free Software
  13. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  14. */
  15. #ifndef __control_types__
  16. #define __control_types__
  17. #include "jslist.h"
  18. #include "JackExports.h"
  19. #ifdef WIN32
  20. #ifdef __MINGW32__
  21. #include <sys/types.h>
  22. #else
  23. typedef HANDLE sigset_t;
  24. #endif
  25. #endif
  26. /** Parameter types, intentionally similar to jack_driver_param_type_t */
  27. typedef enum
  28. {
  29. JackParamInt = 1, /**< @brief value type is a signed integer */
  30. JackParamUInt, /**< @brief value type is an unsigned integer */
  31. JackParamChar, /**< @brief value type is a char */
  32. JackParamString, /**< @brief value type is a string with max size of ::JACK_PARAM_STRING_MAX+1 chars */
  33. JackParamBool, /**< @brief value type is a boolean */
  34. } jackctl_param_type_t;
  35. /** @brief Max value that jackctl_param_type_t type can have */
  36. #define JACK_PARAM_MAX (JackParamBool + 1)
  37. /** @brief Max length of string parameter value, excluding terminating nul char */
  38. #define JACK_PARAM_STRING_MAX 63
  39. /** @brief Type for parameter value */
  40. /* intentionally similar to jack_driver_param_value_t */
  41. union jackctl_parameter_value
  42. {
  43. uint32_t ui; /**< @brief member used for ::JackParamUInt */
  44. int32_t i; /**< @brief member used for ::JackParamInt */
  45. char c; /**< @brief member used for ::JackParamChar */
  46. char str[JACK_PARAM_STRING_MAX + 1]; /**< @brief member used for ::JackParamString */
  47. bool b; /**< @brief member used for ::JackParamBool */
  48. };
  49. /** opaque type for server object */
  50. typedef struct jackctl_server jackctl_server_t;
  51. /** opaque type for driver object */
  52. typedef struct jackctl_driver jackctl_driver_t;
  53. /** opaque type for parameter object */
  54. typedef struct jackctl_parameter jackctl_parameter_t;
  55. #ifdef __cplusplus
  56. extern "C" {
  57. #endif
  58. #if 0
  59. } /* Adjust editor indent */
  60. #endif
  61. EXPORT sigset_t
  62. jackctl_setup_signals(
  63. unsigned int flags);
  64. EXPORT void
  65. jackctl_wait_signals(
  66. sigset_t signals);
  67. EXPORT jackctl_server_t *
  68. jackctl_server_create();
  69. EXPORT void
  70. jackctl_server_destroy(
  71. jackctl_server_t * server);
  72. EXPORT const JSList *
  73. jackctl_server_get_drivers_list(
  74. jackctl_server_t * server);
  75. EXPORT bool
  76. jackctl_server_start(
  77. jackctl_server_t * server,
  78. jackctl_driver_t * driver);
  79. EXPORT bool
  80. jackctl_server_stop(
  81. jackctl_server_t * server);
  82. EXPORT const JSList *
  83. jackctl_server_get_parameters(
  84. jackctl_server_t * server);
  85. EXPORT const char *
  86. jackctl_driver_get_name(
  87. jackctl_driver_t * driver);
  88. EXPORT const JSList *
  89. jackctl_driver_get_parameters(
  90. jackctl_driver_t * driver);
  91. EXPORT const char *
  92. jackctl_parameter_get_name(
  93. jackctl_parameter_t * parameter);
  94. EXPORT const char *
  95. jackctl_parameter_get_short_description(
  96. jackctl_parameter_t * parameter);
  97. EXPORT const char *
  98. jackctl_parameter_get_long_description(
  99. jackctl_parameter_t * parameter);
  100. EXPORT jackctl_param_type_t
  101. jackctl_parameter_get_type(
  102. jackctl_parameter_t * parameter);
  103. EXPORT char
  104. jackctl_parameter_get_id(
  105. jackctl_parameter_t * parameter);
  106. EXPORT bool
  107. jackctl_parameter_is_set(
  108. jackctl_parameter_t * parameter);
  109. EXPORT bool
  110. jackctl_parameter_reset(
  111. jackctl_parameter_t * parameter);
  112. EXPORT union jackctl_parameter_value
  113. jackctl_parameter_get_value(
  114. jackctl_parameter_t * parameter);
  115. EXPORT bool
  116. jackctl_parameter_set_value(
  117. jackctl_parameter_t * parameter,
  118. const union jackctl_parameter_value * value_ptr);
  119. EXPORT union jackctl_parameter_value
  120. jackctl_parameter_get_default_value(
  121. jackctl_parameter_t * parameter);
  122. #if 0
  123. { /* Adjust editor indent */
  124. #endif
  125. #ifdef __cplusplus
  126. } /* extern "C" */
  127. #endif
  128. #endif