2 Copyright (C) 2012 Paul Davis
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.
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.
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.
20 #ifndef __ardour_session_event_h__
21 #define __ardour_session_event_h__
24 #include <boost/function.hpp>
25 #include <boost/shared_ptr.hpp>
28 #include "pbd/ringbuffer.h"
29 #include "pbd/event_loop.h"
31 #include "ardour/libardour_visibility.h"
32 #include "ardour/types.h"
36 class TransportMaster;
39 class LIBARDOUR_API SessionEvent {
56 AdjustPlaybackBuffering,
57 AdjustCaptureBuffering,
58 SetTimecodeTransmission,
62 /* only one of each of these events can be queued at any one time */
77 samplepos_t action_sample;
78 samplepos_t target_sample;
84 samplepos_t target2_sample;
89 bool second_yes_or_no;
97 /* 5 members to handle a multi-group event handled in RT context */
99 typedef boost::function<void (SessionEvent*)> RTeventCallback;
101 boost::shared_ptr<ControlList> controls; /* apply to */
102 boost::shared_ptr<RouteList> routes; /* apply to */
103 boost::function<void (void)> rt_slot; /* what to call in RT context */
104 RTeventCallback rt_return; /* called after rt_slot, with this event as an argument */
105 PBD::EventLoop* event_loop;
107 std::list<AudioRange> audio_range;
108 std::list<MusicRange> music_range;
110 boost::shared_ptr<Region> region;
111 boost::shared_ptr<TransportMaster> transport_master;
113 SessionEvent (Type t, Action a, samplepos_t when, samplepos_t where, double spd, bool yn = false, bool yn2 = false, bool yn3 = false);
115 void set_ptr (void* p) {
119 bool before (const SessionEvent& other) const {
120 return action_sample < other.action_sample;
123 bool after (const SessionEvent& other) const {
124 return action_sample > other.action_sample;
127 static bool compare (const SessionEvent *e1, const SessionEvent *e2) {
128 return e1->before (*e2);
131 void* operator new (size_t);
132 void operator delete (void *ptr, size_t /*size*/);
134 static const samplepos_t Immediate = -1;
136 static bool has_per_thread_pool ();
137 static void create_per_thread_pool (const std::string& n, uint32_t nitems);
138 static void init_event_pool ();
140 CrossThreadPool* event_pool() const { return own_pool; }
143 static PerThreadPool* pool;
144 CrossThreadPool* own_pool;
149 class SessionEventManager {
151 SessionEventManager () : pending_events (2048),
152 auto_loop_event(0), punch_out_event(0), punch_in_event(0) {}
153 virtual ~SessionEventManager() {}
155 virtual void queue_event (SessionEvent *ev) = 0;
156 void clear_events (SessionEvent::Type type);
157 void clear_events (SessionEvent::Type type, boost::function<void (void)> after);
160 PBD::RingBuffer<SessionEvent*> pending_events;
161 typedef std::list<SessionEvent *> Events;
163 Events immediate_events;
164 Events::iterator next_event;
166 Glib::Threads::Mutex rb_write_lock;
168 /* there can only ever be one of each of these */
170 SessionEvent *auto_loop_event;
171 SessionEvent *punch_out_event;
172 SessionEvent *punch_in_event;
174 void dump_events () const;
175 void merge_event (SessionEvent*);
176 void replace_event (SessionEvent::Type, samplepos_t action_sample, samplepos_t target = 0);
177 bool _replace_event (SessionEvent*);
178 bool _remove_event (SessionEvent *);
179 void _clear_event_type (SessionEvent::Type);
181 void add_event (samplepos_t action_sample, SessionEvent::Type type, samplepos_t target_sample = 0);
182 void remove_event (samplepos_t sample, SessionEvent::Type type);
184 virtual void process_event(SessionEvent*) = 0;
185 virtual void set_next_event () = 0;
190 #endif /* __ardour_session_event_h__ */