const DeviceNamesByMaker& devices_by_manufacturer() const { return _devices_by_manufacturer; }
+ void load_midnams_in_thread ();
+
private:
bool load_midi_name_document(const std::string& file_path);
bool add_midi_name_document(boost::shared_ptr<MIDINameDocument>);
MIDINameDocument::MasterDeviceNamesList _master_devices_by_model;
DeviceNamesByMaker _devices_by_manufacturer;
MasterDeviceNames::Models _all_models;
+
+ bool no_patch_changed_messages;
+ pthread_t _midnam_load_thread;
+ static void* _midnam_load (void *);
+ void load_midnams ();
};
} // namespace Name
} // namespace MIDI
#endif /* MIDI_PATCH_MANAGER_H_ */
+
#include <glibmm/fileutils.h>
-#include "pbd/file_utils.h"
#include "pbd/error.h"
+#include "pbd/file_utils.h"
+#include "pbd/pthread_utils.h"
+#include "pbd/unwind.h"
#include "ardour/midi_patch_manager.h"
MidiPatchManager* MidiPatchManager::_manager = 0;
MidiPatchManager::MidiPatchManager ()
+ : no_patch_changed_messages (false)
{
- add_search_path(midi_patch_search_path ());
+ add_search_path (midi_patch_search_path ());
}
void
continue;
}
- add_midnam_files_from_directory (*i);
-
_search_path.add_directory (*i);
}
}
vector<std::string> result;
find_files_matching_pattern (result, directory_path, "*.midnam");
- info << string_compose(
- P_("Loading %1 MIDI patch from %2", "Loading %1 MIDI patches from %2", result.size()),
- result.size(), directory_path)
- << endmsg;
+ info << string_compose (P_("Loading %1 MIDI patch from %2", "Loading %1 MIDI patches from %2", result.size()), result.size(), directory_path) << endmsg;
for (vector<std::string>::const_iterator i = result.begin(); i != result.end(); ++i) {
load_midi_name_document (*i);
assert(_master_devices_by_model.count(device->first) == 1);
}
- if (added) {
+ if (added && !no_patch_changed_messages) {
PatchesChanged(); /* EMIT SIGNAL */
}
+
return added;
}
}
return removed;
}
+
+void*
+MidiPatchManager::_midnam_load (void* arg)
+{
+ MidiPatchManager* mpm = (MidiPatchManager *) arg;
+ mpm->load_midnams ();
+ return 0;
+}
+
+void
+MidiPatchManager::load_midnams ()
+{
+ {
+ PBD::Unwinder<bool> npc (no_patch_changed_messages, true);
+ for (Searchpath::const_iterator i = _search_path.begin(); i != _search_path.end(); ++i) {
+ add_midnam_files_from_directory (*i);
+ }
+ }
+
+ PatchesChanged (); /* EMIT SIGNAL */
+}
+
+void
+MidiPatchManager::load_midnams_in_thread ()
+{
+ pthread_create_and_store (X_("midnam"), &_midnam_load_thread, _midnam_load, this);
+}