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.

214 lines
5.3KB

  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, JackClient* obj)
  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 void ClientOpen(const char* name, int* shared_engine, int* shared_client, int* shared_graph, int* result)
  54. {}
  55. virtual void ClientOpen(const char* name, int* ref, JackEngineControl** shared_engine, JackGraphManager** shared_manager, JackClientInterface* client, int* result)
  56. {}
  57. virtual void ClientClose(int refnum, int* result)
  58. {}
  59. virtual void ClientActivate(int refnum, int* result)
  60. {}
  61. virtual void ClientDeactivate(int refnum, int* result)
  62. {}
  63. virtual void PortRegister(int refnum, const char* name, unsigned int flags, unsigned int buffer_size, jack_port_id_t* port_index, int* result)
  64. {}
  65. virtual void PortUnRegister(int refnum, jack_port_id_t port_index, int* result)
  66. {}
  67. virtual void PortConnect(int refnum, const char* src, const char* dst, int* result)
  68. {}
  69. virtual void PortDisconnect(int refnum, const char* src, const char* dst, int* result)
  70. {}
  71. virtual void PortConnect(int refnum, jack_port_id_t src, jack_port_id_t dst, int* result)
  72. {}
  73. virtual void PortDisconnect(int refnum, jack_port_id_t src, jack_port_id_t dst, int* result)
  74. {}
  75. virtual void SetBufferSize(jack_nframes_t buffer_size, int* result)
  76. {}
  77. virtual void SetFreewheel(int onoff, int* result)
  78. {}
  79. virtual void ReleaseTimebase(int refnum, int* result)
  80. {}
  81. virtual void SetTimebaseCallback(int refnum, int conditional, int* result)
  82. {}
  83. };
  84. /*!
  85. \brief Inter process channel for server to client notifications.
  86. */
  87. class JackNotifyChannelInterface
  88. {
  89. public:
  90. JackNotifyChannelInterface()
  91. {}
  92. virtual ~JackNotifyChannelInterface()
  93. {}
  94. // Open the Server/Client connection
  95. virtual int Open(const char* name)
  96. {
  97. return 0;
  98. }
  99. // Close the Server/Client connection
  100. virtual void Close()
  101. {}
  102. /*
  103. The "sync" parameter allows to choose between "synchronous" and "asynchronous" notification
  104. */
  105. virtual void ClientNotify(int refnum, const char* name, int notify, int sync, int value, int* result)
  106. {}
  107. /*
  108. enum NotificationType {
  109. kAddClient = 0,
  110. kRemoveClient = 1,
  111. kActivateClient = 2,
  112. kXRunCallback = 3,
  113. kGraphOrderCallback = 4,
  114. kBufferSizeCallback = 5,
  115. kStartFreewheel = 6,
  116. kStopFreewheel = 7,
  117. kPortRegistrationOn = 8,
  118. kPortRegistrationOff = 9,
  119. kZombifyClient = 10,
  120. kDeadClient = 11,
  121. kMaxType
  122. };
  123. */
  124. };
  125. /*!
  126. \brief Entry point channel for client/server communication.
  127. */
  128. class JackServerChannelInterface
  129. {
  130. public:
  131. JackServerChannelInterface()
  132. {}
  133. virtual ~JackServerChannelInterface()
  134. {}
  135. // Open the Server/Client connection
  136. virtual int Open(JackServer* server)
  137. {
  138. return 0;
  139. }
  140. // Close the Server/Client connection
  141. virtual void Close()
  142. {}
  143. };
  144. /*!
  145. \brief Channel for server RT thread to request server thread communication.
  146. */
  147. class JackServerNotifyChannelInterface
  148. {
  149. public:
  150. JackServerNotifyChannelInterface()
  151. {}
  152. virtual ~JackServerNotifyChannelInterface()
  153. {}
  154. // Open the Server RT/Server connection
  155. virtual int Open()
  156. {
  157. return 0;
  158. }
  159. // Close the Server RT/Server connection
  160. virtual void Close()
  161. {}
  162. virtual void ClientNotify(int refnum, int notify, int value)
  163. {}
  164. };
  165. } // end of namespace
  166. #endif