diff options
author | Christian Glöckner <cgloeckner@freenet.de> | 2016-01-21 16:42:37 +0100 |
---|---|---|
committer | André Nusser <andre.nusser@googlemail.com> | 2016-02-09 09:02:18 +0100 |
commit | 3ab30fd4168217894ee781cf93df522d3565cec8 (patch) | |
tree | fdb1da6cd78e9d3ae182b7b64e742e505a336436 | |
parent | a0a16d9cdb9d0522053c2e830b7440e9e96231a9 (diff) |
Made midi-in-wav-out work again
-rw-r--r-- | drumgizmo/Makefile.am | 16 | ||||
-rw-r--r-- | drumgizmo/enginefactory.h | 1 | ||||
-rw-r--r-- | drumgizmo/input/midifile.h | 4 | ||||
-rw-r--r-- | drumgizmo/output/wavfile.cc | 24 | ||||
-rw-r--r-- | drumgizmo/output/wavfile.h | 168 |
5 files changed, 26 insertions, 187 deletions
diff --git a/drumgizmo/Makefile.am b/drumgizmo/Makefile.am index 137ea7b..7044303 100644 --- a/drumgizmo/Makefile.am +++ b/drumgizmo/Makefile.am @@ -8,9 +8,9 @@ SUBDIRS = input output bin_PROGRAMS = drumgizmo -drumgizmo_LDADD = $(DRUMGIZMO_LIBS) $(PTHREAD_LIBS) -ldl $(JACK_LIBS) +drumgizmo_LDADD = $(DRUMGIZMO_LIBS) $(PTHREAD_LIBS) $(SMF_LIBS) -ldl $(JACK_LIBS) -drumgizmo_CXXFLAGS = $(SNDFILE_CXXFLAGS) $(PTHREAD_CFLAGS) $(EXPAT_CFLAGS) \ +drumgizmo_CXXFLAGS = $(SNDFILE_CXXFLAGS) $(PTHREAD_CFLAGS) $(SMF_CFLAGS) $(EXPAT_CFLAGS) \ -I$(top_srcdir)/include -I$(top_srcdir)/src \ -I$(top_srcdir)/hugin -DWITH_HUG_MUTEX -DWITH_HUG_FILTER \ $(JACK_CFLAGS) $(SSEFLAGS) \ @@ -20,18 +20,20 @@ drumgizmo_CXXFLAGS = $(SNDFILE_CXXFLAGS) $(PTHREAD_CFLAGS) $(EXPAT_CFLAGS) \ drumgizmo_CFLAGS = -DWITH_HUG_MUTEX -DWITH_HUG_FILTER drumgizmo_SOURCES = \ - audioinputenginedl.cc \ - audiooutputenginedl.cc \ drumgizmoc.cc \ jackclient.cc \ + enginefactory.cc \ + input/midifile.cc \ + output/wavfile.cc \ $(DRUMGIZMO_SOURCES) \ $(top_srcdir)/hugin/hugin.c \ $(top_srcdir)/hugin/hugin_filter.c EXTRA_DIST = \ - audioinputenginedl.h \ - audiooutputenginedl.h \ drumgizmoc.h \ - jackclient.h + jackclient.h \ + enginefactory.h \ + input/midifile.h \ + output/wavfile.h endif diff --git a/drumgizmo/enginefactory.h b/drumgizmo/enginefactory.h index 93624b9..613e49f 100644 --- a/drumgizmo/enginefactory.h +++ b/drumgizmo/enginefactory.h @@ -29,6 +29,7 @@ #include "cpp11fix.h" // required for c++11 #include "audioinputengine.h" +#include "audiooutputengine.h" using InputEnginePtr = std::unique_ptr<AudioInputEngine>; using OutputEnginePtr = std::unique_ptr<AudioOutputEngine>; diff --git a/drumgizmo/input/midifile.h b/drumgizmo/input/midifile.h index c2fcdb6..85abfc9 100644 --- a/drumgizmo/input/midifile.h +++ b/drumgizmo/input/midifile.h @@ -34,8 +34,6 @@ #include <midimapper.h> #include <midimapparser.h> -#define NOTE_ON 0x90 - class MidifileInputEngine : public AudioInputEngine { public: @@ -56,7 +54,7 @@ class MidifileInputEngine smf_t* smf; smf_event_t* current_event; - MidiMapper midiMapper; + MidiMapper midi_mapper; std::string file, midimap; float speed; diff --git a/drumgizmo/output/wavfile.cc b/drumgizmo/output/wavfile.cc index e0c18cb..7a59892 100644 --- a/drumgizmo/output/wavfile.cc +++ b/drumgizmo/output/wavfile.cc @@ -24,6 +24,8 @@ * along with DrumGizmo; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. */ +#include <cassert> + #include "wavfile.h" WavfileOutputEngine::WavfileOutputEngine() @@ -31,7 +33,7 @@ WavfileOutputEngine::WavfileOutputEngine() , channels{} , file{"output"} { info.frames = 0; - info.samplerrate = 44100; + info.samplerate = 44100; info.channels = 1; info.format = SF_FORMAT_WAV | SF_FORMAT_FLOAT; info.sections = 0; @@ -46,13 +48,13 @@ WavfileOutputEngine::~WavfileOutputEngine() { } } -bool WavfileOutputEngine::init(Channels channels) { +bool WavfileOutputEngine::init(Channels data) { channels.clear(), - channels.resize(channels.size(), nullptr); - for (auto i = 0u; i < channels.size(); ++i) { + channels.resize(data.size()); // value-initialized with null + for (auto i = 0u; i < data.size(); ++i) { // write channel to file - auto fname = file + channels[i]->name + "-" + std::to_string(i); - channels[i] = sf_open(fname, SFM_WRITE, &info); + auto fname = file + data[i].name + "-" + std::to_string(i) + ".wav"; + channels[i] = sf_open(fname.c_str(), SFM_WRITE, &info); if (channels[i] == nullptr) { printf("Write error...\n"); return false; @@ -64,10 +66,10 @@ bool WavfileOutputEngine::init(Channels channels) { void WavfileOutputEngine::setParm(std::string parm, std::string value) { if (parm == "file") { file = value; - } else if (parm == "srate") {[ + } else if (parm == "srate") { info.samplerate = std::stoi(value); } else { - printf("Unsupported wavfile parameter '%s'\n", parm); + printf("Unsupported wavfile parameter '%s'\n", parm.c_str()); } } @@ -83,11 +85,13 @@ void WavfileOutputEngine::pre(size_t nsamples) { void WavfileOutputEngine::run(int ch, sample_t* samples, size_t nsamples) { if (ch >= channels.size()) { - printf("Invalid channel %d (%d channels available)", ch, channels.size()); + printf("Invalid channel %d (%lu channels available)", ch, channels.size()); return; } - sf_writef_float(channels[ch], samples, nsampels); + assert(channels[ch] != nullptr); + assert(samples != nullptr); + sf_writef_float(channels[ch], samples, nsamples); } void WavfileOutputEngine::post(size_t nsamples) { diff --git a/drumgizmo/output/wavfile.h b/drumgizmo/output/wavfile.h index 0f93049..5aa9306 100644 --- a/drumgizmo/output/wavfile.h +++ b/drumgizmo/output/wavfile.h @@ -39,7 +39,7 @@ class WavfileOutputEngine ~WavfileOutputEngine(); // based on AudioOutputEngine - bool init(Channels channels) override; + bool init(Channels data) override; void setParm(std::string parm, std::string value) override; bool start() override; void stop() override; @@ -55,169 +55,3 @@ class WavfileOutputEngine std::string file; }; - - - -#include <stdlib.h> - -#include <audiotypes.h> -#include <string> -#include <memory.h> - - -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: - -}; - -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 override; 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 override; i < this->channels; i++) fh[i] = NULL; - - for(size_t i override; 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(); - } -} |