Jack2 1.9.6
|
00001 /* 00002 Copyright (C) 2004-2008 Grame 00003 00004 This program is free software; you can redistribute it and/or modify 00005 it under the terms of the GNU General Public License as published by 00006 the Free Software Foundation; either version 2 of the License, or 00007 (at your option) any later version. 00008 00009 This program is distributed in the hope that it will be useful, 00010 but WITHOUT ANY WARRANTY; without even the implied warranty of 00011 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00012 GNU General Public License for more details. 00013 00014 You should have received a copy of the GNU General Public License 00015 along with this program; if not, write to the Free Software 00016 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 00017 00018 */ 00019 00020 #ifndef __JackInternalClientChannel__ 00021 #define __JackInternalClientChannel__ 00022 00023 #include "JackChannel.h" 00024 00025 namespace Jack 00026 { 00027 00032 class JackInternalClientChannel : public detail::JackClientChannelInterface 00033 { 00034 00035 private: 00036 00037 JackServer* fServer; 00038 JackLockedEngine* fEngine; 00039 00040 public: 00041 00042 JackInternalClientChannel(JackServer* server): fServer(server), fEngine(server->GetEngine()) 00043 {} 00044 virtual ~JackInternalClientChannel() 00045 {} 00046 00047 // Open the Server/Client connection 00048 virtual int Open(const char* name, char* name_res, JackClient* obj, jack_options_t options, jack_status_t* status) 00049 { 00050 return 0; 00051 } 00052 00053 void ClientCheck(const char* name, char* name_res, int protocol, int options, int* status, int* result) 00054 { 00055 *result = fEngine->ClientCheck(name, name_res, protocol, options, status); 00056 } 00057 void ClientOpen(const char* name, int* ref, JackEngineControl** shared_engine, JackGraphManager** shared_manager, JackClientInterface* client, int* result) 00058 { 00059 *result = fEngine->ClientInternalOpen(name, ref, shared_engine, shared_manager, client, true); 00060 } 00061 void ClientClose(int refnum, int* result) 00062 { 00063 *result = fEngine->ClientInternalClose(refnum, true); 00064 } 00065 00066 void ClientActivate(int refnum, int is_real_time, int* result) 00067 { 00068 *result = fEngine->ClientActivate(refnum, is_real_time); 00069 } 00070 void ClientDeactivate(int refnum, int* result) 00071 { 00072 *result = fEngine->ClientDeactivate(refnum); 00073 } 00074 00075 void PortRegister(int refnum, const char* name, const char* type, unsigned int flags, unsigned int buffer_size, unsigned int* port_index, int* result) 00076 { 00077 *result = fEngine->PortRegister(refnum, name, type, flags, buffer_size, port_index); 00078 } 00079 void PortUnRegister(int refnum, jack_port_id_t port_index, int* result) 00080 { 00081 *result = fEngine->PortUnRegister(refnum, port_index); 00082 } 00083 00084 void PortConnect(int refnum, const char* src, const char* dst, int* result) 00085 { 00086 *result = fEngine->PortConnect(refnum, src, dst); 00087 } 00088 void PortDisconnect(int refnum, const char* src, const char* dst, int* result) 00089 { 00090 *result = fEngine->PortDisconnect(refnum, src, dst); 00091 } 00092 00093 void PortConnect(int refnum, jack_port_id_t src, jack_port_id_t dst, int* result) 00094 { 00095 *result = fEngine->PortConnect(refnum, src, dst); 00096 } 00097 void PortDisconnect(int refnum, jack_port_id_t src, jack_port_id_t dst, int* result) 00098 { 00099 *result = fEngine->PortDisconnect(refnum, src, dst); 00100 } 00101 void PortRename(int refnum, jack_port_id_t port, const char* name, int* result) 00102 { 00103 *result = fEngine->PortRename(refnum, port, name); 00104 } 00105 00106 void SetBufferSize(jack_nframes_t buffer_size, int* result) 00107 { 00108 *result = fServer->SetBufferSize(buffer_size); 00109 } 00110 void SetFreewheel(int onoff, int* result) 00111 { 00112 *result = fServer->SetFreewheel(onoff); 00113 } 00114 00115 void ReleaseTimebase(int refnum, int* result) 00116 { 00117 *result = fServer->ReleaseTimebase(refnum); 00118 } 00119 00120 void SetTimebaseCallback(int refnum, int conditional, int* result) 00121 { 00122 *result = fServer->SetTimebaseCallback(refnum, conditional); 00123 } 00124 00125 void GetInternalClientName(int refnum, int int_ref, char* name_res, int* result) 00126 { 00127 *result = fEngine->GetInternalClientName(int_ref, name_res); 00128 } 00129 00130 void InternalClientHandle(int refnum, const char* client_name, int* status, int* int_ref, int* result) 00131 { 00132 *result = fEngine->InternalClientHandle(client_name, status, int_ref); 00133 } 00134 00135 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) 00136 { 00137 *result = fServer->InternalClientLoad(client_name, so_name, objet_data, options, int_ref, status); 00138 } 00139 00140 void InternalClientUnload(int refnum, int int_ref, int* status, int* result) 00141 { 00142 *result = fEngine->InternalClientUnload(int_ref, status); 00143 } 00144 00145 }; 00146 00147 } // end of namespace 00148 00149 #endif 00150