diff options
| -rw-r--r-- | plugin/Makefile.mingw32.in | 1 | ||||
| -rw-r--r-- | src/Makefile.am | 2 | ||||
| -rw-r--r-- | src/audiofile.h | 1 | ||||
| -rw-r--r-- | src/domloader.cc | 68 | ||||
| -rw-r--r-- | src/domloader.h | 49 | ||||
| -rw-r--r-- | src/drumkit.h | 6 | ||||
| -rw-r--r-- | src/drumkitloader.cc | 24 | ||||
| -rw-r--r-- | src/drumkitloader.h | 4 | ||||
| -rw-r--r-- | src/instrument.h | 3 | ||||
| -rw-r--r-- | src/sample.h | 2 | ||||
| -rw-r--r-- | test/Makefile.am | 12 | ||||
| -rw-r--r-- | test/domloadertest.cc | 324 | 
12 files changed, 478 insertions, 18 deletions
| diff --git a/plugin/Makefile.mingw32.in b/plugin/Makefile.mingw32.in index f93f226..46fed53 100644 --- a/plugin/Makefile.mingw32.in +++ b/plugin/Makefile.mingw32.in @@ -20,6 +20,7 @@ DG_SRC = \  	@top_srcdir@/src/channelmixer.cc \  	@top_srcdir@/src/configfile.cc \  	@top_srcdir@/src/configparser.cc \ +	@top_srcdir@/src/domloader.cc \  	@top_srcdir@/src/drumgizmo.cc \  	@top_srcdir@/src/drumkit.cc \  	@top_srcdir@/src/drumkitloader.cc \ diff --git a/src/Makefile.am b/src/Makefile.am index 9a07c83..960f17c 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -25,6 +25,7 @@ nodist_libdg_la_SOURCES = \  	channelmixer.cc \  	configfile.cc \  	configparser.cc \ +	domloader.cc \  	dgxmlparser.cc \  	drumgizmo.cc \  	drumkit.cc \ @@ -66,6 +67,7 @@ EXTRA_DIST = \  	configfile.h \  	configparser.h \  	cpp11fix.h \ +	domloader.h \  	dgxmlparser.h \  	drumgizmo.h \  	drumkit.h \ diff --git a/src/audiofile.h b/src/audiofile.h index 3bc1ac0..5a5cc3a 100644 --- a/src/audiofile.h +++ b/src/audiofile.h @@ -68,6 +68,7 @@ public:  	std::size_t filechannel;  private: +	friend class DOMLoaderTest;  	friend class InstrumentParserTest;  	void* magic{nullptr}; diff --git a/src/domloader.cc b/src/domloader.cc new file mode 100644 index 0000000..aa7d1e2 --- /dev/null +++ b/src/domloader.cc @@ -0,0 +1,68 @@ +/* -*- Mode: c++ -*- */ +/*************************************************************************** + *            domloader.cc + * + *  Sun Jun 10 17:39:01 CEST 2018 + *  Copyright 2018 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 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 "domloader.h" + +#include "DGDOM.h" +#include "drumkit.h" + +#include "cpp11fix.h" + +DOMLoader::DOMLoader(Settings& settings, Random& random) +	: settings(settings) +	, random(random) +{ +} + +bool DOMLoader::loadDom(const DrumkitDOM& dom, +                        const std::vector<InstrumentDOM>& instrumentdoms, +                        DrumKit& drumkit) +{ +	drumkit._name = dom.name; +	drumkit._description = dom.description; +	drumkit._samplerate = dom.samplerate; + +	for(const auto& channel: dom.channels) +	{ +		drumkit.channels.emplace_back(); +		drumkit.channels.back().name = channel.name; +		drumkit.channels.back().num = drumkit.channels.size() - 1; +	} + +	for(const auto& instrumentref : dom.instruments) +	{ +		auto ptr = std::make_unique<Instrument>(settings, random); +		ptr->setGroup(instrumentref.group); + +		//InstrumentParser parser(*ptr, settings); +		//parser.parseFile(path + "/" + instr_file); + +		// Transfer ownership to the DrumKit object. +		drumkit.instruments.emplace_back(std::move(ptr)); +	} + +	return true; +} diff --git a/src/domloader.h b/src/domloader.h new file mode 100644 index 0000000..29288c5 --- /dev/null +++ b/src/domloader.h @@ -0,0 +1,49 @@ +/* -*- Mode: c++ -*- */ +/*************************************************************************** + *            domloader.h + * + *  Sun Jun 10 17:39:01 CEST 2018 + *  Copyright 2018 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 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 <vector> + +class DrumkitDOM; +class InstrumentDOM; +class DrumKit; +class Settings; +class Random; + +class DOMLoader +{ +public: +	DOMLoader(Settings& settings, Random& random); + +	bool loadDom(const DrumkitDOM& dom, +	             const std::vector<InstrumentDOM>& instrumentdoms, +	             DrumKit& drumkit); + +private: +	Settings& settings; +	Random& random; +}; diff --git a/src/drumkit.h b/src/drumkit.h index 1786584..4cee6be 100644 --- a/src/drumkit.h +++ b/src/drumkit.h @@ -35,8 +35,6 @@  class DrumKit  { -	friend class DrumKitParser; -	friend class DrumKitLoader;  public:  	DrumKit();  	~DrumKit(); @@ -60,6 +58,10 @@ public:  	std::size_t getNumberOfFiles() const;  private: +	friend class DOMLoader; +	friend class DOMLoaderTest; +	friend class DrumKitParser; +	friend class DrumKitLoader;  	friend class DrumkitParserTest;  	void* magic{nullptr}; diff --git a/src/drumkitloader.cc b/src/drumkitloader.cc index 02b2c13..0cef31b 100644 --- a/src/drumkitloader.cc +++ b/src/drumkitloader.cc @@ -35,6 +35,7 @@  #include "DGDOM.h"  #include "dgxmlparser.h"  #include "path.h" +#include "domloader.h"  #define REFSFILE "refs.conf" @@ -134,12 +135,17 @@ bool DrumKitLoader::loadkit(const std::string& file)  	std::string path = getPath(edited_filename);  	bool parseerror = parseDrumkitFile(edited_filename, drumkitdom); -	for(InstrumentRefDOM ref: drumkitdom.instruments) { +	for(const auto& ref : drumkitdom.instruments) +	{  		instrumentdoms.emplace_back(); -		parseerror |= parseInstrumentFile(path + "/" + ref.file, instrumentdoms.back()); +		parseerror &= parseInstrumentFile(path + "/" + ref.file, instrumentdoms.back());  	} -	if(parseerror) { +	DOMLoader domloader(settings, rand); +	parseerror &= domloader.loadDom(drumkitdom, instrumentdoms, kit); + +	if(parseerror) +	{  		ERR(drumgizmo, "Drumkit parser failed: %s\n", file.c_str());  		settings.drumkit_load_status.store(LoadStatus::Error); @@ -150,18 +156,6 @@ bool DrumKitLoader::loadkit(const std::string& file)  		return false;  	} -	//TODO: create - -	kit._name = drumkitdom.name; -	kit._description = drumkitdom.description; -	kit._samplerate = drumkitdom.samplerate; - -	for(auto& channel: drumkitdom.channels) { -		kit.channels.emplace_back(); -		kit.channels.back().name = channel.name; -		kit.channels.back().num = kit.channels.size() -1; -	} -  	// Check if there is enough free RAM to load the drumkit.  	//if(!memchecker.enoughFreeMemory(kit))  	//{ diff --git a/src/drumkitloader.h b/src/drumkitloader.h index d14a321..9bd2af9 100644 --- a/src/drumkitloader.h +++ b/src/drumkitloader.h @@ -29,6 +29,7 @@  #include <string>  #include <list>  #include <mutex> +#include <vector>  #include "thread.h"  #include "semaphore.h" @@ -38,6 +39,9 @@  #include "audioinputengine.h"  #include "audiocache.h" +class DrumkitDOM; +class InstrumentDOM; +  //! This class is responsible for loading the drumkits in its own thread.  //! All interaction calls are simply modifying queues and not doing any  //! work in-sync with the caller. diff --git a/src/instrument.h b/src/instrument.h index b62e155..20bcae4 100644 --- a/src/instrument.h +++ b/src/instrument.h @@ -67,6 +67,9 @@ public:  	float getMinPower() const;  private: +	friend class DOMLoader; +	friend class DOMLoaderTest; +  	// For parser:  	friend class InstrumentParser;  	friend class DrumKitParser; diff --git a/src/sample.h b/src/sample.h index daac6aa..5e41e9e 100644 --- a/src/sample.h +++ b/src/sample.h @@ -45,6 +45,8 @@ public:  	float getPower() const;  private: +	friend class DOMLoader; +	friend class DOMLoaderTest;  	friend class InstrumentParser;  	friend class PowerList;  	friend class InstrumentParserTest; diff --git a/test/Makefile.am b/test/Makefile.am index 753555b..47a740d 100644 --- a/test/Makefile.am +++ b/test/Makefile.am @@ -7,7 +7,7 @@ TESTS = resource enginetest paintertest configfile audiocache \  	audiocachefile audiocacheidmanager audiocacheeventhandler \  	randomtest atomictest syncedsettingstest imagecachetest \  	semaphoretest drumkitcreatortest bytesizeparsertest notifiertest \ -	instrumentparsertest drumkitparsertest dgxmlparsertest +	instrumentparsertest drumkitparsertest dgxmlparsertest domloadertest  EXTRA_DIST = \  	dgunit.h \ @@ -226,4 +226,14 @@ dgxmlparsertest_SOURCES = \  	scopedfile.cc \  	test.cc +domloadertest_CXXFLAGS = -DOUTPUT=\"domloadertest\" $(CPPUNIT_CFLAGS) \ +	-I$(top_srcdir)/src -I$(top_srcdir)/include +domloadertest_LDFLAGS = $(CPPUNIT_LIBS) \ +	 $(top_srcdir)/src/libdg.la +domloadertest_SOURCES = \ +	$(top_srcdir)/hugin/hugin.c \ +	domloadertest.cc \ +	scopedfile.cc \ +	test.cc +  endif diff --git a/test/domloadertest.cc b/test/domloadertest.cc new file mode 100644 index 0000000..bb8bb06 --- /dev/null +++ b/test/domloadertest.cc @@ -0,0 +1,324 @@ +/* -*- Mode: c++ -*- */ +/*************************************************************************** + *            domloadertest.cc + * + *  Sun Jun 10 17:48:04 CEST 2018 + *  Copyright 2018 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 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 <cppunit/extensions/HelperMacros.h> + +#include <DGDOM.h> +#include <domloader.h> +#include <dgxmlparser.h> +#include <drumkit.h> +#include <settings.h> +#include <random.h> + +#include "scopedfile.h" + +class DOMLoaderTest +	: public CppUnit::TestFixture +{ +	CPPUNIT_TEST_SUITE(DOMLoaderTest); +	CPPUNIT_TEST(testTest); +	CPPUNIT_TEST_SUITE_END(); + +	Settings settings; +	Random random; + +public: +	void setUp() +	{ +	} + +	void tearDown() +	{ +	} + +	//! This just creates some drumkit. +	void testTest() +	{ +		ScopedFile scoped_instrument_file1( +			"<?xml version='1.0' encoding='UTF-8'?>\n" \ +			"<instrument version=\"2.0\" name=\"Snare\">\n" \ +			" <samples>\n" \ +			"  <sample name=\"Snare-1\" power=\"0.00985718\">\n" \ +			"   <audiofile channel=\"AmbLeft\" file=\"1-Snare.wav\" filechannel=\"1\"/>\n" \ +			"   <audiofile channel=\"AmbRight\" file=\"1-Snare.wav\" filechannel=\"2\"/>\n" \ +			"   <audiofile channel=\"SnareBottom\" file=\"1-Snare.wav\" filechannel=\"12\"/>\n" \ +			"   <audiofile channel=\"SnareTop\" file=\"1-Snare.wav\" filechannel=\"13\"/>\n" \ +			"  </sample>\n" \ +			"  <sample name=\"Snare-2\" power=\"0.0124808\">\n" \ +			"   <audiofile channel=\"AmbLeft\" file=\"2-Snare.wav\" filechannel=\"1\"/>\n" \ +			"   <audiofile channel=\"AmbRight\" file=\"2-Snare.wav\" filechannel=\"2\"/>\n" \ +			"   <audiofile channel=\"SnareBottom\" file=\"2-Snare.wav\" filechannel=\"12\"/>\n" \ +			"   <audiofile channel=\"SnareTop\" file=\"2-Snare.wav\" filechannel=\"13\"/>\n" \ +			"  </sample>\n" \ +			" </samples>\n" \ +			"</instrument>"); + +		ScopedFile scoped_instrument_file2( +			"<?xml version='1.0' encoding='UTF-8'?>\n" \ +			"<instrument version=\"2.0\" name=\"Snare\">\n" \ +			" <samples>\n" \ +			"  <sample name=\"Snare-1\" power=\"0.00985718\">\n" \ +			"   <audiofile channel=\"AmbLeft2\" file=\"1-Snare.wav\" filechannel=\"1\"/>\n" \ +			"   <audiofile channel=\"AmbRight2\" file=\"1-Snare.wav\" filechannel=\"2\"/>\n" \ +			"   <audiofile channel=\"SnareBottom2\" file=\"1-Snare.wav\" filechannel=\"12\"/>\n" \ +			"   <audiofile channel=\"SnareTop2\" file=\"1-Snare.wav\" filechannel=\"13\"/>\n" \ +			"  </sample>\n" \ +			"  <sample name=\"Snare-2\" power=\"0.0124808\">\n" \ +			"   <audiofile channel=\"AmbLeft2\" file=\"2-Snare.wav\" filechannel=\"1\"/>\n" \ +			"   <audiofile channel=\"AmbRight2\" file=\"2-Snare.wav\" filechannel=\"2\"/>\n" \ +			"   <audiofile channel=\"SnareBottom2\" file=\"2-Snare.wav\" filechannel=\"12\"/>\n" \ +			"   <audiofile channel=\"SnareTop2\" file=\"2-Snare.wav\" filechannel=\"13\"/>\n" \ +			"  </sample>\n" \ +			" </samples>\n" \ +			"</instrument>"); + +		ScopedFile scoped_file( +			std::string( +			"<?xml version='1.0' encoding='UTF-8'?>\n" \ +			"<drumkit name=\"CrocellKit\" description=\"my description\" samplerate=\"48000\" version=\"2.0.0\">\n" \ +			"  <channels>\n" \ +			"   <channel name=\"AmbLeft\"/>\n" \ +			"   <channel name=\"AmbRight\"/>\n" \ +			"   <channel name=\"SnareTop\"/>\n" \ +			"   <channel name=\"SnareBottom\"/>\n" \ +			"  </channels>\n" \ +			"  <instruments>\n" \ +			"    <instrument name=\"Snare1\" file=\"") + scoped_instrument_file1.filename() + std::string("\">\n" \ +			"      <channelmap in=\"AmbLeft\" out=\"AmbLeft\" main=\"true\"/>\n" \ +			"      <channelmap in=\"AmbRight\" out=\"AmbRight\" main=\"true\"/>\n" \ +			"      <channelmap in=\"SnareTop\" out=\"SnareTop\"/>\n" \ +			"      <channelmap in=\"SnareBottom\" out=\"SnareBottom\"/>\n" \ +			"    </instrument>\n" \ +			"    <instrument name=\"Snare2\" file=\"") + scoped_instrument_file2.filename() + std::string("\">\n" \ +			"      <channelmap in=\"AmbLeft2\" out=\"AmbLeft\" main=\"true\"/>\n" \ +			"      <channelmap in=\"AmbRight2\" out=\"AmbRight\" main=\"true\"/>\n" \ +			"      <channelmap in=\"SnareTop2\" out=\"SnareTop\"/>\n" \ +			"      <channelmap in=\"SnareBottom2\" out=\"SnareBottom\"/>\n" \ +			"    </instrument>\n" \ +			"  </instruments>\n" \ +			"</drumkit>")); + +		DrumKit drumkit; + +		DrumkitDOM drumkitdom; +		std::vector<InstrumentDOM> instrumentdoms; +		CPPUNIT_ASSERT(parseDrumkitFile(scoped_file.filename(), drumkitdom)); +		for(const auto& ref: drumkitdom.instruments) +		{ +			instrumentdoms.emplace_back(); +			CPPUNIT_ASSERT(parseInstrumentFile(ref.file, instrumentdoms.back())); +		} + +		DOMLoader domloader(settings, random); +		CPPUNIT_ASSERT(domloader.loadDom(drumkitdom, instrumentdoms, drumkit)); + +		// +		// Drumkit: +		// + +		CPPUNIT_ASSERT_EQUAL(std::size_t(2), drumkit.instruments.size()); +		CPPUNIT_ASSERT_EQUAL(std::size_t(4), drumkit.channels.size()); + +		CPPUNIT_ASSERT_EQUAL(std::string("AmbLeft"), drumkit.channels[0].name); +		CPPUNIT_ASSERT_EQUAL(std::string("AmbRight"), drumkit.channels[1].name); +		CPPUNIT_ASSERT_EQUAL(std::string("SnareTop"), drumkit.channels[2].name); +		CPPUNIT_ASSERT_EQUAL(std::string("SnareBottom"), drumkit.channels[3].name); + +		CPPUNIT_ASSERT_EQUAL(std::string("CrocellKit"), drumkit._name); +		CPPUNIT_ASSERT_EQUAL(std::string("my description"), drumkit._description); +		CPPUNIT_ASSERT_EQUAL(std::size_t(48000), drumkit._samplerate); + +		CPPUNIT_ASSERT(VersionStr("2.0.0") == drumkit._version); + +		// +		// Instrument1 'Snare1': +		// +		{ +		auto& instrument = *drumkit.instruments[0]; +		CPPUNIT_ASSERT_EQUAL(std::string(""), instrument._group); +		CPPUNIT_ASSERT_EQUAL(std::string("Snare"), instrument._name); +		CPPUNIT_ASSERT_EQUAL(std::string(""), instrument._description); + +		CPPUNIT_ASSERT(VersionStr("2.0.0") == instrument.version); + +		// NOTE: instrument.samples are the sample map belonging to version 1.0 +		CPPUNIT_ASSERT_EQUAL(std::size_t(2), instrument.samplelist.size()); +		{ +			const auto& sample = *instrument.samplelist[0]; +			CPPUNIT_ASSERT_EQUAL(std::string("Snare-1"), sample.name); +			CPPUNIT_ASSERT_EQUAL(0.00985718f, sample.power); +			CPPUNIT_ASSERT_EQUAL(std::size_t(4), sample.audiofiles.size()); +			for(const auto& audiofile : sample.audiofiles) +			{ +				CPPUNIT_ASSERT_EQUAL(std::string("/tmp/1-Snare.wav"), audiofile.second->filename); +				switch(audiofile.second->filechannel) +				{ +					// NOTE: Channel numbers are zero based - they are 1 based in the xml +				case 0: +					CPPUNIT_ASSERT_EQUAL(std::string("AmbLeft"), +					                     audiofile.second->instrument_channel->name); +					break; +				case 1: +					CPPUNIT_ASSERT_EQUAL(std::string("AmbRight"), +					                     audiofile.second->instrument_channel->name); +					break; +				case 11: +					CPPUNIT_ASSERT_EQUAL(std::string("SnareBottom"), +					                     audiofile.second->instrument_channel->name); +					break; +				case 12: +					CPPUNIT_ASSERT_EQUAL(std::string("SnareTop"), +					                     audiofile.second->instrument_channel->name); +					break; +				default: +					CPPUNIT_ASSERT(false); +					break; +				} +			} +		} + +		{ +			const auto& sample = *instrument.samplelist[1]; +			CPPUNIT_ASSERT_EQUAL(std::string("Snare-2"), sample.name); +			CPPUNIT_ASSERT_EQUAL(0.0124808f, sample.power); +			CPPUNIT_ASSERT_EQUAL(std::size_t(4), sample.audiofiles.size()); +			for(const auto& audiofile : sample.audiofiles) +			{ +				CPPUNIT_ASSERT_EQUAL(std::string("/tmp/2-Snare.wav"), audiofile.second->filename); +				switch(audiofile.second->filechannel) +				{ +					// NOTE: Channel numbers are zero based - they are 1 based in the xml +				case 0: +					CPPUNIT_ASSERT_EQUAL(std::string("AmbLeft"), +					                     audiofile.second->instrument_channel->name); +					break; +				case 1: +					CPPUNIT_ASSERT_EQUAL(std::string("AmbRight"), +					                     audiofile.second->instrument_channel->name); +					break; +				case 11: +					CPPUNIT_ASSERT_EQUAL(std::string("SnareBottom"), +					                     audiofile.second->instrument_channel->name); +					break; +				case 12: +					CPPUNIT_ASSERT_EQUAL(std::string("SnareTop"), +					                     audiofile.second->instrument_channel->name); +					break; +				default: +					CPPUNIT_ASSERT(false); +					break; +				} +			} +		} +		} + +		// +		// Instrument2 'Snare2': +		// + +		{ +		auto& instrument = *drumkit.instruments[1]; +		CPPUNIT_ASSERT_EQUAL(std::string(""), instrument._group); +		CPPUNIT_ASSERT_EQUAL(std::string("Snare"), instrument._name); +		CPPUNIT_ASSERT_EQUAL(std::string(""), instrument._description); + +		CPPUNIT_ASSERT(VersionStr("2.0.0") == instrument.version); + +		// NOTE: instrument.samples are the sample map belonging to version 1.0 +		CPPUNIT_ASSERT_EQUAL(std::size_t(2), instrument.samplelist.size()); +		{ +			const auto& sample = *instrument.samplelist[0]; +			CPPUNIT_ASSERT_EQUAL(std::string("Snare-1"), sample.name); +			CPPUNIT_ASSERT_EQUAL(0.00985718f, sample.power); +			CPPUNIT_ASSERT_EQUAL(std::size_t(4), sample.audiofiles.size()); +			for(const auto& audiofile : sample.audiofiles) +			{ +				CPPUNIT_ASSERT_EQUAL(std::string("/tmp/1-Snare.wav"), audiofile.second->filename); +				switch(audiofile.second->filechannel) +				{ +					// NOTE: Channel numbers are zero based - they are 1 based in the xml +				case 0: +					CPPUNIT_ASSERT_EQUAL(std::string("AmbLeft"), +					                     audiofile.second->instrument_channel->name); +					break; +				case 1: +					CPPUNIT_ASSERT_EQUAL(std::string("AmbRight"), +					                     audiofile.second->instrument_channel->name); +					break; +				case 11: +					CPPUNIT_ASSERT_EQUAL(std::string("SnareBottom"), +					                     audiofile.second->instrument_channel->name); +					break; +				case 12: +					CPPUNIT_ASSERT_EQUAL(std::string("SnareTop"), +					                     audiofile.second->instrument_channel->name); +					break; +				default: +					CPPUNIT_ASSERT(false); +					break; +				} +			} +		} + +		{ +			const auto& sample = *instrument.samplelist[1]; +			CPPUNIT_ASSERT_EQUAL(std::string("Snare-2"), sample.name); +			CPPUNIT_ASSERT_EQUAL(0.0124808f, sample.power); +			CPPUNIT_ASSERT_EQUAL(std::size_t(4), sample.audiofiles.size()); +			for(const auto& audiofile : sample.audiofiles) +			{ +				CPPUNIT_ASSERT_EQUAL(std::string("/tmp/2-Snare.wav"), audiofile.second->filename); +				switch(audiofile.second->filechannel) +				{ +					// NOTE: Channel numbers are zero based - they are 1 based in the xml +				case 0: +					CPPUNIT_ASSERT_EQUAL(std::string("AmbLeft"), +					                     audiofile.second->instrument_channel->name); +					break; +				case 1: +					CPPUNIT_ASSERT_EQUAL(std::string("AmbRight"), +					                     audiofile.second->instrument_channel->name); +					break; +				case 11: +					CPPUNIT_ASSERT_EQUAL(std::string("SnareBottom"), +					                     audiofile.second->instrument_channel->name); +					break; +				case 12: +					CPPUNIT_ASSERT_EQUAL(std::string("SnareTop"), +					                     audiofile.second->instrument_channel->name); +					break; +				default: +					CPPUNIT_ASSERT(false); +					break; +				} +			} +		} +		} +	} +}; + +// Registers the fixture into the 'registry' +CPPUNIT_TEST_SUITE_REGISTRATION(DOMLoaderTest); | 
