Browse Source

Custom lilv changes

tags/1.9.7
falkTX 10 years ago
parent
commit
99812a8195
9 changed files with 317 additions and 108 deletions
  1. +52
    -14
      source/modules/lilv/lilv-0.22.1/lilv/lilv.h
  2. +63
    -44
      source/modules/lilv/lilv-0.22.1/lilv/lilvmm.hpp
  3. +1
    -1
      source/modules/lilv/lilv-0.22.1/src/lilv_internal.h
  4. +127
    -1
      source/modules/lilv/lilv-0.22.1/src/plugin.c
  5. +2
    -2
      source/modules/lilv/lilv-0.22.1/src/port.c
  6. +18
    -35
      source/modules/lilv/lilv-0.22.1/src/state.c
  7. +51
    -0
      source/modules/lilv/lilv-0.22.1/src/ui.c
  8. +1
    -5
      source/modules/lilv/lilv-0.22.1/src/util.c
  9. +2
    -6
      source/modules/lilv/lilv-0.22.1/src/world.c

+ 52
- 14
source/modules/lilv/lilv-0.22.1/lilv/lilv.h View File

@@ -26,8 +26,9 @@
#include <stdint.h> #include <stdint.h>
#include <stdio.h> #include <stdio.h>


#include "lv2/lv2plug.in/ns/lv2core/lv2.h"
#include "lv2/lv2plug.in/ns/ext/urid/urid.h"
#include "lv2/lv2.h"
#include "lv2/state.h"
#include "lv2/urid.h"


#ifdef LILV_SHARED #ifdef LILV_SHARED
# ifdef _WIN32 # ifdef _WIN32
@@ -562,7 +563,7 @@ lilv_world_free(LilvWorld* world);
with special plugin bundles which are installed to a known location). with special plugin bundles which are installed to a known location).
*/ */
LILV_API void LILV_API void
lilv_world_load_all(LilvWorld* world);
lilv_world_load_all(LilvWorld* world, const char* lv2_path);


/** /**
Load a specific bundle. Load a specific bundle.
@@ -1209,9 +1210,9 @@ lilv_port_get_scale_points(const LilvPlugin* plugin,
@return A new LilvState which must be freed with lilv_state_free(), or NULL. @return A new LilvState which must be freed with lilv_state_free(), or NULL.
*/ */
LILV_API LilvState* LILV_API LilvState*
lilv_state_new_from_world(LilvWorld* world,
LV2_URID_Map* map,
const LilvNode* subject);
lilv_state_new_from_world(LilvWorld* world,
const LV2_URID_Map* map,
const LilvNode* subject);


/** /**
Load a state snapshot from a file. Load a state snapshot from a file.
@@ -1229,18 +1230,18 @@ lilv_state_new_from_world(LilvWorld* world,
new memory consumed once this function returns. new memory consumed once this function returns.
*/ */
LILV_API LilvState* LILV_API LilvState*
lilv_state_new_from_file(LilvWorld* world,
LV2_URID_Map* map,
const LilvNode* subject,
const char* path);
lilv_state_new_from_file(LilvWorld* world,
const LV2_URID_Map* map,
const LilvNode* subject,
const char* path);


/** /**
Load a state snapshot from a string made by lilv_state_to_string(). Load a state snapshot from a string made by lilv_state_to_string().
*/ */
LILV_API LilvState* LILV_API LilvState*
lilv_state_new_from_string(LilvWorld* world,
LV2_URID_Map* map,
const char* str);
lilv_state_new_from_string(LilvWorld* world,
const LV2_URID_Map* map,
const char* str);


