aboutsummaryrefslogtreecommitdiffstats
path: root/plugins/LV2/src/DubCenter/DubCenter.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/LV2/src/DubCenter/DubCenter.cpp')
-rw-r--r--plugins/LV2/src/DubCenter/DubCenter.cpp109
1 files changed, 109 insertions, 0 deletions
diff --git a/plugins/LV2/src/DubCenter/DubCenter.cpp b/plugins/LV2/src/DubCenter/DubCenter.cpp
new file mode 100644
index 0000000..6104650
--- /dev/null
+++ b/plugins/LV2/src/DubCenter/DubCenter.cpp
@@ -0,0 +1,109 @@
+#include "DubCenter.h"
+#include <iostream>
+#include <lv2wrapper.h>
+
+DubCenter::DubCenter(double rate)
+ : LV2Plugin(rate)
+{
+}
+
+void DubCenter::activate()
+{
+ A = 0.9;
+ B = 0.5;
+ C = 0.74;
+ D = 1.0;
+ E = 0.95;
+ F = 0.5;
+ G = 0.2;
+ H = 0.2;
+ I = 0.5;
+ J = 1.0;
+
+ WasNegative = false;
+ SubOctave = false;
+ flip = false;
+ bflip = 0;
+ iirDriveSampleAL = 0.0;
+ iirDriveSampleBL = 0.0;
+ iirDriveSampleCL = 0.0;
+ iirDriveSampleDL = 0.0;
+ iirDriveSampleEL = 0.0;
+ iirDriveSampleFL = 0.0;
+ iirDriveSampleAR = 0.0;
+ iirDriveSampleBR = 0.0;
+ iirDriveSampleCR = 0.0;
+ iirDriveSampleDR = 0.0;
+ iirDriveSampleER = 0.0;
+ iirDriveSampleFR = 0.0;
+
+ iirHeadBumpA = 0.0;
+ iirHeadBumpB = 0.0;
+ iirHeadBumpC = 0.0;
+
+ iirSubBumpA = 0.0;
+ iirSubBumpB = 0.0;
+ iirSubBumpC = 0.0;
+
+ lastHeadBump = 0.0;
+ lastSubBump = 0.0;
+
+ iirSampleA = 0.0;
+ iirSampleB = 0.0;
+ iirSampleC = 0.0;
+ iirSampleD = 0.0;
+ iirSampleE = 0.0;
+ iirSampleF = 0.0;
+ iirSampleG = 0.0;
+ iirSampleH = 0.0;
+ iirSampleI = 0.0;
+ iirSampleJ = 0.0;
+ iirSampleK = 0.0;
+ iirSampleL = 0.0;
+ iirSampleM = 0.0;
+ iirSampleN = 0.0;
+ iirSampleO = 0.0;
+ iirSampleP = 0.0;
+ iirSampleQ = 0.0;
+ iirSampleR = 0.0;
+ iirSampleS = 0.0;
+ iirSampleT = 0.0;
+ iirSampleU = 0.0;
+ iirSampleV = 0.0;
+ iirSampleW = 0.0;
+ iirSampleX = 0.0;
+ iirSampleY = 0.0;
+ iirSampleZ = 0.0;
+
+ oscGate = 1.0;
+
+ fpNShapeL = 0.0;
+ fpNShapeR = 0.0;
+ //this is reset: values being initialized only once. Startup values, whatever they are.
+
+}
+
+void DubCenter::run(uint32_t num_samples)
+{
+ A = *params[0];
+ B = *params[1];
+ C = *params[2];
+ D = *params[3];
+ E = *params[4];
+ F = *params[5];
+ G = *params[6];
+ H = *params[7];
+ I = *params[8];
+ J = *params[9];
+
+ processReplacing(const_cast<float **>(in), out, num_samples);
+}
+
+//
+// Include the processing code from the VST version.
+//
+#include <cmath>
+#include "../../../LinuxVST/src/DubCenter/DubCenterProc.cpp"
+
+// Create the LV2Wrapper and register the plugin
+LV2Wrapper<DubCenter> plugin;