/* SpiralSound * Copyleft (C) 2001 David Griffiths * * 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 * (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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #include "OperatorPlugin.h" #include "OperatorPluginGUI.h" #include #include "SpiralIcon.xpm" #include "../../NoteTable.h" extern "C" { SpiralPlugin* SpiralPlugin_CreateInstance() { return new OperatorPlugin; } char** SpiralPlugin_GetIcon() { return SpiralIcon_xpm; } int SpiralPlugin_GetID() { return 44; } string SpiralPlugin_GetGroupName() { return "Maths/Logic"; } } /////////////////////////////////////////////////////// OperatorPlugin::OperatorPlugin() : m_Operator(ADD), m_Constant(0) { m_Version=2; m_PluginInfo.Name="Operator"; m_PluginInfo.Width=120; m_PluginInfo.Height=80; m_PluginInfo.NumInputs=2; m_PluginInfo.NumOutputs=1; m_PluginInfo.PortTips.push_back("Input 1"); m_PluginInfo.PortTips.push_back("Input 2"); m_PluginInfo.PortTips.push_back("Output"); m_AudioCH->Register("Operator",(int*)&m_Operator); m_AudioCH->Register("Constant",&m_Constant); } OperatorPlugin::~OperatorPlugin() { } PluginInfo &OperatorPlugin::Initialise(const HostInfo *Host) { return SpiralPlugin::Initialise(Host); } SpiralGUIType *OperatorPlugin::CreateGUI() { return new OperatorPluginGUI(m_PluginInfo.Width, m_PluginInfo.Height, this,m_AudioCH,m_HostInfo); } void OperatorPlugin::Execute() { float Freq=0, OldFreq=0; switch (m_Operator) { case ADD : if (InputExists(1)) { for (int n=0; nBUFSIZE; n++) { SetOutput(0,n,GetInput(0,n)+GetInput(1,n)); } } else { for (int n=0; nBUFSIZE; n++) { SetOutput(0,n,GetInput(0,n)+m_Constant); } } break; case SUB : if (InputExists(1)) { for (int n=0; nBUFSIZE; n++) { SetOutput(0,n,GetInput(0,n)-GetInput(1,n)); } } else { for (int n=0; nBUFSIZE; n++) { SetOutput(0,n,GetInput(0,n)-m_Constant); } } break; case DIV : if (InputExists(1)) { for (int n=0; nBUFSIZE; n++) { if (GetInput(1,n)==0) SetOutput(0,n,0); else SetOutput(0,n,GetInput(0,n)/GetInput(1,n)); } } else { for (int n=0; nBUFSIZE; n++) { if (m_Constant==0) SetOutput(0,n,0); else SetOutput(0,n,GetInput(0,n)/m_Constant); } } break; case MUL : if (InputExists(1)) { for (int n=0; nBUFSIZE; n++) { SetOutput(0,n,GetInput(0,n)*GetInput(1,n)); } } else { for (int n=0; nBUFSIZE; n++) { SetOutput(0,n,GetInput(0,n)*m_Constant); } } break; default: break; } } void OperatorPlugin::ExecuteCommands() { } void OperatorPlugin::StreamOut(ostream &s) { s<>version; s>>m_Constant; if (version>1) { int t; s>>t; m_Operator=(OperatorType)t; } }