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.

211 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 ClientNew(const char* name, int* shared_engine, int* shared_client, int* shared_ports, int* result)
  54. {}
  55. virtual void ClientNew(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 nframes, 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. typedef enum {
  108. kAddClient = 0,
  109. kRemoveClient = 1,
  110. kXRunCallback = 2,
  111. kGraphOrderCallback = 3,
  112. kBufferSizeCallback = 4,
  113. kStartFreewheel = 5,
  114. kStopFreewheel = 6,
  115. kPortRegistrationOn = 7,
  116. kPortRegistrationOff = 8,
  117. kZombifyClient = 9,
  118. kDeadClient = 10
  119. } NotificationType;
  120. };
  121. /*!
  122. \brief Entry point channel for client/server communication.
  123. */
  124. class JackServerChannelInterface
  125. {
  126. public:
  127. JackServerChannelInterface()
  128. {}
  129. virtual ~JackServerChannelInterface()
  130. {}
  131. // Open the Server/Client connection
  132. virtual int Open(JackServer* server)
  133. {
  134. return 0;
  135. }
  136. // Close the Server/Client connection
  137. virtual void Close()
  138. {}
  139. };
  140. /*!
  141. \brief Channel for server RT thread to request server thread communication.
  142. */
  143. class JackServerNotifyChannelInterface
  144. {
  145. public:
  146. JackServerNotifyChannelInterface()
  147. {}
  148. virtual ~JackServerNotifyChannelInterface()
  149. {}
  150. // Open the Server RT/Server connection
  151. virtual int Open()
  152. {
  153. return 0;
  154. }
  155. // Close the Server RT/Server connection
  156. virtual void Close()
  157. {}
  158. virtual void ClientNotify(int refnum, int notify, int value)
  159. {}
  160. };
  161. } // end of namespace
  162. #endif