/[svn]/linuxsampler/trunk/src/network/lscpserver.h
ViewVC logotype

Contents of /linuxsampler/trunk/src/network/lscpserver.h

Parent Directory Parent Directory | Revision Log Revision Log


Revision 155 - (show annotations) (download) (as text)
Mon Jun 28 04:30:11 2004 UTC (19 years, 9 months ago) by senkov
File MIME type: text/x-c++hdr
File size: 8317 byte(s)
* Updated parser, lscp server and sampler class for new MIDI_INPUT
* Minor fixes (and major new bugs) here and there
* Consolidated 3 SET CHANNEL MIDI_xxx commands into one:
SET CHANNEL MIDI_INPUT

1 /***************************************************************************
2 * *
3 * LinuxSampler - modular, streaming capable sampler *
4 * *
5 * Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck *
6 * *
7 * This program is free software; you can redistribute it and/or modify *
8 * it under the terms of the GNU General Public License as published by *
9 * the Free Software Foundation; either version 2 of the License, or *
10 * (at your option) any later version. *
11 * *
12 * This program is distributed in the hope that it will be useful, *
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
15 * GNU General Public License for more details. *
16 * *
17 * You should have received a copy of the GNU General Public License *
18 * along with this program; if not, write to the Free Software *
19 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, *
20 * MA 02111-1307 USA *
21 ***************************************************************************/
22
23 #ifndef __LSCPSERVER_H_
24 #define __LSCPSERVER_H_
25
26 #include <unistd.h>
27 #include <sys/types.h>
28 #include <sys/socket.h>
29 #include <netinet/in.h>
30 #include <netinet/tcp.h>
31 #include <arpa/inet.h>
32 #include <netdb.h>
33
34 #include "lscp.h"
35 #include "lscpparser.h"
36 #include "../Sampler.h"
37 #include "../common/Thread.h"
38
39 /// TCP Port on which the server should listen for connection requests.
40 #define LSCP_PORT 8888
41
42 using namespace LinuxSampler;
43
44 /// Handle for a client connection (FIXME: doesn't work for more than one network connections of course, thus has to be included to the yyparse() parameters instead).
45 extern int hSession;
46
47 // External references to the main scanner and parser functions
48 extern int yyparse(void* YYPARSE_PARAM);
49 extern int yylex_init(yyscan_t* scanner);
50 extern int yylex_destroy(yyscan_t yyscanner);
51
52 /**
53 * Network server for the LinuxSampler Control Protocol (LSCP).
54 */
55 class LSCPServer : public Thread {
56 public:
57 LSCPServer(Sampler* pSampler);
58
59 // Methods called by the parser
60 String DestroyAudioOutputDevice(uint DeviceIndex);
61 String DestroyMidiInputDevice(uint DeviceIndex);
62 String LoadInstrument(String Filename, uint uiInstrument, uint uiSamplerChannel, bool bBackground = false);
63 String LoadEngine(String EngineName, uint uiSamplerChannel);
64 String GetChannels();
65 String AddChannel();
66 String RemoveChannel(uint uiSamplerChannel);
67 String GetAvailableEngines();
68 String GetEngineInfo(String EngineName);
69 String GetChannelInfo(uint uiSamplerChannel);
70 String GetVoiceCount(uint uiSamplerChannel);
71 String GetStreamCount(uint uiSamplerChannel);
72 String GetBufferFill(fill_response_t ResponseType, uint uiSamplerChannel);
73 String GetAvailableAudioOutputDrivers();
74 String GetAvailableMidiInputDrivers();
75 String GetAudioOutputDriverInfo(String Driver);
76 String GetMidiInputDriverInfo(String Driver);
77 #ifdef __GNUC__
78 typedef std::map<String,String> StringMap; // nasty workaround for a GCC bug (see GCC bug #15980, #57)
79 String GetAudioOutputDriverParameterInfo(String Driver, String Parameter, std::map<String,String> DependencyList = StringMap());
80 String GetMidiInputDriverParameterInfo(String Driver, String Parameter, std::map<String,String> DependencyList = StringMap());
81 String CreateAudioOutputDevice(String Driver, std::map<String,String> Parameters = StringMap());
82 String CreateMidiInputDevice(String Driver, std::map<String,String> Parameters = StringMap());
83 #else
84 String GetAudioOutputDriverParameterInfo(String Driver, String Parameter, std::map<String,String> DependencyList = std::map<String,String>());
85 String GetMidiInputDriverParameterInfo(String Driver, String Parameter, std::map<String,String> DependencyList = std::map<String,String>());
86 String CreateAudioOutputDevice(String Driver, std::map<String,String> Parameters = std::map<String,String>());
87 String CreateMidiInputDevice(String Driver, std::map<String,String> Parameters = std::map<String,String>());
88 #endif // __GNUC__
89 String GetAudioOutputDeviceCount();
90 String GetMidiInputDeviceCount();
91 String GetAudioOutputDevices();
92 String GetMidiInputDevices();
93 String GetAudioOutputDeviceInfo(uint DeviceIndex);
94 String GetMidiInputDeviceInfo(uint DeviceIndex);
95 String GetMidiInputPortInfo(uint DeviceIndex, uint PortIndex);
96 String GetAudioOutputChannelInfo(uint DeviceId, uint ChannelId);
97 String GetAudioOutputChannelParameterInfo(uint DeviceId, uint ChannelId, String ParameterName);
98 String SetAudioOutputChannelParameter(uint DeviceId, uint ChannelId, String ParamKey, String ParamVal);
99 String SetAudioOutputDeviceParameter(uint DeviceIndex, String ParamKey, String ParamVal);
100 String SetMidiInputDeviceParameter(uint DeviceIndex, String ParamKey, String ParamVal);
101 String SetMidiInputPortParameter(uint DeviceIndex, uint PortIndex, String ParamKey, String ParamVal);
102 String SetAudioOutputChannel(uint ChannelAudioOutputChannel, uint AudioOutputDeviceInputChannel, uint uiSamplerChannel);
103 String SetAudioOutputType(String AudioOutputDriver, uint uiSamplerChannel);
104 String SetMIDIInputType(String MidiInputDriver, uint uiSamplerChannel);
105 String SetMIDIInput(uint MIDIDevice, uint MIDIPort, uint MIDIChannel, uint uiSamplerChannel);
106 String SetAudioOutputDevice(uint AudioDeviceId, uint SamplerChannel);
107 String SetVolume(double Volume, uint uiSamplerChannel);
108 String ResetChannel(uint uiSamplerChannel);
109 String SubscribeNotification(event_t Event);
110 String UnsubscribeNotification(event_t Event);
111 void AnswerClient(String ReturnMessage);
112 protected:
113 int hSocket;
114 sockaddr_in SocketAddress;
115 Sampler* pSampler;
116
117 int Main(); ///< Implementation of virtual method from class Thread
118 private:
119
120 /**
121 * Find a created audio output device index.
122 */
123 int GetAudioOutputDeviceIndex (AudioOutputDevice *pDevice);
124
125 /**
126 * Find a created midi input device index.
127 */
128 int GetMidiInputDeviceIndex (MidiInputDevice *pDevice);
129
130 /**
131 * Converts a result_t structure into a valid LSCP answer message.
132 */
133 inline String ConvertResult(result_t result) {
134 switch (result.type) {
135 case result_type_success: {
136 return "OK\r\n";
137 }
138 case result_type_warning: {
139 std::stringstream ss;
140 ss << "WRN:" << result.code << ":" << result.message << "\r\n";
141 return ss.str();
142 }
143 case result_type_error: {
144 std::stringstream ss;
145 ss << "ERR:" << result.code << ":" << result.message << "\r\n";
146 return ss.str();
147 }
148 }
149 }
150
151 template<class T> inline String ToString(T o) {
152 std::stringstream ss;
153 ss << o;
154 return ss.str();
155 }
156 };
157
158
159 /**
160 * Instrument loader thread for the LinuxSampler Control Protocol (LSCP).
161 */
162 class LSCPLoadInstrument : public Thread {
163
164 public:
165 LSCPLoadInstrument(Engine* pEngine, String Filename, uint uiInstrument);
166
167 protected:
168 // Instance variables.
169 Engine* pEngine;
170 String Filename;
171 uint uiInstrument;
172
173 // Implementation of virtual method from class Thread.
174 int Main();
175 };
176
177 #endif // __LSCPSERVER_H_

  ViewVC Help
Powered by ViewVC