aboutsummaryrefslogtreecommitdiffstats
path: root/plugins/LV2/src/AtmosphereBuss/AtmosphereBuss.h
blob: 52dd36eaac53e0f4bd82afc6d2aefc021fcaf0d7 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
#ifndef __AtmosphereBuss_H
#define __AtmosphereBuss_H

#include <lv2plugin.h>

class AtmosphereBuss : public LV2Plugin<1> {
public:
    AtmosphereBuss(double rate);

    void run(uint32_t num_samples);

    static constexpr const char * URI = "https://www.airwindows.com/atmospherebuss";

private:
    /*
     * These are the original DSP functions from the VST plugin.
     * They need to be called from the LV2 plugins `run` function.
     */
    void processReplacing(float **in, float **out, VstInt32 samples);
    void processDoubleReplacing(double **in, double **out, VstInt32 samples);

    /*
     * Members needed by the processing functions.
     */
	double gainchase;
	double settingchase;
	double chasespeed;

	long double fpNShapeL;
	long double lastSampleAL;
	long double lastSampleBL;
	long double lastSampleCL;
	long double lastSampleDL;
	long double lastSampleEL;
	long double lastSampleFL;
	long double lastSampleGL;
	long double lastSampleHL;
	long double lastSampleIL;
	long double lastSampleJL;
	long double lastSampleKL;
	long double lastSampleLL;
	long double lastSampleML;

	long double fpNShapeR;
	long double lastSampleAR;
	long double lastSampleBR;
	long double lastSampleCR;
	long double lastSampleDR;
	long double lastSampleER;
	long double lastSampleFR;
	long double lastSampleGR;
	long double lastSampleHR;
	long double lastSampleIR;
	long double lastSampleJR;
	long double lastSampleKR;
	long double lastSampleLR;
	long double lastSampleMR;

	long double thresholdA;
	long double thresholdB;
	long double thresholdC;
	long double thresholdD;
	long double thresholdE;
	long double thresholdF;
	long double thresholdG;
	long double thresholdH;
	long double thresholdI;
	long double thresholdJ;
	long double thresholdK;
	long double thresholdL;
	long double thresholdM;

    float A;
};


#endif