Remove frame conversion for MidiRegionView::note_in_region_range(), speed up tempo...
[ardour.git] / libs / ardour / ardour / audio_unit.h
index f36e89073bb53cd82e38c5f450cb2c67d9d2cb1e..cabc78842e35abee666cfc3e0b5b82256783df95 100644 (file)
@@ -34,7 +34,7 @@
 
 #include <AudioUnit/AudioUnit.h>
 #include <AudioUnit/AudioUnitProperties.h>
-#include "appleutility/AUParamInfo.h"
+#include "AUParamInfo.h"
 
 #include <boost/shared_ptr.hpp>
 
@@ -48,17 +48,16 @@ namespace ARDOUR {
 class AudioEngine;
 class Session;
 
-struct AUParameterDescriptor : public Plugin::ParameterDescriptor {
+struct LIBARDOUR_API AUParameterDescriptor : public ParameterDescriptor {
        // additional fields to make operations more efficient
        AudioUnitParameterID id;
        AudioUnitScope scope;
        AudioUnitElement element;
-       float default_value;
        bool automatable;
-       AudioUnitParameterUnit unit;
+       AudioUnitParameterUnit au_unit;
 };
 
-class AUPlugin : public ARDOUR::Plugin
+class LIBARDOUR_API AUPlugin : public ARDOUR::Plugin
 {
   public:
        AUPlugin (AudioEngine& engine, Session& session, boost::shared_ptr<CAComponent> comp);
@@ -75,6 +74,8 @@ class AUPlugin : public ARDOUR::Plugin
        void set_parameter (uint32_t which, float val);
        float get_parameter (uint32_t which) const;
 
+       PluginOutputConfiguration possible_output () const { return _output_configs; }
+
        int get_parameter_descriptor (uint32_t which, ParameterDescriptor&) const;
        uint32_t nth_parameter (uint32_t which, bool& ok) const;
        void activate ();
@@ -83,10 +84,12 @@ class AUPlugin : public ARDOUR::Plugin
        int set_block_size (pframes_t nframes);
 
        int connect_and_run (BufferSet& bufs,
-                            ChanMapping in, ChanMapping out,
-                            pframes_t nframes, framecnt_t offset);
+                       framepos_t start, framepos_t end, double speed,
+                       ChanMapping in, ChanMapping out,
+                       pframes_t nframes, framecnt_t offset);
        std::set<Evoral::Parameter> automatable() const;
        std::string describe_parameter (Evoral::Parameter);
+       IOPortDescription describe_io_port (DataType dt, bool input, uint32_t id) const;
        std::string state_node_name () const { return "audiounit"; }
        void print_parameter (uint32_t, char*, uint32_t len) const;
 
@@ -95,16 +98,18 @@ class AUPlugin : public ARDOUR::Plugin
        bool parameter_is_input (uint32_t) const;
        bool parameter_is_output (uint32_t) const;
 
+       void set_info (PluginInfoPtr);
+
        int set_state(const XMLNode& node, int);
 
-       PresetRecord save_preset (std::string name);
        bool load_preset (PresetRecord);
        std::string current_preset() const;
 
        bool has_editor () const;
 
-       bool reconfigurable_io() const { return true; }
-       bool can_support_io_configuration (const ChanCount& in, ChanCount& out) const;
+       bool can_support_io_configuration (const ChanCount& in, ChanCount& out, ChanCount* imprecise);
+       ChanCount output_streams() const;
+       ChanCount input_streams() const;
        bool configure_io (ChanCount in, ChanCount out);
        bool requires_fixed_size_buffers() const;
 
@@ -140,6 +145,21 @@ class AUPlugin : public ARDOUR::Plugin
 
        static std::string maybe_fix_broken_au_id (const std::string&);
 
+        /* this MUST be called from thread in which you want to receive notifications
+          about parameter changes.
+       */
+       int create_parameter_listener (AUEventListenerProc callback, void *arg, float interval_secs);
+        /* these can be called from any thread but SHOULD be called from the same thread
+          that will receive parameter change notifications.
+       */
+       int listen_to_parameter (uint32_t param_id);
+       int end_listen_to_parameter (uint32_t param_id);
+
+
+  protected:
+       std::string do_save_preset (std::string name);
+       void do_remove_preset (std::string);
+
   private:
        void find_presets ();
 
@@ -152,10 +172,13 @@ class AUPlugin : public ARDOUR::Plugin
        std::vector<std::pair<int,int> > io_configs;
        pframes_t _current_block_size;
        framecnt_t _last_nframes;
+       framepos_t _transport_frame;
+       framepos_t _transport_speed;
        bool _requires_fixed_size_buffers;
        AudioBufferList* buffers;
        bool _has_midi_input;
        bool _has_midi_output;
+       PluginOutputConfiguration _output_configs;
 
        /* despite all the cool work that apple did on their AU preset
           system, they left factory presets and user presets as two
@@ -174,42 +197,62 @@ class AUPlugin : public ARDOUR::Plugin
        UInt32 output_elements;
        UInt32 input_elements;
 
-       int set_output_format (AudioStreamBasicDescription&);
-       int set_input_format (AudioStreamBasicDescription&);
-       int set_stream_format (int scope, uint32_t cnt, AudioStreamBasicDescription&);
+       bool variable_inputs;
+       bool variable_outputs;
+
+       uint32_t configured_input_busses;
+       uint32_t configured_output_busses;
+
+       uint32_t *bus_inputs;
+       uint32_t *bus_outputs;
+       std::vector <std::string> _bus_name_in;
+       std::vector <std::string> _bus_name_out;
+
+       int set_stream_format (int scope, uint32_t bus, AudioStreamBasicDescription&);
        void discover_parameters ();
        void add_state (XMLNode *) const;
 
-       std::vector<std::pair<uint32_t, uint32_t> > parameter_map;
-       uint32_t current_maxbuf;
-       framecnt_t current_offset;
-       framecnt_t cb_offset;
-       BufferSet* current_buffers;
+       typedef std::map<uint32_t, uint32_t> ParameterMap;
+       ParameterMap parameter_map;
+       uint32_t   input_maxbuf;
+       framecnt_t input_offset;
+       framecnt_t *cb_offsets;
+       BufferSet* input_buffers;
+       ChanMapping * input_map;
        framecnt_t frames_processed;
+       uint32_t   audio_input_cnt;
 
        std::vector<AUParameterDescriptor> descriptors;
+       AUEventListenerRef _parameter_listener;
+       void * _parameter_listener_arg;
        void init ();
 
        void discover_factory_presets ();
 
-       bool      last_transport_rolling;
-       float     last_transport_speed;
+       framepos_t transport_frame;
+       float      transport_speed;
+       float      last_transport_speed;
+
+       static void _parameter_change_listener (void* /*arg*/, void* /*src*/, const AudioUnitEvent* event, UInt64 host_time, Float32 new_value);
+       void parameter_change_listener (void* /*arg*/, void* /*src*/, const AudioUnitEvent* event, UInt64 host_time, Float32 new_value);
 };
 
 typedef boost::shared_ptr<AUPlugin> AUPluginPtr;
 
