lv2 variant works in Ardour
This commit is contained in:
parent
752f894cbd
commit
23ef788b81
@ -32,8 +32,7 @@
|
|||||||
|
|
||||||
|
|
||||||
enum Parameters {
|
enum Parameters {
|
||||||
program,
|
paramProg,
|
||||||
mix,
|
|
||||||
kParameterCount
|
kParameterCount
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
|
|
||||||
START_NAMESPACE_DISTRHO
|
START_NAMESPACE_DISTRHO
|
||||||
|
|
||||||
BarrVerb::BarrVerb() : Plugin(kParameterCount, 64, 0) { // two parameters, one program, no states
|
BarrVerb::BarrVerb() : Plugin(kParameterCount, 64, 0) { // one parameter, 64 programs, no states
|
||||||
lowpass = new float[getBufferSize()];
|
lowpass = new float[getBufferSize()];
|
||||||
ram = new int16_t[16384];
|
ram = new int16_t[16384];
|
||||||
|
|
||||||
@ -77,6 +77,31 @@ BarrVerb::BarrVerb() : Plugin(kParameterCount, 64, 0) { // two parameters, one
|
|||||||
|
|
||||||
// Initialisation functions
|
// Initialisation functions
|
||||||
|
|
||||||
|
void BarrVerb::initParameter(uint32_t index, Parameter ¶meter) {
|
||||||
|
if (index == paramProgram) {
|
||||||
|
parameter.hints = kParameterIsAutomatable | kParameterIsInteger;
|
||||||
|
parameter.name = "Program";
|
||||||
|
parameter.symbol = "program";
|
||||||
|
parameter.ranges.def = 20.0f;
|
||||||
|
parameter.ranges.min = 1.0f;
|
||||||
|
parameter.ranges.max = 64.0f;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void BarrVerb::setParameterValue(uint32_t index, float value) {
|
||||||
|
if (index == paramProgram) {
|
||||||
|
program = value;
|
||||||
|
prog_offset = (((int)value-1) & 0x3f) << 7;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
float BarrVerb::getParameterValue(uint32_t index) const {
|
||||||
|
if (index == paramProgram) {
|
||||||
|
return program;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
void BarrVerb::initAudioPort(bool input, uint32_t index, AudioPort &port) {
|
void BarrVerb::initAudioPort(bool input, uint32_t index, AudioPort &port) {
|
||||||
port.groupId = kPortGroupStereo;
|
port.groupId = kPortGroupStereo;
|
||||||
Plugin::initAudioPort(input, index, port);
|
Plugin::initAudioPort(input, index, port);
|
||||||
@ -88,8 +113,8 @@ void BarrVerb::initProgramName(uint32_t index, String &programName) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void BarrVerb::loadProgram(uint32_t index) {
|
void BarrVerb::loadProgram(uint32_t index) {
|
||||||
printf("called loadProgram(%d)\n", index);
|
|
||||||
prog_offset = (index & 0x3f) << 7;
|
prog_offset = (index & 0x3f) << 7;
|
||||||
|
program = index + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Processing functions
|
// Processing functions
|
||||||
|
@ -26,7 +26,7 @@ START_NAMESPACE_DISTRHO
|
|||||||
class BarrVerb : public Plugin {
|
class BarrVerb : public Plugin {
|
||||||
public:
|
public:
|
||||||
enum Parameters {
|
enum Parameters {
|
||||||
program,
|
paramProgram,
|
||||||
kParameterCount
|
kParameterCount
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -44,9 +44,16 @@ class BarrVerb : public Plugin {
|
|||||||
|
|
||||||
// Initialisation
|
// Initialisation
|
||||||
void initAudioPort(bool input, uint32_t index, AudioPort &port) override;
|
void initAudioPort(bool input, uint32_t index, AudioPort &port) override;
|
||||||
|
void initParameter(uint32_t index, Parameter ¶meter) override;
|
||||||
|
|
||||||
|
void setParameterValue(uint32_t index, float value) override;
|
||||||
|
float getParameterValue(uint32_t index) const override;
|
||||||
|
|
||||||
|
|
||||||
void initProgramName(uint32_t index, String &programName) override;
|
void initProgramName(uint32_t index, String &programName) override;
|
||||||
void loadProgram(uint32_t index) override;
|
void loadProgram(uint32_t index) override;
|
||||||
|
|
||||||
|
|
||||||
// Processing
|
// Processing
|
||||||
void activate() override;
|
void activate() override;
|
||||||
void deactivate() override;
|
void deactivate() override;
|
||||||
@ -63,6 +70,7 @@ class BarrVerb : public Plugin {
|
|||||||
int16_t *ram;
|
int16_t *ram;
|
||||||
float *lowpass;
|
float *lowpass;
|
||||||
|
|
||||||
|
uint8_t program;
|
||||||
|
|
||||||
DISTRHO_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(BarrVerb);
|
DISTRHO_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(BarrVerb);
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user