/** /**
Function to get a port value. Function to get a port value.
@@ -1435,7 +1436,8 @@ lilv_state_emit_port_values(const LilvState* state,
*/ */
LILV_API void LILV_API void
lilv_state_restore(const LilvState* state, lilv_state_restore(const LilvState* state,
LilvInstance* instance,
const LV2_State_Interface* iface,
LV2_Handle handle,
LilvSetPortValueFunc set_value, LilvSetPortValueFunc set_value,
void* user_data, void* user_data,
uint32_t flags, uint32_t flags,
@@ -1795,6 +1797,42 @@ lilv_ui_get_bundle_uri(const LilvUI* ui);
LILV_API const LilvNode* LILV_API const LilvNode*
lilv_ui_get_binary_uri(const LilvUI* ui); lilv_ui_get_binary_uri(const LilvUI* ui);


/**
Custom calls
*/
LILV_API LilvNode*
lilv_plugin_get_modgui_resources_directory(const LilvPlugin* plugin);

LILV_API LilvNode*
lilv_plugin_get_modgui_stylesheet(const LilvPlugin* plugin);

LILV_API LilvNode*
lilv_plugin_get_modgui_icon_template(const LilvPlugin* plugin);

LILV_API LilvNode*
lilv_plugin_get_modgui_settings_template(const LilvPlugin* plugin);

LILV_API LilvNode*
lilv_plugin_get_modgui_template_data(const LilvPlugin* plugin);

LILV_API LilvNode*
lilv_plugin_get_modgui_screenshot(const LilvPlugin* plugin);

LILV_API LilvNode*
lilv_plugin_get_modgui_thumbnail(const LilvPlugin* plugin);

LILV_API const LilvNodes*
lilv_ui_get_supported_features(const LilvUI* ui);

LILV_API const LilvNodes*
lilv_ui_get_required_features(const LilvUI* ui);

LILV_API const LilvNodes*
lilv_ui_get_optional_features(const LilvUI* ui);

LILV_API const LilvNodes*
lilv_ui_get_extension_data(const LilvUI* ui);

/** /**
@} @}
@} @}


+ 63
- 44
source/modules/lilv/lilv-0.22.1/lilv/lilvmm.hpp View File

@@ -17,6 +17,8 @@
#ifndef LILV_LILVMM_HPP #ifndef LILV_LILVMM_HPP
#define LILV_LILVMM_HPP #define LILV_LILVMM_HPP


#include "CarlaDefines.h"

#include "lilv/lilv.h" #include "lilv/lilv.h"


#if __GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 1) #if __GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 1)
@@ -27,14 +29,12 @@


namespace Lilv { namespace Lilv {


static inline const char*
uri_to_path(const char* uri) {
return lilv_uri_to_path(uri);
}

#define LILV_WRAP0(RT, prefix, name) \ #define LILV_WRAP0(RT, prefix, name) \
inline RT name() { return lilv_ ## prefix ## _ ## name (me); } inline RT name() { return lilv_ ## prefix ## _ ## name (me); }


#define LILV_WRAP0_CONST(RT, prefix, name) \
inline RT name() const { return lilv_ ## prefix ## _ ## name (me); }

#define LILV_WRAP0_VOID(prefix, name) \ #define LILV_WRAP0_VOID(prefix, name) \
inline void name() { lilv_ ## prefix ## _ ## name(me); } inline void name() { lilv_ ## prefix ## _ ## name(me); }


@@ -65,6 +65,7 @@ uri_to_path(const char* uri) {
#endif #endif


struct Node { struct Node {
inline Node(LilvNode* node) : me(node) {}
inline Node(const LilvNode* node) : me(lilv_node_duplicate(node)) {} inline Node(const LilvNode* node) : me(lilv_node_duplicate(node)) {}
inline Node(const Node& copy) : me(lilv_node_duplicate(copy.me)) {} inline Node(const Node& copy) : me(lilv_node_duplicate(copy.me)) {}


@@ -78,20 +79,26 @@ struct Node {


LILV_WRAP_CONVERSION(LilvNode); LILV_WRAP_CONVERSION(LilvNode);


LILV_WRAP0(char*, node, get_turtle_token);
LILV_WRAP0(bool, node, is_uri);
LILV_WRAP0(const char*, node, as_uri);
LILV_WRAP0(bool, node, is_blank);
LILV_WRAP0(const char*, node, as_blank);
LILV_WRAP0(bool, node, is_literal);
LILV_WRAP0(bool, node, is_string);
LILV_WRAP0(const char*, node, as_string);
LILV_WRAP0(bool, node, is_float);
LILV_WRAP0(float, node, as_float);
LILV_WRAP0(bool, node, is_int);
LILV_WRAP0(int, node, as_int);
LILV_WRAP0(bool, node, is_bool);
LILV_WRAP0(bool, node, as_bool);
LILV_WRAP0_CONST(char*, node, get_turtle_token);
LILV_WRAP0_CONST(bool, node, is_uri);
LILV_WRAP0_CONST(const char*, node, as_uri);
LILV_WRAP0_CONST(bool, node, is_blank);
LILV_WRAP0_CONST(const char*, node, as_blank);
LILV_WRAP0_CONST(bool, node, is_literal);
LILV_WRAP0_CONST(bool, node, is_string);
LILV_WRAP0_CONST(const char*, node, as_string);
LILV_WRAP0_CONST(bool, node, is_float);
LILV_WRAP0_CONST(float, node, as_float);
LILV_WRAP0_CONST(bool, node, is_int);
LILV_WRAP0_CONST(int, node, as_int);
LILV_WRAP0_CONST(bool, node, is_bool);
LILV_WRAP0_CONST(bool, node, as_bool);

Node& operator=(const Node& copy) {
lilv_node_free(me);
me = lilv_node_duplicate(copy.me);
return *this;
}


LilvNode* me; LilvNode* me;
}; };
@@ -126,7 +133,7 @@ struct PluginClass {
LILV_WRAP0(LilvIter*, prefix, begin); \ LILV_WRAP0(LilvIter*, prefix, begin); \
LILV_WRAP1(LilvIter*, prefix, next, LilvIter*, i); \ LILV_WRAP1(LilvIter*, prefix, next, LilvIter*, i); \
LILV_WRAP1(bool, prefix, is_end, LilvIter*, i); \ LILV_WRAP1(bool, prefix, is_end, LilvIter*, i); \
const Lilv ## CT* me; \
const Lilv ## CT* me


struct PluginClasses { struct PluginClasses {
LILV_WRAP_COLL(PluginClasses, PluginClass, plugin_classes); LILV_WRAP_COLL(PluginClasses, PluginClass, plugin_classes);
@@ -141,22 +148,24 @@ struct ScalePoints {
struct Nodes { struct Nodes {
LILV_WRAP_COLL(Nodes, Node, nodes); LILV_WRAP_COLL(Nodes, Node, nodes);
LILV_WRAP1(bool, nodes, contains, const Node, node); LILV_WRAP1(bool, nodes, contains, const Node, node);
LILV_WRAP0(Node, nodes, get_first);

inline Node get_first() const {
return Node((const LilvNode*)lilv_nodes_get_first(me));
}
}; };


struct UI { struct UI {
inline UI(const LilvUI* c_obj) : me(c_obj) {} inline UI(const LilvUI* c_obj) : me(c_obj) {}
LILV_WRAP_CONVERSION(const LilvUI); LILV_WRAP_CONVERSION(const LilvUI);


LILV_WRAP0(const LilvNode*, ui, get_uri);
LILV_WRAP0(const LilvNode*, ui, get_bundle_uri);
LILV_WRAP0(const LilvNode*, ui, get_binary_uri);
LILV_WRAP0(const LilvNodes*, ui, get_classes);
/*LILV_WRAP3(bool, ui, is_supported,
LilvUISupportedFunc, supported_func,
const LilvNode*, container_type,
const LilvNode**, ui_type);*/
LILV_WRAP1(bool, ui, is_a, const LilvNode*, class_uri);
LILV_WRAP0(Node, ui, get_uri);
LILV_WRAP1(bool, ui, is_a, LilvNode*, ui_class);
LILV_WRAP0(Node, ui, get_bundle_uri);
LILV_WRAP0(Node, ui, get_binary_uri);
LILV_WRAP0(Nodes, ui, get_supported_features);
LILV_WRAP0(Nodes, ui, get_required_features);
LILV_WRAP0(Nodes, ui, get_optional_features);
LILV_WRAP0(Nodes, ui, get_extension_data);


const LilvUI* me; const LilvUI* me;
}; };
@@ -220,6 +229,13 @@ struct Plugin {
LILV_WRAP0(Nodes, plugin, get_extension_data); LILV_WRAP0(Nodes, plugin, get_extension_data);
LILV_WRAP0(UIs, plugin, get_uis); LILV_WRAP0(UIs, plugin, get_uis);
LILV_WRAP1(Nodes, plugin, get_related, Node, type); LILV_WRAP1(Nodes, plugin, get_related, Node, type);
LILV_WRAP0(Node, plugin, get_modgui_resources_directory);
LILV_WRAP0(Node, plugin, get_modgui_stylesheet);
LILV_WRAP0(Node, plugin, get_modgui_icon_template);
LILV_WRAP0(Node, plugin, get_modgui_settings_template);
LILV_WRAP0(Node, plugin, get_modgui_template_data);
LILV_WRAP0(Node, plugin, get_modgui_screenshot);
LILV_WRAP0(Node, plugin, get_modgui_thumbnail);


inline Port get_port_by_index(unsigned index) { inline Port get_port_by_index(unsigned index) {
return Port(me, lilv_plugin_get_port_by_index(me, index)); return Port(me, lilv_plugin_get_port_by_index(me, index));
@@ -259,15 +275,13 @@ struct Instance {
inline Instance(LilvInstance* instance) : me(instance) {} inline Instance(LilvInstance* instance) : me(instance) {}


LILV_DEPRECATED LILV_DEPRECATED
inline Instance(Plugin plugin, double sample_rate) {
me = lilv_plugin_instantiate(plugin, sample_rate, NULL);
}
inline Instance(Plugin plugin, double sample_rate)
: me(lilv_plugin_instantiate(plugin, sample_rate, NULL)) {}


LILV_DEPRECATED inline Instance(Plugin plugin, LILV_DEPRECATED inline Instance(Plugin plugin,
double sample_rate, double sample_rate,
LV2_Feature* const* features) {
me = lilv_plugin_instantiate(plugin, sample_rate, features);
}
LV2_Feature* const* features)
: me(lilv_plugin_instantiate(plugin, sample_rate, features)) {}


static inline Instance* create(Plugin plugin, static inline Instance* create(Plugin plugin,
double sample_rate, double sample_rate,
@@ -304,22 +318,25 @@ struct Instance {
}; };


struct World { struct World {
inline World() : me(lilv_world_new()) {}
inline ~World() { lilv_world_free(me); }
inline World() : me(lilv_world_new()) {}
inline virtual ~World() { lilv_world_free(me); }


inline LilvNode* new_uri(const char* uri) {
inline LilvNode* new_uri(const char* uri) const {
return lilv_new_uri(me, uri); return lilv_new_uri(me, uri);
} }
inline LilvNode* new_string(const char* str) {
inline LilvNode* new_file_uri(const char* host, const char* path) const {
return lilv_new_file_uri(me, host, path);
}
inline LilvNode* new_string(const char* str) const {
return lilv_new_string(me, str); return lilv_new_string(me, str);
} }
inline LilvNode* new_int(int val) {
inline LilvNode* new_int(int val) const {
return lilv_new_int(me, val); return lilv_new_int(me, val);
} }
inline LilvNode* new_float(float val) {
inline LilvNode* new_float(float val) const {
return lilv_new_float(me, val); return lilv_new_float(me, val);
} }
inline LilvNode* new_bool(bool val) {
inline LilvNode* new_bool(bool val) const {
return lilv_new_bool(me, val); return lilv_new_bool(me, val);
} }
inline Nodes find_nodes(const LilvNode* subject, inline Nodes find_nodes(const LilvNode* subject,
@@ -329,7 +346,7 @@ struct World {
} }


LILV_WRAP2_VOID(world, set_option, const char*, uri, LilvNode*, value); LILV_WRAP2_VOID(world, set_option, const char*, uri, LilvNode*, value);
LILV_WRAP0_VOID(world, load_all);
LILV_WRAP1_VOID(world, load_all, const char*, lv2_path);
LILV_WRAP1_VOID(world, load_bundle, LilvNode*, bundle_uri); LILV_WRAP1_VOID(world, load_bundle, LilvNode*, bundle_uri);
LILV_WRAP0(const LilvPluginClass*, world, get_plugin_class); LILV_WRAP0(const LilvPluginClass*, world, get_plugin_class);
LILV_WRAP0(const LilvPluginClasses*, world, get_plugin_classes); LILV_WRAP0(const LilvPluginClasses*, world, get_plugin_classes);
@@ -337,6 +354,8 @@ struct World {
LILV_WRAP1(int, world, load_resource, const LilvNode*, resource); LILV_WRAP1(int, world, load_resource, const LilvNode*, resource);


LilvWorld* me; LilvWorld* me;

CARLA_DECLARE_NON_COPY_STRUCT(World)
}; };


} /* namespace Lilv */ } /* namespace Lilv */


+ 1
- 1
source/modules/lilv/lilv-0.22.1/src/lilv_internal.h View File

@@ -58,7 +58,7 @@ static inline char* dlerror(void) { return "Unknown error"; }
#include "lilv/lilv.h" #include "lilv/lilv.h"


#ifdef LILV_DYN_MANIFEST #ifdef LILV_DYN_MANIFEST
# include "lv2/lv2plug.in/ns/ext/dynmanifest/dynmanifest.h"
# include "lv2/dynmanifest.h"
#endif #endif


/* /*


+ 127
- 1
source/modules/lilv/lilv-0.22.1/src/plugin.c View File

@@ -27,10 +27,11 @@
#include "lilv_config.h" #include "lilv_config.h"
#include "lilv_internal.h" #include "lilv_internal.h"


#include "lv2/lv2plug.in/ns/extensions/ui/ui.h"
#include "lv2/ui.h"


#define NS_DOAP (const uint8_t*)"http://usefulinc.com/ns/doap#" #define NS_DOAP (const uint8_t*)"http://usefulinc.com/ns/doap#"
#define NS_FOAF (const uint8_t*)"http://xmlns.com/foaf/0.1/" #define NS_FOAF (const uint8_t*)"http://xmlns.com/foaf/0.1/"
#define NS_MOD (const uint8_t*)"http://moddevices.com/ns/modgui#"


/** Ownership of `uri` is taken */ /** Ownership of `uri` is taken */
LilvPlugin* LilvPlugin*
@@ -908,6 +909,131 @@ lilv_plugin_get_author_homepage(const LilvPlugin* plugin)
return NULL; return NULL;
} }


static const SordNode*
lilv_plugin_get_modgui(const LilvPlugin* p)
{
lilv_plugin_load_if_necessary(p);

SordNode* mod_gui = sord_new_uri(
p->world->world, NS_MOD "gui");

SordIter* gui = lilv_world_query_internal(
p->world,
p->plugin_uri->node,
mod_gui,
NULL);

sord_node_free(p->world->world, mod_gui);

if (sord_iter_end(gui)) {
sord_iter_free(gui);
return NULL;
}

const SordNode* Gui = sord_iter_get_node(gui, SORD_OBJECT);

sord_iter_free(gui);
return Gui;
}

LILV_API LilvNode*
lilv_plugin_get_modgui_resources_directory(const LilvPlugin* plugin)
{
const SordNode* modgui = lilv_plugin_get_modgui(plugin);
if (modgui) {
SordWorld* sworld = plugin->world->world;
SordNode* modgui_res = sord_new_uri(sworld, NS_MOD "resourcesDirectory");
LilvNode* ret = lilv_plugin_get_one(plugin, modgui, modgui_res);
sord_node_free(sworld, modgui_res);
return ret;
}
return NULL;
}

LILV_API LilvNode*
lilv_plugin_get_modgui_stylesheet(const LilvPlugin* plugin)
{
const SordNode* modgui = lilv_plugin_get_modgui(plugin);
if (modgui) {
SordWorld* sworld = plugin->world->world;
SordNode* modgui_style = sord_new_uri(sworld, NS_MOD "stylesheet");
LilvNode* ret = lilv_plugin_get_one(plugin, modgui, modgui_style);
sord_node_free(sworld, modgui_style);
return ret;
}
return NULL;
}

LILV_API LilvNode*
lilv_plugin_get_modgui_icon_template(const LilvPlugin* plugin)
{
const SordNode* modgui = lilv_plugin_get_modgui(plugin);
if (modgui) {
SordWorld* sworld = plugin->world->world;
SordNode* modgui_tmpl = sord_new_uri(sworld, NS_MOD "iconTemplate");
LilvNode* ret = lilv_plugin_get_one(plugin, modgui, modgui_tmpl);
sord_node_free(sworld, modgui_tmpl);
return ret;
}
return NULL;
}

LILV_API LilvNode*
lilv_plugin_get_modgui_settings_template(const LilvPlugin* plugin)
{
const SordNode* modgui = lilv_plugin_get_modgui(plugin);
if (modgui) {
SordWorld* sworld = plugin->world->world;
SordNode* modgui_tmpl = sord_new_uri(sworld, NS_MOD "settingsTemplate");
LilvNode* ret = lilv_plugin_get_one(plugin, modgui, modgui_tmpl);
sord_node_free(sworld, modgui_tmpl);
return ret;
}
return NULL;
}

LILV_API LilvNode*
lilv_plugin_get_modgui_template_data(const LilvPlugin* plugin)
{
const SordNode* modgui = lilv_plugin_get_modgui(plugin);
if (modgui) {
SordWorld* sworld = plugin->world->world;
SordNode* modgui_tmpl = sord_new_uri(sworld, NS_MOD "templateData");
LilvNode* ret = lilv_plugin_get_one(plugin, modgui, modgui_tmpl);
sord_node_free(sworld, modgui_tmpl);
return ret;
}
return NULL;
}

LILV_API LilvNode*
lilv_plugin_get_modgui_screenshot(const LilvPlugin* plugin)
{
const SordNode* modgui = lilv_plugin_get_modgui(plugin);
if (modgui) {
SordWorld* sworld = plugin->world->world;
SordNode* modgui_scr = sord_new_uri(sworld, NS_MOD "screenshot");
LilvNode* ret = lilv_plugin_get_one(plugin, modgui, modgui_scr);
sord_node_free(sworld, modgui_scr);
return ret;
}
return NULL;
}

LILV_API LilvNode*
lilv_plugin_get_modgui_thumbnail(const LilvPlugin* plugin)
{
const SordNode* modgui = lilv_plugin_get_modgui(plugin);
if (modgui) {
SordWorld* sworld = plugin->world->world;
SordNode* modgui_thumb = sord_new_uri(sworld, NS_MOD "thumbnail");
LilvNode* ret = lilv_plugin_get_one(plugin, modgui, modgui_thumb);
sord_node_free(sworld, modgui_thumb);
return ret;
}
return NULL;
}

LILV_API bool LILV_API bool
lilv_plugin_is_replaced(const LilvPlugin* plugin) lilv_plugin_is_replaced(const LilvPlugin* plugin)
{ {


+ 2
- 2
source/modules/lilv/lilv-0.22.1/src/port.c View File

@@ -20,8 +20,8 @@
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>


#include "lv2/lv2plug.in/ns/ext/atom/atom.h"
#include "lv2/lv2plug.in/ns/ext/event/event.h"
#include "lv2/atom.h"
#include "lv2/event.h"


#include "lilv_internal.h" #include "lilv_internal.h"




+ 18
- 35
source/modules/lilv/lilv-0.22.1/src/state.c View File

@@ -18,10 +18,10 @@
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>


#include "lv2/lv2plug.in/ns/ext/atom/atom.h"
#include "lv2/lv2plug.in/ns/ext/atom/forge.h"
#include "lv2/lv2plug.in/ns/ext/presets/presets.h"
#include "lv2/lv2plug.in/ns/ext/state/state.h"
#include "lv2/atom.h"
#include "lv2/atom-forge.h"
#include "lv2/presets.h"
#include "lv2/state.h"


#include "lilv_config.h" #include "lilv_config.h"
#include "lilv_internal.h" #include "lilv_internal.h"
@@ -415,35 +415,18 @@ lilv_state_emit_port_values(const LilvState* state,


LILV_API void LILV_API void
lilv_state_restore(const LilvState* state, lilv_state_restore(const LilvState* state,
LilvInstance* instance,
const LV2_State_Interface* iface,
LV2_Handle handle,
LilvSetPortValueFunc set_value, LilvSetPortValueFunc set_value,
void* user_data, void* user_data,
uint32_t flags, uint32_t flags,
const LV2_Feature *const * features) const LV2_Feature *const * features)
{ {
if (!state) {
LILV_ERROR("lilv_state_restore() called on NULL state\n");
return;
}

LV2_State_Map_Path map_path = {
(LilvState*)state, abstract_path, absolute_path };
LV2_Feature map_feature = { LV2_STATE__mapPath, &map_path };

const LV2_Feature** sfeatures = add_features(features, &map_feature, NULL);

const LV2_Descriptor* desc = instance ? instance->lv2_descriptor : NULL;
const LV2_State_Interface* iface = (desc && desc->extension_data)
? (const LV2_State_Interface*)desc->extension_data(LV2_STATE__interface)
: NULL;

if (iface) { if (iface) {
iface->restore(instance->lv2_handle, retrieve_callback,
(LV2_State_Handle)state, flags, sfeatures);
iface->restore(handle, retrieve_callback,
(LV2_State_Handle)state, flags, features);
} }


free(sfeatures);

if (set_value) { if (set_value) {
lilv_state_emit_port_values(state, set_value, user_data); lilv_state_emit_port_values(state, set_value, user_data);
} }
@@ -590,9 +573,9 @@ new_state_from_model(LilvWorld* world,
} }


LILV_API LilvState* LILV_API LilvState*
lilv_state_new_from_world(LilvWorld* world,
LV2_URID_Map* map,
const LilvNode* node)
lilv_state_new_from_world(LilvWorld* world,
const LV2_URID_Map* map,
const LilvNode* node)
{ {
if (!lilv_node_is_uri(node) && !lilv_node_is_blank(node)) { if (!lilv_node_is_uri(node) && !lilv_node_is_blank(node)) {
LILV_ERRORF("Subject `%s' is not a URI or blank node.\n", LILV_ERRORF("Subject `%s' is not a URI or blank node.\n",
@@ -604,10 +587,10 @@ lilv_state_new_from_world(LilvWorld* world,
} }


LILV_API LilvState* LILV_API LilvState*
lilv_state_new_from_file(LilvWorld* world,
LV2_URID_Map* map,
const LilvNode* subject,
const char* path)
lilv_state_new_from_file(LilvWorld* world,
const LV2_URID_Map* map,
const LilvNode* subject,
const char* path)
{ {
if (subject && !lilv_node_is_uri(subject) if (subject && !lilv_node_is_uri(subject)
&& !lilv_node_is_blank(subject)) { && !lilv_node_is_blank(subject)) {
@@ -657,9 +640,9 @@ set_prefixes(SerdEnv* env)
} }


LILV_API LilvState* LILV_API LilvState*
lilv_state_new_from_string(LilvWorld* world,
LV2_URID_Map* map,
const char* str)
lilv_state_new_from_string(LilvWorld* world,
const LV2_URID_Map* map,
const char* str)
{ {
if (!str) { if (!str) {
return NULL; return NULL;


+ 51
- 0
source/modules/lilv/lilv-0.22.1/src/ui.c View File

@@ -109,3 +109,54 @@ lilv_ui_get_binary_uri(const LilvUI* ui)
{ {
return ui->binary_uri; return ui->binary_uri;
} }

static LilvNodes*
lilv_ui_get_value_internal(const LilvUI* ui, const SordNode* predicate)
{
assert(ui);
return lilv_world_find_nodes_internal(ui->world, ui->uri->node, predicate, NULL);
}

LILV_API const LilvNodes*
lilv_ui_get_supported_features(const LilvUI* ui)
{
assert(ui);
LilvNodes* optional = lilv_ui_get_optional_features(ui);
LilvNodes* required = lilv_ui_get_required_features(ui);
LilvNodes* result = lilv_nodes_new();

LILV_FOREACH(nodes, i, optional)
zix_tree_insert((ZixTree*)result, lilv_node_duplicate(lilv_nodes_get(optional, i)), NULL);

LILV_FOREACH(nodes, i, required)
zix_tree_insert((ZixTree*)result, lilv_node_duplicate(lilv_nodes_get(required, i)), NULL);

lilv_nodes_free(optional);
lilv_nodes_free(required);

return result;
}

LILV_API const LilvNodes*
lilv_ui_get_required_features(const LilvUI* ui)
{
assert(ui);
assert(ui->world);
return lilv_ui_get_value_internal(ui, ui->world->uris.lv2_requiredFeature);
}

LILV_API const LilvNodes*
lilv_ui_get_optional_features(const LilvUI* ui)
{
assert(ui);
assert(ui->world);
return lilv_ui_get_value_internal(ui, ui->world->uris.lv2_optionalFeature);
}

LILV_API const LilvNodes*
lilv_ui_get_extension_data(const LilvUI* ui)
{
assert(ui);
assert(ui->world);
return lilv_ui_get_value_internal(ui, ui->world->uris.lv2_extensionData);
}

+ 1
- 5
source/modules/lilv/lilv-0.22.1/src/util.c View File

@@ -29,7 +29,6 @@
#include <string.h> #include <string.h>


#ifdef _WIN32 #ifdef _WIN32
# define _WIN32_WINNT 0x0600 /* for CreateSymbolicLink */
# include <windows.h> # include <windows.h>
# include <direct.h> # include <direct.h>
# include <io.h> # include <io.h>
@@ -459,10 +458,7 @@ lilv_symlink(const char* oldpath, const char* newpath)
int ret = 0; int ret = 0;
if (strcmp(oldpath, newpath)) { if (strcmp(oldpath, newpath)) {
#ifdef _WIN32 #ifdef _WIN32
ret = !CreateSymbolicLink(newpath, oldpath, 0);
if (ret) {
ret = !CreateHardLink(newpath, oldpath, 0);
}
ret = 1;
#else #else
ret = symlink(oldpath, newpath); ret = symlink(oldpath, newpath);
#endif #endif


+ 2
- 6
source/modules/lilv/lilv-0.22.1/src/world.c View File

@@ -19,7 +19,7 @@
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>


#include "lv2/lv2plug.in/ns/ext/presets/presets.h"
#include "lv2/presets.h"


#include "lilv_internal.h" #include "lilv_internal.h"


@@ -797,12 +797,8 @@ lilv_world_load_plugin_classes(LilvWorld* world)
} }


LILV_API void LILV_API void
lilv_world_load_all(LilvWorld* world)
lilv_world_load_all(LilvWorld* world, const char* lv2_path)
{ {
const char* lv2_path = getenv("LV2_PATH");
if (!lv2_path)
lv2_path = LILV_DEFAULT_LV2_PATH;

// Discover bundles and read all manifest files into model // Discover bundles and read all manifest files into model
lilv_world_load_path(world, lv2_path); lilv_world_load_path(world, lv2_path);




Loading…
Cancel
Save