diff options
Diffstat (limited to 'utils/lv2_inspect.c')
-rw-r--r-- | utils/lv2_inspect.c | 50 |
1 files changed, 44 insertions, 6 deletions
diff --git a/utils/lv2_inspect.c b/utils/lv2_inspect.c index 716d9a2..8b6f5ca 100644 --- a/utils/lv2_inspect.c +++ b/utils/lv2_inspect.c @@ -26,6 +26,15 @@ SLV2Value event_class = NULL; SLV2Value control_class = NULL; +SLV2Value in_group_pred = NULL; +SLV2Value role_pred = NULL; + +void +print_group(SLV2Plugin p, SLV2Value group, SLV2Value symbol) +{ + printf("\n\tGroup %s:\n", slv2_value_as_string(group)); + printf("\t\tSymbol: %s\n", slv2_value_as_string(symbol)); +} void print_port(SLV2Plugin p, uint32_t index, float* mins, float* maxes, float* defaults) @@ -41,9 +50,11 @@ print_port(SLV2Plugin p, uint32_t index, float* mins, float* maxes, float* defau SLV2Values classes = slv2_port_get_classes(p, port); - printf("\t\tClasses:\n"); + printf("\t\tType: "); for (unsigned i=0; i < slv2_values_size(classes); ++i) { - printf("\t\t\t%s\n", slv2_value_as_uri(slv2_values_get_at(classes, i))); + printf("%s", slv2_value_as_uri(slv2_values_get_at(classes, i))); + if (i != slv2_values_size(classes) - 1) + printf("\n\t\t "); } if (slv2_port_is_a(p, port, event_class)) { @@ -60,7 +71,7 @@ print_port(SLV2Plugin p, uint32_t index, float* mins, float* maxes, float* defau SLV2ScalePoints points = slv2_port_get_scale_points(p, port); if (points) - printf("\t\tScale Points:\n"); + printf("\n\t\tScale Points:\n"); for (unsigned i=0; i < slv2_scale_points_size(points); ++i) { SLV2ScalePoint p = slv2_scale_points_get_at(points, i); printf("\t\t\t%s = \"%s\"\n", @@ -76,6 +87,16 @@ print_port(SLV2Plugin p, uint32_t index, float* mins, float* maxes, float* defau printf("\t\tName: %s\n", slv2_value_as_string(val)); slv2_value_free(val); + SLV2Values groups = slv2_port_get_value(p, port, in_group_pred); + if (slv2_values_size(groups) > 0) + printf("\t\tGroup: %s\n", slv2_value_as_string(slv2_values_get_at(groups, 0))); + slv2_values_free(groups); + + SLV2Values roles = slv2_port_get_value(p, port, role_pred); + if (slv2_values_size(roles) > 0) + printf("\t\tRole: %s\n", slv2_value_as_string(slv2_values_get_at(roles, 0))); + slv2_values_free(roles); + if (slv2_port_is_a(p, port, control_class)) { if (!isnan(mins[index])) printf("\t\tMinimum: %f\n", mins[index]); @@ -169,9 +190,6 @@ print_plugin(SLV2Plugin p) } slv2_uis_free(uis); - //SLV2Values ui = slv2_plugin_get_value_for_subject(p, - // "<http://ll-plugins.nongnu.org/lv2/ext/gtk2ui#ui>"); - printf("\tData URIs: "); SLV2Values data_uris = slv2_plugin_get_data_uris(p); for (unsigned i=0; i < slv2_values_size(data_uris); ++i) { @@ -231,6 +249,24 @@ SELECT ?name WHERE { <> lv2p:hasPreset ?preset . ?preset dc:title ?name }"); slv2_results_free(presets); + /* Groups */ + + SLV2Results groups = slv2_plugin_query_sparql(p, "\ +PREFIX pg: <http://lv2plug.in/ns/dev/port-groups#> \ +PREFIX dc: <http://dublincore.org/documents/dcmi-namespace/> \ +SELECT DISTINCT ?group ?sym WHERE {\n" +" <> lv2:port ?port .\n" +" ?port pg:inGroup ?group .\n" +" ?group lv2:symbol ?sym .\n" +"}"); + for (; !slv2_results_finished(groups); slv2_results_next(groups)) { + SLV2Value group = slv2_results_get_binding_value(groups, 0); + SLV2Value symbol = slv2_results_get_binding_value(groups, 1); + print_group(p, group, symbol); + } + slv2_results_free(groups); + + /* Ports */ const uint32_t num_ports = slv2_plugin_get_num_ports(p); @@ -280,6 +316,8 @@ main(int argc, char** argv) event_class = slv2_value_new_uri(world, SLV2_PORT_CLASS_EVENT); control_class = slv2_value_new_uri(world, SLV2_PORT_CLASS_CONTROL); + in_group_pred = slv2_value_new_uri(world, "http://lv2plug.in/ns/dev/port-groups#inGroup"); + role_pred = slv2_value_new_uri(world, "http://lv2plug.in/ns/dev/port-groups#role"); if (argc != 2) { print_usage(); |