summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--plugin/Makefile.mingw32.in1
-rw-r--r--src/Makefile.am2
-rw-r--r--src/audiofile.h1
-rw-r--r--src/domloader.cc68
-rw-r--r--src/domloader.h49
-rw-r--r--src/drumkit.h6
-rw-r--r--src/drumkitloader.cc24
-rw-r--r--src/drumkitloader.h4
-rw-r--r--src/instrument.h3
-rw-r--r--src/sample.h2
-rw-r--r--test/Makefile.am12
-rw-r--r--test/domloadertest.cc324
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);