summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2010-02-02 20:37:50 +0000
committerDavid Robillard <d@drobilla.net>2010-02-02 20:37:50 +0000
commit36573e798c986e298c62daabed6036b12ea0314d (patch)
treec908c681c6f584831366283bf7c099b36f94ff52 /src
parent53648252376649bca9868aec48ad4a290e3ae073 (diff)
downloadraul-36573e798c986e298c62daabed6036b12ea0314d.tar.gz
raul-36573e798c986e298c62daabed6036b12ea0314d.tar.bz2
raul-36573e798c986e298c62daabed6036b12ea0314d.zip
Use Glib string interning (quarks) to make Path/URI operator== very fast.
This avoids a ton of string comparison overhead in Ingen when setting various properties (e.g. "ingen:value" was compared several times every time a port value was changed, now this is just a single pointer comparison and the full round trip of a value change does no string comparison at all, but is still property based and RDFey). git-svn-id: http://svn.drobilla.net/lad/trunk/raul@2408 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src')
-rw-r--r--src/Configuration.cpp2
-rw-r--r--src/Path.cpp4
2 files changed, 3 insertions, 3 deletions
diff --git a/src/Configuration.cpp b/src/Configuration.cpp
index 1ea70a3..bc6cfbd 100644
--- a/src/Configuration.cpp
+++ b/src/Configuration.cpp
@@ -85,7 +85,7 @@ Configuration::set_value_from_string(Configuration::Option& option, const std::s
}
break;
case Atom::STRING:
- option.value = Atom(Atom::STRING, value);
+ option.value = Atom(value.c_str());
break;
default:
throw CommandLineError(string("bad option type `--") + option.name + "'");
diff --git a/src/Path.cpp b/src/Path.cpp
index 512d91b..c0eb0df 100644
--- a/src/Path.cpp
+++ b/src/Path.cpp
@@ -24,7 +24,7 @@ namespace Raul {
const string Path::scheme = "path";
const string Path::prefix = Path::scheme + ":";
const size_t Path::prefix_len = prefix.length();
-const string Path::root_uri = Path::prefix + "/";
+const Path Path::root = Path::prefix + "/";
bool
Path::is_valid(const std::basic_string<char>& path_str)
@@ -73,7 +73,7 @@ string
Path::pathify(const std::basic_string<char>& str)
{
if (str.length() == 0)
- return root_uri; // this might not be wise?
+ return root.str(); // this might not be wise?
string path = (str.substr(0, prefix_len) == prefix) ? str : prefix + str;
size_t start = prefix_len + 1;