summaryrefslogtreecommitdiffstats
path: root/src/value.c
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2011-01-30 21:27:39 +0000
committerDavid Robillard <d@drobilla.net>2011-01-30 21:27:39 +0000
commit23ef7a21c277ba5e864748d8e61ff3e20054758f (patch)
tree1f2b2fae3e84b48b0fd2739b6f5a3dba5ed80c35 /src/value.c
parent2c17ab25b34cdada738182daf72607eaa2d3673e (diff)
downloadlilv-23ef7a21c277ba5e864748d8e61ff3e20054758f.tar.gz
lilv-23ef7a21c277ba5e864748d8e61ff3e20054758f.tar.bz2
lilv-23ef7a21c277ba5e864748d8e61ff3e20054758f.zip
Add blank node type for value, to allow the user to 'join' statement
queries on blank node values with the simple get_value functions. Remove use of SPARQL from lv2_inspect. git-svn-id: http://svn.drobilla.net/lad/trunk/slv2@2874 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src/value.c')
-rw-r--r--src/value.c26
1 files changed, 25 insertions, 1 deletions
diff --git a/src/value.c b/src/value.c
index d9e8a9c..819e5fe 100644
--- a/src/value.c
+++ b/src/value.c
@@ -37,6 +37,7 @@ slv2_value_set_numerics_from_string(SLV2Value val)
switch (val->type) {
case SLV2_VALUE_URI:
+ case SLV2_VALUE_BLANK:
case SLV2_VALUE_QNAME_UNUSED:
case SLV2_VALUE_STRING:
break;
@@ -79,6 +80,7 @@ slv2_value_new(SLV2World world, SLV2ValueType type, const char* str)
val->str_val = (char*)librdf_uri_as_string(val->val.uri_val);
break;
case SLV2_VALUE_QNAME_UNUSED:
+ case SLV2_VALUE_BLANK:
case SLV2_VALUE_STRING:
case SLV2_VALUE_INT:
case SLV2_VALUE_FLOAT:
@@ -117,6 +119,7 @@ slv2_value_new_librdf_node(SLV2World world, librdf_node* node)
result = slv2_value_new(world, type, (const char*)librdf_node_get_literal_value(node));
switch (result->type) {
case SLV2_VALUE_URI:
+ case SLV2_VALUE_BLANK:
case SLV2_VALUE_STRING:
case SLV2_VALUE_QNAME_UNUSED:
break;
@@ -126,7 +129,7 @@ slv2_value_new_librdf_node(SLV2World world, librdf_node* node)
}
break;
case LIBRDF_NODE_TYPE_BLANK:
- type = SLV2_VALUE_STRING;
+ type = SLV2_VALUE_BLANK;
result = slv2_value_new(world, type, (const char*)librdf_node_get_blank_identifier(node));
break;
case LIBRDF_NODE_TYPE_UNKNOWN:
@@ -236,6 +239,7 @@ slv2_value_equals(SLV2Value value, SLV2Value other)
switch (value->type) {
case SLV2_VALUE_URI:
return (librdf_uri_equals(value->val.uri_val, other->val.uri_val) != 0);
+ case SLV2_VALUE_BLANK:
case SLV2_VALUE_STRING:
case SLV2_VALUE_QNAME_UNUSED:
return ! strcmp(value->str_val, other->str_val);
@@ -262,6 +266,11 @@ slv2_value_get_turtle_token(SLV2Value value)
result = calloc(len, 1);
snprintf(result, len, "<%s>", value->str_val);
break;
+ case SLV2_VALUE_BLANK:
+ len = strlen(value->str_val) + 3;
+ result = calloc(len, 1);
+ snprintf(result, len, "_:%s", value->str_val);
+ break;
case SLV2_VALUE_STRING:
case SLV2_VALUE_QNAME_UNUSED:
result = strdup(value->str_val);
@@ -318,6 +327,21 @@ slv2_value_as_librdf_uri(SLV2Value value)
bool
+slv2_value_is_blank(SLV2Value value)
+{
+ return (value && value->type == SLV2_VALUE_BLANK);
+}
+
+
+const char*
+slv2_value_as_blank(SLV2Value value)
+{
+ assert(slv2_value_is_blank(value));
+ return value->str_val;
+}
+
+
+bool
slv2_value_is_literal(SLV2Value value)
{
// No blank nodes