2 Copyright (C) 2002 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_types_h__
21 #define __ardour_types_h__
26 #include <boost/shared_ptr.hpp>
27 #include <sys/types.h>
31 #include <jack/types.h>
32 #include <jack/midiport.h>
34 #include "timecode/bbt_time.h"
35 #include "timecode/time.h"
39 #include "ardour/chan_count.h"
54 typedef jack_default_audio_sample_t Sample;
57 typedef uint32_t layer_t;
58 typedef uint64_t microseconds_t;
59 typedef jack_nframes_t pframes_t;
61 /* Any position measured in audio frames.
62 Assumed to be non-negative but not enforced.
64 typedef int64_t framepos_t;
66 /* Any distance from a given framepos_t.
67 Maybe positive or negative.
69 typedef int64_t frameoffset_t;
71 /* Any count of audio frames.
72 Assumed to be positive but not enforced.
74 typedef int64_t framecnt_t;
76 static const framepos_t max_framepos = INT64_MAX;
77 static const framecnt_t max_framecnt = INT64_MAX;
79 // a set of (time) intervals: first of pair is the offset of the start within the region, second is the offset of the end
80 typedef std::list<std::pair<frameoffset_t, frameoffset_t> > AudioIntervalResult;
81 // associate a set of intervals with regions (e.g. for silence detection)
82 typedef std::map<boost::shared_ptr<ARDOUR::Region>,AudioIntervalResult> AudioIntervalMap;
88 ConfigurationChanged = 0x1,
89 ConnectionsChanged = 0x2
92 IOChange () : type (NoChange) {}
93 IOChange (Type t) : type (t) {}
95 /** channel count of IO before a ConfigurationChanged, if appropriate */
96 ARDOUR::ChanCount before;
97 /** channel count of IO after a ConfigurationChanged, if appropriate */
98 ARDOUR::ChanCount after;
102 OverlapNone, // no overlap
103 OverlapInternal, // the overlap is 100% with the object
104 OverlapStart, // overlap covers start, but ends within
105 OverlapEnd, // overlap begins within and covers end
106 OverlapExternal // overlap extends to (at least) begin+end
109 ARDOUR::OverlapType coverage (framepos_t sa, framepos_t ea,
110 framepos_t sb, framepos_t eb);
112 /* policies for inserting/pasting material where overlaps
116 enum InsertMergePolicy {
117 InsertMergeReject, // no overlaps allowed
118 InsertMergeRelax, // we just don't care about overlaps
119 InsertMergeReplace, // replace old with new
120 InsertMergeTruncateExisting, // shorten existing to avoid overlap
121 InsertMergeTruncateAddition, // shorten new to avoid overlap
122 InsertMergeExtend // extend new (or old) to the range of old+new
125 /** See evoral/Parameter.hpp
127 enum AutomationType {
130 PanAzimuthAutomation,
131 PanElevationAutomation,
133 PanFrontBackAutomation,
139 MidiPgmChangeAutomation,
140 MidiPitchBenderAutomation,
141 MidiChannelPressureAutomation,
142 MidiSystemExclusiveAutomation,
155 std::string auto_state_to_string (AutoState);
156 AutoState string_to_auto_state (std::string);
163 std::string auto_style_to_string (AutoStyle);
164 AutoStyle string_to_auto_style (std::string);
191 AllChannels = 0, ///< Pass through all channel information unmodified
192 FilterChannels, ///< Ignore events on certain channels
193 ForceChannel ///< Force all events to a certain channel
202 enum TimecodeFormat {
225 Timecode::Time timecode;
226 Timecode::BBT_Time bbt;
233 AnyTime() { type = Frames; frames = 0; }
235 bool operator== (AnyTime const & other) const {
236 if (type != other.type) { return false; }
240 return timecode == other.timecode;
242 return bbt == other.bbt;
244 return frames == other.frames;
246 return seconds == other.seconds;
250 bool not_zero() const
254 return timecode.hours != 0 || timecode.minutes != 0 ||
255 timecode.seconds != 0 || timecode.frames != 0;
257 return bbt.bars != 0 || bbt.beats != 0 || bbt.ticks != 0;
271 AudioRange (framepos_t s, framepos_t e, uint32_t i) : start (s), end (e) , id (i) {}
273 framecnt_t length() { return end - start + 1; }
275 bool operator== (const AudioRange& other) const {
276 return start == other.start && end == other.end && id == other.id;
279 bool equal (const AudioRange& other) const {
280 return start == other.start && end == other.end;
283 OverlapType coverage (framepos_t s, framepos_t e) const {
284 return ARDOUR::coverage (start, end, s, e);
289 Timecode::BBT_Time start;
290 Timecode::BBT_Time end;
293 MusicRange (Timecode::BBT_Time& s, Timecode::BBT_Time& e, uint32_t i)
294 : start (s), end (e), id (i) {}
296 bool operator== (const MusicRange& other) const {
297 return start == other.start && end == other.end && id == other.id;
300 bool equal (const MusicRange& other) const {
301 return start == other.start && end == other.end;
306 Slowest = 6.6dB/sec falloff at update rate of 40ms
307 Slow = 6.8dB/sec falloff at update rate of 40ms
312 MeterFalloffSlowest = 1,
313 MeterFalloffSlow = 2,
314 MeterFalloffMedium = 3,
315 MeterFalloffFast = 4,
316 MeterFalloffFaster = 5,
317 MeterFalloffFastest = 6
323 MeterHoldMedium = 100,
351 /** PFL signals come from before pre-fader processors */
352 PFLFromBeforeProcessors,
353 /** PFL signals come pre-fader but after pre-fader processors */
354 PFLFromAfterProcessors
358 /** AFL signals come post-fader and before post-fader processors */
359 AFLFromBeforeProcessors,
360 /** AFL signals come post-fader but after post-fader processors */
361 AFLFromAfterProcessors
377 enum CrossfadeModel {
388 enum ListenPosition {
393 enum AutoConnectOption {
395 AutoConnectPhysical = 0x1,
396 AutoConnectMaster = 0x2
399 struct InterThreadInfo {
400 InterThreadInfo () : done (false), cancel (false), progress (0), thread (0) {}
403 volatile bool cancel;
404 volatile float progress;
414 enum CDMarkerFormat {
431 typedef Sample PeakDatum;
456 enum ShuttleBehaviour {
466 typedef std::vector<boost::shared_ptr<Source> > SourceList;
476 struct TimeFXRequest : public InterThreadInfo {
478 : time_fraction(0), pitch_fraction(0),
479 quick_seek(false), antialias(false), opts(0) {}
481 float pitch_fraction;
486 int opts; // really RubberBandStretcher::Options
489 typedef std::list<framepos_t> AnalysisFeatureList;
491 typedef std::list<boost::shared_ptr<Route> > RouteList;
494 typedef std::vector<boost::shared_ptr<Bundle> > BundleList;
512 struct CleanupReport {
513 std::vector<std::string> paths;
517 enum PositionLockStyle {
522 /** A struct used to describe changes to processors in a route.
523 * This is useful because objects that respond to a change in processors
524 * can optimise what work they do based on details of what has changed.
526 struct RouteProcessorChange {
529 MeterPointChange = 0x1
532 RouteProcessorChange () : type (GeneralChange), meter_visibly_changed (true)
535 RouteProcessorChange (Type t) : type (t), meter_visibly_changed (true)
538 RouteProcessorChange (Type t, bool m) : type (t), meter_visibly_changed (m)
541 /** type of change; "GeneralChange" means anything could have changed */
543 /** true if, when a MeterPointChange has occurred, the change is visible to the user */
544 bool meter_visibly_changed;
548 AutoConnectOption input_ac; /* override the RC config for input auto-connection */
549 AutoConnectOption output_ac; /* override the RC config for output auto-connection */
550 uint32_t master_out_channels; /* how many channels for the master bus */
551 uint32_t requested_physical_in; /* now many of the available physical inputs to consider usable */
552 uint32_t requested_physical_out; /* now many of the available physical inputs to consider usable */
563 } // namespace ARDOUR
566 /* these cover types declared above in this header. See enums.cc
570 std::istream& operator>>(std::istream& o, ARDOUR::SampleFormat& sf);
571 std::istream& operator>>(std::istream& o, ARDOUR::HeaderFormat& sf);
572 std::istream& operator>>(std::istream& o, ARDOUR::AutoConnectOption& sf);
573 std::istream& operator>>(std::istream& o, ARDOUR::EditMode& sf);
574 std::istream& operator>>(std::istream& o, ARDOUR::MonitorModel& sf);
575 std::istream& operator>>(std::istream& o, ARDOUR::PFLPosition& sf);
576 std::istream& operator>>(std::istream& o, ARDOUR::AFLPosition& sf);
577 std::istream& operator>>(std::istream& o, ARDOUR::RemoteModel& sf);
578 std::istream& operator>>(std::istream& o, ARDOUR::ListenPosition& sf);
579 std::istream& operator>>(std::istream& o, ARDOUR::LayerModel& sf);
580 std::istream& operator>>(std::istream& o, ARDOUR::InsertMergePolicy& sf);
581 std::istream& operator>>(std::istream& o, ARDOUR::CrossfadeModel& sf);
582 std::istream& operator>>(std::istream& o, ARDOUR::SyncSource& sf);
583 std::istream& operator>>(std::istream& o, ARDOUR::ShuttleBehaviour& sf);
584 std::istream& operator>>(std::istream& o, ARDOUR::ShuttleUnits& sf);
585 std::istream& operator>>(std::istream& o, ARDOUR::TimecodeFormat& sf);
586 std::istream& operator>>(std::istream& o, ARDOUR::DenormalModel& sf);
587 std::istream& operator>>(std::istream& o, ARDOUR::WaveformScale& sf);
588 std::istream& operator>>(std::istream& o, ARDOUR::WaveformShape& sf);
589 std::istream& operator>>(std::istream& o, ARDOUR::PositionLockStyle& sf);
591 std::ostream& operator<<(std::ostream& o, const ARDOUR::SampleFormat& sf);
592 std::ostream& operator<<(std::ostream& o, const ARDOUR::HeaderFormat& sf);
593 std::ostream& operator<<(std::ostream& o, const ARDOUR::AutoConnectOption& sf);
594 std::ostream& operator<<(std::ostream& o, const ARDOUR::EditMode& sf);
595 std::ostream& operator<<(std::ostream& o, const ARDOUR::MonitorModel& sf);
596 std::ostream& operator<<(std::ostream& o, const ARDOUR::PFLPosition& sf);
597 std::ostream& operator<<(std::ostream& o, const ARDOUR::AFLPosition& sf);
598 std::ostream& operator<<(std::ostream& o, const ARDOUR::RemoteModel& sf);
599 std::ostream& operator<<(std::ostream& o, const ARDOUR::ListenPosition& sf);
600 std::ostream& operator<<(std::ostream& o, const ARDOUR::LayerModel& sf);
601 std::ostream& operator<<(std::ostream& o, const ARDOUR::InsertMergePolicy& sf);
602 std::ostream& operator<<(std::ostream& o, const ARDOUR::CrossfadeModel& sf);
603 std::ostream& operator<<(std::ostream& o, const ARDOUR::SyncSource& sf);
604 std::ostream& operator<<(std::ostream& o, const ARDOUR::ShuttleBehaviour& sf);
605 std::ostream& operator<<(std::ostream& o, const ARDOUR::ShuttleUnits& sf);
606 std::ostream& operator<<(std::ostream& o, const ARDOUR::TimecodeFormat& sf);
607 std::ostream& operator<<(std::ostream& o, const ARDOUR::DenormalModel& sf);
608 std::ostream& operator<<(std::ostream& o, const ARDOUR::WaveformScale& sf);
609 std::ostream& operator<<(std::ostream& o, const ARDOUR::WaveformShape& sf);
610 std::ostream& operator<<(std::ostream& o, const ARDOUR::PositionLockStyle& sf);
612 static inline ARDOUR::framepos_t
613 session_frame_to_track_frame (ARDOUR::framepos_t session_frame, double speed)
615 return (ARDOUR::framepos_t)( (double)session_frame * speed );
618 static inline ARDOUR::framepos_t
619 track_frame_to_session_frame (ARDOUR::framepos_t track_frame, double speed)
621 return (ARDOUR::framepos_t)( (double)track_frame / speed );
624 /* for now, break the rules and use "using" to make this "global" */
626 using ARDOUR::framepos_t;
629 #endif /* __ardour_types_h__ */