diff options
Diffstat (limited to 'drumgizmo')
25 files changed, 0 insertions, 2839 deletions
diff --git a/drumgizmo/audioinputenginedl.cc b/drumgizmo/audioinputenginedl.cc deleted file mode 100644 index cba59fa..0000000 --- a/drumgizmo/audioinputenginedl.cc +++ /dev/null @@ -1,251 +0,0 @@ -/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/*************************************************************************** - * audioinputenginedl.cc - * - * Wed Jul 13 14:39:54 CEST 2011 - * Copyright 2011 Bent Bisballe Nyeng - * deva@aasimon.org - ****************************************************************************/ - -/* - * This file is part of DrumGizmo. - * - * DrumGizmo 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. - * - * DrumGizmo 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 DrumGizmo; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. - */ -#include "audioinputenginedl.h" - -#include <stdio.h> - -#include <dlfcn.h> - -#include <config.h> -#include <string.h> -#include <stdlib.h> - -#include "jackclient.h" - -AudioInputEngineDL::AudioInputEngineDL(std::string name) -{ - is_jack_plugin = strstr(name.c_str(), "jack"); - - std::string plugin = INPUT_PLUGIN_DIR"/" + name + ".so"; - lib = dlopen(plugin.c_str(), RTLD_LAZY); - if(!lib) { - printf("Cannot load device: %s\n", dlerror()); - return; - } - - i_create = (input_create_func_t) dlsym(lib, "create"); - const char* dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol create: %s\n", dlsym_error); - return; - } - - i_destroy = (input_destroy_func_t) dlsym(lib, "destroy"); - dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol destroy: %s\n", dlsym_error); - return; - } - - i_init = (input_init_func_t) dlsym(lib, "init"); - dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol init: %s\n", dlsym_error); - return; - } - - i_setparm = (input_setparm_func_t) dlsym(lib, "setparm"); - dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol setparm: %s\n", dlsym_error); - return; - } - - i_start = (input_start_func_t) dlsym(lib, "start"); - dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol start: %s\n", dlsym_error); - return; - } - - i_stop = (input_stop_func_t) dlsym(lib, "stop"); - dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol stop: %s\n", dlsym_error); - return; - } - - i_pre = (input_pre_func_t) dlsym(lib, "pre"); - dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol pre: %s\n", dlsym_error); - return; - } - - i_run = (input_run_func_t) dlsym(lib, "run"); - dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol run: %s\n", dlsym_error); - return; - } - - i_post = (input_post_func_t) dlsym(lib, "post"); - dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol post: %s\n", dlsym_error); - return; - } - - ptr = i_create(); - - if(is_jack_plugin) { - char ptrbuf[32]; - jackclient = init_jack_client(); - sprintf(ptrbuf, "%p", jackclient); - setParm("jack_client", ptrbuf); - } -} - -AudioInputEngineDL::~AudioInputEngineDL() -{ - i_destroy(ptr); - if(is_jack_plugin) close_jack_client(); - dlclose(lib); - lib = nullptr; -} - -bool AudioInputEngineDL::init(Instruments &instruments) -{ - char **n = (char**)malloc(sizeof(char*)*instruments.size()); - for(size_t i = 0; i < instruments.size(); i++) { - n[i] = strdup(instruments[i]->name().c_str()); - } - - bool ret = i_init(ptr, instruments.size(), n); - - for(size_t i = 0; i < instruments.size(); i++) { - free(n[i]); - } - free(n); - - return ret; -} - -void AudioInputEngineDL::setParm(std::string parm, std::string value) -{ - i_setparm(ptr, parm.c_str(), value.c_str()); -} - -bool AudioInputEngineDL::start() -{ - if(is_jack_plugin) jackclient->activate(); - return i_start(ptr); -} - -void AudioInputEngineDL::stop() -{ - return i_stop(ptr); -} - -void AudioInputEngineDL::pre() -{ - return i_pre(ptr); -} - -event_t *AudioInputEngineDL::run(size_t pos, size_t len, size_t *nevents) -{ - return i_run(ptr, pos, len, nevents); -} - -void AudioInputEngineDL::post() -{ - return i_post(ptr); -} - -//#include "audioinputenginedummy.h" -//#include "audioinputenginejackmidi.h" -//#include "audioinputenginemidifile.h" - -/* - -typedef Device* (*create_func_t)(void); -typedef void (*destroy_func_t)(Device*); - -struct device_t { - Device* dev; - destroy_func_t destroyer; - void* lib; -}; - -int load_shared_device(device_t &dev, std::string devlib, - std::string devfile, ConfMap devconfmap) { - // load library - dev.lib = dlopen(devlib.c_str(), RTLD_LAZY); - if(!dev.lib ) { - printf("Cannot load device: %s\n", dlerror()); - return -1; - } - - create_func_t create_device = (create_func_t) dlsym(dev.lib, "create"); - const char* dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol create: %s\n", dlsym_error); - return -1; - } - - dev.destroyer = (destroy_func_t) dlsym(dev.lib, "destroy"); - dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol destroy: %s\n", dlsym_error); - return -1; - } - - dev.dev = create_device(); - - // initialize device - DevData devdata = dev.dev->init(devfile, devconfmap); - if(devdata.retval != DevData::VALUE_SUCCESS) { - printf("Error while initializing device: %s\n", devdata.msg.c_str()); - return -1; - } - - return 0; -} - -void unload_shared_device(device_t &dev) { - - dev.destroyer(dev.dev); - dlclose(dev.lib); -} -*/ - -#ifdef TEST_AUDIOINPUTENGINEDL -//Additional dependency files -//deps: -//Required cflags (autoconf vars may be used) -//cflags: -//Required link options (autoconf vars may be used) -//libs: -#include "test.h" - -TEST_BEGIN; - -// TODO: Put some testcode here (see test.h for usable macros). - -TEST_END; - -#endif/*TEST_AUDIOINPUTENGINEDL*/ diff --git a/drumgizmo/audioinputenginedl.h b/drumgizmo/audioinputenginedl.h deleted file mode 100644 index 94bd89d..0000000 --- a/drumgizmo/audioinputenginedl.h +++ /dev/null @@ -1,77 +0,0 @@ -/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/*************************************************************************** - * audioinputenginedl.h - * - * Wed Jul 13 14:39:54 CEST 2011 - * Copyright 2011 Bent Bisballe Nyeng - * deva@aasimon.org - ****************************************************************************/ - -/* - * This file is part of DrumGizmo. - * - * DrumGizmo 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. - * - * DrumGizmo 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 DrumGizmo; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. - */ -#ifndef __DRUMGIZMO_AUDIOINPUTENGINEDL_H__ -#define __DRUMGIZMO_AUDIOINPUTENGINEDL_H__ - -#include "audioinputengine.h" -#include "jackclient.h" - -typedef void* (*input_create_func_t)(void); -typedef void (*input_destroy_func_t)(void*); -typedef bool (*input_init_func_t)(void*,int,char**); -typedef void (*input_setparm_func_t)(void*,const char*,const char*); -typedef bool (*input_start_func_t)(void*); -typedef void (*input_stop_func_t)(void*); -typedef void (*input_pre_func_t)(void*); -typedef event_t* (*input_run_func_t)(void*,size_t,size_t,size_t*); -typedef void (*input_post_func_t)(void*); - -class AudioInputEngineDL : public AudioInputEngine { -public: - AudioInputEngineDL(std::string name); - ~AudioInputEngineDL(); - - bool init(Instruments &instruments); - - void setParm(std::string parm, std::string value); - - bool start(); - void stop(); - - void pre(); - event_t *run(size_t pos, size_t len, size_t *nevents); - void post(); - -private: - void *ptr{nullptr}; - input_create_func_t i_create{nullptr}; - input_destroy_func_t i_destroy{nullptr}; - input_init_func_t i_init{nullptr}; - input_setparm_func_t i_setparm{nullptr}; - input_start_func_t i_start{nullptr}; - input_stop_func_t i_stop{nullptr}; - input_pre_func_t i_pre{nullptr}; - input_run_func_t i_run{nullptr}; - input_post_func_t i_post{nullptr}; - - bool is_jack_plugin; - JackClient *jackclient{nullptr}; - - void *lib{nullptr}; -}; - -#endif/*__DRUMGIZMO_AUDIOINPUTENGINEDL_H__*/ diff --git a/drumgizmo/audiooutputenginedl.cc b/drumgizmo/audiooutputenginedl.cc deleted file mode 100644 index 042db4a..0000000 --- a/drumgizmo/audiooutputenginedl.cc +++ /dev/null @@ -1,197 +0,0 @@ -/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/*************************************************************************** - * audiooutputenginedl.cc - * - * Wed Jul 13 14:40:01 CEST 2011 - * Copyright 2011 Bent Bisballe Nyeng - * deva@aasimon.org - ****************************************************************************/ - -/* - * This file is part of DrumGizmo. - * - * DrumGizmo 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. - * - * DrumGizmo 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 DrumGizmo; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. - */ -#include "audiooutputenginedl.h" - -#include <dlfcn.h> -#include <stdio.h> -#include <config.h> -#include <string.h> - -AudioOutputEngineDL::AudioOutputEngineDL(std::string name) -{ - is_jack_plugin = strstr(name.c_str(), "jack"); - - std::string plugin = OUTPUT_PLUGIN_DIR"/" + name + ".so"; - lib = dlopen(plugin.c_str(), RTLD_LAZY); - if(!lib) { - printf("Cannot load device: %s\n", dlerror()); - return; - } - - o_create = (output_create_func_t) dlsym(lib, "create"); - const char* dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol create: %s\n", dlsym_error); - return; - } - - o_destroy = (output_destroy_func_t) dlsym(lib, "destroy"); - dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol destroy: %s\n", dlsym_error); - return; - } - - o_init = (output_init_func_t) dlsym(lib, "init"); - dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol destroy: %s\n", dlsym_error); - return; - } - - o_setparm = (output_setparm_func_t) dlsym(lib, "setparm"); - dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol destroy: %s\n", dlsym_error); - return; - } - - o_start = (output_start_func_t) dlsym(lib, "start"); - dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol destroy: %s\n", dlsym_error); - return; - } - - o_stop = (output_stop_func_t) dlsym(lib, "stop"); - dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol destroy: %s\n", dlsym_error); - return; - } - - o_pre = (output_pre_func_t) dlsym(lib, "pre"); - dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol destroy: %s\n", dlsym_error); - return; - } - - o_run = (output_run_func_t) dlsym(lib, "run"); - dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol destroy: %s\n", dlsym_error); - return; - } - - o_post = (output_post_func_t) dlsym(lib, "post"); - dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol destroy: %s\n", dlsym_error); - return; - } - - o_bufsize = (output_bufsize_func_t) dlsym(lib, "bufsize"); - dlsym_error = dlerror(); - if(dlsym_error) { - o_bufsize = NULL; - } - - o_samplerate = (output_samplerate_func_t) dlsym(lib, "samplerate"); - dlsym_error = dlerror(); - if(dlsym_error) { - printf("Cannot load symbol samplerate: %s\n", dlsym_error); - return; - } - - ptr = o_create(); - - if(is_jack_plugin) { - char ptrbuf[32]; - jackclient = init_jack_client(); - sprintf(ptrbuf, "%p", jackclient); - setParm("jack_client", ptrbuf); - } -} - -AudioOutputEngineDL::~AudioOutputEngineDL() -{ - o_destroy(ptr); - if(is_jack_plugin) close_jack_client(); - dlclose(lib); - lib = nullptr; -} - -bool AudioOutputEngineDL::init(Channels channels) -{ - char **n = (char**)malloc(sizeof(char*)*channels.size()); - for(size_t i = 0; i < channels.size(); i++) { - n[i] = strdup(channels[i].name.c_str()); - } - - bool ret = o_init(ptr, channels.size(), n); - - for(size_t i = 0; i < channels.size(); i++) { - free(n[i]); - } - free(n); - - return ret; -} - -void AudioOutputEngineDL::setParm(std::string parm, std::string value) -{ - o_setparm(ptr, parm.c_str(), value.c_str()); -} - -bool AudioOutputEngineDL::start() -{ - if(is_jack_plugin) jackclient->activate(); - return o_start(ptr); -} - -void AudioOutputEngineDL::stop() -{ - return o_stop(ptr); -} - -void AudioOutputEngineDL::pre(size_t size) -{ - return o_pre(ptr, size); -} - -void AudioOutputEngineDL::run(int ch, sample_t *samples, size_t nsamples) -{ - o_run(ptr, ch, samples, nsamples); -} - -void AudioOutputEngineDL::post(size_t size) -{ - return o_post(ptr, size); -} - -size_t AudioOutputEngineDL::getBufferSize() -{ - if(o_bufsize) return o_bufsize(ptr); - return 1024; -} - -size_t AudioOutputEngineDL::samplerate() -{ - if(o_samplerate) return o_samplerate(ptr); - return 44100; -} diff --git a/drumgizmo/audiooutputenginedl.h b/drumgizmo/audiooutputenginedl.h deleted file mode 100644 index 4b31015..0000000 --- a/drumgizmo/audiooutputenginedl.h +++ /dev/null @@ -1,90 +0,0 @@ -/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/*************************************************************************** - * audiooutputenginedl.h - * - * Wed Jul 13 14:40:01 CEST 2011 - * Copyright 2011 Bent Bisballe Nyeng - * deva@aasimon.org - ****************************************************************************/ - -/* - * This file is part of DrumGizmo. - * - * DrumGizmo 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. - * - * DrumGizmo 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 DrumGizmo; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. - */ -#ifndef __DRUMGIZMO_AUDIOOUTPUTENGINEDL_H__ -#define __DRUMGIZMO_AUDIOOUTPUTENGINEDL_H__ - -#include <string> -#include <stdlib.h> -#include <audiotypes.h> - -#include "channel.h" - -#include "audiooutputengine.h" -#include "jackclient.h" - -typedef void* (*output_create_func_t)(void); -typedef void (*output_destroy_func_t)(void*); -typedef bool (*output_start_func_t)(void*); -typedef void (*output_stop_func_t)(void*); -typedef bool (*output_init_func_t)(void*,int,char**); -typedef void (*output_setparm_func_t)(void*,const char*,const char*); -typedef void (*output_pre_func_t)(void*, size_t); -typedef void (*output_run_func_t)(void*,int,sample_t*,size_t); -typedef void (*output_post_func_t)(void*, size_t); -typedef size_t (*output_bufsize_func_t)(void*); -typedef size_t (*output_samplerate_func_t)(void*); - -class AudioOutputEngineDL : public AudioOutputEngine { -public: - AudioOutputEngineDL(std::string name); - ~AudioOutputEngineDL(); - - bool init(Channels channels); - - void setParm(std::string parm, std::string value); - - bool start(); - void stop(); - - void pre(size_t nsamples); - void run(int ch, sample_t *samples, size_t nsamples); - void post(size_t nsamples); - - size_t getBufferSize(); - size_t samplerate(); - -private: - void *ptr{nullptr}; - output_create_func_t o_create{nullptr}; - output_destroy_func_t o_destroy{nullptr}; - output_init_func_t o_init{nullptr}; - output_setparm_func_t o_setparm{nullptr}; - output_start_func_t o_start{nullptr}; - output_stop_func_t o_stop{nullptr}; - output_pre_func_t o_pre{nullptr}; - output_run_func_t o_run{nullptr}; - output_post_func_t o_post{nullptr}; - output_bufsize_func_t o_bufsize{nullptr}; - output_samplerate_func_t o_samplerate{nullptr}; - - bool is_jack_plugin; - JackClient *jackclient{nullptr}; - - void* lib{nullptr}; -}; - -#endif/*__DRUMGIZMO_AUDIOOUTPUTENGINEDL_H__*/ diff --git a/drumgizmo/input/Makefile.am b/drumgizmo/input/Makefile.am deleted file mode 100644 index ee82f63..0000000 --- a/drumgizmo/input/Makefile.am +++ /dev/null @@ -1,2 +0,0 @@ -DISTDIRS = midifile jackmidi dummy test -SUBDIRS = @INPUT_PLUGINS@ diff --git a/drumgizmo/input/dummy/Makefile.am b/drumgizmo/input/dummy/Makefile.am deleted file mode 100644 index dfe0a57..0000000 --- a/drumgizmo/input/dummy/Makefile.am +++ /dev/null @@ -1,29 +0,0 @@ - -dummysources = \ - dummy.cc - -if HAVE_INPUT_DUMMY - -dummyltlibs = dummy.la -dummybuildsources = $(dummysources) - -else - -dummyltlibs = -dummybuildsources = - -endif - -EXTRA_DIST = $(dummysources) - -lib_LTLIBRARIES = $(dummyltlibs) - -libdir = $(INPUT_PLUGIN_DIR) - -AM_CPPFLAGS = -I$(top_srcdir)/include -dummy_la_LDFLAGS = -module -avoid-version -shared -dummy_la_LIBADD = -dummy_la_SOURCES = $(dummybuildsources) - -install-exec-hook: - rm -f $(DESTDIR)$(libdir)/dummy.la diff --git a/drumgizmo/input/dummy/dummy.cc b/drumgizmo/input/dummy/dummy.cc deleted file mode 100644 index 4a570db..0000000 --- a/drumgizmo/input/dummy/dummy.cc +++ /dev/null @@ -1,185 +0,0 @@ -/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/*************************************************************************** - * dummy.cc - * - * Sat Apr 30 21:11:54 CEST 2011 - * Copyright 2011 Bent Bisballe Nyeng - * deva@aasimon.org - ****************************************************************************/ - -/* - * This file is part of DrumGizmo. - * - * DrumGizmo 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. - * - * DrumGizmo 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 DrumGizmo; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. - */ -#include <stdlib.h> - -#include <string> -#include <event.h> - -class Dummy { -public: - Dummy() {} - ~Dummy() {} - - bool init(int instruments, char *inames[]); - - void setParm(std::string parm, std::string value); - - bool start(); - void stop(); - - void pre(); - event_t *run(size_t pos, size_t len, size_t *nevents); - void post(); -}; - -bool Dummy::init(int instruments, char *inames[]) -{ - return true; -} - -void Dummy::setParm(std::string parm, std::string value) -{ -} - -bool Dummy::start() -{ - return true; -} - -void Dummy::stop() -{ -} - -void Dummy::pre() -{ -} - -event_t *Dummy::run(size_t pos, size_t len, size_t *nevents) -{ - *nevents = 0; - return NULL; - /* - if(rand() % 10 != 0) return; - - Instrument *i = NULL; - int d = rand() % drumkit->instruments.size(); - Instruments::iterator it = drumkit->instruments.begin(); - while(d--) { - i = &(it->second); - it++; - } - - if(i == NULL) return; - - Sample *s = i->sample((double)rand()/(double)RAND_MAX); - - if(s == NULL) { - printf("Missing Sample.\n"); - // continue; - } - - Channels::iterator j = drumkit->channels.begin(); - while(j != drumkit->channels.end()) { - Channel &ch = *j; - AudioFile *af = s->getAudioFile(&ch); - if(af == NULL) { - printf("Missing AudioFile.\n"); - } else { - printf("Adding event.\n"); - Event *evt = new EventSample(ch.num, 1.0, af); - eventqueue->post(evt, pos); - } - j++; - } - */ -} - -void Dummy::post() -{ -} - -extern "C" { - void *create() - { - return new Dummy(); - } - - void destroy(void *h) - { - Dummy *dummy = (Dummy*)h; - delete dummy; - } - - bool init(void *h, int i, char *inames[]) - { - Dummy *dummy = (Dummy*)h; - return dummy->init(i, inames); - } - - void setparm(void *h, const char *parm, const char *value) - { - Dummy *dummy = (Dummy*)h; - dummy->setParm(parm, value); - } - - bool start(void *h) - { - Dummy *dummy = (Dummy*)h; - return dummy->start(); - } - - void stop(void *h) - { - Dummy *dummy = (Dummy*)h; - dummy->stop(); - } - - void pre(void *h) - { - Dummy *dummy = (Dummy*)h; - dummy->pre(); - } - - event_t *run(void *h, size_t pos, size_t len, size_t *nev) - { - Dummy *dummy = (Dummy*)h; - return dummy->run(pos, len, nev); - } - - void post(void *h) - { - Dummy *dummy = (Dummy*)h; - dummy->post(); - } -} - -#ifdef TEST_AUDIOINPUTENGINEDUMMY -//Additional dependency files -//deps: -//Required cflags (autoconf vars may be used) -//cflags: -//Required link options (autoconf vars may be used) -//libs: -#include "test.h" - -TEST_BEGIN; - -// TODO: Put some testcode here (see test.h for usable macros). - -TEST_END; - -#endif/*TEST_AUDIOINPUTENGINEDUMMY*/ diff --git a/drumgizmo/input/jackmidi/Makefile.am b/drumgizmo/input/jackmidi/Makefile.am deleted file mode 100644 index d392f19..0000000 --- a/drumgizmo/input/jackmidi/Makefile.am +++ /dev/null @@ -1,34 +0,0 @@ - -jackmidisources = \ - jackmidi.cc \ - $(top_srcdir)/src/midimapper.cc \ - $(top_srcdir)/src/midimapparser.cc \ - $(top_srcdir)/src/saxparser.cc \ - $(top_srcdir)/hugin/hugin.c - -if HAVE_INPUT_JACKMIDI - -jackmidiltlibs = jackmidi.la -jackmidibuildsources = $(jackmidisources) - -else - -jackmidiltlibs = -jackmidibuildsources = - -endif - -EXTRA_DIST = $(jackmidisources) - -lib_LTLIBRARIES = $(jackmidiltlibs) - -libdir = $(INPUT_PLUGIN_DIR) - -AM_CPPFLAGS = -I$(top_srcdir)/include -I$(top_srcdir)/src -I$(top_srcdir)/hugin -jackmidi_la_LDFLAGS = -module -avoid-version -shared -jackmidi_la_LIBADD = $(EXPAT_LIBS) -jackmidi_la_CXXFLAGS = $(EXPAT_CFLAGS) -jackmidi_la_SOURCES = $(jackmidibuildsources) - -install-exec-hook: - rm -f $(DESTDIR)$(libdir)/jackmidi.la diff --git a/drumgizmo/input/jackmidi/audioinputenginejackmidi.cc b/drumgizmo/input/jackmidi/audioinputenginejackmidi.cc deleted file mode 100644 index 5e1fb85..0000000 --- a/drumgizmo/input/jackmidi/audioinputenginejackmidi.cc +++ /dev/null @@ -1,153 +0,0 @@ -/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/*************************************************************************** - * audioinputenginejackmidi.cc - * - * Sun Feb 27 11:33:31 CET 2011 - * Copyright 2011 Bent Bisballe Nyeng - * deva@aasimon.org - ****************************************************************************/ - -/* - * This file is part of DrumGizmo. - * - * DrumGizmo 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. - * - * DrumGizmo 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 DrumGizmo; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. - */ -#include "audioinputenginejackmidi.h" - -#define NOTE_ON 0x90 - -AudioInputEngineJackMidi::AudioInputEngineJackMidi() -{ - jackclient = init_jack_client(); - - jackclient->addJackProcess(this); - - pos = 0; -} - -AudioInputEngineJackMidi::~AudioInputEngineJackMidi() -{ - jackclient->removeJackProcess(this); - close_jack_client(); -} - -void AudioInputEngineJackMidi::jack_process(jack_nframes_t nframes) -{ - void *midibuffer = jack_port_get_buffer(midi_port, nframes); - - jack_nframes_t midievents = jack_midi_get_event_count(midibuffer); - - for(jack_nframes_t i = 0; i < midievents; i++) { - jack_midi_event_t event; - jack_midi_event_get(&event, midibuffer, i); - - if(event.size != 3) continue; - if((event.buffer[0] & NOTE_ON) != NOTE_ON) continue; - - int key = event.buffer[1]; - int velocity = event.buffer[2]; - - printf("Event key:%d vel:%d\n", key, velocity); - /* - if(kit->midimap.find(key) == kit->midimap.end()) { - printf("Missing note %d in midimap.\n", key); - continue; - } - - std::string instr = kit->midimap[key]; - - if(kit->instruments.find(instr) == kit->instruments.end()) { - printf("Missing instrument %s.\n", instr.c_str()); - continue; - } - */ - - Instrument *i = NULL; - int d = key % kit->instruments.size(); - Instruments::iterator it = kit->instruments.begin(); - while(d--) { - i = &(it->second); - it++; - } - - if(i == NULL) { - continue; - } - - // Sample *s = i.sample((float)velocity/127.0); - Sample *s = i->sample(0.5); - - if(s == NULL) { - printf("Missing Sample.\n"); - continue; - } - - Channels::iterator j = kit->channels.begin(); - while(j != kit->channels.end()) { - Channel &ch = *j; - AudioFile *af = s->getAudioFile(&ch); - if(af == NULL) { - printf("Missing AudioFile.\n"); - } else { - printf("Adding event.\n"); - Event *evt = new EventSample(ch.num, 1.0, af); - eventqueue->post(evt, pos + event.time + nframes); - } - j++; - } - } - - jack_midi_clear_buffer(midibuffer); - - pos += nframes; -} - -bool AudioInputEngineJackMidi::init(EventQueue *e, DrumKit *dk) -{ - eventqueue = e; - kit = dk; - - midi_port = jack_port_register(jackclient->jack_client, - "drumgizmo_midiin", - JACK_DEFAULT_MIDI_TYPE, - JackPortIsInput,// | JackPortIsTerminal, - 0); - - return true; -} - - -bool AudioInputEngineJackMidi::activate() -{ - jackclient->activate(); - return true; -} - -#ifdef TEST_AUDIOINPUTENGINEJACKMIDI -//Additional dependency files -//deps: -//Required cflags (autoconf vars may be used) -//cflags: -//Required link options (autoconf vars may be used) -//libs: -#include "test.h" - -TEST_BEGIN; - -// TODO: Put some testcode here (see test.h for usable macros). - -TEST_END; - -#endif/*TEST_AUDIOINPUTENGINEJACKMIDI*/ diff --git a/drumgizmo/input/jackmidi/audioinputenginejackmidi.h b/drumgizmo/input/jackmidi/audioinputenginejackmidi.h deleted file mode 100644 index e4c6e69..0000000 --- a/drumgizmo/input/jackmidi/audioinputenginejackmidi.h +++ /dev/null @@ -1,61 +0,0 @@ -/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/*************************************************************************** - * audioinputenginejackmidi.h - * - * Sun Feb 27 11:33:31 CET 2011 - * Copyright 2011 Bent Bisballe Nyeng - * deva@aasimon.org - ****************************************************************************/ - -/* - * This file is part of DrumGizmo. - * - * DrumGizmo 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. - * - * DrumGizmo 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 DrumGizmo; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. - */ -#ifndef __DRUMGIZMO_AUDIOINPUTENGINEJACKMIDI_H__ -#define __DRUMGIZMO_AUDIOINPUTENGINEJACKMIDI_H__ - -#include <jack/jack.h> -#include <jack/midiport.h> - -#include "audioinputengine.h" -#include "event.h" - -#include "jackclient.h" - -class AudioInputEngineJackMidi : public AudioInputEngine, public JackProcess { -public: - AudioInputEngineJackMidi(); - ~AudioInputEngineJackMidi(); - - bool init(EventQueue *e, DrumKit *drumkit); - bool activate(); - void run(size_t pos, size_t len) {} - - void thread_main(); - - void jack_process(jack_nframes_t nframes); - -private: - DrumKit *kit; - size_t pos; - EventQueue *eventqueue; - - JackClient *jackclient; - jack_port_t *midi_port; -}; - -#endif/*__DRUMGIZMO_AUDIOINPUTENGINEJACKMIDI_H__*/ - diff --git a/drumgizmo/input/jackmidi/jackmidi.cc b/drumgizmo/input/jackmidi/jackmidi.cc deleted file mode 100644 index e632484..0000000 --- a/drumgizmo/input/jackmidi/jackmidi.cc +++ /dev/null @@ -1,252 +0,0 @@ -/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/*************************************************************************** - * jackmidi.cc - * - * Sat Apr 30 21:11:54 CEST 2011 - * Copyright 2011 Bent Bisballe Nyeng - * deva@aasimon.org - ****************************************************************************/ - -/* - * This file is part of DrumGizmo. - * - * DrumGizmo 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. - * - * DrumGizmo 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 DrumGizmo; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. - */ -/* -#include <stdlib.h> - -#include <event.h> -#include <string> - -#include <stdio.h> -#include <midimapper.h> -#include <midimapparser.h> - -#define NOTE_ON 0x90 - -#include "../../jackclient.h" - -#include <jack/midiport.h> - -class JackMidi : public JackProcess { -public: - JackMidi(); - virtual ~JackMidi(); - - bool init(int instruments, char *inames[]); - - void setParm(std::string parm, std::string value); - - bool start(); - void stop(); - - void pre(); - event_t *run(size_t pos, size_t len, size_t *nevents); - void post(); - - void jack_process(jack_nframes_t nframes); - -private: - void loadMap(std::string map) {} - - JackClient *jackclient{nullptr}; - jack_port_t *midi_port{nullptr}; - - size_t pos; - - event_t *list; - size_t listsize; - - std::string midimapfile; - MidiMapper mmap; -}; - -JackMidi::JackMidi() -{ - pos = 0; - - list = (event_t *)malloc(sizeof(event_t) * 1000); - listsize = 0; -} - -JackMidi::~JackMidi() -{ -} - -bool JackMidi::init(int instruments, char *inames[]) -{ - midi_port = jack_port_register(jackclient->jack_client, - "drumgizmo_midiin", - JACK_DEFAULT_MIDI_TYPE, - JackPortIsInput,// | JackPortIsTerminal, - 0); - - MidiMapParser p(midimapfile); - if(p.parse()) return false; - mmap.midimap = p.midimap; - - for(int i = 0; i < instruments; i++) { - mmap.instrmap[inames[i]] = i; - } - - return true; -} - -void JackMidi::setParm(std::string parm, std::string value) -{ - if(parm == "midimap") midimapfile = value; - if(parm == "jack_client") { - sscanf(value.c_str(), "%p", &jackclient); - if(jackclient) jackclient->addJackProcess(this); - } -} - -bool JackMidi::start() -{ - // jackclient->activate(); - return true; -} - -void JackMidi::stop() -{ -} - -void JackMidi::pre() -{ -} - -event_t *JackMidi::run(size_t pos, size_t len, size_t *nevents) -{ - *nevents = listsize; - event_t *l = list; - list = (event_t *)malloc(sizeof(event_t) * 1000); - listsize = 0; - return l; -} - -void JackMidi::jack_process(jack_nframes_t nframes) -{ - // printf("i"); fflush(stdout); - - void *midibuffer = jack_port_get_buffer(midi_port, nframes); - - jack_nframes_t midievents = jack_midi_get_event_count(midibuffer); - - for(jack_nframes_t i = 0; i < midievents; i++) { - jack_midi_event_t event; - jack_midi_event_get(&event, midibuffer, i); - - if(event.size != 3) continue; - if((event.buffer[0] & NOTE_ON) != NOTE_ON) continue; - - int key = event.buffer[1]; - int velocity = event.buffer[2]; - - printf("Event key:%d vel:%d\n", key, velocity); - - int k = mmap.lookup(key); - if(k != -1) { - - if(velocity) { - list[listsize].type = TYPE_ONSET; - list[listsize].instrument = k; - list[listsize].velocity = velocity / 127.0; - list[listsize].offset = event.time; - listsize++; - } - } - } - - jack_midi_clear_buffer(midibuffer); - - pos += nframes; -} - -void JackMidi::post() -{ -} - -extern "C" { - void *create() - { - return new JackMidi(); - } - - void destroy(void *h) - { - JackMidi *jackmidi = (JackMidi*)h; - delete jackmidi; - } - - bool init(void *h, int i, char *inames[]) - { - JackMidi *jackmidi = (JackMidi*)h; - return jackmidi->init(i, inames); - } - - void setparm(void *h, const char *parm, const char *value) - { - JackMidi *jackmidi = (JackMidi*)h; - jackmidi->setParm(parm, value); - } - - bool start(void *h) - { - JackMidi *jackmidi = (JackMidi*)h; - return jackmidi->start(); - } - - void stop(void *h) - { - JackMidi *jackmidi = (JackMidi*)h; - jackmidi->stop(); - } - - void pre(void *h) - { - JackMidi *jackmidi = (JackMidi*)h; - jackmidi->pre(); - } - - event_t *run(void *h, size_t pos, size_t len, size_t *nev) - { - JackMidi *jackmidi = (JackMidi*)h; - return jackmidi->run(pos, len, nev); - } - - void post(void *h) - { - JackMidi *jackmidi = (JackMidi*)h; - jackmidi->post(); - } -} -*/ - -#ifdef TEST_AUDIOINPUTENGINEJACKMIDI -//Additional dependency files -//deps: -//Required cflags (autoconf vars may be used) -//cflags: -//Required link options (autoconf vars may be used) -//libs: -#include "test.h" - -TEST_BEGIN; - -// TODO: Put some testcode here (see test.h for usable macros). - -TEST_END; - -#endif/*TEST_AUDIOINPUTENGINEJACKMIDI*/ diff --git a/drumgizmo/input/midifile/Makefile.am b/drumgizmo/input/midifile/Makefile.am deleted file mode 100644 index 9ade475..0000000 --- a/drumgizmo/input/midifile/Makefile.am +++ /dev/null @@ -1,36 +0,0 @@ - -midifilesources = \ - midifile.cc \ - $(top_srcdir)/src/midimapper.cc \ - $(top_srcdir)/src/midimapparser.cc \ - $(top_srcdir)/src/saxparser.cc \ - $(top_srcdir)/hugin/hugin.c - - -if HAVE_INPUT_MIDIFILE - -midifileltlibs = midifile.la -midifilebuildsources = $(midifilesources) - -else - -midifileltlibs = -midifilebuildsources = - -endif - -EXTRA_DIST = $(midifilesources) - -lib_LTLIBRARIES = $(midifileltlibs) - -libdir = $(INPUT_PLUGIN_DIR) - -AM_CPPFLAGS = -I$(top_srcdir)/src -I$(top_srcdir)/include $(SMF_CFLAGS) \ - $(EXPAT_CFLAGS) -I$(top_srcdir)/hugin -DWITH_HUG_MUTEX -midifile_la_LDFLAGS = -module -avoid-version -shared -midifile_la_LIBADD = $(EXPAT_LIBS) $(SMF_LIBS) -midifile_la_CXXFLAGS =$(EXPAT_CFLAGS) -midifile_la_SOURCES = $(midifilebuildsources) - -install-exec-hook: - rm -f $(DESTDIR)$(libdir)/midifile.la diff --git a/drumgizmo/input/midifile/audioinputenginemidifile.cc b/drumgizmo/input/midifile/audioinputenginemidifile.cc deleted file mode 100644 index 878ca1b..0000000 --- a/drumgizmo/input/midifile/audioinputenginemidifile.cc +++ /dev/null @@ -1,44 +0,0 @@ -/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/*************************************************************************** - * audioinputenginemidifile.cc - * - * Sun Feb 27 11:43:32 CET 2011 - * Copyright 2011 Bent Bisballe Nyeng - * deva@aasimon.org - ****************************************************************************/ - -/* - * This file is part of DrumGizmo. - * - * DrumGizmo 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. - * - * DrumGizmo 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 DrumGizmo; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. - */ -#include "audioinputenginemidifile.h" - -#ifdef TEST_AUDIOINPUTENGINEMIDIFILE -//Additional dependency files -//deps: -//Required cflags (autoconf vars may be used) -//cflags: -//Required link options (autoconf vars may be used) -//libs: -#include "test.h" - -TEST_BEGIN; - -// TODO: Put some testcode here (see test.h for usable macros). - -TEST_END; - -#endif/*TEST_AUDIOINPUTENGINEMIDIFILE*/ diff --git a/drumgizmo/input/midifile/audioinputenginemidifile.h b/drumgizmo/input/midifile/audioinputenginemidifile.h deleted file mode 100644 index 6bb9ff6..0000000 --- a/drumgizmo/input/midifile/audioinputenginemidifile.h +++ /dev/null @@ -1,41 +0,0 @@ -/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/*************************************************************************** - * audioinputenginemidifile.h - * - * Sun Feb 27 11:43:32 CET 2011 - * Copyright 2011 Bent Bisballe Nyeng - * deva@aasimon.org - ****************************************************************************/ - -/* - * This file is part of DrumGizmo. - * - * DrumGizmo 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. - * - * DrumGizmo 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 DrumGizmo; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. - */ -#ifndef __DRUMGIZMO_AUDIOINPUTENGINEMIDIFILE_H__ -#define __DRUMGIZMO_AUDIOINPUTENGINEMIDIFILE_H__ - -#include "audioinputengine.h" - -class AudioInputEngineMidiFile : public AudioInputEngine { -public: - AudioInputEngineMidiFile() {} - ~AudioInputEngineMidiFile() {} - - bool init(EventQueue *eventqueue, DrumKit *drumkit) { return true; } - void run(size_t pos, size_t len) {} -}; - -#endif/*__DRUMGIZMO_AUDIOINPUTENGINEMIDIFILE_H__*/ diff --git a/drumgizmo/input/midifile/midifile.cc b/drumgizmo/input/midifile/midifile.cc deleted file mode 100644 index d73d382..0000000 --- a/drumgizmo/input/midifile/midifile.cc +++ /dev/null @@ -1,271 +0,0 @@ -/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/*************************************************************************** - * dummy.cc - * - * Sat Apr 30 21:11:54 CEST 2011 - * Copyright 2011 Bent Bisballe Nyeng - * deva@aasimon.org - ****************************************************************************/ - -/* - * This file is part of DrumGizmo. - * - * DrumGizmo 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. - * - * DrumGizmo 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 DrumGizmo; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. - */ -#include <stdlib.h> - -#include <string> -#include <event.h> - -#include <smf.h> - -#include <midimapper.h> -#include <midimapparser.h> - -#define NOTE_ON 0x90 - -class MidiFile { -public: - MidiFile(); - ~MidiFile() {} - - bool init(int instruments, char *inames[]); - - void setParm(std::string parm, std::string value); - - bool start(); - void stop(); - - void pre(); - event_t *run(size_t pos, size_t len, size_t *nevents); - void post(); - -private: - smf_t *smf; - smf_event_t *cur_event; - - MidiMapper mmap; - - // Parameters - std::string filename; - float speed; - int track; - std::string midimapfile; - bool loop; - double offset; -}; - -MidiFile::MidiFile() -{ - cur_event = NULL; - smf = NULL; - - speed = 1.0; - track = -1; // -1 is OMNI/all tracks - loop = false; - offset = 0; -} - -bool MidiFile::init(int instruments, char *inames[]) -{ - if(filename == "") { - fprintf(stderr, "Missing midifile argument 'file'\n"); - return false; - } - - if(midimapfile == "") { - fprintf(stderr, "Missing midimapfile argument 'midimap'.\n"); - return false; - } - - smf = smf_load(filename.c_str()); - - if(!smf) { - fprintf(stderr, "Could not open midifile '%s'.\n", filename.c_str()); - return false; - } - - MidiMapParser p(midimapfile); - if(p.parse()) { - fprintf(stderr, "Could not parse midimapfile '%s'.\n", midimapfile.c_str()); - return false; - } - mmap.midimap = p.midimap; - - for(int i = 0; i < instruments; i++) { - mmap.instrmap[inames[i]] = i; - } - - return true; -} - -void MidiFile::setParm(std::string parm, std::string value) -{ - if(parm == "file") filename = value; - if(parm == "speed") speed = atof(value.c_str()); - if(parm == "track") track = atoi(value.c_str()); - if(parm == "midimap") midimapfile = value; - if(parm == "loop") loop = true; -} - -bool MidiFile::start() -{ - return true; -} - -void MidiFile::stop() -{ -} - -void MidiFile::pre() -{ -} - -event_t *MidiFile::run(size_t pos, size_t len, size_t *nevents) -{ - event_t *evs = NULL; - size_t nevs = 0; - - double cur_max_time = (double)(pos + len) / (44100.0 / speed); - cur_max_time -= offset; - // double cur_min_time = (double)(pos) / (44100.0 / speed); - - if(!cur_event) cur_event = smf_get_next_event(smf); - - while(cur_event && cur_event->time_seconds < cur_max_time) { - if(!smf_event_is_metadata(cur_event)) { - if( (cur_event->midi_buffer_length == 3) && - ((cur_event->midi_buffer[0] & NOTE_ON) == NOTE_ON) && - (track == -1 || cur_event->track_number == track) && - cur_event->midi_buffer[2] > 0) { - - if(evs == NULL) evs = (event_t *)malloc(sizeof(event_t) * 1000); - - int key = cur_event->midi_buffer[1]; - int velocity = cur_event->midi_buffer[2]; - - evs[nevs].type = TYPE_ONSET; - size_t evpos = cur_event->time_seconds * (44100.0 / speed); - evs[nevs].offset = evpos - pos; - - int i = mmap.lookup(key); - if(i != -1) { - evs[nevs].instrument = i; - evs[nevs].velocity = velocity / 127.0; - - nevs++; - if(nevs > 999) { - fprintf(stderr, "PANIC!\n"); - break; - } - } - } - } - - cur_event = smf_get_next_event(smf); - } - - if(!cur_event) { - if(loop) { - smf_rewind(smf); - offset += cur_max_time; - } else { - if(evs == NULL) evs = (event_t *)malloc(sizeof(event_t) * 1000); - evs[nevs].type = TYPE_STOP; - evs[nevs].offset = len - 1; - nevs++; - } - } - - *nevents = nevs; - - return evs; -} - -void MidiFile::post() -{ -} - -extern "C" { - void *create() - { - return new MidiFile(); - } - - void destroy(void *h) - { - MidiFile *midifile = (MidiFile*)h; - delete midifile; - } - - bool init(void *h, int i, char *inames[]) - { - MidiFile *midifile = (MidiFile*)h; - return midifile->init(i, inames); - } - - void setparm(void *h, const char *parm, const char *value) - { - MidiFile *midifile = (MidiFile*)h; - midifile->setParm(parm, value); - } - - bool start(void *h) - { - MidiFile *midifile = (MidiFile*)h; - return midifile->start(); - } - - void stop(void *h) - { - MidiFile *midifile = (MidiFile*)h; - midifile->stop(); - } - - void pre(void *h) - { - MidiFile *midifile = (MidiFile*)h; - midifile->pre(); - } - - event_t *run(void *h, size_t pos, size_t len, size_t *nev) - { - MidiFile *midifile = (MidiFile*)h; - return midifile->run(pos, len, nev); - } - - void post(void *h) - { - MidiFile *midifile = (MidiFile*)h; - midifile->post(); - } -} - -#ifdef TEST_AUDIOINPUTENGINEMIDIFILE -//Additional dependency files -//deps: -//Required cflags (autoconf vars may be used) -//cflags: -//Required link options (autoconf vars may be used) -//libs: -#include "test.h" - -TEST_BEGIN; - -// TODO: Put some testcode here (see test.h for usable macros). - -TEST_END; - -#endif/*TEST_AUDIOINPUTENGINEMIDIFILE*/ diff --git a/drumgizmo/input/test/Makefile.am b/drumgizmo/input/test/Makefile.am deleted file mode 100644 index 35466ab..0000000 --- a/drumgizmo/input/test/Makefile.am +++ /dev/null @@ -1,29 +0,0 @@ - -testsources = \ - test.cc - -if HAVE_INPUT_TEST - -testltlibs = test.la -testbuildsources = $(testsources) - -else - -testltlibs = -testbuildsources = - -endif - -EXTRA_DIST = $(testsources) - -lib_LTLIBRARIES = $(testltlibs) - -libdir = $(INPUT_PLUGIN_DIR) - -AM_CPPFLAGS = -I$(top_srcdir)/include -test_la_LDFLAGS = -module -avoid-version -shared -test_la_LIBADD = -test_la_SOURCES = $(testbuildsources) - -install-exec-hook: - rm -f $(DESTDIR)$(libdir)/test.la diff --git a/drumgizmo/input/test/test.cc b/drumgizmo/input/test/test.cc deleted file mode 100644 index b7b4a7d..0000000 --- a/drumgizmo/input/test/test.cc +++ /dev/null @@ -1,173 +0,0 @@ -/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/*************************************************************************** - * audioinputenginedummy.cc - * - * Sat Apr 30 21:11:54 CEST 2011 - * Copyright 2011 Bent Bisballe Nyeng - * deva@aasimon.org - ****************************************************************************/ - -/* - * This file is part of DrumGizmo. - * - * DrumGizmo 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. - * - * DrumGizmo 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 DrumGizmo; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. - */ -#include <stdlib.h> - -#include <event.h> -#include <string> - -class Test { -public: - Test() { p = 0.1; instr = -1; len = -1; } - ~Test() {} - - bool init(int instruments, char *inames[]); - - void setParm(std::string parm, std::string value); - - bool start(); - void stop(); - - void pre(); - event_t *run(size_t pos, size_t len, size_t *nevents); - void post(); - -private: - float p; - int instr; - int len; -}; - -bool Test::init(int instruments, char *inames[]) -{ - return true; -} - -void Test::setParm(std::string parm, std::string value) -{ - if(parm == "p") p = atof(value.c_str()); - if(parm == "instr") instr = atoi(value.c_str()); - if(parm == "len") len = atoi(value.c_str()); -} - -bool Test::start() -{ - return true; -} - -void Test::stop() -{ -} - -void Test::pre() -{ -} - -event_t *Test::run(size_t pos, size_t nsamples, size_t *nevents) -{ - if((float)rand() / (float)RAND_MAX > p) { - *nevents = 0; - return NULL; - } - - *nevents = 1; - event_t *evs = (event_t *)malloc(sizeof(event_t)); - evs[0].type = TYPE_ONSET; - if(len != -1 && (int)pos > len * 44100) evs[0].type = TYPE_STOP; - - if(instr != -1) evs[0].instrument = instr; - else evs[0].instrument = rand() % 32; - - evs[0].velocity = (float)rand()/(float)RAND_MAX; - evs[0].offset = nsamples?rand()%nsamples:0; - return evs; -} - -void Test::post() -{ -} - -extern "C" { - void *create() - { - return new Test(); - } - - void destroy(void *h) - { - Test *test = (Test*)h; - delete test; - } - - bool init(void *h, int i, char *inames[]) - { - Test *test = (Test*)h; - return test->init(i, inames); - } - - void setparm(void *h, const char *parm, const char *value) - { - Test *test = (Test*)h; - test->setParm(parm, value); - } - - bool start(void *h) - { - Test *test = (Test*)h; - return test->start(); - } - - void stop(void *h) - { - Test *test = (Test*)h; - test->stop(); - } - - void pre(void *h) - { - Test *test = (Test*)h; - test->pre(); - } - - event_t *run(void *h, size_t pos, size_t len, size_t *nev) - { - Test *test = (Test*)h; - return test->run(pos, len, nev); - } - - void post(void *h) - { - Test *test = (Test*)h; - test->post(); - } -} - -#ifdef TEST_AUDIOINPUTENGINETEST -//Additional dependency files -//deps: -//Required cflags (autoconf vars may be used) -//cflags: -//Required link options (autoconf vars may be used) -//libs: -#include "test.h" - -TEST_BEGIN; - -// TODO: Put some testcode here (see test.h for usable macros). - -TEST_END; - -#endif/*TEST_AUDIOINPUTENGINETEST*/ diff --git a/drumgizmo/output/alsa/Makefile.am b/drumgizmo/output/alsa/Makefile.am deleted file mode 100644 index 9f20844..0000000 --- a/drumgizmo/output/alsa/Makefile.am +++ /dev/null @@ -1,29 +0,0 @@ - -alsasources = \ - alsa.cc - -if HAVE_OUTPUT_ALSA - -alsaltlibs = alsa.la -alsabuildsources = $(alsasources) - -else - -alsaltlibs = -alsabuildsources = - -endif - -EXTRA_DIST = $(alsasources) - -lib_LTLIBRARIES = $(alsaltlibs) - -libdir = $(OUTPUT_PLUGIN_DIR) - -AM_CPPFLAGS = -I$(top_srcdir)/src -I$(top_srcdir)/include $(ALSA_CFLAGS) -alsa_la_LDFLAGS = $(ALSA_LIBS) -module -avoid-version -shared -alsa_la_LIBADD = -alsa_la_SOURCES = $(alsabuildsources) - -install-exec-hook: - rm -f $(DESTDIR)$(libdir)/alsa.la diff --git a/drumgizmo/output/alsa/alsa.cc b/drumgizmo/output/alsa/alsa.cc deleted file mode 100644 index 71e0c3d..0000000 --- a/drumgizmo/output/alsa/alsa.cc +++ /dev/null @@ -1,225 +0,0 @@ -/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/*************************************************************************** - * audiooutputenginedummy.cc - * - * Sat Apr 30 21:12:02 CEST 2011 - * Copyright 2011 Bent Bisballe Nyeng - * deva@aasimon.org - ****************************************************************************/ - -/* - * This file is part of DrumGizmo. - * - * DrumGizmo 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. - * - * DrumGizmo 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 DrumGizmo; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. - */ -#include <stdlib.h> - -#include <audiotypes.h> -#include <string> - -// Use the newer ALSA API -#define ALSA_PCM_NEW_HW_PARAMS_API - -#include <asoundlib.h> - -#define T(x, msg) if(x < 0) { printf("%s failed: %s\n", msg, snd_strerror(x)); fflush(stdout); return false; } - -#define BUFSZ 40960 - -class Alsa { -public: - Alsa(); - ~Alsa(); - bool init(int channels, char *cnames[]); - void setParm(std::string parm, std::string value); - bool start(); - void stop(); - void pre(size_t size); - void run(int channel, sample_t* data, size_t size); - void post(size_t size); - size_t samplerate(); - -private: - snd_pcm_t *handle{nullptr}; - snd_pcm_hw_params_t *params{nullptr}; - sample_t *data{nullptr}; - size_t channels{0}; - - // Parameters - std::string device; - unsigned int srate{0}; - snd_pcm_uframes_t frames{0}; -}; - -Alsa::Alsa() -{ - handle = NULL; - data = NULL; - - device = "default"; - srate = 44100; - frames = 32; -} - -Alsa::~Alsa() -{ - if(handle) snd_pcm_close(handle); - if(data) free(data); -} - -bool Alsa::init(int channels, char *cnames[]) -{ - int rc; - - rc = snd_pcm_open(&handle, device.c_str(), SND_PCM_STREAM_PLAYBACK, 0); - T(rc, "snd_pcm_open"); - - this->channels = channels; - if(!handle) { - printf("No handle!\n"); - return false; - } - - // Allocate a hardware parameters object. - snd_pcm_hw_params_alloca(¶ms); - // if(rc < 0) return false; - - // Fill it in with default values. - rc = snd_pcm_hw_params_any(handle, params); - T(rc, "snd_pcm_hw_params_any"); - - rc = snd_pcm_hw_params_set_access(handle, params, - SND_PCM_ACCESS_RW_INTERLEAVED); - T(rc, "snd_pcm_hw_params_set_access"); - - rc = snd_pcm_hw_params_set_format(handle, params, SND_PCM_FORMAT_FLOAT); - T(rc, "snd_pcm_hw_params_set_format"); - - rc = snd_pcm_hw_params_set_channels(handle, params, channels); - T(rc, "snd_pcm_hw_params_set_channels"); - - rc = snd_pcm_hw_params_set_rate_near(handle, params, &srate, 0); - T(rc, "snd_pcm_hw_params_set_rate_near"); - - rc = snd_pcm_hw_params_set_period_size_near(handle, params, &frames, 0); - T(rc, "snd_pcm_hw_params_set_period_size_near"); - - rc = snd_pcm_hw_params(handle, params); - T(rc, "snd_pcm_hw_params"); - - data = (sample_t*)malloc(sizeof(sample_t) * BUFSZ * channels); - - return true; -} - -void Alsa::setParm(std::string parm, std::string value) -{ - if(parm == "dev") device = value; - if(parm == "frames") frames = atoi(value.c_str()); - if(parm == "srate") srate = atoi(value.c_str()); -} - -bool Alsa::start() -{ - return true; -} - -void Alsa::stop() -{ -} - -void Alsa::pre(size_t size) -{ -} - -void Alsa::run(int channel, sample_t* cdata, size_t csize) -{ - // Write channel data in interleaved buffer. - for(size_t i = 0; i < csize; i++) { - data[i * channels + channel] = cdata[i]; - } -} - -void Alsa::post(size_t size) -{ - // Write the interleaved buffer to the soundcard - snd_pcm_writei(handle, data, size); -} - -size_t Alsa::samplerate() -{ - return srate; -} - -extern "C" { - void *create() - { - return new Alsa(); - } - - void destroy(void *h) - { - Alsa *alsa = (Alsa*)h; - delete alsa; - } - - bool init(void *h, int cs, char *cnames[]) - { - Alsa *alsa = (Alsa*)h; - return alsa->init(cs, cnames); - } - - void setparm(void *h, const char *parm, const char *value) - { - Alsa *alsa = (Alsa*)h; - alsa->setParm(parm, value); - } - - bool start(void *h) - { - Alsa *alsa = (Alsa*)h; - return alsa->start(); - } - - void stop(void *h) - { - Alsa *alsa = (Alsa*)h; - alsa->stop(); - } - - void pre(void *h, size_t s) - { - Alsa *alsa = (Alsa*)h; - alsa->pre(s); - } - - void run(void *h, int ch, sample_t *data, size_t size) - { - Alsa *alsa = (Alsa*)h; - alsa->run(ch, data, size); - } - - void post(void *h, size_t s) - { - Alsa *alsa = (Alsa*)h; - alsa->post(s); - } - - size_t samplerate(void *h) - { - Alsa *alsa = (Alsa*)h; - return alsa->samplerate(); - } -} diff --git a/drumgizmo/output/dummy/Makefile.am b/drumgizmo/output/dummy/Makefile.am deleted file mode 100644 index bff3daf..0000000 --- a/drumgizmo/output/dummy/Makefile.am +++ /dev/null @@ -1,29 +0,0 @@ - -dummysources = \ - dummy.cc - -if HAVE_OUTPUT_DUMMY - -dummyltlibs = dummy.la -dummybuildsources = $(dummysources) - -else - -dummyltlibs = -dummybuildsources = - -endif - -EXTRA_DIST = $(dummysources) - -lib_LTLIBRARIES = $(dummyltlibs) - -libdir = $(OUTPUT_PLUGIN_DIR) - -AM_CPPFLAGS = -I$(top_srcdir)/src -I$(top_srcdir)/include -dummy_la_LDFLAGS = -module -avoid-version -shared -dummy_la_LIBADD = -dummy_la_SOURCES = $(dummybuildsources) - -install-exec-hook: - rm -f $(DESTDIR)$(libdir)/dummy.la diff --git a/drumgizmo/output/dummy/dummy.cc b/drumgizmo/output/dummy/dummy.cc deleted file mode 100644 index e60f2b7..0000000 --- a/drumgizmo/output/dummy/dummy.cc +++ /dev/null @@ -1,152 +0,0 @@ -/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/*************************************************************************** - * audiooutputenginedummy.cc - * - * Sat Apr 30 21:12:02 CEST 2011 - * Copyright 2011 Bent Bisballe Nyeng - * deva@aasimon.org - ****************************************************************************/ - -/* - * This file is part of DrumGizmo. - * - * DrumGizmo 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. - * - * DrumGizmo 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 DrumGizmo; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. - */ -#include <stdlib.h> - -#include <audiotypes.h> -#include <string> - -class Dummy { -public: - Dummy(); - ~Dummy(); - bool init(int channels, char *cnames[]); - - void setParm(std::string parm, std::string value); - - bool start(); - void stop(); - - void pre(size_t size); - void run(int channel, sample_t* data, size_t size); - void post(size_t size); - - size_t samplerate(); -}; - -Dummy::Dummy() -{ -} - -Dummy::~Dummy() -{ -} - -bool Dummy::init(int channels, char *cnames[]) -{ - return true; -} - -void Dummy::setParm(std::string parm, std::string value) -{ -} - -bool Dummy::start() -{ - return true; -} - -void Dummy::stop() -{ -} - -void Dummy::pre(size_t size) -{ -} - -void Dummy::run(int channel, sample_t* data, size_t size) -{ -} - -void Dummy::post(size_t size) -{ -} - -size_t Dummy::samplerate() -{ - return 44100; -} - -extern "C" { - void *create() - { - return new Dummy(); - } - - void destroy(void *h) - { - Dummy *dummy = (Dummy*)h; - delete dummy; - } - - bool init(void *h, int cs, char *cnames[]) - { - Dummy *dummy = (Dummy*)h; - return dummy->init(cs, cnames); - } - - void setparm(void *h, const char *parm, const char *value) - { - Dummy *dummy = (Dummy*)h; - dummy->setParm(parm, value); - } - - bool start(void *h) - { - Dummy *dummy = (Dummy*)h; - return dummy->start(); - } - - void stop(void *h) - { - Dummy *dummy = (Dummy*)h; - dummy->stop(); - } - - void pre(void *h, size_t size) - { - Dummy *dummy = (Dummy*)h; - dummy->pre(size); - } - - void run(void *h, int ch, sample_t *data, size_t size) - { - Dummy *dummy = (Dummy*)h; - dummy->run(ch, data, size); - } - - void post(void *h, size_t size) - { - Dummy *dummy = (Dummy*)h; - dummy->post(size); - } - - size_t samplerate(void *h) - { - Dummy *dummy = (Dummy*)h; - return dummy->samplerate(); - } -} diff --git a/drumgizmo/output/jackaudio/Makefile.am b/drumgizmo/output/jackaudio/Makefile.am deleted file mode 100644 index 46cdb23..0000000 --- a/drumgizmo/output/jackaudio/Makefile.am +++ /dev/null @@ -1,31 +0,0 @@ - -jackaudiosources = \ - jackaudio.cc \ - $(top_srcdir)/src/semaphore.cc \ - $(top_srcdir)/hugin/hugin.c - -if HAVE_OUTPUT_JACKAUDIO - -jackaudioltlibs = jackaudio.la -jackaudiobuildsources = $(jackaudiosources) - -else - -jackaudioltlibs = -jackaudiobuildsources = - -endif - -EXTRA_DIST = $(jackaudiosources) - -lib_LTLIBRARIES = $(jackaudioltlibs) - -libdir = $(OUTPUT_PLUGIN_DIR) - -AM_CPPFLAGS = -I$(top_srcdir)/include $(JACK_CFLAGS) -I$(top_srcdir)/hugin -I$(top_srcdir)/src -jackaudio_la_LDFLAGS = $(JACK_LIBS) -module -avoid-version -shared -jackaudio_la_LIBADD = -jackaudio_la_SOURCES = $(jackaudiobuildsources) - -install-exec-hook: - rm -f $(DESTDIR)$(libdir)/jackaudio.la diff --git a/drumgizmo/output/jackaudio/jackaudio.cc b/drumgizmo/output/jackaudio/jackaudio.cc deleted file mode 100644 index 3e489a9..0000000 --- a/drumgizmo/output/jackaudio/jackaudio.cc +++ /dev/null @@ -1,222 +0,0 @@ -/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/*************************************************************************** - * jackaudio.cc - * - * Sat Apr 30 21:11:54 CEST 2011 - * Copyright 2011 Bent Bisballe Nyeng - * deva@aasimon.org - ****************************************************************************/ - -/* - * This file is part of DrumGizmo. - * - * DrumGizmo 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. - * - * DrumGizmo 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 DrumGizmo; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. - */ -/* -#include <stdlib.h> - -#include <string> -#include <audiotypes.h> -#include <semaphore.h> -#include <stdlib.h> - -#define NOTE_ON 0x90 - -#include "../../jackclient.h" -#include <stdio.h> - -class JackAudio : public JackProcess { -public: - JackAudio(); - ~JackAudio(); - bool init(int channels, char *cnames[]); - - void setParm(std::string parm, std::string value); - - bool start(); - void stop(); - - void pre(size_t size); - void run(int channel, sample_t* data, size_t size); - void post(size_t size); - - void jack_process(jack_nframes_t nframes); - - size_t bufsize(); - size_t samplerate(); - -private: - JackClient *jackclient{nullptr}; - jack_port_t *output_port[64] = {}; - size_t nchannels{0}; - sample_t **channels{nullptr}; - Semaphore sem; -}; - -JackAudio::JackAudio() : sem("jackaudio") -{ -} - -JackAudio::~JackAudio() -{ -} - -bool JackAudio::init(int nchannels, char *cnames[]) -{ - this->nchannels = nchannels; - channels = (sample_t**)malloc(nchannels * sizeof(sample_t*)); - - for(int i = 0; i < nchannels; i++) { - char buf[32]; - sprintf(buf, "%d", i + 1); - std::string name; - name += buf; - name += "-"; - name += cnames[i]; - output_port[i] = jack_port_register(jackclient->jack_client, - name.c_str(), - JACK_DEFAULT_AUDIO_TYPE, - JackPortIsOutput, 0); - channels[i] = (sample_t*)malloc(bufsize() * sizeof(sample_t)); - } - return true; -} - -void JackAudio::setParm(std::string parm, std::string value) -{ - if(parm == "jack_client") { - sscanf(value.c_str(), "%p", &jackclient); - if(jackclient) jackclient->addJackProcess(this); - } -} - -bool JackAudio::start() -{ - //jackclient->activate(); - return true; -} - -void JackAudio::stop() -{ -} - -void JackAudio::pre(size_t size) -{ -} - -void JackAudio::run(int channel, sample_t* data, size_t size) -{ - // Copy engine data to ringbuffer. - for(size_t i = 0; i < size; i++) { - channels[channel][i] = data[i]; - } -} - -void JackAudio::post(size_t size) -{ - sem.wait(); -} - -void JackAudio::jack_process(jack_nframes_t nframes) -{ - //printf("o"); fflush(stdout); - for(size_t c = 0; c < nchannels; c++) { - jack_default_audio_sample_t *out = - (jack_default_audio_sample_t *) jack_port_get_buffer(output_port[c], - nframes); - for(size_t i = 0; i < nframes; i++) { - out[i] = channels[c][i]; - } - } - sem.post(); -} - -size_t JackAudio::bufsize() -{ - return jack_get_buffer_size(jackclient->jack_client); -} - -size_t JackAudio::samplerate() -{ - return jack_get_sample_rate(jackclient->jack_client); -} - -extern "C" { - void *create() - { - return new JackAudio(); - } - - void destroy(void *h) - { - JackAudio *jack = (JackAudio*)h; - delete jack; - } - - bool init(void *h, int cs, char *cnames[]) - { - JackAudio *jack = (JackAudio*)h; - return jack->init(cs, cnames); - } - - void setparm(void *h, const char *parm, const char *value) - { - JackAudio *jack = (JackAudio*)h; - jack->setParm(parm, value); - } - - bool start(void *h) - { - JackAudio *jack = (JackAudio*)h; - return jack->start(); - } - - void stop(void *h) - { - JackAudio *jack = (JackAudio*)h; - jack->stop(); - } - - void pre(void *h, size_t s) - { - JackAudio *jack = (JackAudio*)h; - jack->pre(s); - } - - void run(void *h, int ch, sample_t *data, size_t size) - { - JackAudio *jack = (JackAudio*)h; - jack->run(ch, data, size); - } - - void post(void *h, size_t s) - { - JackAudio *jack = (JackAudio*)h; - jack->post(s); - } - - size_t bufsize(void *h) - { - JackAudio *jack = (JackAudio*)h; - return jack->bufsize(); - } - - size_t samplerate(void *h) - { - JackAudio *jack = (JackAudio*)h; - return jack->samplerate(); - } -} -*/ diff --git a/drumgizmo/output/wavfile/Makefile.am b/drumgizmo/output/wavfile/Makefile.am deleted file mode 100644 index ad26294..0000000 --- a/drumgizmo/output/wavfile/Makefile.am +++ /dev/null @@ -1,29 +0,0 @@ - -wavfilesources = \ - wavfile.cc - -if HAVE_OUTPUT_WAVFILE - -wavfileltlibs = wavfile.la -wavfilebuildsources = $(wavfilesources) - -else - -wavfileltlibs = -wavfilebuildsources = - -endif - -EXTRA_DIST = $(wavfilesources) - -lib_LTLIBRARIES = $(wavfileltlibs) - -libdir = $(OUTPUT_PLUGIN_DIR) - -AM_CPPFLAGS = -I$(top_srcdir)/src -I$(top_srcdir)/include $(SNDFILE_CFLAGS) -wavfile_la_LDFLAGS = $(SNDFILE_LIBS) -module -avoid-version -shared -wavfile_la_LIBADD = -wavfile_la_SOURCES = $(wavfilebuildsources) - -install-exec-hook: - rm -f $(DESTDIR)$(libdir)/wavfile.la diff --git a/drumgizmo/output/wavfile/wavfile.cc b/drumgizmo/output/wavfile/wavfile.cc deleted file mode 100644 index 8401f80..0000000 --- a/drumgizmo/output/wavfile/wavfile.cc +++ /dev/null @@ -1,197 +0,0 @@ -/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ -/*************************************************************************** - * wavfile.cc - * - * Sat Apr 30 21:12:02 CEST 2011 - * Copyright 2011 Bent Bisballe Nyeng - * deva@aasimon.org - ****************************************************************************/ - -/* - * This file is part of DrumGizmo. - * - * DrumGizmo 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. - * - * DrumGizmo 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 DrumGizmo; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. - */ -#include <stdlib.h> - -#include <audiotypes.h> -#include <string> -#include <memory.h> - -#include <sndfile.h> - -#define T(x, msg) if(x < 0) { printf("%s failed: %s\n", msg, snd_strerror(x)); fflush(stdout); return false; } - -class WavFile { -public: - WavFile(); - ~WavFile(); - bool init(int channels, char *cnames[]); - void setParm(std::string parm, std::string value); - bool start(); - void stop(); - void pre(size_t size); - void run(int channel, sample_t* data, size_t size); - void post(size_t size); - size_t samplerate(); - -private: - SF_INFO sf_info; - SNDFILE **fh{nullptr}; - size_t channels{0}; - - // Parameters - std::string filename; -}; - -WavFile::WavFile() -{ - fh = NULL; - filename = "output"; - - memset(&sf_info, 0, sizeof(sf_info)); - sf_info.channels = 1;//channels; - sf_info.format = SF_FORMAT_WAV | SF_FORMAT_FLOAT; - sf_info.samplerate = 44100; -} - -WavFile::~WavFile() -{ - if(fh == NULL) return; - - for(size_t i = 0; i < channels; i++) { - if(fh[i]) sf_close(fh[i]); - } - - if(fh) free(fh); -} - -bool WavFile::init(int channels, char *cnames[]) -{ - this->channels = channels; - - fh = (SNDFILE **)malloc(sizeof(SNDFILE *)*channels); - - for(size_t i = 0; i < this->channels; i++) fh[i] = NULL; - - for(size_t i = 0; i < this->channels; i++) { - char fname[512]; - - sprintf(fname, "%s%s-%d.wav", filename.c_str(), cnames[i], (int)i); - // printf("[%s]\n", fname); - - fh[i] = sf_open(fname, SFM_WRITE, &sf_info); - if(!fh[i]) { - printf("Write error...\n"); - return false; - } - } - - return true; -} - -void WavFile::setParm(std::string parm, std::string value) -{ - if(parm == "file") filename = value; - if(parm == "srate") sf_info.samplerate = atoi(value.c_str()); -} - -bool WavFile::start() -{ - return true; -} - -void WavFile::stop() -{ -} - -void WavFile::pre(size_t size) -{ -} - -void WavFile::run(int channel, sample_t* cdata, size_t csize) -{ - if(channel < (int)channels) sf_writef_float(fh[channel], cdata, csize); -} - -void WavFile::post(size_t size) -{ -} - -size_t WavFile::samplerate() -{ - return sf_info.samplerate; -} - -extern "C" { - void *create() - { - return new WavFile(); - } - - void destroy(void *h) - { - WavFile *sndfile = (WavFile*)h; - delete sndfile; - } - - bool init(void *h, int cs, char *cnames[]) - { - WavFile *sndfile = (WavFile*)h; - return sndfile->init(cs, cnames); - } - - void setparm(void *h, const char *parm, const char *value) - { - WavFile *sndfile = (WavFile*)h; - sndfile->setParm(parm, value); - } - - bool start(void *h) - { - WavFile *sndfile = (WavFile*)h; - return sndfile->start(); - } - - void stop(void *h) - { - WavFile *sndfile = (WavFile*)h; - sndfile->stop(); - } - - void pre(void *h, size_t s) - { - WavFile *sndfile = (WavFile*)h; - sndfile->pre(s); - } - - void run(void *h, int ch, sample_t *data, size_t size) - { - WavFile *sndfile = (WavFile*)h; - sndfile->run(ch, data, size); - } - - void post(void *h, size_t s) - { - WavFile *sndfile = (WavFile*)h; - sndfile->post(s); - } - - size_t samplerate(void *h) - { - WavFile *wavfile = (WavFile*)h; - return wavfile->samplerate(); - } -} |