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 | a645d2b8be4d7d31f6eef1649156b166a01e0c31 (patch) | |
tree | 3d83c08e9a5460cc6582482bcfc673dff956a1e7 /src/client/DeprecatedLoader.cpp | |
parent | 653679e967f11a0e008521885fcaf6994d2961fa (diff) | |
download | ingen-a645d2b8be4d7d31f6eef1649156b166a01e0c31.tar.gz ingen-a645d2b8be4d7d31f6eef1649156b166a01e0c31.tar.bz2 ingen-a645d2b8be4d7d31f6eef1649156b166a01e0c31.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/ingen@2408 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src/client/DeprecatedLoader.cpp')
-rw-r--r-- | src/client/DeprecatedLoader.cpp | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/src/client/DeprecatedLoader.cpp b/src/client/DeprecatedLoader.cpp index 9af1a781..ec603760 100644 --- a/src/client/DeprecatedLoader.cpp +++ b/src/client/DeprecatedLoader.cpp @@ -174,7 +174,7 @@ DeprecatedLoader::add_variable(GraphObject::Properties& data, string old_key, st if (endptr != c_val && *endptr == '\0') data.insert(make_pair(key, Atom(fval))); else - data.insert(make_pair(key, Atom(Atom::STRING, value))); + data.insert(make_pair(key, value)); free(c_val); } @@ -210,7 +210,7 @@ DeprecatedLoader::load_patch(const Glib::ustring& filename, bool merge, boost::optional<Path> parent_path, boost::optional<Symbol> name, - GraphObject::Properties initial_data, + GraphObject::Properties initial_data, bool existing) { LOG(info) << "Loading patch " << filename << " under " @@ -220,7 +220,7 @@ DeprecatedLoader::load_patch(const Glib::ustring& filename, if (parent_path) path = *parent_path; if (name) - path = path.base() + *name; + path = path.child(*name); size_t poly = 0; |