From cb42d2cc4daa09c7d1db5515e39e94b9a5a43447 Mon Sep 17 00:00:00 2001 From: David Robillard Date: Tue, 2 Dec 2008 05:49:41 +0000 Subject: Rewrite pretty much everything to do with paths in Serialiser to actually make an ounce of sense. Fix various things with nested patches (fix tickets #286 #289). Cascade successive pastes nicely. git-svn-id: http://svn.drobilla.net/lad/trunk/ingen@1840 a436a847-0d15-0410-975c-d299462d15a1 --- src/engine/events/CreatePortEvent.cpp | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) (limited to 'src/engine/events/CreatePortEvent.cpp') diff --git a/src/engine/events/CreatePortEvent.cpp b/src/engine/events/CreatePortEvent.cpp index 8cb30a4b..0e0dabd2 100644 --- a/src/engine/events/CreatePortEvent.cpp +++ b/src/engine/events/CreatePortEvent.cpp @@ -117,6 +117,8 @@ CreatePortEvent::pre_process() assert(_ports_array->size() == _patch->num_ports()); + } else { + _error = CREATION_FAILED; } } QueuedEvent::pre_process(); @@ -149,12 +151,20 @@ CreatePortEvent::execute(ProcessContext& context) void CreatePortEvent::post_process() { - if (_error != NO_ERROR || !_patch_port) { - const string msg = string("Could not create port - ").append(_path); - _responder->respond_error(msg); - } else { + string msg; + switch (_error) { + case NO_ERROR: _responder->respond_ok(); _engine.broadcaster()->send_object(_patch_port, true); + break; + case UNKNOWN_TYPE: + msg = string("Could not create port ") + _path + " (Unknown type)"; + _responder->respond_error(msg); + break; + case CREATION_FAILED: + msg = string("Could not create port ") + _path + " (Creation failed)"; + _responder->respond_error(msg); + break; } } -- cgit v1.2.1