summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--drumgizmo/audioinputenginedl.cc251
-rw-r--r--drumgizmo/audioinputenginedl.h77
-rw-r--r--drumgizmo/audiooutputenginedl.cc197
-rw-r--r--drumgizmo/audiooutputenginedl.h90
-rw-r--r--drumgizmo/input/Makefile.am2
-rw-r--r--drumgizmo/input/dummy/Makefile.am29
-rw-r--r--drumgizmo/input/dummy/dummy.cc185
-rw-r--r--drumgizmo/input/jackmidi/Makefile.am34
-rw-r--r--drumgizmo/input/jackmidi/audioinputenginejackmidi.cc153
-rw-r--r--drumgizmo/input/jackmidi/audioinputenginejackmidi.h61
-rw-r--r--drumgizmo/input/jackmidi/jackmidi.cc252
-rw-r--r--drumgizmo/input/midifile/Makefile.am36
-rw-r--r--drumgizmo/input/midifile/audioinputenginemidifile.cc44
-rw-r--r--drumgizmo/input/midifile/audioinputenginemidifile.h41
-rw-r--r--drumgizmo/input/midifile/midifile.cc271
-rw-r--r--drumgizmo/input/test/Makefile.am29
-rw-r--r--drumgizmo/input/test/test.cc173
-rw-r--r--drumgizmo/output/alsa/Makefile.am29
-rw-r--r--drumgizmo/output/alsa/alsa.cc225
-rw-r--r--drumgizmo/output/dummy/Makefile.am29
-rw-r--r--drumgizmo/output/dummy/dummy.cc152
-rw-r--r--drumgizmo/output/jackaudio/Makefile.am31
-rw-r--r--drumgizmo/output/jackaudio/jackaudio.cc222
-rw-r--r--drumgizmo/output/wavfile/Makefile.am29
-rw-r--r--drumgizmo/output/wavfile/wavfile.cc197
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(&params);
- // 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();
- }
-}