Initial backend support for external export encoder
[ardour.git] / libs / ardour / internal_return.cc
1 /*
2     Copyright (C) 2009 Paul Davis
3
4     This program is free software; you can redistribute it and/or modify
5     it under the terms of the GNU General Public License as published by
6     the Free Software Foundation; either version 2 of the License, or
7     (at your option) any later version.
8
9     This program is distributed in the hope that it will be useful,
10     but WITHOUT ANY WARRANTY; without even the implied warranty of
11     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12     GNU General Public License for more details.
13
14     You should have received a copy of the GNU General Public License
15     along with this program; if not, write to the Free Software
16     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17 */
18
19 #include <glibmm/threads.h>
20
21 #include "ardour/internal_return.h"
22 #include "ardour/internal_send.h"
23 #include "ardour/route.h"
24
25 using namespace std;
26 using namespace ARDOUR;
27
28 InternalReturn::InternalReturn (Session& s)
29         : Return (s, true)
30 {
31         _display_to_user = false;
32 }
33
34 void
35 InternalReturn::run (BufferSet& bufs, samplepos_t /*start_sample*/, samplepos_t /*end_sample*/, double /*speed*/, pframes_t nframes, bool)
36 {
37         if (!_active && !_pending_active) {
38                 return;
39         }
40
41         Glib::Threads::Mutex::Lock lm (_sends_mutex, Glib::Threads::TRY_LOCK);
42
43         if (lm.locked ()) {
44                 for (list<InternalSend*>::iterator i = _sends.begin(); i != _sends.end(); ++i) {
45                         if ((*i)->active () && (!(*i)->source_route() || (*i)->source_route()->active())) {
46                                 bufs.merge_from ((*i)->get_buffers(), nframes);
47                         }
48                 }
49         }
50
51         _active = _pending_active;
52 }
53
54 void
55 InternalReturn::add_send (InternalSend* send)
56 {
57         Glib::Threads::Mutex::Lock lm (_sends_mutex);
58         _sends.push_back (send);
59 }
60
61 void
62 InternalReturn::remove_send (InternalSend* send)
63 {
64         Glib::Threads::Mutex::Lock lm (_sends_mutex);
65         _sends.remove (send);
66 }
67
68 void
69 InternalReturn::set_playback_offset (samplecnt_t cnt)
70 {
71         Processor::set_playback_offset (cnt);
72
73         Glib::Threads::Mutex::Lock lm (_sends_mutex); // TODO reader lock
74         for (list<InternalSend*>::iterator i = _sends.begin(); i != _sends.end(); ++i) {
75                 (*i)->set_delay_out (cnt);
76         }
77 }
78
79 XMLNode&
80 InternalReturn::state ()
81 {
82         XMLNode& node (Return::state ());
83         /* override type */
84         node.set_property("type", "intreturn");
85         return node;
86 }
87
88 bool
89 InternalReturn::can_support_io_configuration (const ChanCount& in, ChanCount& out)
90 {
91         out = in;
92         return true;
93 }
94
95 bool
96 InternalReturn::configure_io (ChanCount in, ChanCount out)
97 {
98         IOProcessor::configure_io (in, out);
99         return true;
100 }