-struct AUPluginCachedInfo {
+struct LIBARDOUR_API AUPluginCachedInfo {
        std::vector<std::pair<int,int> > io_configs;
 };
 
-class AUPluginInfo : public PluginInfo {
+class LIBARDOUR_API AUPluginInfo : public PluginInfo {
   public:
         AUPluginInfo (boost::shared_ptr<CAComponentDescription>);
        ~AUPluginInfo ();
 
        PluginPtr load (Session& session);
 
-       bool needs_midi_input ();
+       std::vector<Plugin::PresetRecord> get_presets (bool user_only) const;
+
+       bool needs_midi_input () const;
        bool is_effect () const;
        bool is_effect_without_midi_input () const;
        bool is_effect_with_midi_input () const;
@@ -217,8 +260,11 @@ class AUPluginInfo : public PluginInfo {
 
        AUPluginCachedInfo cache;
 
-       static PluginInfoList* discover ();
-       static void get_names (CAComponentDescription&, std::string& name, std::string& maker);
+       bool reconfigurable_io() const { return true; }
+
+       static void clear_cache ();
+       static PluginInfoList* discover (bool scan_only);
+       static bool au_get_crashlog (std::string &msg);
        static std::string stringify_descriptor (const CAComponentDescription&);
 
        static int load_cached_info ();
@@ -226,6 +272,12 @@ class AUPluginInfo : public PluginInfo {
   private:
        boost::shared_ptr<CAComponentDescription> descriptor;
        UInt32 version;
+       static FILE * _crashlog_fd;
+       static bool _scan_only;
+
+       static void au_start_crashlog (void);
+       static void au_remove_crashlog (void);
+       static void au_crashlog (std::string);
 
        static void discover_music (PluginInfoList&);
        static void discover_fx (PluginInfoList&);
@@ -237,7 +289,7 @@ class AUPluginInfo : public PluginInfo {
        typedef std::map<std::string,AUPluginCachedInfo> CachedInfoMap;
        static CachedInfoMap cached_info;
 
-       static bool cached_io_configuration (const std::string&, UInt32, CAComponent&, AUPluginCachedInfo&, const std::string& name);
+       static int cached_io_configuration (const std::string&, UInt32, CAComponent&, AUPluginCachedInfo&, const std::string& name);
        static void add_cached_info (const std::string&, AUPluginCachedInfo&);
        static void save_cached_info ();
 };