/* SLV2 * Copyright (C) 2007 Dave Robillard * * This library is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the Free * Software Foundation; either version 2 of the License, or (at your option) * any later version. * * This library 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 General Public License * for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. */ #define _XOPEN_SOURCE 500 #include #include #include #include #include #include #include #include #include "private_types.h" /* private */ SLV2Port slv2_port_new(uint32_t index, const char* symbol/*, const char* node_id*/) { struct _Port* port = malloc(sizeof(struct _Port)); port->index = index; port->symbol = strdup(symbol); //port->node_id = strdup(node_id); return port; } /* private */ void slv2_port_free(SLV2Port port) { free(port->symbol); //free(port->node_id); free(port); } /* private */ SLV2Port slv2_port_duplicate(SLV2Port port) { struct _Port* result = malloc(sizeof(struct _Port)); result->index = port->index; result->symbol = strdup(port->symbol); //result->node_id = strdup(port->node_id); return result; } SLV2PortClass slv2_port_get_class(SLV2Plugin p, SLV2Port port) { SLV2Strings class = slv2_port_get_value(p, port, "rdf:type"); assert(class); SLV2PortClass ret = SLV2_UNKNOWN_PORT_CLASS; int io = -1; // 0 = in, 1 = out enum { UNKNOWN, AUDIO, CONTROL, MIDI } type = UNKNOWN; for (unsigned i=0; i < slv2_strings_size(class); ++i) { const char* value = slv2_strings_get_at(class, i); if (!strcmp(value, "http://lv2plug.in/ontology#InputPort")) io = 0; else if (!strcmp(value, "http://lv2plug.in/ontology#OutputPort")) io = 1; else if (!strcmp(value, "http://lv2plug.in/ontology#ControlPort")) type = CONTROL; else if (!strcmp(value, "http://lv2plug.in/ontology#AudioPort")) type = AUDIO; else if (!strcmp(value, "http://ll-plugins.nongnu.org/lv2/ext/MidiPort")) type = MIDI; } if (io == 0) { if (type == AUDIO) ret = SLV2_AUDIO_INPUT; else if (type == CONTROL) ret = SLV2_CONTROL_INPUT; else if (type == MIDI) ret = SLV2_MIDI_INPUT; } else if (io == 1) { if (type == AUDIO) ret = SLV2_AUDIO_OUTPUT; else if (type == CONTROL) ret = SLV2_CONTROL_OUTPUT; else if (type == MIDI) ret = SLV2_MIDI_OUTPUT; } slv2_strings_free(class); return ret; } SLV2Strings slv2_port_get_value(SLV2Plugin p, SLV2Port port, const char* property) { assert(property); SLV2Strings result = NULL; char* query = slv2_strjoin( "SELECT DISTINCT ?value WHERE {\n" "?port lv2:symbol \"", port->symbol, "\";\n\t", property, " ?value .\n}", 0); result = slv2_plugin_simple_query(p, query, "value"); free(query); return result; } char* slv2_port_get_symbol(SLV2Plugin p, SLV2Port port) { char* symbol = NULL; SLV2Strings result = slv2_port_get_value(p, port, "lv2:symbol"); if (result && slv2_strings_size(result) == 1) symbol = strdup(slv2_strings_get_at(result, 0)); slv2_strings_free(result); return symbol; } char* slv2_port_get_name(SLV2Plugin p, SLV2Port port) { char* name = NULL; SLV2Strings result = slv2_port_get_value(p, port, "lv2:name"); if (result && slv2_strings_size(result) == 1) name = strdup(slv2_strings_get_at(result, 0)); slv2_strings_free(result); return name; } float slv2_port_get_default_value(SLV2Plugin p, SLV2Port port) { // FIXME: do casting properly in the SPARQL query float value = 0.0f; SLV2Strings result = slv2_port_get_value(p, port, "lv2:default"); if (result && slv2_strings_size(result) == 1) value = atof(slv2_strings_get_at(result, 0)); slv2_strings_free(result); return value; } float slv2_port_get_minimum_value(SLV2Plugin p, SLV2Port port) { // FIXME: need better access to literal types float value = 0.0f; SLV2Strings result = slv2_port_get_value(p, port, "lv2:minimum"); if (result && slv2_strings_size(result) == 1) value = atof(slv2_strings_get_at(result, 0)); slv2_strings_free(result); return value; } float slv2_port_get_maximum_value(SLV2Plugin p, SLV2Port port) { // FIXME: need better access to literal types float value = 0.0f; SLV2Strings result = slv2_port_get_value(p, port, "lv2:maximum"); if (result && slv2_strings_size(result) == 1) value = atof(slv2_strings_get_at(result, 0)); slv2_strings_free(result); return value; } SLV2Strings slv2_port_get_properties(SLV2Plugin p, SLV2Port port) { return slv2_port_get_value(p, port, "lv2:portProperty"); } SLV2Strings slv2_port_get_hints(SLV2Plugin p, SLV2Port port) { return slv2_port_get_value(p, port, "lv2:portHint"); }