From b3c31c94eb572063ec97f24a89e5f7f98d5eae41 Mon Sep 17 00:00:00 2001 From: David Robillard Date: Thu, 28 May 2009 23:11:21 +0000 Subject: Working engine->client plugin information communication via HTTP. git-svn-id: http://svn.drobilla.net/lad/trunk/ingen@2044 a436a847-0d15-0410-975c-d299462d15a1 --- src/client/ClientStore.cpp | 18 ++++++++++-------- src/client/HTTPClientReceiver.cpp | 8 ++++++-- 2 files changed, 16 insertions(+), 10 deletions(-) (limited to 'src/client') diff --git a/src/client/ClientStore.cpp b/src/client/ClientStore.cpp index cdfeb276..bb501079 100644 --- a/src/client/ClientStore.cpp +++ b/src/client/ClientStore.cpp @@ -365,24 +365,26 @@ ClientStore::clear_patch(const Path& path) void -ClientStore::set_property(const URI& subject_path, const URI& predicate, const Atom& value) +ClientStore::set_property(const URI& subject_uri, const URI& predicate, const Atom& value) { - SharedPtr subject = resource(subject_path); + SharedPtr subject = resource(subject_uri); - size_t hash = subject_path.find("#"); + size_t hash = subject_uri.find("#"); if (!value.is_valid()) { cerr << "ERROR: property '" << predicate << "' is invalid" << endl; } else if (subject) { subject->set_property(predicate, value); - } else if (hash != string::npos) { - cerr << "META OBJECT " << subject_path << " PROPERTY " << predicate << endl; - Path instance_path = string("/") + subject_path.chop_start("#"); + } else if (subject_uri.substr(0, 6) == "meta:#") { + Path instance_path = string("/") + subject_uri.substr(hash + 1); SharedPtr om = PtrCast(subject); if (om) om->meta().set_property(predicate, value); } else { - //add_property_orphan(subject_path, predicate, value); - cerr << "WARNING: property '" << predicate << "' for unknown object " << subject_path << endl; + SharedPtr plugin = this->plugin(subject_uri); + if (plugin) + plugin->set_property(predicate, value); + else + cerr << "WARNING: property '" << predicate << "' for unknown object " << subject_uri << endl; } } diff --git a/src/client/HTTPClientReceiver.cpp b/src/client/HTTPClientReceiver.cpp index 9d603c2d..6d0dbb1b 100644 --- a/src/client/HTTPClientReceiver.cpp +++ b/src/client/HTTPClientReceiver.cpp @@ -99,7 +99,7 @@ HTTPClientReceiver::Listener::Listener(HTTPClientReceiver* receiver, const std:: void HTTPClientReceiver::update(const std::string& str) { - cout << _parser->parse_update(_world, _target.get(), str, "/"); + cout << _parser->parse_update(_world, _target.get(), str, "."); } void @@ -136,6 +136,10 @@ HTTPClientReceiver::message_callback(SoupSession* session, SoupMessage* msg, voi { HTTPClientReceiver* me = (HTTPClientReceiver*)ptr; const string path = soup_message_get_uri(msg)->path; + + /*cerr << "HTTP MESSAGE " << path << endl; + cerr << msg->response_body->data << endl;*/ + if (path == Path::root_uri) { me->_target->response_ok(0); @@ -147,7 +151,7 @@ HTTPClientReceiver::message_callback(SoupSession* session, SoupMessage* msg, voi me->_target->response_ok(0); me->_parser->parse_string(me->_world, me->_target.get(), Glib::ustring(msg->response_body->data), - Glib::ustring(".")); + Glib::ustring("")); } } else if (path == "/patch") { -- cgit v1.2.1