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.

215 lines
5.6KB

  1. /*
  2. Copyright (C) 2004-2006 Grame
  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, write to the Free Software
  13. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  14. */
  15. #ifndef __JackChannel__
  16. #define __JackChannel__
  17. #include "types.h"
  18. #include "JackError.h"
  19. #include "JackTransportEngine.h"
  20. namespace Jack
  21. {
  22. class JackClientInterface;
  23. class JackClient;
  24. class JackServer;
  25. struct JackEngineControl;
  26. class JackGraphManager;
  27. /*!
  28. \brief Inter process channel for server/client bidirectionnal communication : request and (receiving) notifications.
  29. */
  30. class JackClientChannelInterface
  31. {
  32. public:
  33. JackClientChannelInterface()
  34. {}
  35. virtual ~JackClientChannelInterface()
  36. {}
  37. // Open the Server/Client connection
  38. virtual int Open(const char* name, char* name_res, JackClient* obj, jack_options_t options, jack_status_t* status)
  39. {
  40. return 0;
  41. }
  42. // Close the Server/Client connection
  43. virtual void Close()
  44. {}
  45. // Start listening for messages from the server
  46. virtual int Start()
  47. {
  48. return 0;
  49. }
  50. // Stop listening for messages from the server
  51. virtual void Stop()
  52. {}
  53. virtual int ServerCheck(const char* server_name)
  54. {
  55. return -1;
  56. }
  57. virtual void ClientCheck(const char* name, char* name_res, int protocol, int options, int* status, int* result)
  58. {}
  59. virtual void ClientOpen(const char* name, int* shared_engine, int* shared_client, int* shared_graph, int* result)
  60. {}
  61. virtual void ClientOpen(const char* name, int* ref, JackEngineControl** shared_engine, JackGraphManager** shared_manager, JackClientInterface* client, int* result)
  62. {}
  63. virtual void ClientClose(int refnum, int* result)
  64. {}
  65. virtual void ClientActivate(int refnum, int* result)
  66. {}
  67. virtual void ClientDeactivate(int refnum, int* result)
  68. {}
  69. virtual void PortRegister(int refnum, const char* name, unsigned int flags, unsigned int buffer_size, jack_port_id_t* port_index, int* result)
  70. {}
  71. virtual void PortUnRegister(int refnum, jack_port_id_t port_index, int* result)
  72. {}
  73. virtual void PortConnect(int refnum, const char* src, const char* dst, int* result)
  74. {}
  75. virtual void PortDisconnect(int refnum, const char* src, const char* dst, int* result)
  76. {}
  77. virtual void PortConnect(int refnum, jack_port_id_t src, jack_port_id_t dst, int* result)
  78. {}
  79. virtual void PortDisconnect(int refnum, jack_port_id_t src, jack_port_id_t dst, int* result)
  80. {}
  81. virtual void SetBufferSize(jack_nframes_t buffer_size, int* result)
  82. {}
  83. virtual void SetFreewheel(int onoff, int* result)
  84. {}
  85. virtual void ReleaseTimebase(int refnum, int* result)
  86. {}
  87. virtual void SetTimebaseCallback(int refnum, int conditional, int* result)
  88. {}
  89. virtual void GetInternalClientName(int refnum, int int_ref, char* name_res, int* result)
  90. {}
  91. virtual void InternalClientHandle(int refnum, const char* client_name, int* status, int* int_ref, int* result)
  92. {}
  93. virtual void InternalClientLoad(int refnum, const char* client_name, const char* so_name, const char* objet_data, int options, int* status, int* int_ref, int* result)
  94. {}
  95. virtual void InternalClientUnload(int refnum, int int_ref, int* status, int* result)
  96. {}
  97. };
  98. /*!
  99. \brief Inter process channel for server to client notifications.
  100. */
  101. class JackNotifyChannelInterface
  102. {
  103. public:
  104. JackNotifyChannelInterface()
  105. {}
  106. virtual ~JackNotifyChannelInterface()
  107. {}
  108. // Open the Server/Client connection
  109. virtual int Open(const char* name)
  110. {
  111. return 0;
  112. }
  113. // Close the Server/Client connection
  114. virtual void Close()
  115. {}
  116. /*
  117. The "sync" parameter allows to choose between "synchronous" and "asynchronous" notification
  118. */
  119. virtual void ClientNotify(int refnum, const char* name, int notify, int sync, int value, int* result)
  120. {}
  121. };
  122. /*!
  123. \brief Entry point channel for client/server communication.
  124. */
  125. class JackServerChannelInterface
  126. {
  127. public:
  128. JackServerChannelInterface()
  129. {}
  130. virtual ~JackServerChannelInterface()
  131. {}
  132. // Open the Server/Client connection
  133. virtual int Open(JackServer* server)
  134. {
  135. return 0;
  136. }
  137. // Close the Server/Client connection
  138. virtual void Close()
  139. {}
  140. };
  141. /*!
  142. \brief Channel for server RT thread to request server thread communication.
  143. */
  144. class JackServerNotifyChannelInterface
  145. {
  146. public:
  147. JackServerNotifyChannelInterface()
  148. {}
  149. virtual ~JackServerNotifyChannelInterface()
  150. {}
  151. // Open the Server RT/Server connection
  152. virtual int Open()
  153. {
  154. return 0;
  155. }
  156. // Close the Server RT/Server connection
  157. virtual void Close()
  158. {}
  159. virtual void ClientNotify(int refnum, int notify, int value)
  160. {}
  161. };
  162. } // end of namespace
  163. #endif