annotate plugin/LADSPAPluginInstance.h @ 1287:97f21b03269b 3.0-integration

Tag load diagnostic
author Chris Cannam
date Wed, 23 Nov 2016 14:51:03 +0000
parents a1cd5abcb38b
children 48e9f538e6e9
rev   line source
Chris@49 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@0 2
Chris@0 3 /*
Chris@52 4 Sonic Visualiser
Chris@52 5 An audio file viewer and annotation editor.
Chris@52 6 Centre for Digital Music, Queen Mary, University of London.
Chris@0 7
Chris@52 8 This program is free software; you can redistribute it and/or
Chris@52 9 modify it under the terms of the GNU General Public License as
Chris@52 10 published by the Free Software Foundation; either version 2 of the
Chris@52 11 License, or (at your option) any later version. See the file
Chris@52 12 COPYING included with this distribution for more information.
Chris@0 13 */
Chris@0 14
Chris@0 15 /*
Chris@0 16 This is a modified version of a source file from the
Chris@0 17 Rosegarden MIDI and audio sequencer and notation editor.
Chris@17 18 This file copyright 2000-2006 Chris Cannam and Richard Bown.
Chris@0 19 */
Chris@0 20
Chris@0 21 #ifndef _LADSPAPLUGININSTANCE_H_
Chris@0 22 #define _LADSPAPLUGININSTANCE_H_
Chris@0 23
Chris@0 24 #include <vector>
Chris@0 25 #include <set>
Chris@0 26 #include <QString>
Chris@0 27
Chris@0 28 #include "api/ladspa.h"
Chris@0 29 #include "RealTimePluginInstance.h"
Chris@1039 30 #include "base/BaseTypes.h"
Chris@0 31
Chris@0 32 // LADSPA plugin instance. LADSPA is a variable block size API, but
Chris@0 33 // for one reason and another it's more convenient to use a fixed
Chris@0 34 // block size in this wrapper.
Chris@0 35 //
Chris@0 36 class LADSPAPluginInstance : public RealTimePluginInstance
Chris@0 37 {
Chris@0 38 public:
Chris@0 39 virtual ~LADSPAPluginInstance();
Chris@0 40
Chris@0 41 virtual bool isOK() const { return m_instanceHandles.size() != 0; }
Chris@0 42
Chris@0 43 int getClientId() const { return m_client; }
Chris@237 44 virtual QString getPluginIdentifier() const { return m_identifier; }
Chris@0 45 int getPosition() const { return m_position; }
Chris@0 46
Chris@239 47 virtual std::string getIdentifier() const;
Chris@51 48 virtual std::string getName() const;
Chris@51 49 virtual std::string getDescription() const;
Chris@51 50 virtual std::string getMaker() const;
Chris@51 51 virtual int getPluginVersion() const;
Chris@51 52 virtual std::string getCopyright() const;
Chris@51 53
Chris@1040 54 virtual void run(const RealTime &rt, int count = 0);
Chris@0 55
Chris@1039 56 virtual int getParameterCount() const;
Chris@1039 57 virtual void setParameterValue(int parameter, float value);
Chris@1039 58 virtual float getParameterValue(int parameter) const;
Chris@1039 59 virtual float getParameterDefault(int parameter) const;
Chris@1039 60 virtual int getParameterDisplayHint(int parameter) const;
Chris@51 61
Chris@51 62 virtual ParameterList getParameterDescriptors() const;
Chris@51 63 virtual float getParameter(std::string) const;
Chris@51 64 virtual void setParameter(std::string, float);
Chris@0 65
Chris@1040 66 virtual int getBufferSize() const { return m_blockSize; }
Chris@1040 67 virtual int getAudioInputCount() const { return int(m_instanceCount * m_audioPortsIn.size()); }
Chris@1040 68 virtual int getAudioOutputCount() const { return int(m_instanceCount * m_audioPortsOut.size()); }
Chris@0 69 virtual sample_t **getAudioInputBuffers() { return m_inputBuffers; }
Chris@0 70 virtual sample_t **getAudioOutputBuffers() { return m_outputBuffers; }
Chris@0 71
Chris@1040 72 virtual int getControlOutputCount() const { return int(m_controlPortsOut.size()); }
Chris@1040 73 virtual float getControlOutputValue(int n) const;
Chris@60 74
Chris@0 75 virtual bool isBypassed() const { return m_bypassed; }
Chris@0 76 virtual void setBypassed(bool bypassed) { m_bypassed = bypassed; }
Chris@0 77
Chris@1040 78 virtual sv_frame_t getLatency();
Chris@0 79
Chris@0 80 virtual void silence();
Chris@1040 81 virtual void setIdealChannelCount(int channels); // may re-instantiate
Chris@0 82
Chris@57 83 virtual std::string getType() const { return "LADSPA Real-Time Plugin"; }
Chris@57 84
Chris@0 85 protected:
Chris@0 86 // To be constructed only by LADSPAPluginFactory
Chris@0 87 friend class LADSPAPluginFactory;
Chris@0 88
Chris@0 89 // Constructor that creates the buffers internally
Chris@0 90 //
Chris@0 91 LADSPAPluginInstance(RealTimePluginFactory *factory,
Chris@0 92 int client,
Chris@0 93 QString identifier,
Chris@0 94 int position,
Chris@1040 95 sv_samplerate_t sampleRate,
Chris@1040 96 int blockSize,
Chris@0 97 int idealChannelCount,
Chris@0 98 const LADSPA_Descriptor* descriptor);
Chris@0 99
Chris@0 100 void init(int idealChannelCount = 0);
Chris@1040 101 void instantiate(sv_samplerate_t sampleRate);
Chris@0 102 void cleanup();
Chris@0 103 void activate();
Chris@0 104 void deactivate();
Chris@0 105
Chris@0 106 // Connection of data (and behind the scenes control) ports
Chris@0 107 //
Chris@0 108 void connectPorts();
Chris@0 109
Chris@0 110 int m_client;
Chris@0 111 int m_position;
Chris@0 112 std::vector<LADSPA_Handle> m_instanceHandles;
Chris@1040 113 int m_instanceCount;
Chris@0 114 const LADSPA_Descriptor *m_descriptor;
Chris@0 115
Chris@1039 116 std::vector<std::pair<int, LADSPA_Data*> > m_controlPortsIn;
Chris@1039 117 std::vector<std::pair<int, LADSPA_Data*> > m_controlPortsOut;
Chris@0 118
Chris@0 119 std::vector<int> m_audioPortsIn;
Chris@0 120 std::vector<int> m_audioPortsOut;
Chris@0 121
Chris@1040 122 int m_blockSize;
Chris@0 123 sample_t **m_inputBuffers;
Chris@0 124 sample_t **m_outputBuffers;
Chris@0 125 bool m_ownBuffers;
Chris@1040 126 sv_samplerate_t m_sampleRate;
Chris@0 127 float *m_latencyPort;
Chris@0 128 bool m_run;
Chris@0 129
Chris@0 130 bool m_bypassed;
Chris@0 131 };
Chris@0 132
Chris@0 133 #endif // _LADSPAPLUGININSTANCE_H_
Chris@0 134