, _input (in)
, _output (out)
{
- _own_input = false;
- _own_output = false;
+ if (in) {
+ _own_input = false;
+ } else {
+ _own_input = true;
+ }
+
+ if (out) {
+ _own_output = false;
+ } else {
+ _own_output = true;
+ }
}
IOProcessor::~IOProcessor ()
XMLNode& node (Processor::state (full_state));
if (_own_input) {
- XMLNode& i (_input->state (full_state));
- // i.name() = X_("output");
- node.add_child_nocopy (i);
node.add_property ("own-input", "yes");
+ if (_input) {
+ XMLNode& i (_input->state (full_state));
+ // i.name() = X_("output");
+ node.add_child_nocopy (i);
+ }
} else {
node.add_property ("own-input", "no");
if (_input) {
}
if (_own_output) {
- XMLNode& o (_output->state (full_state));
- // o.name() = X_("output");
- node.add_child_nocopy (o);
node.add_property ("own-output", "yes");
+ if (_output) {
+ XMLNode& o (_output->state (full_state));
+ // o.name() = X_("output");
+ node.add_child_nocopy (o);
+ }
} else {
node.add_property ("own-output", "no");
if (_output) {
_own_output = (prop->value() == "yes");
}
- cerr << _name << " own input = " << _own_input << " output = " << _own_output << endl;
-
/* don't attempt to set state for a proxied IO that we don't own */
XMLNodeList nlist = node.children();
}
} else {
- error << _("XML node describing an IOProcessor is missing an IO node") << endmsg;
- return -1;
+ /* no input */
}
+
}
if (_own_output) {
if ((prop = node.property ("name")) == 0) {
set_name (_output->name());
}
- }
+ } else {
+ /* no output */
+ }
}
return 0;
return ret;
}
+
+bool
+IOProcessor::feeds (boost::shared_ptr<Route> other) const
+{
+ return _output && _output->connected_to (other->input());
+}