summaryrefslogtreecommitdiff
path: root/libs/ardour/midi_patch_manager.cc
diff options
context:
space:
mode:
authorRobin Gareus <robin@gareus.org>2016-10-29 19:01:16 +0200
committerRobin Gareus <robin@gareus.org>2016-10-29 19:57:43 +0200
commit0332c127cd54b9386bb59eb0ec18c49917c0cf57 (patch)
treeb736d0023348d18158b990b6b42627c10d067cee /libs/ardour/midi_patch_manager.cc
parent06700cb2f48b8da62b56d5cce4deb50cac029e6a (diff)
Allow to dynamically un/load Midnam Patches
Diffstat (limited to 'libs/ardour/midi_patch_manager.cc')
-rw-r--r--libs/ardour/midi_patch_manager.cc52
1 files changed, 48 insertions, 4 deletions
diff --git a/libs/ardour/midi_patch_manager.cc b/libs/ardour/midi_patch_manager.cc
index 8a6d8dfd10..e3bf899bf5 100644
--- a/libs/ardour/midi_patch_manager.cc
+++ b/libs/ardour/midi_patch_manager.cc
@@ -68,6 +68,28 @@ MidiPatchManager::add_search_path (const Searchpath& search_path)
}
}
+bool
+MidiPatchManager::add_custom_midnam (const std::string& id, const std::string& midnam)
+{
+ boost::shared_ptr<MIDINameDocument> document;
+ document = boost::shared_ptr<MIDINameDocument>(new MIDINameDocument());
+ XMLTree mxml;
+ if (mxml.read_buffer (midnam, true)) {
+ if (0 == document->set_state (mxml, *mxml.root())) {
+ document->set_file_path ("custom:" + id);
+ add_midi_name_document (document);
+ return true;
+ }
+ }
+ return false;
+}
+
+bool
+MidiPatchManager::remove_custom_midnam (const std::string& id)
+{
+ return remove_midi_name_document ("custom:" + id);
+}
+
void
MidiPatchManager::add_midnam_files_from_directory(const std::string& directory_path)
{
@@ -80,7 +102,7 @@ MidiPatchManager::add_midnam_files_from_directory(const std::string& directory_p
<< endmsg;
for (vector<std::string>::const_iterator i = result.begin(); i != result.end(); ++i) {
- add_midi_name_document (*i);
+ load_midi_name_document (*i);
}
}
@@ -116,7 +138,7 @@ MidiPatchManager::remove_midnam_files_from_directory(const std::string& director
}
bool
-MidiPatchManager::add_midi_name_document (const std::string& file_path)
+MidiPatchManager::load_midi_name_document (const std::string& file_path)
{
boost::shared_ptr<MIDINameDocument> document;
try {
@@ -127,6 +149,22 @@ MidiPatchManager::add_midi_name_document (const std::string& file_path)
<< endmsg;
return false;
}
+ return add_midi_name_document (document);
+}
+
+boost::shared_ptr<MIDINameDocument>
+MidiPatchManager::document_by_model(std::string model_name) const
+{
+ MidiNameDocuments::const_iterator i = _documents.find (model_name);
+ if (i != _documents.end ()) {
+ return i->second;
+ }
+ return boost::shared_ptr<MIDINameDocument> ();
+}
+
+bool
+MidiPatchManager::add_midi_name_document (boost::shared_ptr<MIDINameDocument> document)
+{
for (MIDINameDocument::MasterDeviceNamesList::const_iterator device =
document->master_device_names_by_model().begin();
device != document->master_device_names_by_model().end();
@@ -134,7 +172,7 @@ MidiPatchManager::add_midi_name_document (const std::string& file_path)
if (_documents.find(device->first) != _documents.end()) {
warning << string_compose(_("Duplicate MIDI device `%1' in `%2' ignored"),
device->first,
- file_path) << endmsg;
+ document->file_path()) << endmsg;
continue;
}
@@ -155,6 +193,8 @@ MidiPatchManager::add_midi_name_document (const std::string& file_path)
assert(_documents.count(device->first) == 1);
assert(_master_devices_by_model.count(device->first) == 1);
}
+
+ PatchesChanged(); /* EMIT SIGNAL */
return true;
}
@@ -167,9 +207,10 @@ MidiPatchManager::remove_midi_name_document (const std::string& file_path)
boost::shared_ptr<MIDINameDocument> document = i->second;
+ cout << string_compose(_("Removing MIDI patch file %1"), file_path) << "\n";
info << string_compose(_("Removing MIDI patch file %1"), file_path) << endmsg;
- _documents.erase(i++);
+ i = _documents.erase(i);
for (MIDINameDocument::MasterDeviceNamesList::const_iterator device =
document->master_device_names_by_model().begin();
@@ -189,5 +230,8 @@ MidiPatchManager::remove_midi_name_document (const std::string& file_path)
++i;
}
}
+ if (removed) {
+ PatchesChanged(); /* EMIT SIGNAL */
+ }
return removed;
}