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.

142 lines
4.1KB

  1. /*
  2. Copyright (C) 2001-2003 Paul Davis
  3. Copyright (C) 2004-2006 Grame
  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; either version 2 of the License, or
  7. (at your option) any later version.
  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. #ifdef WIN32
  17. #pragma warning (disable : 4786)
  18. #endif
  19. #include "JackGraphManager.h"
  20. #include "JackInternalClient.h"
  21. #include "JackServer.h"
  22. #include "JackDebugClient.h"
  23. #include "JackServerGlobals.h"
  24. #include "JackError.h"
  25. #include "JackServerLaunch.h"
  26. #include "JackTools.h"
  27. #ifdef WIN32
  28. #define EXPORT __declspec(dllexport)
  29. #else
  30. #define EXPORT
  31. #endif
  32. #ifdef __cplusplus
  33. extern "C"
  34. {
  35. #endif
  36. EXPORT jack_client_t * jack_client_open (const char *client_name,
  37. jack_options_t options,
  38. jack_status_t *status, ...);
  39. EXPORT jack_client_t * jack_client_new (const char *client_name);
  40. EXPORT int jack_client_close (jack_client_t *client);
  41. #ifdef __cplusplus
  42. }
  43. #endif
  44. using namespace Jack;
  45. EXPORT jack_client_t* jack_client_new(const char* client_name)
  46. {
  47. int options = JackUseExactName;
  48. if (getenv("JACK_START_SERVER") == NULL)
  49. options |= JackNoStartServer;
  50. return jack_client_open(client_name, (jack_options_t)options, NULL);
  51. }
  52. EXPORT jack_client_t* jack_client_open(const char* ext_client_name, jack_options_t options, jack_status_t* status, ...)
  53. {
  54. va_list ap; /* variable argument pointer */
  55. jack_varargs_t va; /* variable arguments */
  56. jack_status_t my_status;
  57. JackClient* client;
  58. char client_name[JACK_CLIENT_NAME_SIZE];
  59. JackTools::RewriteName(ext_client_name, client_name);
  60. if (status == NULL) /* no status from caller? */
  61. status = &my_status; /* use local status word */
  62. *status = (jack_status_t)0;
  63. /* validate parameters */
  64. if ((options & ~JackOpenOptions)) {
  65. int my_status1 = *status | (JackFailure | JackInvalidOption);
  66. *status = (jack_status_t)my_status1;
  67. return NULL;
  68. }
  69. /* parse variable arguments */
  70. va_start(ap, status);
  71. jack_varargs_parse(options, ap, &va);
  72. va_end(ap);
  73. JackLog("jack_client_open %s\n", client_name);
  74. if (client_name == NULL) {
  75. jack_error("jack_client_new called with a NULL client_name");
  76. return NULL;
  77. }
  78. if (!JackServerGlobals::Init()) { // jack server initialisation
  79. int my_status1 = (JackFailure | JackServerError);
  80. *status = (jack_status_t)my_status1;
  81. return NULL;
  82. }
  83. #ifndef WIN32
  84. char* jack_debug = getenv("JACK_CLIENT_DEBUG");
  85. if (jack_debug && strcmp(jack_debug, "on") == 0)
  86. client = new JackDebugClient(new JackInternalClient(JackServer::fInstance, GetSynchroTable())); // Debug mode
  87. else
  88. client = new JackInternalClient(JackServer::fInstance, GetSynchroTable());
  89. #else
  90. client = new JackInternalClient(JackServer::fInstance, GetSynchroTable());
  91. #endif
  92. int res = client->Open(va.server_name, client_name, options, status);
  93. if (res < 0) {
  94. delete client;
  95. JackServerGlobals::Destroy(); // jack server destruction
  96. int my_status1 = (JackFailure | JackServerError);
  97. *status = (jack_status_t)my_status1;
  98. return NULL;
  99. } else {
  100. return (jack_client_t*)client;
  101. }
  102. }
  103. EXPORT int jack_client_close(jack_client_t* ext_client)
  104. {
  105. JackLog("jack_client_close\n");
  106. JackClient* client = (JackClient*)ext_client;
  107. if (client == NULL) {
  108. jack_error("jack_client_close called with a NULL client");
  109. return -1;
  110. } else {
  111. int res = client->Close();
  112. delete client;
  113. JackLog("jack_client_close OK\n");
  114. JackServerGlobals::Destroy(); // jack server destruction
  115. return res;
  116. }
  117. }