--- liblscp/trunk/lscp/client.h 2005/02/13 17:20:46 378 +++ liblscp/trunk/lscp/client.h 2005/08/16 09:48:42 735 @@ -39,6 +39,15 @@ //------------------------------------------------------------------------- // Client data structures. +/** Server info cache struct. */ +typedef struct _lscp_server_info_t +{ + char * description; + char * version; + +} lscp_server_info_t; + + /** Engine info cache struct. */ typedef struct _lscp_engine_info_t { @@ -63,6 +72,8 @@ int midi_port; int midi_channel; float volume; + int mute; + int solo; } lscp_channel_info_t; @@ -143,7 +154,9 @@ int * lscp_list_channels (lscp_client_t *pClient); int lscp_add_channel (lscp_client_t *pClient); lscp_status_t lscp_remove_channel (lscp_client_t *pClient, int iSamplerChannel); -const char ** lscp_get_available_engines (lscp_client_t *pClient); + +int lscp_get_available_engines (lscp_client_t *pClient); +const char ** lscp_list_available_engines (lscp_client_t *pClient); lscp_engine_info_t * lscp_get_engine_info (lscp_client_t *pClient, const char *pszEngineName); lscp_channel_info_t * lscp_get_channel_info (lscp_client_t *pClient, int iSamplerChannel); @@ -164,10 +177,15 @@ lscp_status_t lscp_set_channel_midi_channel (lscp_client_t *pClient, int iSamplerChannel, int iMidiChannel); lscp_status_t lscp_set_channel_volume (lscp_client_t *pClient, int iSamplerChannel, float fVolume); +lscp_status_t lscp_set_channel_mute (lscp_client_t *pClient, int iSamplerChannel, int iMute); +lscp_status_t lscp_set_channel_solo (lscp_client_t *pClient, int iSamplerChannel, int iSolo); + lscp_status_t lscp_reset_channel (lscp_client_t *pClient, int iSamplerChannel); lscp_status_t lscp_reset_sampler (lscp_client_t *pClient); +lscp_server_info_t * lscp_get_server_info (lscp_client_t *pClient); + #if defined(__cplusplus) } #endif