diff options
| author | Goran Mekić <meka@tilda.center> | 2017-12-30 15:55:53 +0100 | 
|---|---|---|
| committer | Goran Mekić <meka@tilda.center> | 2017-12-30 15:55:53 +0100 | 
| commit | eb10ac5e8abd41c386d05e555406ec92a54f0164 (patch) | |
| tree | 70cd659a85d49679debf49fe7da25ffa5908234a /drumgizmo | |
| parent | 992750a805d21de4ffcf7f4382fea8aa1f58c3b7 (diff) | |
| parent | 74f18e24e100b487184e3dd7a57fe1609f645654 (diff) | |
Merge branch 'feature/oss-midi'
Diffstat (limited to 'drumgizmo')
| -rw-r--r-- | drumgizmo/Makefile.am | 6 | ||||
| -rw-r--r-- | drumgizmo/drumgizmoc.cc | 1 | ||||
| -rw-r--r-- | drumgizmo/enginefactory.cc | 9 | ||||
| -rw-r--r-- | drumgizmo/enginefactory.h | 9 | ||||
| -rw-r--r-- | drumgizmo/input/ossmidi.cc | 132 | ||||
| -rw-r--r-- | drumgizmo/input/ossmidi.h | 54 | 
6 files changed, 211 insertions, 0 deletions
| diff --git a/drumgizmo/Makefile.am b/drumgizmo/Makefile.am index de5cad6..940630a 100644 --- a/drumgizmo/Makefile.am +++ b/drumgizmo/Makefile.am @@ -72,6 +72,11 @@ drumgizmo_SOURCES += output/oss.cc  drumgizmo_CXXFLAGS += -DHAVE_OUTPUT_OSS  endif # HAVE_OUTPUT_OSS +if HAVE_INPUT_OSSMIDI +drumgizmo_SOURCES += input/ossmidi.cc +drumgizmo_CXXFLAGS += -DHAVE_INPUT_OSSMIDI +endif # HAVE_INPUT_OSSMIDI +  # Only compile jackclient.cc if at least one of the jack modules are included.  if HAVE_OUTPUT_JACKAUDIO @@ -91,6 +96,7 @@ EXTRA_DIST = \  	input/test.h \  	input/jackmidi.h \  	input/midifile.h \ +	input/ossmidi.h \  	output/alsa.h \  	output/jackaudio.h \  	output/outputdummy.h \ diff --git a/drumgizmo/drumgizmoc.cc b/drumgizmo/drumgizmoc.cc index ba3abfc..6a2458b 100644 --- a/drumgizmo/drumgizmoc.cc +++ b/drumgizmo/drumgizmoc.cc @@ -103,6 +103,7 @@ static std::string usage(std::string name)  	output << "  midifile:  file=<midifile>, speed=<tempo> (default 1.0),\n";  	output << "             track=<miditrack> (default -1, all tracks)\n";  	output << "             midimap=<midimapfile>, loop=<true|false>\n"; +	output << "  ossmidi:   midimap=<midimapfile>, dev=<device> (default '/dev/midi')\n";  	output << "  test:      p=<hit_propability> (default 0.1)\n";  	output << "             instr=<instrument> (default -1, random instrument)\n";  	output << "             len=<seconds> (default -1, forever)\n"; diff --git a/drumgizmo/enginefactory.cc b/drumgizmo/enginefactory.cc index a1b8a0b..c93607e 100644 --- a/drumgizmo/enginefactory.cc +++ b/drumgizmo/enginefactory.cc @@ -49,6 +49,9 @@ EngineFactory::EngineFactory()  #ifdef HAVE_INPUT_JACKMIDI  	input.push_back("jackmidi");  #endif +#ifdef HAVE_INPUT_OSS +	input.push_back("oss"); +#endif  // list available output engines  #ifdef HAVE_OUTPUT_DUMMY @@ -115,6 +118,12 @@ std::unique_ptr<AudioInputEngine> EngineFactory::createInput(const std::string&  		return std::make_unique<JackMidiInputEngine>(*jack);  	}  #endif +#ifdef HAVE_INPUT_OSSMIDI +	if(name == "ossmidi") +	{ +		return std::make_unique<OSSInputEngine>(); +	} +#endif  	// todo: add more engines diff --git a/drumgizmo/enginefactory.h b/drumgizmo/enginefactory.h index 2a1457e..0b37c6e 100644 --- a/drumgizmo/enginefactory.h +++ b/drumgizmo/enginefactory.h @@ -53,6 +53,10 @@  #include "input/jackmidi.h"  #endif +#ifdef HAVE_INPUT_OSS +#include "input/ossmidi.h" +#endif +  #ifdef HAVE_OUTPUT_DUMMY  #include "output/outputdummy.h"  #endif @@ -74,6 +78,11 @@  #endif +#ifdef HAVE_INPUT_OSSMIDI +#include "input/ossmidi.h" +#endif + +  //! Factory for various input- and output engines  class EngineFactory  { diff --git a/drumgizmo/input/ossmidi.cc b/drumgizmo/input/ossmidi.cc new file mode 100644 index 0000000..325a83d --- /dev/null +++ b/drumgizmo/input/ossmidi.cc @@ -0,0 +1,132 @@ +/* -*- Mode: c++ -*- */ +/*************************************************************************** + *            ossmidi.cc + * + *  Sun May 21 10:52:09 CEST 2017 + *  Copyright 2017 Goran Mekić + *  meka@tilda.center + ****************************************************************************/ + +/* + *  This file is part of DrumGizmo. + * + *  DrumGizmo is free software; you can redistribute it and/or modify + *  it under the terms of the GNU Lesser General Public License as published by + *  the Free Software Foundation; either version 3 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 Lesser General Public License for more details. + * + *  You should have received a copy of the GNU Lesser 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 "ossmidi.h" +#include <sys/soundcard.h> +#include <fcntl.h> +#include <stdlib.h> +#include <unistd.h> +#include <iostream> + + +static int const NOTE_ON = 0x90; +static int const NOTE_MASK = 0xF0; + + +OSSInputEngine::OSSInputEngine() +	: AudioInputEngineMidi{} +	, dev{"/dev/midi"} +{ +} + + +OSSInputEngine::~OSSInputEngine() +{ +} + + +bool OSSInputEngine::init(const Instruments& instruments) +{ +	if(!loadMidiMap(midimap_file, instruments)) +	{ +		std::cerr << "[OSSInputEngine] Failed to parse midimap '" +		          << midimap_file << std::endl; +		return false; +	} +	if ((fd = open(dev.data(), O_RDONLY | O_NONBLOCK, 0)) == -1) +	{ +		std::cerr << dev.data() << ' ' << std::strerror(errno) << std::endl; +		return false; +	} +	return true; +} + + +void OSSInputEngine::setParm(const std::string& parm, const std::string& value) +{ +	if(parm == "dev") +	{ +		dev = value; +	} +	else if(parm == "midimap") +	{ +		midimap_file = value; +	} +} + + +bool OSSInputEngine::start() +{ +	return true; +} + +void OSSInputEngine::stop() +{ +} + + +void OSSInputEngine::pre() +{ +	events.clear(); +} + + +void OSSInputEngine::run(size_t pos, size_t len, std::vector<event_t>& events) +{ +	int l; +	unsigned char buf[128]; +	if ((l = read (fd, buf, sizeof (buf))) != -1) +	{ +		int masked_note = buf[0] & NOTE_MASK; +		if (masked_note == NOTE_ON) { +			int note = buf[1]; +			int velocity = buf[2]; +			event_t event; +			event.instrument = mmap.lookup(note); +			if(event.instrument != -1) +			{ +				event.velocity = velocity / 127.0; +				event.type = 0; +				event.offset = 0; +				events.push_back(event); +			} +		} +	} else if (errno != EAGAIN) { +		std::cerr << "Error code: " << errno << std::endl; +		std::cerr << std::strerror(errno) << std::endl; +	} +} + + +void OSSInputEngine::post() +{ +} + + +bool OSSInputEngine::isFreewheeling() const +{ +	return false; +} diff --git a/drumgizmo/input/ossmidi.h b/drumgizmo/input/ossmidi.h new file mode 100644 index 0000000..c6abacd --- /dev/null +++ b/drumgizmo/input/ossmidi.h @@ -0,0 +1,54 @@ +/* -*- Mode: c++ -*- */ +/*************************************************************************** + *            ossmidi.h + * + *  Sun May 21 10:52:09 CEST 2017 + *  Copyright 2017 Goran Mekić + *  meka@tilda.center + ****************************************************************************/ + +/* + *  This file is part of DrumGizmo. + * + *  DrumGizmo is free software; you can redistribute it and/or modify + *  it under the terms of the GNU Lesser General Public License as published by + *  the Free Software Foundation; either version 3 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 Lesser General Public License for more details. + * + *  You should have received a copy of the GNU Lesser 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. + */ +#pragma once +#include "audioinputenginemidi.h" + + +class OSSInputEngine +	: public AudioInputEngineMidi +{ +public: +	OSSInputEngine(); +	~OSSInputEngine(); + +	// based on AudioInputEngine +	bool init(const Instruments& instruments) override; +	void setParm(const std::string& parm, const std::string& value) override; +	bool start() override; +	void stop() override; +	void pre() override; +	void run(size_t pos, size_t len, std::vector<event_t>& events) override; +	void post() override; +	bool isFreewheeling() const override; + +private: +	int fd; +	std::string dev; +	std::size_t pos; +	std::vector<event_t> events; +	std::string midimap_file; +}; | 
