| 
							- /*
 - Copyright (C) 2001 Paul Davis
 - Copyright (C) 2004-2008 Grame
 - 
 - This program is free software; you can redistribute it and/or modify
 - it under the terms of the GNU Lesser General Public License as published by
 - the Free Software Foundation; either version 2.1 of the License, or
 - (at your option) any later version.
 - 
 - This program is distributed in the hope that it will be useful,
 - but WITHOUT ANY WARRANTY; without even the implied warranty of
 - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 - GNU Lesser General Public License for more details.
 - 
 - You should have received a copy of the GNU Lesser General Public License
 - along with this program; if not, write to the Free Software 
 - Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
 - 
 - */
 - 
 - #ifndef __JackRequest__
 - #define __JackRequest__
 - 
 - #include "JackConstants.h"
 - #include "JackPlatformPlug.h"
 - #include "types.h"
 - #include <string.h>
 - #include <stdio.h>
 - 
 - namespace Jack
 - {
 - 
 - #define CheckRes(exp) { if ((exp) < 0) return -1;}
 - 
 - /*!
 - \brief Request from client to server.
 - */
 - 
 - struct JackRequest
 - {
 - 
 -     enum RequestType {
 -         kRegisterPort = 1,
 -         kUnRegisterPort = 2,
 -         kConnectPorts = 3,
 -         kDisconnectPorts = 4,
 -         kSetTimeBaseClient = 5,
 -         kActivateClient = 6,
 -         kDeactivateClient = 7,
 -         kDisconnectPort = 8,
 -         kSetClientCapabilities = 9,
 -         kGetPortConnections = 10,
 -         kGetPortNConnections = 11,
 -         kReleaseTimebase = 12,
 -         kSetTimebaseCallback = 13,
 -         kSetBufferSize = 20,
 -         kSetFreeWheel = 21,
 -         kClientCheck = 22,
 -         kClientOpen = 23,
 -         kClientClose = 24,
 -         kConnectNamePorts = 25,
 -         kDisconnectNamePorts = 26,
 -         kGetInternalClientName = 27,
 -         kInternalClientHandle = 28,
 -         kInternalClientLoad = 29,
 -         kInternalClientUnload = 30,
 -         kPortRename = 31,
 -         kNotification = 32
 -     };
 - 
 -     RequestType fType;
 - 
 -     JackRequest()
 -     {}
 - 
 -     JackRequest(RequestType type): fType(type)
 -     {}
 - 
 -     virtual ~JackRequest()
 -     {}
 - 
 -     virtual int Read(JackChannelTransaction* trans)
 -     {
 -         return trans->Read(&fType, sizeof(RequestType));
 -     }
 - 
 -     virtual int Write(JackChannelTransaction* trans)
 -     {
 -         return trans->Write(&fType, sizeof(RequestType));
 -     }
 - 
 - };
 - 
 - /*!
 - \brief Result from the server.
 - */
 - 
 - struct JackResult
 - {
 - 
 -     int	fResult;
 - 
 -     JackResult(): fResult( -1)
 -     {}
 -     JackResult(int result): fResult(result)
 -     {}
 -     virtual ~JackResult()
 -     {}
 - 
 -     virtual int Read(JackChannelTransaction* trans)
 -     {
 -         return trans->Read(&fResult, sizeof(int));
 -     }
 - 
 -     virtual int Write(JackChannelTransaction* trans)
 -     {
 -         return trans->Write(&fResult, sizeof(int));
 -     }
 -     
 - };
 - 
 - /*!
 - \brief CheckClient request.
 - */
 - 
 - struct JackClientCheckRequest : public JackRequest
 - {
 - 
 -     char fName[JACK_CLIENT_NAME_SIZE + 1];
 -     int fProtocol;
 -     int fOptions;
 - 
 -     JackClientCheckRequest()
 -     {}
 -     JackClientCheckRequest(const char* name, int protocol, int options)
 -         : JackRequest(JackRequest::kClientCheck), fProtocol(protocol), fOptions(options)
 -     {
 -         snprintf(fName, sizeof(fName), "%s", name);
 -     }
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(trans->Read(&fName, JACK_CLIENT_NAME_SIZE + 1));
 -         CheckRes(trans->Read(&fProtocol, sizeof(int)));
 -         return trans->Read(&fOptions, sizeof(int));
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         CheckRes(trans->Write(&fName, JACK_CLIENT_NAME_SIZE + 1));
 -         CheckRes(trans->Write(&fProtocol, sizeof(int)));
 -         return trans->Write(&fOptions, sizeof(int));
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief CheckClient result.
 - */
 - 
 - struct JackClientCheckResult : public JackResult
 - {
 - 
 -     char fName[JACK_CLIENT_NAME_SIZE + 1];
 -     int fStatus;
 - 
 -     JackClientCheckResult(): JackResult(), fStatus(0)
 -     {}
 -     JackClientCheckResult(int32_t result, const char* name, int status)
 -             : JackResult(result), fStatus(status)
 -     {
 -         snprintf(fName, sizeof(fName), "%s", name);
 -     }
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackResult::Read(trans));
 -         CheckRes(trans->Read(&fName, JACK_CLIENT_NAME_SIZE + 1));
 -         CheckRes(trans->Read(&fStatus, sizeof(int)));
 -         return 0;
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackResult::Write(trans));
 -         CheckRes(trans->Write(&fName, JACK_CLIENT_NAME_SIZE + 1));
 -         CheckRes(trans->Write(&fStatus, sizeof(int)));
 -         return 0;
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief NewClient request.
 - */
 - 
 - struct JackClientOpenRequest : public JackRequest
 - {
 - 
 -     int fPID;
 -     char fName[JACK_CLIENT_NAME_SIZE + 1];
 - 
 -     JackClientOpenRequest()
 -     {}
 -     JackClientOpenRequest(const char* name, int pid): JackRequest(JackRequest::kClientOpen)
 -     {
 -         snprintf(fName, sizeof(fName), "%s", name);
 -         fPID = pid;
 -     }
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(trans->Read(&fPID, sizeof(int)));
 -         return trans->Read(&fName, JACK_CLIENT_NAME_SIZE + 1);
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         CheckRes(trans->Write(&fPID, sizeof(int)));
 -         return trans->Write(&fName, JACK_CLIENT_NAME_SIZE + 1);
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief NewClient result.
 - */
 - 
 - struct JackClientOpenResult : public JackResult
 - {
 - 
 -     int fSharedEngine;
 -     int fSharedClient;
 -     int fSharedGraph;
 -    
 -     JackClientOpenResult()
 -             : JackResult(), fSharedEngine(-1), fSharedClient(-1), fSharedGraph(-1)
 -     {}
 -     JackClientOpenResult(int32_t result, int index1, int index2, int index3)
 -             : JackResult(result), fSharedEngine(index1), fSharedClient(index2), fSharedGraph(index3)
 -     {}
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackResult::Read(trans));
 -         CheckRes(trans->Read(&fSharedEngine, sizeof(int)));
 -         CheckRes(trans->Read(&fSharedClient, sizeof(int)));
 -         CheckRes(trans->Read(&fSharedGraph, sizeof(int)));
 -         return 0;
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackResult::Write(trans));
 -         CheckRes(trans->Write(&fSharedEngine, sizeof(int)));
 -         CheckRes(trans->Write(&fSharedClient, sizeof(int)));
 -         CheckRes(trans->Write(&fSharedGraph, sizeof(int)));
 -         return 0;
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief CloseClient request.
 - */
 - 
 - struct JackClientCloseRequest : public JackRequest
 - {
 - 
 -     int fRefNum;
 - 
 -     JackClientCloseRequest()
 -     {}
 -     JackClientCloseRequest(int refnum): JackRequest(JackRequest::kClientClose), fRefNum(refnum)
 -     {}
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         return trans->Read(&fRefNum, sizeof(int));
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         return trans->Write(&fRefNum, sizeof(int));
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief Activate request.
 - */
 - 
 - struct JackActivateRequest : public JackRequest
 - {
 - 
 -     int fRefNum;
 -     int fState;
 - 
 -     JackActivateRequest()
 -     {}
 -     JackActivateRequest(int refnum, int state)
 -         : JackRequest(JackRequest::kActivateClient), fRefNum(refnum), fState(state)
 -     {}
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(trans->Read(&fRefNum, sizeof(int)));
 -         return trans->Read(&fState, sizeof(int));
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         CheckRes(trans->Write(&fRefNum, sizeof(int)));
 -         return trans->Write(&fState, sizeof(int));
 -     }
 - 
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief Deactivate request.
 - */
 - 
 - struct JackDeactivateRequest : public JackRequest
 - {
 - 
 -     int fRefNum;
 - 
 -     JackDeactivateRequest()
 -     {}
 -     JackDeactivateRequest(int refnum): JackRequest(JackRequest::kDeactivateClient), fRefNum(refnum)
 -     {}
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         return trans->Read(&fRefNum, sizeof(int));
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         return trans->Write(&fRefNum, sizeof(int));
 -     }
 - 
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief PortRegister request.
 - */
 - 
 - struct JackPortRegisterRequest : public JackRequest
 - {
 - 
 -     int fRefNum;
 -     char fName[JACK_PORT_NAME_SIZE + 1];
 -     char fPortType[JACK_PORT_TYPE_SIZE + 1];
 -     unsigned int fFlags;
 -     unsigned int fBufferSize;
 - 
 -     JackPortRegisterRequest()
 -     {}
 -     JackPortRegisterRequest(int refnum, const char* name, const char* port_type, unsigned int flags, unsigned int buffer_size)
 -             : JackRequest(JackRequest::kRegisterPort), fRefNum(refnum), fFlags(flags), fBufferSize(buffer_size)
 -     {
 -         strcpy(fName, name);
 -         strcpy(fPortType, port_type);
 -     }
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(trans->Read(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Read(&fName, JACK_PORT_NAME_SIZE + 1));
 -         CheckRes(trans->Read(&fPortType, JACK_PORT_TYPE_SIZE + 1));
 -         CheckRes(trans->Read(&fFlags, sizeof(unsigned int)));
 -         CheckRes(trans->Read(&fBufferSize, sizeof(unsigned int)));
 -         return 0;
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         CheckRes(trans->Write(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Write(&fName, JACK_PORT_NAME_SIZE + 1));
 -         CheckRes(trans->Write(&fPortType, JACK_PORT_TYPE_SIZE + 1));
 -         CheckRes(trans->Write(&fFlags, sizeof(unsigned int)));
 -         CheckRes(trans->Write(&fBufferSize, sizeof(unsigned int)));
 -         return 0;
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief PortRegister result.
 - */
 - 
 - struct JackPortRegisterResult : public JackResult
 - {
 - 
 -     jack_port_id_t fPortIndex;
 - 
 -     JackPortRegisterResult(): JackResult(), fPortIndex(NO_PORT)
 -     {}
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackResult::Read(trans));
 -         return trans->Read(&fPortIndex, sizeof(jack_port_id_t));
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackResult::Write(trans));
 -         return trans->Write(&fPortIndex, sizeof(jack_port_id_t));
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief PortUnregister request.
 - */
 - 
 - struct JackPortUnRegisterRequest : public JackRequest
 - {
 - 
 -     int fRefNum;
 -     jack_port_id_t fPortIndex;
 - 
 -     JackPortUnRegisterRequest()
 -     {}
 -     JackPortUnRegisterRequest(int refnum, jack_port_id_t index)
 -         : JackRequest(JackRequest::kUnRegisterPort), fRefNum(refnum), fPortIndex(index)
 -     {}
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(trans->Read(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Read(&fPortIndex, sizeof(jack_port_id_t)));
 -         return 0;
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         CheckRes(trans->Write(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Write(&fPortIndex, sizeof(jack_port_id_t)));
 -         return 0;
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief PortConnectName request.
 - */
 - 
 - struct JackPortConnectNameRequest : public JackRequest
 - {
 - 
 -     int fRefNum;
 -     char fSrc[JACK_PORT_NAME_SIZE + 1];
 -     char fDst[JACK_PORT_NAME_SIZE + 1];
 - 
 -     JackPortConnectNameRequest()
 -     {}
 -     JackPortConnectNameRequest(int refnum, const char* src_name, const char* dst_name)
 -         : JackRequest(JackRequest::kConnectNamePorts), fRefNum(refnum)
 -     {
 -         strcpy(fSrc, src_name);
 -         strcpy(fDst, dst_name);
 -     }
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(trans->Read(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Read(&fSrc, JACK_PORT_NAME_SIZE + 1));
 -         CheckRes(trans->Read(&fDst, JACK_PORT_NAME_SIZE + 1));
 -         return 0;
 - 
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         CheckRes(trans->Write(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Write(&fSrc, JACK_PORT_NAME_SIZE + 1));
 -         CheckRes(trans->Write(&fDst, JACK_PORT_NAME_SIZE + 1));
 -         return 0;
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief PortDisconnectName request.
 - */
 - 
 - struct JackPortDisconnectNameRequest : public JackRequest
 - {
 - 
 -     int fRefNum;
 -     char fSrc[JACK_PORT_NAME_SIZE + 1];
 -     char fDst[JACK_PORT_NAME_SIZE + 1];
 - 
 -     JackPortDisconnectNameRequest()
 -     {}
 -     JackPortDisconnectNameRequest(int refnum, const char* src_name, const char* dst_name)
 -         : JackRequest(JackRequest::kDisconnectNamePorts), fRefNum(refnum)
 -     {
 -         strcpy(fSrc, src_name);
 -         strcpy(fDst, dst_name);
 -     }
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(trans->Read(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Read(&fSrc, JACK_PORT_NAME_SIZE + 1));
 -         CheckRes(trans->Read(&fDst, JACK_PORT_NAME_SIZE + 1));
 -         return 0;
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         CheckRes(trans->Write(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Write(&fSrc, JACK_PORT_NAME_SIZE + 1));
 -         CheckRes(trans->Write(&fDst, JACK_PORT_NAME_SIZE + 1));
 -         return 0;
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief PortConnect request.
 - */
 - 
 - struct JackPortConnectRequest : public JackRequest
 - {
 - 
 -     int fRefNum;
 -     jack_port_id_t fSrc;
 -     jack_port_id_t fDst;
 - 
 -     JackPortConnectRequest()
 -     {}
 -     JackPortConnectRequest(int refnum, jack_port_id_t src, jack_port_id_t dst)
 -         : JackRequest(JackRequest::kConnectPorts), fRefNum(refnum), fSrc(src), fDst(dst)
 -     {}
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(trans->Read(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Read(&fSrc, sizeof(jack_port_id_t)));
 -         CheckRes(trans->Read(&fDst, sizeof(jack_port_id_t)));
 -         return 0;
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         CheckRes(trans->Write(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Write(&fSrc, sizeof(jack_port_id_t)));
 -         CheckRes(trans->Write(&fDst, sizeof(jack_port_id_t)));
 -         return 0;
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief PortDisconnect request.
 - */
 - 
 - struct JackPortDisconnectRequest : public JackRequest
 - {
 - 
 -     int fRefNum;
 -     jack_port_id_t fSrc;
 -     jack_port_id_t fDst;
 - 
 -     JackPortDisconnectRequest()
 -     {}
 -     JackPortDisconnectRequest(int refnum, jack_port_id_t src, jack_port_id_t dst)
 -         : JackRequest(JackRequest::kDisconnectPorts), fRefNum(refnum), fSrc(src), fDst(dst)
 -     {}
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(trans->Read(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Read(&fSrc, sizeof(jack_port_id_t)));
 -         CheckRes(trans->Read(&fDst, sizeof(jack_port_id_t)));
 -         return 0;
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         CheckRes(trans->Write(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Write(&fSrc, sizeof(jack_port_id_t)));
 -         CheckRes(trans->Write(&fDst, sizeof(jack_port_id_t)));
 -         return 0;
 - 
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief PortRename request.
 - */
 - 
 - struct JackPortRenameRequest : public JackRequest
 - {
 - 
 -     int fRefNum;
 -     jack_port_id_t fPort;
 -     char fName[JACK_PORT_NAME_SIZE + 1];
 - 
 -     JackPortRenameRequest()
 -     {}
 -     JackPortRenameRequest(int refnum, jack_port_id_t port, const char* name)
 -         : JackRequest(JackRequest::kPortRename), fRefNum(refnum), fPort(port)
 -     {
 -         strcpy(fName, name);
 -     }
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(trans->Read(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Read(&fPort, sizeof(jack_port_id_t)));
 -         CheckRes(trans->Read(&fName, JACK_PORT_NAME_SIZE + 1));
 -         return 0;
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         CheckRes(trans->Write(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Write(&fPort, sizeof(jack_port_id_t)));
 -         CheckRes(trans->Write(&fName, JACK_PORT_NAME_SIZE + 1));
 -         return 0;
 - 
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief SetBufferSize request.
 - */
 - 
 - struct JackSetBufferSizeRequest : public JackRequest
 - {
 - 
 -     jack_nframes_t fBufferSize;
 - 
 -     JackSetBufferSizeRequest()
 -     {}
 -     JackSetBufferSizeRequest(jack_nframes_t buffer_size)
 -         : JackRequest(JackRequest::kSetBufferSize), fBufferSize(buffer_size)
 -     {}
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         return trans->Read(&fBufferSize, sizeof(jack_nframes_t));
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         return trans->Write(&fBufferSize, sizeof(jack_nframes_t));
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief SetFreeWheel request.
 - */
 - 
 - struct JackSetFreeWheelRequest : public JackRequest
 - {
 - 
 -     int fOnOff;
 - 
 -     JackSetFreeWheelRequest()
 -     {}
 -     JackSetFreeWheelRequest(int onoff)
 -         : JackRequest(JackRequest::kSetFreeWheel), fOnOff(onoff)
 -     {}
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         return trans->Read(&fOnOff, sizeof(int));
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         return trans->Write(&fOnOff, sizeof(int));
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief ReleaseTimebase request.
 - */
 - 
 - struct JackReleaseTimebaseRequest : public JackRequest
 - {
 - 
 -     int fRefNum;
 - 
 -     JackReleaseTimebaseRequest()
 -     {}
 -     JackReleaseTimebaseRequest(int refnum)
 -         : JackRequest(JackRequest::kReleaseTimebase), fRefNum(refnum)
 -     {}
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         return trans->Read(&fRefNum, sizeof(int));
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         return trans->Write(&fRefNum, sizeof(int));
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief SetTimebaseCallback request.
 - */
 - 
 - struct JackSetTimebaseCallbackRequest : public JackRequest
 - {
 - 
 -     int fRefNum;
 -     int fConditionnal;
 - 
 -     JackSetTimebaseCallbackRequest()
 -     {}
 -     JackSetTimebaseCallbackRequest(int refnum, int conditional)
 -         : JackRequest(JackRequest::kSetTimebaseCallback), fRefNum(refnum), fConditionnal(conditional)
 -     {}
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(trans->Read(&fRefNum, sizeof(int)));
 -         return trans->Read(&fConditionnal, sizeof(int));
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         CheckRes(trans->Write(&fRefNum, sizeof(int)));
 -         return trans->Write(&fConditionnal, sizeof(int));
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief GetInternalClientName request.
 - */
 - 
 - struct JackGetInternalClientNameRequest : public JackRequest
 - {
 - 
 -     int fRefNum;
 -     int fIntRefNum;
 - 
 -     JackGetInternalClientNameRequest()
 -     {}
 -     JackGetInternalClientNameRequest(int refnum, int int_ref)
 -             : JackRequest(JackRequest::kGetInternalClientName), fRefNum(refnum), fIntRefNum(int_ref)
 -     {}
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(trans->Read(&fRefNum, sizeof(int)));
 -         return trans->Read(&fIntRefNum, sizeof(int));
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         CheckRes(trans->Write(&fRefNum, sizeof(int)));
 -         return trans->Write(&fIntRefNum, sizeof(int));
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief GetInternalClient result.
 - */
 - 
 - struct JackGetInternalClientNameResult : public JackResult
 - {
 - 
 -     char fName[JACK_CLIENT_NAME_SIZE + 1];
 - 
 -     JackGetInternalClientNameResult(): JackResult()
 -     {}
 -     JackGetInternalClientNameResult(int32_t result, const char* name)
 -             : JackResult(result)
 -     {
 -         snprintf(fName, sizeof(fName), "%s", name);
 -     }
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackResult::Read(trans));
 -         CheckRes(trans->Read(&fName, JACK_CLIENT_NAME_SIZE + 1));
 -         return 0;
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackResult::Write(trans));
 -         CheckRes(trans->Write(&fName, JACK_CLIENT_NAME_SIZE + 1));
 -         return 0;
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief InternalClientHandle request.
 - */
 - 
 - struct JackInternalClientHandleRequest : public JackRequest
 - {
 - 
 -     int fRefNum;
 -     char fName[JACK_CLIENT_NAME_SIZE + 1];
 - 
 -     JackInternalClientHandleRequest()
 -     {}
 -     JackInternalClientHandleRequest(int refnum, const char* client_name)
 -             : JackRequest(JackRequest::kInternalClientHandle), fRefNum(refnum)
 -     {
 -         snprintf(fName, sizeof(fName), "%s", client_name);
 -     }
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(trans->Read(&fRefNum, sizeof(int)));
 -         return trans->Read(&fName, JACK_CLIENT_NAME_SIZE + 1);
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         CheckRes(trans->Write(&fRefNum, sizeof(int)));
 -         return trans->Write(&fName, JACK_CLIENT_NAME_SIZE + 1);
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief InternalClientHandle result.
 - */
 - 
 - struct JackInternalClientHandleResult : public JackResult
 - {
 - 
 -     int fStatus;
 -     int fIntRefNum;
 - 
 -     JackInternalClientHandleResult(): JackResult()
 -     {}
 -     JackInternalClientHandleResult(int32_t result, int status, int int_ref)
 -             : JackResult(result), fStatus(status), fIntRefNum(int_ref)
 -     {}
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackResult::Read(trans));
 -         CheckRes(trans->Read(&fStatus, sizeof(int)));
 -         CheckRes(trans->Read(&fIntRefNum, sizeof(int)));
 -         return 0;
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackResult::Write(trans));
 -         CheckRes(trans->Write(&fStatus, sizeof(int)));
 -         CheckRes(trans->Write(&fIntRefNum, sizeof(int)));
 -         return 0;
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief InternalClientLoad request.
 - */
 - 
 - struct JackInternalClientLoadRequest : public JackRequest
 - {
 - 
 - #ifndef MAX_PATH
 - #define MAX_PATH 256
 - #endif
 - 
 -     int fRefNum;
 -     char fName[JACK_CLIENT_NAME_SIZE + 1];
 -     char fDllName[MAX_PATH + 1];
 -     char fLoadInitName[JACK_LOAD_INIT_LIMIT + 1];
 -     int fOptions;
 - 
 -     JackInternalClientLoadRequest()
 -     {}
 -     JackInternalClientLoadRequest(int refnum, const char* client_name, const char* so_name, const char* objet_data, int options)
 -             : JackRequest(JackRequest::kInternalClientLoad), fRefNum(refnum), fOptions(options)
 -     {
 -         snprintf(fName, sizeof(fName), "%s", client_name);
 -         snprintf(fDllName, sizeof(fDllName), "%s", so_name);
 -         snprintf(fLoadInitName, sizeof(fLoadInitName), "%s", objet_data);
 -     }
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(trans->Read(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Read(&fName, JACK_CLIENT_NAME_SIZE + 1));
 -         CheckRes(trans->Read(&fDllName, MAX_PATH + 1));
 -         CheckRes(trans->Read(&fLoadInitName, JACK_LOAD_INIT_LIMIT + 1));
 -         return trans->Read(&fOptions, sizeof(int));
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         CheckRes(trans->Write(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Write(&fName, JACK_CLIENT_NAME_SIZE + 1));
 -         CheckRes(trans->Write(&fDllName, MAX_PATH + 1));
 -         CheckRes(trans->Write(&fLoadInitName, JACK_LOAD_INIT_LIMIT + 1));
 -         return trans->Write(&fOptions, sizeof(int));
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief InternalClientLoad result.
 - */
 - 
 - struct JackInternalClientLoadResult : public JackResult
 - {
 - 
 -     int fStatus;
 -     int fIntRefNum;
 - 
 -     JackInternalClientLoadResult(): JackResult()
 -     {}
 -     JackInternalClientLoadResult(int32_t result, int status, int int_ref)
 -             : JackResult(result), fStatus(status), fIntRefNum(int_ref)
 -     {}
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackResult::Read(trans));
 -         CheckRes(trans->Read(&fStatus, sizeof(int)));
 -         CheckRes(trans->Read(&fIntRefNum, sizeof(int)));
 -         return 0;
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackResult::Write(trans));
 -         CheckRes(trans->Write(&fStatus, sizeof(int)));
 -         CheckRes(trans->Write(&fIntRefNum, sizeof(int)));
 -         return 0;
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief InternalClientUnload request.
 - */
 - 
 - struct JackInternalClientUnloadRequest : public JackRequest
 - {
 - 
 -     int fRefNum;
 -     int fIntRefNum;
 - 
 -     JackInternalClientUnloadRequest()
 -     {}
 -     JackInternalClientUnloadRequest(int refnum, int int_ref)
 -             : JackRequest(JackRequest::kInternalClientUnload), fRefNum(refnum), fIntRefNum(int_ref)
 -     {}
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(trans->Read(&fRefNum, sizeof(int)));
 -         return trans->Read(&fIntRefNum, sizeof(int));
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         CheckRes(trans->Write(&fRefNum, sizeof(int)));
 -         return trans->Write(&fIntRefNum, sizeof(int));
 -     }
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief InternalClientLoad result.
 - */
 - 
 - struct JackInternalClientUnloadResult : public JackResult
 - {
 - 
 -     int fStatus;
 - 
 -     JackInternalClientUnloadResult(): JackResult()
 -     {}
 -     JackInternalClientUnloadResult(int32_t result, int status)
 -             : JackResult(result), fStatus(status)
 -     {}
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackResult::Read(trans));
 -         CheckRes(trans->Read(&fStatus, sizeof(int)));
 -         return 0;
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackResult::Write(trans));
 -         CheckRes(trans->Write(&fStatus, sizeof(int)));
 -         return 0;
 -     }
 -     
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief ClientNotification request.
 - */
 - 
 - struct JackClientNotificationRequest : public JackRequest
 - {
 - 
 -     int fRefNum;
 -     int fNotify;
 -     int fValue;
 - 
 -     JackClientNotificationRequest()
 -     {}
 -     JackClientNotificationRequest(int refnum, int notify, int value)
 -             : JackRequest(JackRequest::kNotification), fRefNum(refnum), fNotify(notify), fValue(value)
 -     {}
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(trans->Read(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Read(&fNotify, sizeof(int)));
 -         CheckRes(trans->Read(&fValue, sizeof(int)));
 -         return 0;
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(JackRequest::Write(trans));
 -         CheckRes(trans->Write(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Write(&fNotify, sizeof(int)));
 -         CheckRes(trans->Write(&fValue, sizeof(int)));
 -         return 0;
 -     }
 - 
 - } POST_PACKED_STRUCTURE;
 - 
 - /*!
 - \brief ClientNotification.
 - */
 - 
 - struct JackClientNotification
 - {
 -     char fName[JACK_CLIENT_NAME_SIZE + 1];
 -     int fRefNum;
 -     int fNotify;
 -     int fValue1;
 -     int fValue2;
 -     int fSync;
 - 
 -     JackClientNotification(): fNotify(-1), fValue1(-1), fValue2(-1)
 -     {}
 -     JackClientNotification(const char* name, int refnum, int notify, int sync, int value1, int value2)
 -             : fRefNum(refnum), fNotify(notify), fValue1(value1), fValue2(value2), fSync(sync)
 -     {
 -         snprintf(fName, sizeof(fName), "%s", name);
 -     }
 - 
 -     int Read(JackChannelTransaction* trans)
 -     {
 -         CheckRes(trans->Read(&fName, JACK_CLIENT_NAME_SIZE + 1));
 -         CheckRes(trans->Read(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Read(&fNotify, sizeof(int)));
 -         CheckRes(trans->Read(&fValue1, sizeof(int)));
 -         CheckRes(trans->Read(&fValue2, sizeof(int)));
 -         CheckRes(trans->Read(&fSync, sizeof(int)));
 -         return 0;
 -     }
 - 
 -     int Write(JackChannelTransaction* trans)
 -     {
 -         CheckRes(trans->Write(&fName, JACK_CLIENT_NAME_SIZE + 1));
 -         CheckRes(trans->Write(&fRefNum, sizeof(int)));
 -         CheckRes(trans->Write(&fNotify, sizeof(int)));
 -         CheckRes(trans->Write(&fValue1, sizeof(int)));
 -         CheckRes(trans->Write(&fValue2, sizeof(int)));
 -         CheckRes(trans->Write(&fSync, sizeof(int)));
 -         return 0;
 -     }
 - 
 - } POST_PACKED_STRUCTURE;
 - 
 - } // end of namespace
 - 
 - #endif
 
 
  |