X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fmidi_patch_manager.cc;h=e0638f035e510232d27e5701b5e216990451ac38;hb=8488d8f6a53d3385893a435481cb60ed21c21ea0;hp=39a5be9b5a1850279958ab997bdf2227e8b3c84f;hpb=e0aaed6d65f160c328cb8b56d7c6552ee15d65e2;p=ardour.git diff --git a/libs/ardour/midi_patch_manager.cc b/libs/ardour/midi_patch_manager.cc index 39a5be9b5a..e0638f035e 100644 --- a/libs/ardour/midi_patch_manager.cc +++ b/libs/ardour/midi_patch_manager.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2008 Hans Baier + Copyright (C) 2008 Hans Baier This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -18,74 +18,82 @@ $Id$ */ -#include #include +#include + #include "pbd/file_utils.h" +#include "pbd/error.h" #include "ardour/session.h" #include "ardour/session_directory.h" #include "ardour/midi_patch_manager.h" +#include "ardour/search_paths.h" + +#include "i18n.h" + using namespace std; -using namespace sigc; using namespace ARDOUR; using namespace MIDI; using namespace MIDI::Name; using namespace PBD; -using namespace PBD::sys; MidiPatchManager* MidiPatchManager::_manager = 0; +MidiPatchManager::MidiPatchManager () +{ + refresh (); +} + void -MidiPatchManager::set_session (Session& s) +MidiPatchManager::set_session (Session* s) { - _session = &s; - _session->GoingAway.connect (mem_fun (*this, &MidiPatchManager::drop_session)); - - refresh(); + SessionHandlePtr::set_session (s); + refresh (); + add_session_patches (); } void -MidiPatchManager::refresh() +MidiPatchManager::add_session_patches () { - _documents.clear(); - _master_devices_by_model.clear(); - _all_models.clear(); - - path path_to_patches = _session->session_directory().midi_patch_path(); - - cerr << "Path to patches: " << path_to_patches.to_string() << endl; - - if(!exists(path_to_patches)) { + if (!_session) { return; } - cerr << "Path to patches: " << path_to_patches.to_string() << " exists" << endl; - assert(is_directory(path_to_patches)); - - Glib::PatternSpec pattern(Glib::ustring("*.midnam")); - vector result; - - find_matching_files_in_directory(path_to_patches, pattern, result); + std::string path_to_patches = _session->session_directory().midi_patch_path(); - cerr << "patchfiles result contains " << result.size() << " elements" << endl; - - for(vector::iterator i = result.begin(); i != result.end(); ++i) { - cerr << "processing patchfile " << i->to_string() << endl; - - boost::shared_ptr document(new MIDINameDocument(i->to_string())); - for(MIDINameDocument::MasterDeviceNamesList::const_iterator device = - document->master_device_names_by_model().begin(); - device != document->master_device_names_by_model().end(); - ++device) { - cerr << "got model " << device->first << endl; + if (!Glib::file_test (path_to_patches, Glib::FILE_TEST_EXISTS)) { + return; + } + + assert (Glib::file_test (path_to_patches, Glib::FILE_TEST_IS_DIR)); + + vector result; + + find_files_matching_pattern (result, path_to_patches, "*.midnam"); + + info << "Loading " << result.size() << " MIDI patches from " << path_to_patches << endmsg; + + for (vector::iterator i = result.begin(); i != result.end(); ++i) { + boost::shared_ptr document(new MIDINameDocument(*i)); + for (MIDINameDocument::MasterDeviceNamesList::const_iterator device = + document->master_device_names_by_model().begin(); + device != document->master_device_names_by_model().end(); + ++device) { + //cerr << "got model " << device->first << endl; // have access to the documents by model name _documents[device->first] = document; // build a list of all master devices from all documents _master_devices_by_model[device->first] = device->second; - _all_models.push_back(device->first); - + _all_models.insert(device->first); + const std::string& manufacturer = device->second->manufacturer(); + if (_devices_by_manufacturer.find(manufacturer) == _devices_by_manufacturer.end()) { + MIDINameDocument::MasterDeviceNamesList empty; + _devices_by_manufacturer.insert(std::make_pair(manufacturer, empty)); + } + _devices_by_manufacturer[manufacturer].insert(std::make_pair(device->first, device->second)); + // make sure there are no double model names // TODO: handle this gracefully. assert(_documents.count(device->first) == 1); @@ -95,10 +103,63 @@ MidiPatchManager::refresh() } void -MidiPatchManager::drop_session () +MidiPatchManager::refresh() +{ + _documents.clear(); + _master_devices_by_model.clear(); + _all_models.clear(); + _devices_by_manufacturer.clear(); + + Searchpath search_path = midi_patch_search_path (); + vector result; + + find_files_matching_pattern (result, search_path, "*.midnam"); + + info << "Loading " << result.size() << " MIDI patches from " << search_path.to_string() << endmsg; + + for (vector::iterator i = result.begin(); i != result.end(); ++i) { + boost::shared_ptr document; + try { + document = boost::shared_ptr(new MIDINameDocument(*i)); + } catch (...) { + error << "Error parsing MIDI patch file " << *i << endmsg; + continue; + } + for (MIDINameDocument::MasterDeviceNamesList::const_iterator device = + document->master_device_names_by_model().begin(); + device != document->master_device_names_by_model().end(); + ++device) { + if (_documents.find(device->first) != _documents.end()) { + warning << string_compose(_("Duplicate MIDI device `%1' in `%2' ignored"), + device->first, *i) + << endmsg; + continue; + } + + _documents[device->first] = document; + _master_devices_by_model[device->first] = device->second; + + _all_models.insert(device->first); + const std::string& manufacturer = device->second->manufacturer(); + if (_devices_by_manufacturer.find(manufacturer) == _devices_by_manufacturer.end()) { + MIDINameDocument::MasterDeviceNamesList empty; + _devices_by_manufacturer.insert(std::make_pair(manufacturer, empty)); + } + _devices_by_manufacturer[manufacturer].insert(std::make_pair(device->first, device->second)); + } + } + + if (_session) { + add_session_patches (); + } +} + +void +MidiPatchManager::session_going_away () { - _session = 0; + SessionHandlePtr::session_going_away (); _documents.clear(); _master_devices_by_model.clear(); _all_models.clear(); + _devices_by_manufacturer.clear(); }