summaryrefslogtreecommitdiffstats
path: root/raul
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2007-09-08 00:53:43 +0000
committerDavid Robillard <d@drobilla.net>2007-09-08 00:53:43 +0000
commita6eadd534d1a3971cac14a1073ad6e29a3d88751 (patch)
tree1c423bee507949e21d7d1553e26fc13a9bb7177b /raul
parent3fa994bfb73d53f24deb3dd66bf97e8e34b1d966 (diff)
downloadraul-a6eadd534d1a3971cac14a1073ad6e29a3d88751.tar.gz
raul-a6eadd534d1a3971cac14a1073ad6e29a3d88751.tar.bz2
raul-a6eadd534d1a3971cac14a1073ad6e29a3d88751.zip
Support for writing pretty Turtle boolean literals.
git-svn-id: http://svn.drobilla.net/lad/raul@698 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'raul')
-rw-r--r--raul/Atom.hpp6
-rw-r--r--raul/AtomRedland.hpp8
2 files changed, 14 insertions, 0 deletions
diff --git a/raul/Atom.hpp b/raul/Atom.hpp
index 4b9e6a8..01d783f 100644
--- a/raul/Atom.hpp
+++ b/raul/Atom.hpp
@@ -39,6 +39,7 @@ public:
NIL,
INT,
FLOAT,
+ BOOL,
STRING,
BLOB
};
@@ -46,6 +47,7 @@ public:
Atom() : _type(NIL), _blob_val(0) {}
Atom(int32_t val) : _type(INT), _int_val(val) {}
Atom(float val) : _type(FLOAT), _float_val(val) {}
+ Atom(bool val) : _type(BOOL), _bool_val(val) {}
Atom(const char* val) : _type(STRING), _string_val(strdup(val)) {}
Atom(const std::string& val) : _type(STRING), _string_val(strdup(val.c_str())) {}
@@ -70,6 +72,7 @@ public:
case NIL: _blob_val = 0; break;
case INT: _int_val = copy._int_val; break;
case FLOAT: _float_val = copy._float_val; break;
+ case BOOL: _bool_val = copy._bool_val; break;
case STRING: _string_val = strdup(copy._string_val); break;
case BLOB: _blob_val = malloc(_blob_size);
@@ -94,6 +97,7 @@ public:
case NIL: _blob_val = 0; break;
case INT: _int_val = other._int_val; break;
case FLOAT: _float_val = other._float_val; break;
+ case BOOL: _bool_val = other._bool_val; break;
case STRING: _string_val = strdup(other._string_val); break;
case BLOB: _blob_val = malloc(_blob_size);
@@ -112,6 +116,7 @@ public:
inline int32_t get_int32() const { assert(_type == INT); return _int_val; }
inline float get_float() const { assert(_type == FLOAT); return _float_val; }
+ inline bool get_bool() const { assert(_type == BOOL); return _bool_val; }
inline const char* get_string() const { assert(_type == STRING); return _string_val; }
inline const void* get_blob() const { assert(_type == BLOB); return _blob_val; }
@@ -125,6 +130,7 @@ private:
union {
int32_t _int_val;
float _float_val;
+ bool _bool_val;
char* _string_val;
void* _blob_val;
};
diff --git a/raul/AtomRedland.hpp b/raul/AtomRedland.hpp
index 6e753d7..0ce260b 100644
--- a/raul/AtomRedland.hpp
+++ b/raul/AtomRedland.hpp
@@ -65,6 +65,14 @@ public:
// xsd:decimal -> pretty decimal (float) literals in Turtle
type = librdf_new_uri(world, U("http://www.w3.org/2001/XMLSchema#decimal"));
break;
+ case Atom::BOOL:
+ // xsd:boolean -> pretty boolean literals in Turtle
+ if (atom.get_bool())
+ str = "true";
+ else
+ str = "false";
+ type = librdf_new_uri(world, U("http://www.w3.org/2001/XMLSchema#boolean"));
+ break;
case Atom::STRING:
str = atom.get_string();
break;