/* Copyright (C) 2016 Paul Davis This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include "ardour/audioengine.h" #include "ardour/record_enable_control.h" #include "pbd/i18n.h" using namespace ARDOUR; using namespace PBD; RecordEnableControl::RecordEnableControl (Session& session, std::string const & name, Recordable& r) : SlavableAutomationControl (session, RecEnableAutomation, ParameterDescriptor (RecEnableAutomation), boost::shared_ptr(new AutomationList(Evoral::Parameter(RecEnableAutomation))), name) , _recordable (r) { _list->set_interpolation(Evoral::ControlList::Discrete); /* record-enable changes must be synchronized by the process cycle */ set_flags (Controllable::Flag (flags() | Controllable::RealTime)); } void RecordEnableControl::set_value (double val, Controllable::GroupControlDisposition gcd) { /* Because we are marked as a RealTime control, this will queue up the control change to be executed in a realtime context. */ SlavableAutomationControl::set_value (val, gcd); } void RecordEnableControl::actually_set_value (double val, Controllable::GroupControlDisposition gcd) { if (val && !_recordable.can_be_record_enabled()) { std::cerr << "rec-enable not allowed\n"; return; } SlavableAutomationControl::actually_set_value (val, gcd); } void RecordEnableControl::do_pre_realtime_queue_stuff (double newval) { /* do the non-RT part of rec-enabling first - the RT part will be done * on the next process cycle. This does mean that theoretically we are * doing things provisionally on the assumption that the rec-enable * change will work, but this had better be a solid assumption for * other reasons. * * this is guaranteed to be called from a non-process thread. */ if (_recordable.prep_record_enabled (newval)) { /* failed */ std::cerr << "Prep rec-enable failed\n"; } }