1 |
// common.h |
2 |
// |
3 |
/**************************************************************************** |
4 |
liblscp - LinuxSampler Control Protocol API |
5 |
Copyright (C) 2004, rncbc aka Rui Nuno Capela. All rights reserved. |
6 |
|
7 |
This library is free software; you can redistribute it and/or |
8 |
modify it under the terms of the GNU Lesser General Public |
9 |
License as published by the Free Software Foundation; either |
10 |
version 2.1 of the License, or (at your option) any later version. |
11 |
|
12 |
This library 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 GNU |
15 |
Lesser General Public License for more details. |
16 |
|
17 |
You should have received a copy of the GNU Lesser General Public |
18 |
License along with this library; if not, write to the Free Software |
19 |
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
20 |
|
21 |
*****************************************************************************/ |
22 |
|
23 |
#ifndef __LSCP_COMMON_H |
24 |
#define __LSCP_COMMON_H |
25 |
|
26 |
#include "lscp/client.h" |
27 |
#include "lscp/device.h" |
28 |
|
29 |
|
30 |
// Case unsensitive comparison substitutes. |
31 |
#if defined(WIN32) |
32 |
#define strcasecmp stricmp |
33 |
#define strncasecmp strnicmp |
34 |
#endif |
35 |
|
36 |
//------------------------------------------------------------------------- |
37 |
// Client opaque descriptor struct. |
38 |
|
39 |
struct _lscp_client_t |
40 |
{ |
41 |
// Client socket stuff. |
42 |
lscp_client_proc_t pfnCallback; |
43 |
void * pvData; |
44 |
lscp_socket_agent_t cmd; |
45 |
lscp_socket_agent_t evt; |
46 |
// Subscribed events. |
47 |
lscp_event_t events; |
48 |
// Client struct persistent caches. |
49 |
char ** audio_drivers; |
50 |
char ** midi_drivers; |
51 |
int * audio_devices; |
52 |
int * midi_devices; |
53 |
char ** engines; |
54 |
int * channels; |
55 |
// Client struct volatile caches. |
56 |
lscp_driver_info_t audio_driver_info; |
57 |
lscp_driver_info_t midi_driver_info; |
58 |
lscp_device_info_t audio_device_info; |
59 |
lscp_device_info_t midi_device_info; |
60 |
lscp_param_info_t audio_param_info; |
61 |
lscp_param_info_t midi_param_info; |
62 |
lscp_device_port_info_t audio_channel_info; |
63 |
lscp_device_port_info_t midi_port_info; |
64 |
lscp_param_info_t audio_channel_param_info; |
65 |
lscp_param_info_t midi_port_param_info; |
66 |
lscp_engine_info_t engine_info; |
67 |
lscp_channel_info_t channel_info; |
68 |
// Result and error status. |
69 |
char * pszResult; |
70 |
int iErrno; |
71 |
// Stream buffers status. |
72 |
lscp_buffer_fill_t *buffer_fill; |
73 |
int iStreamCount; |
74 |
// Transaction call timeout (msecs). |
75 |
int iTimeout; |
76 |
lscp_mutex_t mutex; |
77 |
}; |
78 |
|
79 |
|
80 |
//------------------------------------------------------------------------- |
81 |
// Local client request executive. |
82 |
|
83 |
lscp_status_t lscp_client_call (lscp_client_t *pClient, const char *pszQuery); |
84 |
void lscp_client_set_result (lscp_client_t *pClient, char *pszResult, int iErrno); |
85 |
|
86 |
//------------------------------------------------------------------------- |
87 |
// General utility function prototypes. |
88 |
|
89 |
char * lscp_strtok (char *pchBuffer, const char *pszSeps, char **ppch); |
90 |
char * lscp_ltrim (char *psz); |
91 |
char * lscp_unquote (char **ppsz, int dup); |
92 |
|
93 |
char ** lscp_szsplit_create (const char *pszCsv, const char *pszSeps); |
94 |
void lscp_szsplit_destroy (char **ppszSplit); |
95 |
#ifdef LSCP_SZSPLIT_COUNT |
96 |
int lscp_szsplit_count (char **ppszSplit); |
97 |
int lscp_szsplit_size (char **ppszSplit); |
98 |
#endif |
99 |
|
100 |
int * lscp_isplit_create (const char *pszCsv, const char *pszSeps); |
101 |
void lscp_isplit_destroy (int *piSplit); |
102 |
#ifdef LSCP_ISPLIT_COUNT |
103 |
int lscp_isplit_count (int *piSplit); |
104 |
int lscp_isplit_size (int *piSplit); |
105 |
#endif |
106 |
|
107 |
lscp_param_t * lscp_psplit_create (const char *pszCsv, const char *pszSep1, const char *pszSep2); |
108 |
void lscp_psplit_destroy (lscp_param_t *ppSplit); |
109 |
#ifdef LSCP_PSPLIT_COUNT |
110 |
int lscp_psplit_count (lscp_param_t *ppSplit); |
111 |
int lscp_psplit_size (lscp_param_t *ppSplit); |
112 |
#endif |
113 |
|
114 |
void lscp_plist_alloc (lscp_param_t **ppList); |
115 |
void lscp_plist_free (lscp_param_t **ppList); |
116 |
void lscp_plist_append (lscp_param_t **ppList, const char *pszKey, const char *pszValue); |
117 |
#ifdef LSCP_PLIST_COUNT |
118 |
int lscp_plist_count (lscp_param_t **ppList); |
119 |
int lscp_plist_size (lscp_param_t **ppList); |
120 |
#endif |
121 |
|
122 |
//------------------------------------------------------------------------- |
123 |
// Engine struct helper functions. |
124 |
|
125 |
void lscp_engine_info_init (lscp_engine_info_t *pEngineInfo); |
126 |
void lscp_engine_info_reset (lscp_engine_info_t *pEngineInfo); |
127 |
|
128 |
//------------------------------------------------------------------------- |
129 |
// Channel struct helper functions. |
130 |
|
131 |
void lscp_channel_info_init (lscp_channel_info_t *pChannelInfo); |
132 |
void lscp_channel_info_reset (lscp_channel_info_t *pChannelInfo); |
133 |
|
134 |
//------------------------------------------------------------------------- |
135 |
// Driver struct helper functions. |
136 |
|
137 |
void lscp_driver_info_init (lscp_driver_info_t *pDriverInfo); |
138 |
void lscp_driver_info_reset (lscp_driver_info_t *pDriverInfo); |
139 |
|
140 |
//------------------------------------------------------------------------- |
141 |
// Device struct helper functions. |
142 |
|
143 |
void lscp_device_info_init (lscp_device_info_t *pDeviceInfo); |
144 |
void lscp_device_info_reset (lscp_device_info_t *pDeviceInfo); |
145 |
|
146 |
//------------------------------------------------------------------------- |
147 |
// Device channel/port struct helper functions. |
148 |
|
149 |
void lscp_device_port_info_init (lscp_device_port_info_t *pDevicePortInfo); |
150 |
void lscp_device_port_info_reset (lscp_device_port_info_t *pDevicePortInfo); |
151 |
|
152 |
//------------------------------------------------------------------------- |
153 |
// Parameter struct helper functions. |
154 |
|
155 |
void lscp_param_info_init (lscp_param_info_t *pParamInfo); |
156 |
void lscp_param_info_reset (lscp_param_info_t *pParamInfo); |
157 |
|
158 |
//------------------------------------------------------------------------- |
159 |
// Concatenate a parameter list (key='value'...) into a string. |
160 |
|
161 |
int lscp_param_concat (char *pszBuffer, int cchMaxBuffer, lscp_param_t *pParams); |
162 |
|
163 |
|
164 |
#endif // __LSCP_COMMON_H |
165 |
|
166 |
// end of common.h |