diff options
author | David Robillard <d@drobilla.net> | 2011-12-21 19:15:13 +0000 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2011-12-21 19:15:13 +0000 |
commit | a6c98c802249b48b2e3cc5dbd89e1ab6595d89d9 (patch) | |
tree | c236c6512bc45175247d70127ec1af7970fd1cdc | |
parent | 06b9ff8c265d7199ad5aebf1c8c7abc90cba934a (diff) | |
download | jalv-a6c98c802249b48b2e3cc5dbd89e1ab6595d89d9.tar.gz jalv-a6c98c802249b48b2e3cc5dbd89e1ab6595d89d9.tar.bz2 jalv-a6c98c802249b48b2e3cc5dbd89e1ab6595d89d9.zip |
Make load_state_from_file fully generic.
git-svn-id: http://svn.drobilla.net/lad/trunk/jalv@3894 a436a847-0d15-0410-975c-d299462d15a1
-rw-r--r-- | src/state.c | 33 |
1 files changed, 24 insertions, 9 deletions
diff --git a/src/state.c b/src/state.c index d28ae90..5eb50a1 100644 --- a/src/state.c +++ b/src/state.c @@ -287,13 +287,35 @@ on_statement(void* handle, return SERD_SUCCESS; } +static PluginState* +load_state_from_file(LilvWorld* world, + LV2_URID_Map* map, + const char* state_uri); + PluginState* jalv_load_state(Jalv* jalv, const char* dir) { + const size_t dir_len = strlen(dir); + const size_t state_uri_len = strlen("file:///state.ttl") + dir_len + 1; + char* state_uri = (char*)malloc(state_uri_len); + snprintf(state_uri, state_uri_len, "file://%s/state.ttl", dir); + + PluginState* state = load_state_from_file( + jalv->world, &jalv->map, state_uri); + + free(state_uri); + return state; +} + +static PluginState* +load_state_from_file(LilvWorld* world, + LV2_URID_Map* map, + const char* state_uri) +{ RestoreData data; memset(&data, '\0', sizeof(RestoreData)); - data.world = jalv->world; - data.map = &jalv->map; + data.world = world; + data.map = map; SerdReader* reader = serd_reader_new( SERD_TURTLE, @@ -303,20 +325,13 @@ jalv_load_state(Jalv* jalv, const char* dir) on_statement, NULL); - const size_t dir_len = strlen(dir); - const size_t state_uri_len = strlen("file:///state.ttl") + dir_len + 1; - char* state_uri = (char*)malloc(state_uri_len); - snprintf(state_uri, state_uri_len, "file://%s/state.ttl", dir); - SerdStatus st = serd_reader_read_file(reader, USTR(state_uri)); if (st) { fprintf(stderr, "Error reading state from %s (%s)\n", state_uri, serd_strerror(st)); - free(state_uri); return NULL; } - free(state_uri); serd_reader_free(reader); PluginState* state = (PluginState*)malloc(sizeof(PluginState)); |