X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Ftypes.h;h=17a86fc6c571399f8017df45f4f5aa31457e06ea;hb=b45a3c816484346f44cd65341fade0850670c2bb;hp=50a96030b19ac05ec955fd2c47c4f006adde0c37;hpb=658bb3ccd43658de18fbd43cd91a8e66650e27a7;p=ardour.git diff --git a/libs/ardour/ardour/types.h b/libs/ardour/ardour/types.h index 50a96030b1..17a86fc6c5 100644 --- a/libs/ardour/ardour/types.h +++ b/libs/ardour/ardour/types.h @@ -38,6 +38,7 @@ #include "evoral/Range.hpp" #include "ardour/chan_count.h" +#include "ardour/plugin_types.h" #include @@ -51,6 +52,9 @@ namespace ARDOUR { class AudioSource; class Route; class Region; + class Stripable; + class VCA; + class AutomationControl; typedef float Sample; typedef float pan_t; @@ -107,15 +111,22 @@ namespace ARDOUR { */ enum InsertMergePolicy { - InsertMergeReject, // no overlaps allowed - InsertMergeRelax, // we just don't care about overlaps - InsertMergeReplace, // replace old with new - InsertMergeTruncateExisting, // shorten existing to avoid overlap - InsertMergeTruncateAddition, // shorten new to avoid overlap - InsertMergeExtend // extend new (or old) to the range of old+new + InsertMergeReject, ///< no overlaps allowed + InsertMergeRelax, ///< we just don't care about overlaps + InsertMergeReplace, ///< replace old with new + InsertMergeTruncateExisting, ///< shorten existing to avoid overlap + InsertMergeTruncateAddition, ///< shorten new to avoid overlap + InsertMergeExtend ///< extend new (or old) to the range of old+new }; /** See evoral/Parameter.hpp + * + * When you add things here, you REALLY SHOULD add a case clause to + * the constructor of ParameterDescriptor, unless the Controllables + * that the enum refers to are completely standard (0-1.0 range, 0.0 as + * normal, non-toggled, non-enumerated). Anything else needs to be + * added there so that things that try to represent them can do so + * with as much information as possible. */ enum AutomationType { NullAutomation, @@ -126,17 +137,39 @@ namespace ARDOUR { PanFrontBackAutomation, PanLFEAutomation, PluginAutomation, + PluginPropertyAutomation, SoloAutomation, + SoloIsolateAutomation, + SoloSafeAutomation, MuteAutomation, MidiCCAutomation, MidiPgmChangeAutomation, MidiPitchBenderAutomation, MidiChannelPressureAutomation, + MidiNotePressureAutomation, MidiSystemExclusiveAutomation, FadeInAutomation, FadeOutAutomation, EnvelopeAutomation, - RecEnableAutomation + RecEnableAutomation, + RecSafeAutomation, + TrimAutomation, + PhaseAutomation, + MonitoringAutomation, + EQGain, + EQFrequency, + EQQ, + EQShape, + EQHPF, + EQEnable, + CompThreshold, + CompSpeed, + CompMode, + CompMakeup, + CompRedux, + CompEnable, + BusSendLevel, + BusSendEnable, }; enum AutoState { @@ -177,18 +210,20 @@ namespace ARDOUR { }; enum MeterType { - MeterMaxSignal = 0x001, - MeterMaxPeak = 0x002, - MeterPeak = 0x004, - MeterKrms = 0x008, - MeterK20 = 0x010, - MeterK14 = 0x020, - MeterIEC1DIN = 0x040, - MeterIEC1NOR = 0x080, - MeterIEC2BBC = 0x100, - MeterIEC2EBU = 0x200, - MeterVU = 0x400, - MeterK12 = 0x800 + MeterMaxSignal = 0x0001, + MeterMaxPeak = 0x0002, + MeterPeak = 0x0004, + MeterKrms = 0x0008, + MeterK20 = 0x0010, + MeterK14 = 0x0020, + MeterIEC1DIN = 0x0040, + MeterIEC1NOR = 0x0080, + MeterIEC2BBC = 0x0100, + MeterIEC2EBU = 0x0200, + MeterVU = 0x0400, + MeterK12 = 0x0800, + MeterPeak0dB = 0x1000, + MeterMCP = 0x2000 }; enum TrackMode { @@ -214,6 +249,14 @@ namespace ARDOUR { TrackColor }; + enum RoundMode { + RoundDownMaybe = -2, ///< Round down only if necessary + RoundDownAlways = -1, ///< Always round down, even if on a division + RoundNearest = 0, ///< Round to nearest + RoundUpAlways = 1, ///< Always round up, even if on a division + RoundUpMaybe = 2 ///< Round up only if necessary + }; + class AnyTime { public: enum Type { @@ -265,12 +308,32 @@ namespace ARDOUR { return seconds != 0; } - /* NOTREACHED */ - assert (false); + abort(); /* NOTREACHED */ return false; } }; + /* used for translating audio frames to an exact musical position using a note divisor. + an exact musical position almost never falls exactly on an audio frame, but for sub-sample + musical accuracy we need to derive exact musical locations from a frame position + the division follows TempoMap::exact_beat_at_frame(). + division + -1 musical location is the bar closest to frame + 0 musical location is the musical position of the frame + 1 musical location is the BBT beat closest to frame + n musical location is the quarter-note division n closest to frame + */ + struct MusicFrame { + framepos_t frame; + int32_t division; + + MusicFrame (framepos_t f, int32_t d) : frame (f), division (d) {} + + void set (framepos_t f, int32_t d) {frame = f; division = d; } + + MusicFrame operator- (MusicFrame other) { return MusicFrame (frame - other.frame, 0); } + }; + /* XXX: slightly unfortunate that there is this and Evoral::Range<>, but this has a uint32_t id which Evoral::Range<> does not. */ @@ -281,7 +344,7 @@ namespace ARDOUR { AudioRange (framepos_t s, framepos_t e, uint32_t i) : start (s), end (e) , id (i) {} - framecnt_t length() { return end - start + 1; } + framecnt_t length() const { return end - start + 1; } bool operator== (const AudioRange& other) const { return start == other.start && end == other.end && id == other.id; @@ -340,9 +403,21 @@ namespace ARDOUR { enum EditMode { Slide, Splice, + Ripple, Lock }; + enum RegionSelectionAfterSplit { + None = 0, + NewlyCreatedLeft = 1, // bit 0 + NewlyCreatedRight = 2, // bit 1 + NewlyCreatedBoth = 3, + Existing = 4, // bit 2 + ExistingNewlyCreatedLeft = 5, + ExistingNewlyCreatedRight = 6, + ExistingNewlyCreatedBoth = 7 + }; + enum RegionPoint { Start, End, @@ -413,20 +488,9 @@ namespace ARDOUR { DenormalFTZDAZ }; - enum RemoteModel { - UserOrdered, - MixerOrdered - }; - - enum CrossfadeModel { - FullCrossfade, - ShortCrossfade - }; - - enum CrossfadeChoice { - RegionFades, - ConstantPowerMinus3dB, - ConstantPowerMinus6dB, + enum LayerModel { + LaterHigher, + Manual }; enum ListenPosition { @@ -440,16 +504,24 @@ namespace ARDOUR { AutoConnectMaster = 0x2 }; + enum TracksAutoNamingRule { + UseDefaultNames = 0x1, + NameAfterDriver = 0x2 + }; + enum SampleFormat { FormatFloat = 0, FormatInt24, FormatInt16 }; + int format_data_width (ARDOUR::SampleFormat); + enum CDMarkerFormat { CDMarkerNone, CDMarkerCUE, - CDMarkerTOC + CDMarkerTOC, + MP4Chaps }; enum HeaderFormat { @@ -459,7 +531,9 @@ namespace ARDOUR { CAF, AIFF, iXML, - RF64 + RF64, + RF64_WAV, + MBWF, }; struct PeakData { @@ -469,14 +543,6 @@ namespace ARDOUR { PeakDatum max; }; - enum PluginType { - AudioUnit, - LADSPA, - LV2, - Windows_VST, - LXVST, - }; - enum RunContext { ButlerContext = 0, TransportContext, @@ -518,7 +584,12 @@ namespace ARDOUR { typedef std::list AnalysisFeatureList; typedef std::list > RouteList; + typedef std::list > StripableList; typedef std::list > WeakRouteList; + typedef std::list > WeakStripableList; + typedef std::list > ControlList; + + typedef std::list > VCAList; class Bundle; typedef std::vector > BundleList; @@ -550,7 +621,8 @@ namespace ARDOUR { struct RouteProcessorChange { enum Type { GeneralChange = 0x0, - MeterPointChange = 0x1 + MeterPointChange = 0x1, + RealTimeChange = 0x2 }; RouteProcessorChange () : type (GeneralChange), meter_visibly_changed (true) @@ -589,8 +661,8 @@ namespace ARDOUR { this equality cannot be assumed. */ TransportStopped = 0, - TransportRolling = 1, - TransportLooping = 2, + TransportRolling = 1, + TransportLooping = 2, TransportStarting = 3, }; @@ -598,11 +670,22 @@ namespace ARDOUR { /* these values happen to match the constants used by JACK but this equality cannot be assumed. */ - IsInput = 0x1, + IsInput = 0x1, IsOutput = 0x2, IsPhysical = 0x4, CanMonitor = 0x8, - IsTerminal = 0x10 + IsTerminal = 0x10, + + /* non-JACK related flags */ + Hidden = 0x20, + Shadow = 0x40 + }; + + enum MidiPortFlags { + MidiPortMusic = 0x1, + MidiPortControl = 0x2, + MidiPortSelection = 0x4, + MidiPortVirtual = 0x8 }; struct LatencyRange { @@ -610,69 +693,66 @@ namespace ARDOUR { uint32_t max; //< samples }; -} // namespace ARDOUR + enum BufferingPreset { + Small, + Medium, + Large, + Custom, + }; + + enum AutoReturnTarget { + LastLocate = 0x1, + RangeSelectionStart = 0x2, + Loop = 0x4, + RegionSelectionStart = 0x8, + }; + enum PlaylistDisposition { + CopyPlaylist, + NewPlaylist, + SharePlaylist + }; -/* these cover types declared above in this header. See enums.cc - for the definitions. -*/ + enum MidiTrackNameSource { + SMFTrackNumber, + SMFTrackName, + SMFInstrumentName + }; -std::istream& operator>>(std::istream& o, ARDOUR::SampleFormat& sf); -std::istream& operator>>(std::istream& o, ARDOUR::HeaderFormat& sf); -std::istream& operator>>(std::istream& o, ARDOUR::AutoConnectOption& sf); -std::istream& operator>>(std::istream& o, ARDOUR::EditMode& sf); -std::istream& operator>>(std::istream& o, ARDOUR::MonitorModel& sf); -std::istream& operator>>(std::istream& o, ARDOUR::VUMeterStandard& sf); -std::istream& operator>>(std::istream& o, ARDOUR::MeterLineUp& sf); -std::istream& operator>>(std::istream& o, ARDOUR::PFLPosition& sf); -std::istream& operator>>(std::istream& o, ARDOUR::AFLPosition& sf); -std::istream& operator>>(std::istream& o, ARDOUR::RemoteModel& sf); -std::istream& operator>>(std::istream& o, ARDOUR::ListenPosition& sf); -std::istream& operator>>(std::istream& o, ARDOUR::InsertMergePolicy& sf); -std::istream& operator>>(std::istream& o, ARDOUR::CrossfadeModel& sf); -std::istream& operator>>(std::istream& o, ARDOUR::CrossfadeChoice& sf); -std::istream& operator>>(std::istream& o, ARDOUR::SyncSource& sf); -std::istream& operator>>(std::istream& o, ARDOUR::ShuttleBehaviour& sf); -std::istream& operator>>(std::istream& o, ARDOUR::ShuttleUnits& sf); -std::istream& operator>>(std::istream& o, Timecode::TimecodeFormat& sf); -std::istream& operator>>(std::istream& o, ARDOUR::DenormalModel& sf); -std::istream& operator>>(std::istream& o, ARDOUR::WaveformScale& sf); -std::istream& operator>>(std::istream& o, ARDOUR::WaveformShape& sf); -std::istream& operator>>(std::istream& o, ARDOUR::PositionLockStyle& sf); - -std::ostream& operator<<(std::ostream& o, const ARDOUR::SampleFormat& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::HeaderFormat& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::AutoConnectOption& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::EditMode& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::MonitorModel& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::VUMeterStandard& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::MeterLineUp& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::PFLPosition& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::AFLPosition& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::RemoteModel& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::ListenPosition& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::InsertMergePolicy& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::CrossfadeModel& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::CrossfadeChoice& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::SyncSource& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::ShuttleBehaviour& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::ShuttleUnits& sf); -std::ostream& operator<<(std::ostream& o, const Timecode::TimecodeFormat& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::DenormalModel& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::WaveformScale& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::WaveformShape& sf); -std::ostream& operator<<(std::ostream& o, const ARDOUR::PositionLockStyle& sf); + enum MidiTempoMapDisposition { + SMFTempoIgnore, + SMFTempoUse, + }; + +} // namespace ARDOUR static inline ARDOUR::framepos_t session_frame_to_track_frame (ARDOUR::framepos_t session_frame, double speed) { - return (ARDOUR::framepos_t) ((long double) session_frame * (long double) speed); + long double result = (long double) session_frame * (long double) speed; + + if (result >= (long double) ARDOUR::max_framepos) { + return ARDOUR::max_framepos; + } else if (result <= (long double) (ARDOUR::max_framepos) * (ARDOUR::framepos_t)(-1)) { + return (ARDOUR::max_framepos * (ARDOUR::framepos_t)(-1)); + } else { + return result; + } } static inline ARDOUR::framepos_t track_frame_to_session_frame (ARDOUR::framepos_t track_frame, double speed) { - return (ARDOUR::framepos_t) ((long double) track_frame / (long double) speed); + /* NB - do we need a check for speed == 0 ??? */ + long double result = (long double) track_frame / (long double) speed; + + if (result >= (long double) ARDOUR::max_framepos) { + return ARDOUR::max_framepos; + } else if (result <= (long double) (ARDOUR::max_framepos) * (ARDOUR::framepos_t)(-1)) { + return (ARDOUR::max_framepos * (ARDOUR::framepos_t)(-1)); + } else { + return result; + } } /* for now, break the rules and use "using" to make this "global" */ @@ -681,4 +761,3 @@ using ARDOUR::framepos_t; #endif /* __ardour_types_h__ */ -