//=========================================================
//  DoubleChorus for MusE
//  
//  (C) Copyright 2006 Nil Geisweiller
//
//  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; version 2 of
//  the License, or (at your option) 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.
//
//  You should have received a copy of the GNU General Public License
//  along with this program; if not, write to the Free Software
//  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
//
//=========================================================

#include "doublechorusmodel.h"
#include <stdio.h>

//---------------------------------------------------------
//   instantiate doublechorus
//    Construct a new plugin instance.
//---------------------------------------------------------

LADSPA_Handle instantiate(const LADSPA_Descriptor* /*Descriptor*/,
			  unsigned long samplerate)
{
  return new DoubleChorusModel(samplerate);
}

//---------------------------------------------------------
//   connect PortTo doublechorus
//    Connect a port to a data location.
//---------------------------------------------------------

void connect(LADSPA_Handle Instance, unsigned long port,
	     LADSPA_Data* data)
{
  ((DoubleChorusModel *)Instance)->port[port] = data;
}

//---------------------------------------------------------
//   activate
//---------------------------------------------------------

void activate(LADSPA_Handle instance)
{
  ((DoubleChorusModel *)instance)->activate();
}

//---------------------------------------------------------
//   deactivate
//---------------------------------------------------------

void deactivate(LADSPA_Handle /*Instance*/)
{
}

//---------------------------------------------------------
//   run doublechorus
//---------------------------------------------------------

void run(LADSPA_Handle Instance, unsigned long n)
{
  ((DoubleChorusModel *)Instance)->processReplace(n);
}

//---------------------------------------------------------
//   runAdding doublechorus
//    *ADD* the output to the output buffer.
//---------------------------------------------------------

void runAdding(LADSPA_Handle Instance, unsigned long n)
{
  ((DoubleChorusModel *)Instance)->processMix(n);
}

//---------------------------------------------------------
//   set doublechorus RunAddingGain
//---------------------------------------------------------

void setGain(LADSPA_Handle /*Instance*/, LADSPA_Data /*Gain*/)
{
  printf("TEST setGain\n");
  //      ((DoubleChorusModel *)Instance)->m_fRunAddingGain = Gain;
}

//---------------------------------------------------------
//   cleanup doublechorus
//---------------------------------------------------------

void cleanup(LADSPA_Handle Instance)
{
  delete (DoubleChorusModel *)Instance;
}

static const char* portNames[] = {
  "Input (Left)",
  "Input (Right)",
  "Output (Left)",
  "Output (Right)",
  "Pan 1",
  "LFOFreq 1",
  "Depth 1",
  "Pan 2",
  "LFOFreq 2",
  "Depth 2",
  "Dry/Wet"
};

LADSPA_PortDescriptor portDescriptors[] = {
  LADSPA_PORT_INPUT  | LADSPA_PORT_AUDIO,
  LADSPA_PORT_INPUT  | LADSPA_PORT_AUDIO,
  LADSPA_PORT_OUTPUT | LADSPA_PORT_AUDIO,
  LADSPA_PORT_OUTPUT | LADSPA_PORT_AUDIO,
  LADSPA_PORT_INPUT  | LADSPA_PORT_CONTROL,
  LADSPA_PORT_INPUT  | LADSPA_PORT_CONTROL,
  LADSPA_PORT_INPUT  | LADSPA_PORT_CONTROL,
  LADSPA_PORT_INPUT  | LADSPA_PORT_CONTROL,
  LADSPA_PORT_INPUT  | LADSPA_PORT_CONTROL,
  LADSPA_PORT_INPUT  | LADSPA_PORT_CONTROL,
  LADSPA_PORT_INPUT  | LADSPA_PORT_CONTROL
};

LADSPA_PortRangeHint portRangeHints[] = {
  { 0, 0.0, 0.0 },
  { 0, 0.0, 0.0 },
  { 0, 0.0, 0.0 },
  { 0, 0.0, 0.0 },
  { LADSPA_HINT_BOUNDED_ABOVE | LADSPA_HINT_BOUNDED_BELOW | LADSPA_HINT_DEFAULT_HIGH,  0.0, 1.0 },
  { LADSPA_HINT_BOUNDED_ABOVE | LADSPA_HINT_BOUNDED_BELOW | LADSPA_HINT_LOGARITHMIC | LADSPA_HINT_DEFAULT_HIGH, MINFREQ, MAXFREQ },
  { LADSPA_HINT_BOUNDED_ABOVE | LADSPA_HINT_BOUNDED_BELOW | LADSPA_HINT_DEFAULT_LOW, 0.0, 1.0 },
  { LADSPA_HINT_BOUNDED_ABOVE | LADSPA_HINT_BOUNDED_BELOW | LADSPA_HINT_DEFAULT_LOW,  0.0, 1.0 },
  { LADSPA_HINT_BOUNDED_ABOVE | LADSPA_HINT_BOUNDED_BELOW | LADSPA_HINT_LOGARITHMIC | LADSPA_HINT_DEFAULT_MIDDLE, MINFREQ, MAXFREQ },
  { LADSPA_HINT_BOUNDED_ABOVE | LADSPA_HINT_BOUNDED_BELOW | LADSPA_HINT_DEFAULT_LOW, 0.0, 1.0 },
  { LADSPA_HINT_BOUNDED_ABOVE | LADSPA_HINT_BOUNDED_BELOW | LADSPA_HINT_DEFAULT_MIDDLE, 0.0, 1.0 },
};

LADSPA_Descriptor descriptor = {
  1051,
  "doublechorus1",
  LADSPA_PROPERTY_HARD_RT_CAPABLE,
  "DoubleChorus",
  "Nil Geisweiller",
  "GPL",
  NBRPARAM + 4,
  portDescriptors,
  portNames,
  portRangeHints,
  0,                // impl. data
  instantiate,
  connect,
  activate,
  run,
  runAdding,
  setGain,
  deactivate,
  cleanup
};

//---------------------------------------------------------
//   _init
//    called automatically when the plugin library is first
//    loaded.
//---------------------------------------------------------
void _init() {
}

//---------------------------------------------------------
//   _fini
//    called automatically when the library is unloaded.
//---------------------------------------------------------
void _fini() {
}

//---------------------------------------------------------
//   ladspa_descriptor
//    Return a descriptor of the requested plugin type.
//---------------------------------------------------------
const LADSPA_Descriptor* ladspa_descriptor(unsigned long i) {
  return (i == 0) ? &descriptor : 0;
}