X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Fprocessor.h;h=85d466a169265434d859ba44da3aa4a7343d727e;hb=c96ec968c7bb4b1d7c358f522a49b0685c022920;hp=a07c9dcfafb24979b3278751098eecb016e9eab1;hpb=50dd880d7e75b49e7c80c79f32165a756839651c;p=ardour.git diff --git a/libs/ardour/ardour/processor.h b/libs/ardour/ardour/processor.h index a07c9dcfaf..85d466a169 100644 --- a/libs/ardour/ardour/processor.h +++ b/libs/ardour/ardour/processor.h @@ -26,13 +26,13 @@ #include "pbd/statefuldestructible.h" - #include "ardour/ardour.h" -#include "ardour/automatable_controls.h" #include "ardour/buffer_set.h" #include "ardour/latent.h" #include "ardour/session_object.h" +#include "ardour/libardour_visibility.h" #include "ardour/types.h" +#include "ardour/automatable.h" class XMLNode; @@ -41,15 +41,14 @@ namespace ARDOUR { class Session; class Route; -/* A mixer strip element - plugin, send, meter, etc. - */ -class Processor : public SessionObject, public AutomatableControls, public Latent +/** A mixer strip element - plugin, send, meter, etc */ +class LIBARDOUR_API Processor : public SessionObject, public Automatable, public Latent { public: static const std::string state_node_name; Processor(Session&, const std::string& name); - Processor(Session&, const XMLNode& node); + Processor (const Processor& other); virtual ~Processor() { } @@ -60,32 +59,44 @@ class Processor : public SessionObject, public AutomatableControls, public Laten bool active () const { return _pending_active; } + virtual bool does_routing() const { return false; } + bool get_next_ab_is_active () const { return _next_ab_is_active; } void set_next_ab_is_active (bool yn) { _next_ab_is_active = yn; } - virtual nframes_t signal_latency() const { return 0; } - - virtual void transport_stopped (sframes_t /*frame*/) {} + virtual framecnt_t signal_latency() const { return 0; } - virtual void set_block_size (nframes_t /*nframes*/) {} + virtual int set_block_size (pframes_t /*nframes*/) { return 0; } + virtual bool requires_fixed_sized_buffers() const { return false; } - /** @param result_required true if, on return from this method, bufs is required to contain valid data; - * if false, the method need not bother writing to bufs if it doesn't want to. - */ - virtual void run (BufferSet& /*bufs*/, sframes_t /*start_frame*/, sframes_t /*end_frame*/, nframes_t /*nframes*/, bool result_required) {} - virtual void silence (nframes_t /*nframes*/) {} + /** @param result_required true if, on return from this method, @a bufs is required to contain valid data; + * if false, the method need not bother writing to @a bufs if it doesn't want to. + */ + virtual void run (BufferSet& /*bufs*/, framepos_t /*start_frame*/, framepos_t /*end_frame*/, pframes_t /*nframes*/, bool /*result_required*/) {} + virtual void silence (framecnt_t /*nframes*/) {} virtual void activate () { _pending_active = true; ActiveChanged(); } virtual void deactivate () { _pending_active = false; ActiveChanged(); } + virtual void flush() {} virtual bool configure_io (ChanCount in, ChanCount out); /* Derived classes should override these, or processor appears as an in-place pass-through */ - virtual bool can_support_io_configuration (const ChanCount& in, ChanCount& out) const = 0; + virtual bool can_support_io_configuration (const ChanCount& in, ChanCount& out) = 0; virtual ChanCount input_streams () const { return _configured_input; } virtual ChanCount output_streams() const { return _configured_output; } + virtual void realtime_handle_transport_stopped () {} + virtual void realtime_locate () {} + + /* most processors won't care about this, but plugins that + receive MIDI or similar data from an input source that + may suddenly go "quiet" because of monitoring changes + need to know about it. + */ + virtual void monitoring_changed() {} + /* note: derived classes should implement state(), NOT get_state(), to allow us to merge C++ inheritance and XML lack-of-inheritance reasonably smoothly. @@ -94,27 +105,31 @@ class Processor : public SessionObject, public AutomatableControls, public Laten virtual XMLNode& state (bool full); XMLNode& get_state (void); int set_state (const XMLNode&, int version); - - void *get_gui () const { return _gui; } - void set_gui (void *p) { _gui = p; } - static PBD::Signal1 ProcessorCreated; + void set_pre_fader (bool); PBD::Signal0 ActiveChanged; PBD::Signal2 ConfigurationChanged; + void set_ui (void*); + void* get_ui () const { return _ui_pointer; } + + void set_owner (SessionObject*); + SessionObject* owner() const; + protected: + virtual int set_state_2X (const XMLNode&, int version); + int _pending_active; bool _active; bool _next_ab_is_active; bool _configured; ChanCount _configured_input; ChanCount _configured_output; - void* _gui; /* generic, we don't know or care what this is */ - bool _display_to_user; - -private: - int set_state_2X (const XMLNode&, int version); + bool _display_to_user; + bool _pre_fader; ///< true if this processor is currently placed before the Amp, otherwise false + void* _ui_pointer; + SessionObject* _owner; }; } // namespace ARDOUR