summaryrefslogtreecommitdiffstats
path: root/raul
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2008-11-09 03:45:35 +0000
committerDavid Robillard <d@drobilla.net>2008-11-09 03:45:35 +0000
commit33cd95af08ac8a2d463ee6a0f6a55809c13bfc54 (patch)
treecfa8089c745907845ae800593a46f0cfb13207cd /raul
parentec41a09ba4135c33c56e0016a0c098e9bd698df1 (diff)
downloadraul-33cd95af08ac8a2d463ee6a0f6a55809c13bfc54.tar.gz
raul-33cd95af08ac8a2d463ee6a0f6a55809c13bfc54.tar.bz2
raul-33cd95af08ac8a2d463ee6a0f6a55809c13bfc54.zip
Add concept of 'Resource' and make plugins a resource (as well as graph objects).
Get rid of crufty imperative Plugin API. Loading of plugin data from engine over HTTP. git-svn-id: http://svn.drobilla.net/lad/trunk/raul@1713 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'raul')
-rw-r--r--raul/Atom.hpp12
1 files changed, 10 insertions, 2 deletions
diff --git a/raul/Atom.hpp b/raul/Atom.hpp
index 5a7263c..639b2ca 100644
--- a/raul/Atom.hpp
+++ b/raul/Atom.hpp
@@ -41,6 +41,7 @@ public:
INT,
FLOAT,
BOOL,
+ URI,
STRING,
BLOB
};
@@ -50,7 +51,8 @@ public:
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())) {}
+
+ Atom(Type t, const std::string& val) : _type(t), _string_val(strdup(val.c_str())) {}
Atom(const char* type_uri, size_t size, void* val) : _type(BLOB) {
_blob_type_length = strlen(type_uri) + 1; // + 1 for \0
@@ -61,7 +63,7 @@ public:
}
~Atom() {
- if (_type == STRING)
+ if (_type == URI || _type == STRING)
free(_string_val);
else if (_type == BLOB)
free(_blob_val);
@@ -77,6 +79,7 @@ public:
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 URI:
case STRING: _string_val = strdup(copy._string_val); break;
case BLOB: _blob_size = copy._blob_size;
_blob_type_length = copy._blob_type_length;
@@ -99,6 +102,7 @@ public:
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 URI:
case STRING: _string_val = strdup(other._string_val); break;
case BLOB: _blob_size = other._blob_size;
_blob_type_length = other._blob_type_length;
@@ -116,6 +120,7 @@ public:
case INT: return _int_val == other._int_val;
case FLOAT: return _float_val == other._float_val;
case BOOL: return _bool_val == other._bool_val;
+ case URI:
case STRING: return strcmp(_string_val, other._string_val) == 0;
case BLOB: return _blob_val == other._blob_val;
}
@@ -132,6 +137,7 @@ public:
case INT: return _int_val < other._int_val;
case FLOAT: return _float_val < other._float_val;
case BOOL: return _bool_val < other._bool_val;
+ case URI:
case STRING: return strcmp(_string_val, other._string_val) < 0;
case BLOB: return _blob_val < other._blob_val;
}
@@ -145,6 +151,7 @@ public:
case INT: return sizeof(uint32_t);
case FLOAT: return sizeof(float);
case BOOL: return sizeof(bool);
+ case URI:
case STRING: return strlen(_string_val);
case BLOB: return _blob_size;
}
@@ -162,6 +169,7 @@ public:
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 char* get_uri() const { assert(_type == URI); return _string_val; }
inline const char* get_blob_type() const { assert(_type == BLOB); return (const char*)_blob_val; }
inline const void* get_blob() const { assert(_type == BLOB); return (const char*)_blob_val + _blob_type_length; }