| 
							- /*
 -  * ZamCompX2 stereo compressor
 -  * Copyright (C) 2014  Damien Zammit <damien@zamaudio.com>
 -  *
 -  * This program is free software; you can redistribute it and/or
 -  * modify it under the terms of the GNU General Public License as
 -  * published by the Free Software Foundation; either version 2 of
 -  * the License, or any later version.
 -  *
 -  * This program is distributed in the hope that it will be useful,
 -  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 -  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 -  * GNU General Public License for more details.
 -  *
 -  * For a full copy of the GNU General Public License see the doc/GPL.txt file.
 -  */
 - 
 - #ifndef ZAMCOMPX2PLUGIN_HPP_INCLUDED
 - #define ZAMCOMPX2PLUGIN_HPP_INCLUDED
 - 
 - #define STEREOLINK_UNCOUPLED 0
 - #define STEREOLINK_AVERAGE 1
 - #define STEREOLINK_MAX 2
 - 
 - #include "DistrhoPlugin.hpp"
 - 
 - START_NAMESPACE_DISTRHO
 - 
 - // -----------------------------------------------------------------------
 - 
 - class ZamCompX2Plugin : public Plugin
 - {
 - public:
 -     enum Parameters
 -     {
 -         paramAttack = 0,
 -         paramRelease,
 -         paramKnee,
 -         paramRatio,
 -         paramThresh,
 -         paramMakeup,
 -         paramGainRed,
 -         paramStereo,
 -         paramOutputLevel,
 -         paramCount
 -     };
 - 
 -     ZamCompX2Plugin();
 - 
 - protected:
 -     // -------------------------------------------------------------------
 -     // Information
 - 
 -     const char* d_getLabel() const noexcept override
 -     {
 -         return "ZamCompX2";
 -     }
 - 
 -     const char* d_getMaker() const noexcept override
 -     {
 -         return "Damien Zammit";
 -     }
 - 
 -     const char* d_getLicense() const noexcept override
 -     {
 -         return "GPL v2+";
 -     }
 - 
 -     uint32_t d_getVersion() const noexcept override
 -     {
 -         return 0x1000;
 -     }
 - 
 -     long d_getUniqueId() const noexcept override
 -     {
 -         return d_cconst('Z', 'C', 'P', '2');
 -     }
 - 
 -     // -------------------------------------------------------------------
 -     // Init
 - 
 -     void d_initParameter(uint32_t index, Parameter& parameter) override;
 -     void d_initProgramName(uint32_t index, d_string& programName) override;
 - 
 -     // -------------------------------------------------------------------
 -     // Internal data
 - 
 -     float d_getParameterValue(uint32_t index) const override;
 -     void  d_setParameterValue(uint32_t index, float value) override;
 -     void  d_setProgram(uint32_t index) override;
 - 
 -     // -------------------------------------------------------------------
 -     // Process
 - 
 - 	static inline float
 - 	sanitize_denormal(float v) {
 - 	        if(!std::isnormal(v))
 - 	                return 0.f;
 - 	        return v;
 - 	}
 - 
 - 	static inline float
 - 	from_dB(float gdb) {
 - 	        return (exp(gdb/20.f*log(10.f)));
 - 	}
 - 
 - 	static inline float
 - 	to_dB(float g) {
 - 	        return (20.f*log10(g));
 - 	}
 - 
 -     void d_activate() override;
 -     void d_run(const float** inputs, float** outputs, uint32_t frames) override;
 - 
 -     // -------------------------------------------------------------------
 - 
 - private:
 -     float attack,release,knee,ratio,thresdb,makeup,gainred,stereolink,outlevel; //parameters
 -     float oldL_yl, oldL_y1, oldR_yl, oldR_y1;
 - };
 - 
 - // -----------------------------------------------------------------------
 - 
 - END_NAMESPACE_DISTRHO
 - 
 - #endif  // ZAMCOMPX2_HPP_INCLUDED
 
 
  |