aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/jalv_internal.h5
-rw-r--r--src/persist.c72
-rw-r--r--src/presets.c79
3 files changed, 65 insertions, 91 deletions
diff --git a/src/jalv_internal.h b/src/jalv_internal.h
index 43a5c9c..1030acd 100644
--- a/src/jalv_internal.h
+++ b/src/jalv_internal.h
@@ -173,6 +173,11 @@ void
jalv_save(Jalv* jalv, const char* dir);
void
+jalv_save_port_values(Jalv* jalv,
+ SerdWriter* writer,
+ const SerdNode* subject);
+
+void
jalv_restore(Jalv* jalv, const char* dir);
void
diff --git a/src/persist.c b/src/persist.c
index 11ad183..f87ed6f 100644
--- a/src/persist.c
+++ b/src/persist.c
@@ -27,11 +27,13 @@
#include "jalv-config.h"
#include "jalv_internal.h"
+#define NS_ATOM (const uint8_t*)"http://lv2plug.in/ns/ext/atom#"
#define NS_JALV (const uint8_t*)"http://drobilla.net/ns/jalv#"
#define NS_LV2 (const uint8_t*)"http://lv2plug.in/ns/lv2core#"
-#define NS_XSD (const uint8_t*)"http://www.w3.org/2001/XMLSchema#"
-#define NS_ATOM (const uint8_t*)"http://lv2plug.in/ns/ext/atom#"
+#define NS_PSET (const uint8_t*)"http://lv2plug.in/ns/ext/presets#"
#define NS_STATE (const uint8_t*)"http://lv2plug.in/ns/ext/state#"
+#define NS_XSD (const uint8_t*)"http://www.w3.org/2001/XMLSchema#"
+#define NS_RDFS (const uint8_t*)"http://www.w3.org/2000/01/rdf-schema#"
#define USTR(s) ((const uint8_t*)s)
@@ -124,24 +126,19 @@ jalv_save(Jalv* jalv, const char* dir)
snprintf(path, path_len + 1, "%s%s", dir, filename);
FILE* out_fd = fopen(path, "w");
- SerdNode jalv_name = serd_node_from_string(SERD_LITERAL, USTR("jalv"));
- SerdNode jalv_prefix = serd_node_from_string(SERD_URI, NS_JALV);
- SerdNode lv2_name = serd_node_from_string(SERD_LITERAL, USTR("lv2"));
- SerdNode lv2_prefix = serd_node_from_string(SERD_URI, NS_LV2);
- SerdNode state_name = serd_node_from_string(SERD_LITERAL, USTR("state"));
- SerdNode state_prefix = serd_node_from_string(SERD_URI, NS_STATE);
- SerdNode atom_name = serd_node_from_string(SERD_LITERAL, USTR("atom"));
- SerdNode atom_prefix = serd_node_from_string(SERD_URI, NS_ATOM);
- SerdNode jalv_plugin = serd_node_from_string(SERD_URI, NS_JALV "plugin");
- SerdNode jalv_value = serd_node_from_string(SERD_URI, (NS_JALV "value"));
- SerdNode lv2_symbol = serd_node_from_string(SERD_URI, (NS_LV2 "symbol"));
- SerdNode xsd_decimal = serd_node_from_string(SERD_URI, (NS_XSD "decimal"));
- SerdNode jalv_port = serd_node_from_string(SERD_URI, (NS_JALV "port"));
+ SerdEnv* env = serd_env_new(NULL);
+ serd_env_set_prefix_from_strings(env, USTR("atom"), USTR(NS_ATOM));
+ serd_env_set_prefix_from_strings(env, USTR("jalv"), USTR(NS_JALV));
+ serd_env_set_prefix_from_strings(env, USTR("lv2"), USTR(NS_LV2));
+ serd_env_set_prefix_from_strings(env, USTR("pset"), USTR(NS_PSET));
+ serd_env_set_prefix_from_strings(env, USTR("rdfs"), USTR(NS_RDFS));
+ serd_env_set_prefix_from_strings(env, USTR("state"), USTR(NS_STATE));
+
+ SerdNode jalv_plugin = serd_node_from_string(SERD_URI, NS_JALV "plugin");
SerdNode plugin_uri = serd_node_from_string(SERD_URI, USTR(lilv_node_as_uri(
lilv_plugin_get_uri(jalv->plugin))));
- SerdEnv* env = serd_env_new(NULL);
SerdNode subject = serd_node_from_string(SERD_URI, USTR(""));
@@ -153,10 +150,7 @@ jalv_save(Jalv* jalv, const char* dir)
file_sink,
out_fd);
- serd_writer_set_prefix(jalv->writer, &atom_name, &atom_prefix);
- serd_writer_set_prefix(jalv->writer, &jalv_name, &jalv_prefix);
- serd_writer_set_prefix(jalv->writer, &lv2_name, &lv2_prefix);
- serd_writer_set_prefix(jalv->writer, &state_name, &state_prefix);
+ serd_env_foreach(env, (SerdPrefixSink)serd_writer_set_prefix, jalv->writer);
// <> jalv:plugin <http://example.org/plugin>
serd_writer_write_statement(jalv->writer, 0, NULL,
@@ -164,41 +158,7 @@ jalv_save(Jalv* jalv, const char* dir)
&jalv_plugin,
&plugin_uri, NULL, NULL);
- for (uint32_t i = 0; i < jalv->num_ports; ++i) {
- struct Port* port = &jalv->ports[i];
- if (port->flow != FLOW_INPUT || port->type != TYPE_CONTROL) {
- continue;
- }
-
- const uint8_t* sym = (const uint8_t*)lilv_node_as_string(
- lilv_port_get_symbol(jalv->plugin, port->lilv_port));
-
- const SerdNode sym_node = serd_node_from_string(SERD_LITERAL, sym);
- const SerdNode blank = serd_node_from_string(SERD_BLANK, sym);
-
- // <> jalv:port []
- serd_writer_write_statement(jalv->writer, SERD_ANON_O_BEGIN, NULL,
- &subject,
- &jalv_port,
- &blank, NULL, NULL);
-
- char value_str[128];
- snprintf(value_str, sizeof(value_str), "%f", port->control);
-
- SerdNode value = serd_node_from_string(SERD_LITERAL, USTR(value_str));
-
- // [] lv2:symbol "example"
- serd_writer_write_statement(jalv->writer, SERD_ANON_CONT, NULL,
- &blank, &lv2_symbol, &sym_node,
- NULL, NULL);
-
- // [] jalv:value 1.0
- serd_writer_write_statement(jalv->writer, SERD_ANON_CONT, NULL,
- &blank, &jalv_value, &value,
- &xsd_decimal, NULL);
-
- serd_writer_end_anon(jalv->writer, &blank);
- }
+ jalv_save_port_values(jalv, jalv->writer, &subject);
#ifdef HAVE_LV2_STATE
assert(jalv->symap);
@@ -275,7 +235,7 @@ on_statement(void* handle,
} else if (!strcmp((const char*)predicate->buf, "lv2:symbol")) {
serd_node_free(&jalv->last_sym);
jalv->last_sym = serd_node_copy(object);
- } else if (!strcmp((const char*)predicate->buf, "jalv:value")) {
+ } else if (!strcmp((const char*)predicate->buf, "pset:value")) {
const char* sym = (const char*)jalv->last_sym.buf;
struct Port* port = jalv_port_by_symbol(jalv, sym);
if (port) {
diff --git a/src/presets.c b/src/presets.c
index b396f56..2e145cd 100644
--- a/src/presets.c
+++ b/src/presets.c
@@ -161,6 +161,49 @@ strjoin(const char* a, const char* b)
return out;
}
+void
+jalv_save_port_values(Jalv* jalv,
+ SerdWriter* writer,
+ const SerdNode* subject)
+{
+ for (uint32_t i = 0; i < jalv->num_ports; ++i) {
+ struct Port* const port = &jalv->ports[i];
+ if (port->type != TYPE_CONTROL || port->flow != FLOW_INPUT) {
+ continue;
+ }
+
+ const LilvNode* sym = lilv_port_get_symbol(jalv->plugin, port->lilv_port);
+ LilvNode* val = lilv_new_float(jalv->world, port->control);
+
+ const SerdNode port_node = serd_node_from_string(
+ SERD_BLANK, USTR(lilv_node_as_string(sym)));
+
+ // <> lv2:port _:symbol
+ SerdNode p = serd_node_from_string(SERD_URI,
+ USTR(NS_LV2 "port"));
+ serd_writer_write_statement(writer, SERD_ANON_O_BEGIN,
+ NULL, subject, &p, &port_node, NULL, NULL);
+
+ // _:symbol lv2:symbol "symbol"
+ p = serd_node_from_string(SERD_URI, USTR(NS_LV2 "symbol"));
+ SerdNode o = serd_node_from_string(SERD_LITERAL,
+ USTR(lilv_node_as_string(sym)));
+ serd_writer_write_statement(writer, SERD_ANON_CONT,
+ NULL, &port_node, &p, &o, NULL, NULL);
+
+ // _:symbol pset:value value
+ p = serd_node_from_string(SERD_URI, USTR(NS_PSET "value"));
+ o = serd_node_from_string(SERD_LITERAL,
+ USTR(lilv_node_as_string(val)));
+ SerdNode t = serd_node_from_string(SERD_URI, USTR(NS_XSD "decimal"));
+ serd_writer_write_statement(writer, SERD_ANON_CONT,
+ NULL, &port_node, &p, &o, &t, NULL);
+
+ lilv_node_free(val);
+ serd_writer_end_anon(writer, &port_node);
+ }
+}
+
int
jalv_save_preset(Jalv* jalv, const char* label)
{
@@ -230,41 +273,7 @@ jalv_save_preset(Jalv* jalv, const char* label)
serd_writer_write_statement(writer, 0,
NULL, &s, &p, &o, NULL, NULL);
- for (uint32_t i = 0; i < jalv->num_ports; ++i) {
- struct Port* const port = &jalv->ports[i];
- if (port->type != TYPE_CONTROL || port->flow != FLOW_INPUT) {
- continue;
- }
-
- const LilvNode* sym = lilv_port_get_symbol(jalv->plugin, port->lilv_port);
- LilvNode* val = lilv_new_float(jalv->world, port->control);
-
- const SerdNode port_node = serd_node_from_string(
- SERD_BLANK, USTR(lilv_node_as_string(sym)));
-
- // <> lv2:port _:symbol
- p = serd_node_from_string(SERD_URI, USTR(NS_LV2 "port"));
- serd_writer_write_statement(writer, SERD_ANON_O_BEGIN,
- NULL, &s, &p, &port_node, NULL, NULL);
-
- // _:symbol lv2:symbol "symbol"
- p = serd_node_from_string(SERD_URI, USTR(NS_LV2 "symbol"));
- o = serd_node_from_string(SERD_LITERAL,
- USTR(lilv_node_as_string(sym)));
- serd_writer_write_statement(writer, SERD_ANON_CONT,
- NULL, &port_node, &p, &o, NULL, NULL);
-
- // _:symbol pset:value value
- p = serd_node_from_string(SERD_URI, USTR(NS_PSET "value"));
- o = serd_node_from_string(SERD_LITERAL,
- USTR(lilv_node_as_string(val)));
- SerdNode t = serd_node_from_string(SERD_URI, USTR(NS_XSD "decimal"));
- serd_writer_write_statement(writer, SERD_ANON_CONT,
- NULL, &port_node, &p, &o, &t, NULL);
-
- lilv_node_free(val);
- serd_writer_end_anon(writer, &port_node);
- }
+ jalv_save_port_values(jalv, writer, &s);
serd_writer_free(writer);
serd_node_free(&base);