aboutsummaryrefslogtreecommitdiff
path: root/pluginhost~/src
diff options
context:
space:
mode:
Diffstat (limited to 'pluginhost~/src')
-rw-r--r--pluginhost~/src/pluginhost~.c392
-rw-r--r--pluginhost~/src/pluginhost~.h205
2 files changed, 295 insertions, 302 deletions
diff --git a/pluginhost~/src/pluginhost~.c b/pluginhost~/src/pluginhost~.c
index 347309d..42488e3 100644
--- a/pluginhost~/src/pluginhost~.c
+++ b/pluginhost~/src/pluginhost~.c
@@ -26,7 +26,9 @@
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
+#include <stdarg.h>
#include <assert.h>
+#include <pthread.h>
#include "pluginhost~.h"
#include "jutils.h"
@@ -109,7 +111,8 @@ static DSSI_Descriptor *ladspa_to_dssi(LADSPA_Descriptor *ladspaDesc)
return (DSSI_Descriptor *)dssiDesc;
}
-static void ph_tilde_port_info(t_ph_tilde *x){
+static void ph_tilde_port_info(ph_tilde *x)
+{
t_int i;
for (i = 0; i < (t_int)x->descriptor->LADSPA_Plugin->PortCount; i++) {
@@ -180,8 +183,9 @@ static void ph_tilde_port_info(t_ph_tilde *x){
}
-static void ph_tilde_assign_ports(t_ph_tilde *x){
- int i;
+static void ph_tilde_assign_ports(ph_tilde *x)
+{
+ unsigned int i;
ph_debug_post("%d instances", x->n_instances);
@@ -233,12 +237,12 @@ static void ph_tilde_assign_ports(t_ph_tilde *x){
}
-static void ph_tilde_init_instance(t_ph_tilde *x, t_int instance){
+static void ph_tilde_init_instance(ph_tilde *x, t_int instance)
+{
x->instances[instance].pluginPrograms = NULL;
x->instances[instance].currentBank = 0;
x->instances[instance].currentProgram = 0;
- x->instances[instance].uiTarget = NULL;
x->instances[instance].ui_osc_control_path = NULL;
x->instances[instance].ui_osc_program_path = NULL;
x->instances[instance].ui_osc_show_path = NULL;
@@ -252,13 +256,13 @@ static void ph_tilde_init_instance(t_ph_tilde *x, t_int instance){
x->instances[instance].pendingBankLSB = -1;
x->instances[instance].ui_hidden = 1;
x->instances[instance].ui_show = 0;
- x->instances[instance].gui_pid = 0;
ph_debug_post("Instance %d initialized!", instance);
}
-static void ph_tilde_connect_ports(t_ph_tilde *x, t_int instance){
+static void ph_tilde_connect_ports(ph_tilde *x, t_int instance)
+{
t_int i;
@@ -316,7 +320,8 @@ static void ph_tilde_connect_ports(t_ph_tilde *x, t_int instance){
}
-static void ph_tilde_activate_plugin(t_ph_tilde *x, t_int instance){
+static void ph_tilde_activate_plugin(ph_tilde *x, t_int instance)
+{
if(x->descriptor->LADSPA_Plugin->activate){
ph_debug_post("trying to activate instance: %d", instance);
@@ -327,7 +332,8 @@ static void ph_tilde_activate_plugin(t_ph_tilde *x, t_int instance){
}
-static void ph_tilde_deactivate_plugin(t_ph_tilde *x, t_float instance_f){
+static void ph_tilde_deactivate_plugin(ph_tilde *x, t_float instance_f)
+{
t_int instance = (t_int)instance_f;
if(x->descriptor->LADSPA_Plugin->deactivate)
@@ -341,8 +347,9 @@ static void osc_error(int num, const char *msg, const char *where)
post("pluginhost~: osc error %d in path %s: %s\n",num, where, msg);
}
-static void query_programs(t_ph_tilde *x, t_int instance) {
- int i;
+static void query_programs(ph_tilde *x, t_int instance)
+{
+ unsigned int i;
ph_debug_post("querying programs");
/* free old lot */
@@ -394,7 +401,7 @@ static void query_programs(t_ph_tilde *x, t_int instance) {
*/ }
}
-static LADSPA_Data get_port_default(t_ph_tilde *x, int port)
+static LADSPA_Data get_port_default(ph_tilde *x, int port)
{
LADSPA_Descriptor *plugin = (LADSPA_Descriptor *)x->descriptor->LADSPA_Plugin;
LADSPA_PortRangeHint hint = plugin->PortRangeHints[port];
@@ -457,7 +464,7 @@ static LADSPA_Data get_port_default(t_ph_tilde *x, int port)
return 0.0f;
}
-static unsigned ph_tilde_get_parm_number (t_ph_tilde *x,
+static unsigned ph_tilde_get_parm_number (ph_tilde *x,
const char *str)
/* find out if str points to a parameter number or not and return the
number or zero. The number string has to begin with a '#' character */
@@ -486,8 +493,8 @@ static unsigned ph_tilde_get_parm_number (t_ph_tilde *x,
}
}
-static void ph_tilde_set_control_input_by_index (t_ph_tilde *x,
- signed ctrl_input_index,
+static void ph_tilde_set_control_input_by_index (ph_tilde *x,
+ unsigned int ctrl_input_index,
float value,
t_int instance)
{
@@ -516,16 +523,13 @@ static void ph_tilde_set_control_input_by_index (t_ph_tilde *x,
ph_debug_post("Global ctrl input number = %d", ctrl_input_index);
post("Global ctrl input value = %.2f", value);
-
-
-
-
/* set the appropriate control port value */
x->plugin_ControlDataInput[portno] = value;
/* Update the UI if there is one */
if(x->is_DSSI){
- if(x->instances[instance].uiTarget == NULL){
+ /* FIX:OSC */
+ /*if(x->instances[instance].uiTarget == NULL){
ph_debug_post("pluginhost~: unable to send to NULL target");
return;
@@ -534,15 +538,17 @@ static void ph_tilde_set_control_input_by_index (t_ph_tilde *x,
ph_debug_post("pluginhost~: unable to send to NULL control path");
return;
- }
- lo_send(x->instances[instance].uiTarget,
+ }*/
+ /* FIX:OSC */
+ /* lo_send(x->instances[instance].uiTarget,
x->instances[instance].ui_osc_control_path, "if", port, value);
+ */
}
}
-static void ph_tilde_set_control_input_by_name (t_ph_tilde *x,
+static void ph_tilde_set_control_input_by_name (ph_tilde *x,
const char* name,
float value,
t_int instance)
@@ -592,24 +598,22 @@ static void ph_tilde_set_control_input_by_name (t_ph_tilde *x,
ph_tilde_set_control_input_by_index (x, ctrl_input_index, value, instance);
}
-static void ph_tilde_control (t_ph_tilde *x,
- t_symbol* ctrl_name,
+static void ph_tilde_control (ph_tilde *x, t_symbol* ctrl_name,
t_float ctrl_value,
t_float instance_f)
/* Change the value of a named control port of the plug-in */
{
unsigned parm_num = 0;
- t_int instance = (t_int)instance_f - 1;
- int n_instances = x->n_instances;
+ int instance = (unsigned int)instance_f - 1;
+ unsigned int n_instances = x->n_instances;
- if (instance > x->n_instances || instance < -1){
+ if (instance > (int)x->n_instances || instance < -1){
post("pluginhost~: control: invalid instance number %d", instance);
return;
}
ph_debug_post("Received LADSPA control data for instance %d", instance);
-
if (ctrl_name->s_name == NULL || strlen (ctrl_name->s_name) == 0) {
post("pluginhost~: control messages must have a name and a value");
return;
@@ -637,7 +641,8 @@ static void ph_tilde_control (t_ph_tilde *x,
}
}
-static void ph_tilde_info (t_ph_tilde *x){
+static void ph_tilde_info (ph_tilde *x)
+{
unsigned int i,
ctrl_portno,
audio_portno;
@@ -672,7 +677,7 @@ static void ph_tilde_info (t_ph_tilde *x){
}
}
-static void ph_tilde_ladspa_description(t_ph_tilde *x, t_atom *at,
+static void ph_tilde_ladspa_description(ph_tilde *x, t_atom *at,
DSSI_Descriptor *psDescriptor){
at[0].a_w.w_symbol =
gensym ((char*)psDescriptor->LADSPA_Plugin->Name);
@@ -695,7 +700,7 @@ static void ph_tilde_ladspa_describe(const char * pcFullFilename,
void* user_data,
int is_DSSI) {
- t_ph_tilde *x = (((void**)user_data)[0]);
+ ph_tilde *x = (((void**)user_data)[0]);
t_atom at[1];
DSSI_Descriptor *psDescriptor;
long lIndex;
@@ -717,13 +722,6 @@ static void ph_tilde_ladspa_describe(const char * pcFullFilename,
lIndex = 0;
do{
psDescriptor = ladspa_to_dssi((LADSPA_Descriptor *)fDescriptorFunction(lIndex++));
- /* psDescriptor = (DSSI_Descriptor *)calloc(1,
- sizeof(DSSI_Descriptor));
- ((DSSI_Descriptor *)psDescriptor)->DSSI_API_Version = 1;
- ((DSSI_Descriptor *)psDescriptor)->LADSPA_Plugin =
- (LADSPA_Descriptor *)
- fDescriptorFunction(lIndex++);
- */
if(psDescriptor->LADSPA_Plugin != NULL){
ph_tilde_ladspa_description(x, &at[0], psDescriptor);
free((DSSI_Descriptor *)psDescriptor);
@@ -731,31 +729,34 @@ static void ph_tilde_ladspa_describe(const char * pcFullFilename,
else
break;
} while(1);
- /* Not needed
- dlclose(pvPluginHandle);
- */
}
-static void ph_tilde_list_plugins (t_ph_tilde *x) {
+static void ph_tilde_list_plugins (ph_tilde *x)
+{
void* user_data[1];
user_data[0] = x;
LADSPAPluginSearch(ph_tilde_ladspa_describe,(void*)user_data);
}
+/* FIX:OSC */
+#if 0
static int osc_debug_handler(const char *path, const char *types, lo_arg **argv,
- int argc, void *data, t_ph_tilde *x)
+ int argc, void *data, ph_tilde *x)
{
int i;
printf("got unhandled OSC message:\npath: <%s>\n", path);
for (i=0; i<argc; i++) {
printf("arg %d '%c' ", i, types[i]);
- lo_arg_pp(types[i], argv[i]);
+ /* FIX:OSC */
+ //lo_arg_pp(types[i], argv[i]);
printf("\n");
}
return 1;
}
+#endif
-static void ph_tilde_get_current_program(t_ph_tilde *x, int instance){
+static void ph_tilde_get_current_program(ph_tilde *x, int instance)
+{
int i;
t_atom argv[3];
@@ -772,7 +773,8 @@ static void ph_tilde_get_current_program(t_ph_tilde *x, int instance){
}
-static void ph_tilde_program_change(t_ph_tilde *x, int instance){
+static void ph_tilde_program_change(ph_tilde *x, int instance)
+{
/* jack-dssi-host queues program changes by using pending program change variables. In the audio callback, if a program change is received via MIDI it over writes the pending value (if any) set by the GUI. If unset, or processed the value will default back to -1. The following call to select_program is then made. I don't think it eventually needs to be done this way - i.e. do we need 'pending'? */
ph_debug_post("executing program change");
@@ -800,11 +802,13 @@ static void ph_tilde_program_change(t_ph_tilde *x, int instance){
ph_debug_post("Updating GUI program");
/* FIX - this is a hack to make text ui work*/
- if(x->instances[instance].uiTarget)
- lo_send(x->instances[instance].uiTarget,
+ /* FIX:OSC */
+ /* if(x->instances[instance].uiTarget){
+ lo_send(x->instances[instance].uiTarget,
x->instances[instance].ui_osc_program_path, "ii",
x->instances[instance].currentBank,
x->instances[instance].currentProgram);
+ } */
}
x->instances[instance].uiNeedsProgramUpdate = 0;
@@ -815,7 +819,9 @@ static void ph_tilde_program_change(t_ph_tilde *x, int instance){
ph_tilde_get_current_program(x, instance);
}
-static int osc_program_handler(t_ph_tilde *x, lo_arg **argv, int instance)
+/* FIX:OSC */
+#if 0
+static int osc_program_handler(ph_tilde *x, lo_arg **argv, int instance)
{
unsigned long bank = argv[0]->i;
unsigned long program = argv[1]->i;
@@ -852,7 +858,7 @@ static int osc_program_handler(t_ph_tilde *x, lo_arg **argv, int instance)
return 0;
}
-static int osc_control_handler(t_ph_tilde *x, lo_arg **argv, int instance)
+static int osc_control_handler(ph_tilde *x, lo_arg **argv, int instance)
{
int port = argv[0]->i;
LADSPA_Data value = argv[1]->f;
@@ -864,7 +870,7 @@ static int osc_control_handler(t_ph_tilde *x, lo_arg **argv, int instance)
return 0;
}
-static int osc_midi_handler(t_ph_tilde *x, lo_arg **argv, t_int instance)
+static int osc_midi_handler(ph_tilde *x, lo_arg **argv, t_int instance)
{
int ev_type = 0, chan = 0;
@@ -898,7 +904,7 @@ static int osc_midi_handler(t_ph_tilde *x, lo_arg **argv, t_int instance)
return 0;
}
-static int osc_configure_handler(t_ph_tilde *x, lo_arg **argv, int instance)
+static int osc_configure_handler(ph_tilde *x, lo_arg **argv, int instance)
{
const char *key = (const char *)&argv[0]->s;
const char *value = (const char *)&argv[1]->s;
@@ -929,7 +935,8 @@ static int osc_configure_handler(t_ph_tilde *x, lo_arg **argv, int instance)
return 0;
}
-static int osc_exiting_handler(t_ph_tilde *x, lo_arg **argv, int instance){
+static int osc_exiting_handler(ph_tilde *x, lo_arg **argv, int instance)
+{
ph_debug_post("exiting handler called: Freeing ui_osc");
@@ -956,13 +963,13 @@ static int osc_exiting_handler(t_ph_tilde *x, lo_arg **argv, int instance){
return 0;
}
-static int osc_update_handler(t_ph_tilde *x, lo_arg **argv, int instance)
+static int osc_update_handler(ph_tilde *x, lo_arg **argv, int instance)
{
const char *url = (char *)&argv[0]->s;
const char *path;
t_int i;
char *host, *port;
- t_ph_configure_pair *p;
+ ph_configure_pair *p;
p = x->configure_buffer_head;
@@ -1054,9 +1061,12 @@ static int osc_update_handler(t_ph_tilde *x, lo_arg **argv, int instance)
return 0;
}
+#endif
-static void ph_tilde_osc_setup(t_ph_tilde *x, int instance){
+static void ph_tilde_osc_setup(ph_tilde *x, int instance)
+{
+#if 0
if(instance == 0){
x->osc_thread = lo_server_thread_new(NULL, osc_error);
char *osc_url_tmp;
@@ -1077,10 +1087,12 @@ static void ph_tilde_osc_setup(t_ph_tilde *x, int instance){
x->descriptor->LADSPA_Plugin->Label, instance);
ph_debug_post("OSC Path is: %s", x->instances[instance].osc_url_path);
post("OSC thread started: %s", x->osc_url_base);
+#endif
}
-static void ph_tilde_init_programs(t_ph_tilde *x, int instance){
+static void ph_tilde_init_programs(ph_tilde *x, int instance)
+{
ph_debug_post("Setting up program data");
@@ -1099,9 +1111,11 @@ static void ph_tilde_init_programs(t_ph_tilde *x, int instance){
}
}
-static void ph_tilde_load_gui(t_ph_tilde *x, int instance){
+/* FIX:OSC */
+#if 0
+static void ph_tilde_load_gui(ph_tilde *x, int instance)
+{
t_int err = 0;
- char *osc_url;
char *gui_path;
struct dirent *dir_entry = NULL;
char *gui_base;
@@ -1156,7 +1170,6 @@ static void ph_tilde_load_gui(t_ph_tilde *x, int instance){
(sizeof(char) * (strlen(x->osc_url_base) +
strlen(x->instances[instance].osc_url_path) + 2));
- /* char osc_url[1024];*/
sprintf(osc_url, "%s/%s", x->osc_url_base,
x->instances[instance].osc_url_path);
post("pluginhost~: instance %d URL: %s",instance, osc_url);
@@ -1184,10 +1197,13 @@ static void ph_tilde_load_gui(t_ph_tilde *x, int instance){
}
}
+#endif
-static void MIDIbuf(int type, int chan, int param, int val, t_ph_tilde *x){
+static void MIDIbuf(int type, unsigned int chan, int param, int val,
+ ph_tilde *x)
+{
- if(chan > x->n_instances - 1 || chan < 0){
+ if(chan > x->n_instances - 1){
post("pluginhost~: note discarded: MIDI data is destined for a channel that doesn't exist");
return;
}
@@ -1264,7 +1280,8 @@ static void MIDIbuf(int type, int chan, int param, int val, t_ph_tilde *x){
pthread_mutex_unlock(&x->midiEventBufferMutex); /**release mutex*/
}
-static void ph_tilde_list(t_ph_tilde *x, t_symbol *s, int argc, t_atom *argv) {
+static void ph_tilde_list(ph_tilde *x, t_symbol *s, int argc, t_atom *argv)
+{
char *msg_type;
int ev_type = 0;
msg_type = (char *)malloc(TYPE_STRING_SIZE);
@@ -1301,34 +1318,38 @@ static void ph_tilde_list(t_ph_tilde *x, t_symbol *s, int argc, t_atom *argv) {
free(msg_type);
}
-static char *ph_tilde_send_configure(t_ph_tilde *x, char *key,
- char *value, t_int instance){
+static char *ph_tilde_send_configure(ph_tilde *x, char *key,
+ char *value, int instance){
char *debug;
debug = x->descriptor->configure(
x->instanceHandles[instance],
key, value);
- if(x->instances[instance].uiTarget != NULL && x->is_DSSI)
- lo_send(x->instances[instance].uiTarget,
+ /* FIX:OSC */
+ /* if(x->instances[instance].uiTarget != NULL && x->is_DSSI) {
+ lo_send(x->instances[instance].uiTarget,
x->instances[instance].ui_osc_configure_path,
"ss", key, value);
+ }
+ */
query_programs(x, instance);
return debug;
}
-static void ph_show(t_ph_tilde *x, t_int instance, t_int toggle){
-
+static void ph_show(ph_tilde *x, t_int instance, t_int toggle)
+{
+ /* FIX:OSC */
+/*
if(x->instances[instance].uiTarget){
if (x->instances[instance].ui_hidden && toggle) {
- lo_send(x->instances[instance].uiTarget,
- x->instances[instance].ui_osc_show_path, "");
+ lo_send(x->instances[instance].uiTarget,
+ x->instances[instance].ui_osc_show_path, "");
x->instances[instance].ui_hidden = 0;
}
else if (!x->instances[instance].ui_hidden && !toggle) {
- lo_send(x->instances[instance].uiTarget,
- x->instances[instance].ui_osc_hide_path, "");
+ x->instances[instance].ui_osc_hide_path, "");
x->instances[instance].ui_hidden = 1;
}
}
@@ -1337,12 +1358,13 @@ static void ph_show(t_ph_tilde *x, t_int instance, t_int toggle){
ph_tilde_load_gui(x, instance);
}
+ */
}
-static t_int ph_tilde_configure_buffer(t_ph_tilde *x, char *key,
+static t_int ph_tilde_configure_buffer(ph_tilde *x, char *key,
char *value, t_int instance){
- t_ph_configure_pair *current, *p;
+ ph_configure_pair *current, *p;
t_int add_node;
add_node = 0;
current = x->configure_buffer_head;
@@ -1356,8 +1378,8 @@ static t_int ph_tilde_configure_buffer(t_ph_tilde *x, char *key,
if(current)
free(current->value);
else {
- current = (t_ph_configure_pair *)malloc(sizeof
- (t_ph_configure_pair));
+ current = (ph_configure_pair *)malloc(sizeof
+ (ph_configure_pair));
current->next = x->configure_buffer_head;
x->configure_buffer_head = current;
current->key = strdup(key);
@@ -1378,8 +1400,9 @@ static t_int ph_tilde_configure_buffer(t_ph_tilde *x, char *key,
return 0;
}
-static t_int ph_tilde_configure_buffer_free(t_ph_tilde *x){
- t_ph_configure_pair *curr, *prev;
+static t_int ph_tilde_configure_buffer_free(ph_tilde *x)
+{
+ ph_configure_pair *curr, *prev;
prev = curr = NULL;
for(curr = x->configure_buffer_head; curr != NULL; curr = curr->next){
@@ -1394,11 +1417,12 @@ static t_int ph_tilde_configure_buffer_free(t_ph_tilde *x){
return 0;
}
-static t_int ph_tilde_reset(t_ph_tilde *x, t_float instance_f){
+static t_int ph_tilde_reset(ph_tilde *x, t_float instance_f)
+{
t_int instance = (t_int)instance_f - 1;
if (instance == -1){
- for(instance = 0; instance < x->n_instances; instance++) {
+ for(instance = 0; instance < (int)x->n_instances; instance++) {
if (x->descriptor->LADSPA_Plugin->deactivate &&
x->descriptor->LADSPA_Plugin->activate){
x->descriptor->LADSPA_Plugin->deactivate
@@ -1466,7 +1490,7 @@ static void ph_tilde_search_plugin_callback (
}
}
-static const char* plugin_tilde_search_plugin_by_label (t_ph_tilde *x,
+static const char* plugin_tilde_search_plugin_by_label (ph_tilde *x,
const char *name)
{
char* lib_name = NULL;
@@ -1486,29 +1510,30 @@ static const char* plugin_tilde_search_plugin_by_label (t_ph_tilde *x,
}
-static t_int ph_tilde_ph_methods(t_ph_tilde *x, t_symbol *s, int argc, t_atom *argv)
-{
+static t_int ph_tilde_dssi_methods(ph_tilde *x, t_symbol *s, int argc, t_atom *argv)
+{
if (!x->is_DSSI) {
- post("pluginhost~: plugin is not a DSSI plugin, operation not supported");
+ post(
+ "pluginhost~: plugin is not a DSSI plugin, operation not supported");
return 0;
}
- char *msg_type,
- *debug,
- *filename,
- *filepath,
- *key,
- *value,
- *temp,
- mydir[MAXPDSTRING];
- int instance = -1,
- pathlen,
- toggle,
- fd,
- n_instances = x->n_instances,
- count,
- i,
- chan,
- maxpatches;
+ char *msg_type;
+ char *debug;
+ char *filename;
+ char *filepath;
+ char *key;
+ char *value;
+ char *temp;
+ char mydir[MAXPDSTRING];
+ int instance = -1;
+ int pathlen;
+ int toggle;
+ int fd;
+ int n_instances = x->n_instances;
+ int count;
+ int chan;
+ int maxpatches;
+ unsigned int i;
t_float val;
long filelength = 0;
unsigned char *raw_patch_data = NULL;
@@ -1766,7 +1791,7 @@ static t_int ph_tilde_ph_methods(t_ph_tilde *x, t_symbol *s, int argc, t_atom *a
return 0;
}
-static void ph_tilde_bang(t_ph_tilde *x)
+static void ph_tilde_bang(ph_tilde *x)
{
t_atom at[3];
@@ -1789,10 +1814,12 @@ static void ph_tilde_bang(t_ph_tilde *x)
static t_int *ph_tilde_perform(t_int *w)
{
int N = (t_int)(w[2]);
- t_ph_tilde *x = (t_ph_tilde *)(w[1]);
+ ph_tilde *x = (ph_tilde *)(w[1]);
t_float **inputs = (t_float **)(&w[3]);
t_float **outputs = (t_float **)(&w[3] + x->plugin_ins);
- int i, n, timediff, framediff, instance = 0;
+ unsigned int i;
+ unsigned int instance;
+ int n, timediff, framediff;
/*See comment for ph_tilde_plug_plugin */
if(x->dsp){
x->dsp_loop = 1;
@@ -1809,10 +1836,9 @@ static t_int *ph_tilde_perform(t_int *w)
instance = x->midiEventBuf[x->bufReadIndex].data.note.channel;
- /*This should never happen, but check anyway*/
- if(instance > x->n_instances || instance < 0){
+ if(instance > x->n_instances){
post(
- "pluginhost~: %s: discarding spurious MIDI data, for instance %d",
+ "pluginhost~: %s: discarding spurious MIDI data, for instance %d",
x->descriptor->LADSPA_Plugin->Label,
instance);
ph_debug_post("n_instances = %d", x->n_instances);
@@ -1890,70 +1916,43 @@ static t_int *ph_tilde_perform(t_int *w)
return w + (x->plugin_ins + x->plugin_outs + 3);
}
-static void ph_tilde_dsp(t_ph_tilde *x, t_signal **sp)
+static void ph_tilde_dsp(ph_tilde *x, t_signal **sp)
{
- if(x->n_instances){
-
-
- t_int *dsp_vector, i, N, M;
-
- M = x->plugin_ins + x->plugin_outs + 2;
-
- dsp_vector = (t_int *) getbytes(M * sizeof(t_int));
-
- dsp_vector[0] = (t_int)x;
- dsp_vector[1] = (t_int)sp[0]->s_n;
-
- for(i = 2; i < M; i++)
- dsp_vector[i] = (t_int)sp[i - 1]->s_vec;
-
- dsp_addv(ph_tilde_perform, M, dsp_vector);
-
+ if(!x->n_instances){
+ return;
+ }
- /* int n, m;
- t_float **outlets;
- t_float **inlets;
+ t_int *dsp_vector, i, N, M;
- for(n = 0, m = 1; n < x->plugin_ins; n++, m++)
- inlets[n] = sp[m]->s_vec;
- for(n = 0; n < x->plugin_outs; n++, ++m)
- outlets[n] = sp[m]->s_vec;
+ M = x->plugin_ins + x->plugin_outs + 2;
-*/ /*
+ dsp_vector = (t_int *) getbytes(M * sizeof(t_int));
- t_float **outlets = (t_float **)x->outlets;
- t_float **inlets = (t_float **)x->inlets;
+ dsp_vector[0] = (t_int)x;
+ dsp_vector[1] = (t_int)sp[0]->s_n;
- m = 1;
+ for(i = 2; i < M; i++)
+ dsp_vector[i] = (t_int)sp[i - 1]->s_vec;
- for(n = 0; n < x->plugin_ins; n++)
- *inlets++ = sp[m++]->s_vec;
- for(n = 0; n < x->plugin_outs; n++)
- *outlets++ = sp[m++]->s_vec;
- */ }
- /* dsp_add(ph_tilde_perform, 2, sp[0]->s_n, x); */
+ dsp_addv(ph_tilde_perform, M, dsp_vector);
}
-static void ph_tilde_quit_plugin(t_ph_tilde *x){
+static void ph_tilde_quit_plugin(ph_tilde *x)
+{
- t_int i, instance;
+ int i;
+ unsigned int instance;
for(instance = 0; instance < x->n_instances; instance++) {
- if(x->instances[instance].uiTarget && x->is_DSSI){
- lo_send(x->instances[instance].uiTarget,
+ /* FIX:OSC */
+ /* if(x->instances[instance].uiTarget && x->is_DSSI){
+ lo_send(x->instances[instance].uiTarget,
x->instances[instance].ui_osc_quit_path, "");
- lo_address_free(x->instances[instance].uiTarget);
- x->instances[instance].uiTarget = NULL;
- }
- /* no -- see comment in osc_exiting_handler */
- /* if (!instances[i].inactive) { */
- /* if (x->descriptor->LADSPA_Plugin->deactivate) {
- x->descriptor->LADSPA_Plugin->deactivate
- (x->instanceHandles[instance]);
- }*/
+ lo_address_free(x->instances[instance].uiTarget);
+ x->instances[instance].uiTarget = NULL; */
+
ph_tilde_deactivate_plugin(x, (t_float)instance);
- /* } */
if (x->descriptor->LADSPA_Plugin &&
x->descriptor->LADSPA_Plugin->cleanup) {
x->descriptor->LADSPA_Plugin->cleanup
@@ -1962,9 +1961,11 @@ static void ph_tilde_quit_plugin(t_ph_tilde *x){
}
}
-static void ph_tilde_free_plugin(t_ph_tilde *x){
+static void ph_tilde_free_plugin(ph_tilde *x)
+{
- t_int i, instance;
+ int instance;
+ unsigned int i;
if(x->plugin_label != NULL)
free((char *)x->plugin_label);
if(x->plugin_handle != NULL){
@@ -1978,11 +1979,13 @@ static void ph_tilde_free_plugin(t_ph_tilde *x){
while(instance--){
+ /* FIX:OSC */
+ /*
if(x->instances[instance].gui_pid){
ph_debug_post("Killing GUI process PID = %d", x->instances[instance].gui_pid);
kill(x->instances[instance].gui_pid, SIGINT);
- }
+ } */
if (x->instances[instance].pluginPrograms) {
for (i = 0; i <
x->instances[instance].plugin_ProgramCount; i++)
@@ -2016,7 +2019,6 @@ static void ph_tilde_free_plugin(t_ph_tilde *x){
free(x->instances);
free((t_float *)x->plugin_OutputBuffers);
- /*sleep(1);*/
if(x->plugin_ins){
for(i = 0; i < x->plugin_ins; i++)
inlet_free((t_inlet *)x->inlets[i]);
@@ -2037,7 +2039,8 @@ static void ph_tilde_free_plugin(t_ph_tilde *x){
}
}
-static void ph_tilde_init_plugin(t_ph_tilde *x){
+static void ph_tilde_init_plugin(ph_tilde *x)
+{
x->project_dir = NULL;
x->configure_buffer_head = NULL;
@@ -2068,7 +2071,8 @@ static void ph_tilde_init_plugin(t_ph_tilde *x){
}
-static void *ph_tilde_load_plugin(t_ph_tilde *x, t_int argc, t_atom *argv){
+static void *ph_tilde_load_plugin(ph_tilde *x, t_int argc, t_atom *argv)
+{
char *plugin_basename = NULL,
*plugin_full_path = NULL,
*tmpstr,
@@ -2077,9 +2081,9 @@ static void *ph_tilde_load_plugin(t_ph_tilde *x, t_int argc, t_atom *argv){
ph_debug_post("argc = %d", argc);
- int i,
- stop,
- fd;
+ unsigned int i;
+ int stop;
+ int fd;
size_t pathlen;
stop = 0;
@@ -2178,22 +2182,18 @@ static void *ph_tilde_load_plugin(t_ph_tilde *x, t_int argc, t_atom *argv){
else
x->n_instances = 1;
-
ph_debug_post("n_instances = %d", x->n_instances);
- x->instances = (t_ph_instance *)malloc(sizeof(t_ph_instance) *
+ x->instances = (ph_instance *)malloc(sizeof(ph_instance) *
x->n_instances);
if(x->descriptor){
ph_debug_post("%s loaded successfully!",
x->descriptor->LADSPA_Plugin->Label);
-
- /*allocate memory for port_info*/
-
- x->port_info = (t_port_info *)malloc
+ x->port_info = (ph_port_info *)malloc
(x->descriptor->LADSPA_Plugin->PortCount *
- sizeof(t_port_info));
+ sizeof(ph_port_info));
ph_tilde_port_info(x);
ph_tilde_assign_ports(x);
@@ -2247,21 +2247,14 @@ static void *ph_tilde_load_plugin(t_ph_tilde *x, t_int argc, t_atom *argv){
x->outlets = (t_outlet **)getbytes(x->plugin_outs * sizeof(t_outlet *));
for(i = 0;i < x->plugin_outs; i++)
x->outlets[i] = outlet_new(&x->x_obj, &s_signal);
- /* x->outlets =
- (t_float **)calloc(x->plugin_outs,
- sizeof(t_float *));
- */
}
else
post("pluginhost~: error: plugin has no outputs");
if(x->plugin_ins){
x->inlets = (t_inlet **)getbytes(x->plugin_ins * sizeof(t_inlet *));
for(i = 0;i < x->plugin_ins; i++)
- x->inlets[i] = inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_signal, &s_signal);
- /* x->inlets =
- (t_float **)calloc(x->plugin_ins,
- sizeof(t_float *));
- */
+ x->inlets[i] = inlet_new(&x->x_obj, &x->x_obj.ob_pd,
+ &s_signal, &s_signal);
}
else
post("pluginhost~: error: plugin has no inputs");
@@ -2278,7 +2271,8 @@ static void *ph_tilde_load_plugin(t_ph_tilde *x, t_int argc, t_atom *argv){
/* This method is currently buggy. PD's inlet/outlet handling seems buggy if you try to create ins/outs on the fly. Needs further investigation ...*/
-static void ph_tilde_plug_plugin(t_ph_tilde *x, t_symbol *s, int argc, t_atom *argv){
+static void ph_tilde_plug_plugin(ph_tilde *x, t_symbol *s, int argc, t_atom *argv)
+{
x->dsp = 0;
ph_tilde_quit_plugin(x);
@@ -2292,9 +2286,10 @@ static void ph_tilde_plug_plugin(t_ph_tilde *x, t_symbol *s, int argc, t_atom *a
ph_tilde_load_plugin(x, argc, argv);
}
-static void *ph_tilde_new(t_symbol *s, t_int argc, t_atom *argv){
+static void *ph_tilde_new(t_symbol *s, t_int argc, t_atom *argv)
+{
- t_ph_tilde *x = (t_ph_tilde *)pd_new(ph_tilde_class);
+ ph_tilde *x = (ph_tilde *)pd_new(ph_tilde_class);
post("\n========================================\npluginhost~: DSSI/LADSPA host - version %.2f\n========================================\n", VERSION);
ph_tilde_init_plugin(x);
@@ -2311,29 +2306,31 @@ static void *ph_tilde_new(t_symbol *s, t_int argc, t_atom *argv){
}
-static void ph_tilde_free(t_ph_tilde *x){
-
- ph_debug_post("Calling ph_tilde_free");
+static void ph_tilde_free(ph_tilde *x)
+{
+ ph_debug_post("Calling %s", __FUNCTION__);
ph_tilde_quit_plugin(x);
ph_tilde_free_plugin(x);
}
-static void ph_tilde_sigchld_handler(int sig) {
+static void ph_tilde_sigchld_handler(int sig)
+{
wait(NULL);
}
-void pluginhost_tilde_setup(void) {
+void pluginhost_tilde_setup(void)
+{
ph_tilde_class = class_new(gensym("pluginhost~"), (t_newmethod)ph_tilde_new,
- (t_method)ph_tilde_free, sizeof(t_ph_tilde), 0, A_GIMME, 0);
+ (t_method)ph_tilde_free, sizeof(ph_tilde), 0, A_GIMME, 0);
class_addlist(ph_tilde_class, ph_tilde_list);
class_addbang(ph_tilde_class, ph_tilde_bang);
class_addmethod(ph_tilde_class,
(t_method)ph_tilde_dsp, gensym("dsp"), 0);
- class_addmethod(ph_tilde_class, (t_method)ph_tilde_ph_methods,
+ class_addmethod(ph_tilde_class, (t_method)ph_tilde_dssi_methods,
gensym("dssi"), A_GIMME, 0);
class_addmethod (ph_tilde_class,(t_method)ph_tilde_control,
gensym ("control"),A_DEFSYM, A_DEFFLOAT, A_DEFFLOAT, 0);
@@ -2350,10 +2347,11 @@ void pluginhost_tilde_setup(void) {
class_addmethod (ph_tilde_class,(t_method)ph_tilde_deactivate_plugin,
gensym ("deactivate"),A_DEFFLOAT - 1,0);*/
class_sethelpsymbol(ph_tilde_class, gensym("pluginhost~-help"));
- CLASS_MAINSIGNALIN(ph_tilde_class, t_ph_tilde, f);
+ CLASS_MAINSIGNALIN(ph_tilde_class, ph_tilde, f);
signal(SIGCHLD, ph_tilde_sigchld_handler);
}
-
+/* FIX:OSC */
+/*
static int osc_message_handler(const char *path, const char *types,
lo_arg **argv,int argc, void *data, void *user_data)
{
@@ -2362,7 +2360,7 @@ static int osc_message_handler(const char *path, const char *types,
int i, instance = 0;
const char *method;
char chantemp[2];
- t_ph_tilde *x = (t_ph_tilde *)(user_data);
+ ph_tilde *x = (ph_tilde *)(user_data);
if (strncmp(path, "/dssi/", 6)){
ph_debug_post("calling osc_debug_handler");
@@ -2430,7 +2428,7 @@ static int osc_message_handler(const char *path, const char *types,
return osc_debug_handler(path, types, argv, argc, data, x);
}
-
+*/
static void ph_debug_post(const char *fmt, ...)
{
#if DEBUG
diff --git a/pluginhost~/src/pluginhost~.h b/pluginhost~/src/pluginhost~.h
index ddf439c..48dff96 100644
--- a/pluginhost~/src/pluginhost~.h
+++ b/pluginhost~/src/pluginhost~.h
@@ -5,7 +5,7 @@
* This file incorporates code from the following sources:
*
* jack-dssi-host (BSD-style license): Copyright 2004 Chris Cannam, Steve Harris and Sean Bolton.
- *
+ *
* Hexter (GPL license): Copyright (C) 2004 Sean Bolton and others.
*
*
@@ -25,15 +25,15 @@
*/
#include <dlfcn.h>
-#include <lo/lo.h>
#include <unistd.h>
#include <stdio.h>
#include <string.h>
-#include <stdlib.h> /*for exit()*/
-#include <sys/types.h> /* for fork() */
-#include <signal.h> /* for kill() */
-#include <sys/wait.h> /* for wait() */
-#include <dirent.h> /* for readdir() */
+#include <stdint.h> /* for uint8_t */
+#include <stdlib.h> /* for exit() */
+#include <sys/types.h> /* for fork() */
+#include <signal.h> /* for kill() */
+#include <sys/wait.h> /* for wait() */
+#include <dirent.h> /* for readdir() */
#include "m_pd.h"
#include "dssi.h"
@@ -41,30 +41,26 @@
#define DX7_VOICE_SIZE_PACKED 128 /*From hexter_types.h by Sean Bolton */
#define DX7_DUMP_SIZE_BULK 4096+8
-
-#define VERSION 0.99
-#define MY_NAME "pluginhost~"
-#define EVENT_BUFSIZE 1024
-#define OSC_BASE_MAX 1024
-#define TYPE_STRING_SIZE 20 /* Max size of event type string (must be two more bytes than needed) */
-#define DIR_STRING_SIZE 1024 /* Max size of directory string */
+#define VERSION 0.99
+#define MY_NAME "pluginhost~"
+#define EVENT_BUFSIZE 1024
+#define OSC_BASE_MAX 1024
+#define TYPE_STRING_SIZE 20
+#define DIR_STRING_SIZE 1024
#define DEBUG_STRING_SIZE 1024
-#define ASCII_n 110
-#define ASCII_p 112
-#define ASCII_c 99
-#define ASCII_b 98
-#define ASCII_t 116
-#define ASCII_a 97
-
-#define LOADGUI 0 /* FIX: depracate this */
+#define ASCII_n 110
+#define ASCII_p 112
+#define ASCII_c 99
+#define ASCII_b 98
+#define ASCII_t 116
+#define ASCII_a 97
+
+#define LOADGUI 0 /* FIX: deprecate this */
#ifdef DEBUG
#define CHECKSUM_PATCH_FILES_ON_LOAD 1
#endif
-#ifndef MIN
#define MIN(a,b) ((a)<(b)?(a):(b))
-#endif
-
/*From dx7_voice.h by Sean Bolton */
@@ -74,114 +70,113 @@ typedef struct _dx7_patch_t {
typedef struct _ph_instance {
- long currentBank;
- long currentProgram;
- int pendingBankLSB;
- int pendingBankMSB;
- int pendingProgramChange;
-
- int plugin_ProgramCount;
- DSSI_Program_Descriptor *pluginPrograms;
-
- lo_address uiTarget; /*osc stuff */
- int ui_hidden;
- int ui_show;
- int uiNeedsProgramUpdate;
+ unsigned int plugin_ProgramCount;
char *ui_osc_control_path;
char *ui_osc_configure_path;
char *ui_osc_program_path;
char *ui_osc_show_path;
char *ui_osc_hide_path;
char *ui_osc_quit_path;
+ char *osc_url_path;
+ long currentBank;
+ long currentProgram;
+ int uiNeedsProgramUpdate;
+ int pendingProgramChange;
+ int pendingBankLSB;
+ int pendingBankMSB;
+ int ui_hidden;
+ int ui_show;
int *plugin_PortControlInNumbers; /*not sure if this should go here?*/
+ DSSI_Program_Descriptor *pluginPrograms;
- char *osc_url_path;
- pid_t gui_pid;
+} ph_instance;
-} t_ph_instance;
+typedef struct ph_configure_pair {
-struct ph_configure_pair {
- t_int instance;
- char *key,
- *value;
struct ph_configure_pair *next;
-};
+ char *value;
+ char *key;
+ int instance;
+
+} ph_configure_pair;
-typedef struct ph_configure_pair t_ph_configure_pair;
+//typedef struct ph_configure_pair t_ph_configure_pair;
typedef struct _port_info {
- t_atom type,
- data_type,
- name,
- lower_bound,
- upper_bound,
- p_default;
-} t_port_info;
+
+ t_atom lower_bound;
+ t_atom upper_bound;
+ t_atom data_type;
+ t_atom p_default;
+ t_atom type;
+ t_atom name;
+
+} ph_port_info;
typedef struct _ph_tilde {
- t_object x_obj;
- t_int is_DSSI;
+
+ int sr;
+ int blksize;
+ int time_ref;
+ int ports_in;
+ int ports_out;
+ int ports_controlIn;
+ int ports_controlOut;
+ int bufWriteIndex;
+ int bufReadIndex;
+
+ bool is_DSSI;
+ bool dsp;
+ bool dsp_loop;
+
+ char *plugin_basename;
char *plugin_label;
- char *plugin_full_path; /*absolute path to plugin */
- t_canvas *x_canvas; /* pointer to the canvas the object is instantiated on */
+ char *plugin_full_path;
+ char *project_dir;
void *plugin_handle;
- char *project_dir; /* project dircetory */
- LADSPA_Handle *instanceHandles; /*was handle*/
- t_ph_instance *instances;
- int n_instances;
+ char *osc_url_base;
+
+ float f;
+ float sr_inv;
+ float **plugin_InputBuffers;
+ float **plugin_OutputBuffers;
+ float *plugin_ControlDataInput;
+ float *plugin_ControlDataOutput;
+
+ unsigned int n_instances;
+ unsigned int plugin_ins;
+ unsigned int plugin_outs;
+ unsigned int plugin_controlIns;
+ unsigned int plugin_controlOuts;
unsigned long *instanceEventCounts;
+ unsigned long *plugin_ControlInPortNumbers;
unsigned char channelMap[128];
- snd_seq_event_t **instanceEventBuffers;
-
- snd_seq_event_t midiEventBuf[EVENT_BUFSIZE];
- /*static snd_seq_event_t **instanceEventBuffers;*/
- int bufWriteIndex, bufReadIndex;
- pthread_mutex_t midiEventBufferMutex;
- /*static pthread_mutex_t listHandlerMutex = PTHREAD_MUTEX_INITIALIZER;*/
DSSI_Descriptor_Function desc_func;
DSSI_Descriptor *descriptor;
+ LADSPA_Handle *instanceHandles;
- t_port_info *port_info;
-
- t_int ports_in, ports_out, ports_controlIn, ports_controlOut;
- t_int plugin_ins;/* total audio input ports for plugin*/
- t_int plugin_outs;/* total audio output ports plugin*/
- t_int plugin_controlIns;/* total control input ports*/
- t_int plugin_controlOuts;/* total control output ports */
-
- unsigned long *plugin_ControlInPortNumbers; /*Array of input port numbers for the plugin */
-
- t_float **plugin_InputBuffers, **plugin_OutputBuffers; /* arrays of arrays for buffering audio for each audio port */
- t_float *plugin_ControlDataInput, *plugin_ControlDataOutput; /*arrays for control data for each port (1 item per 'run')*/
- lo_server_thread osc_thread;
- char *osc_url_base;
- char *plugin_basename;
-
- t_int time_ref; /*logical time reference */
- t_int sr;
- t_float sr_inv;
- t_int blksize;
- t_float f;
-
- t_outlet **outlets;
- t_inlet **inlets;
+ t_inlet **inlets;
+ t_outlet **outlets;
t_outlet *control_outlet;
+ t_canvas *x_canvas;
+ t_object x_obj;
- t_ph_configure_pair *configure_buffer_head;
+ ph_port_info *port_info;
+ ph_instance *instances;
+ ph_configure_pair *configure_buffer_head;
- t_int dsp; /* boolean dsp setting */
- t_int dsp_loop;
-
-} t_ph_tilde;
+ snd_seq_event_t **instanceEventBuffers;
+ snd_seq_event_t midiEventBuf[EVENT_BUFSIZE];
-static char *ph_tilde_send_configure(t_ph_tilde *x, char *key,
- char *value, t_int instance);
-static int osc_message_handler(const char *path, const char *types,
- lo_arg **argv, int argc, void *data, void *user_data);
-static LADSPA_Data get_port_default(t_ph_tilde *x, int port);
-static void MIDIbuf(int type, int chan, int param, int val, t_ph_tilde *x);
-static void ph_debug_post(const char *fmt, ...);
+ pthread_mutex_t midiEventBufferMutex;
+} ph_tilde;
+static char *ph_tilde_send_configure(ph_tilde *x, char *key, char *value,
+ int instance);
+static void MIDIbuf(int type, unsigned int chan, int param, int val,
+ ph_tilde *x);
+static void ph_debug_post(const char *fmt, ...);
+static LADSPA_Data get_port_default(ph_tilde *x, int port);