diff options
author | David Robillard <d@drobilla.net> | 2010-02-02 20:37:50 +0000 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2010-02-02 20:37:50 +0000 |
commit | 36573e798c986e298c62daabed6036b12ea0314d (patch) | |
tree | c908c681c6f584831366283bf7c099b36f94ff52 /src | |
parent | 53648252376649bca9868aec48ad4a290e3ae073 (diff) | |
download | raul-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.cpp | 2 | ||||
-rw-r--r-- | src/Path.cpp | 4 |
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; |