Jack2 1.9.6

JackInternalClientChannel.h

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