X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Fmidi_patch_manager.h;h=3c10a3a149047e2200a1e846ac31af044953f8d2;hb=74a604d261b1ecb0f20ee0c69aef7648da3a1d86;hp=cd898aa00f7de543aabab45c49165abca31ba5f8;hpb=6fc1f270137a06115a79c6089004174c5cab5ed7;p=ardour.git diff --git a/libs/ardour/ardour/midi_patch_manager.h b/libs/ardour/ardour/midi_patch_manager.h index cd898aa00f..3c10a3a149 100644 --- a/libs/ardour/ardour/midi_patch_manager.h +++ b/libs/ardour/ardour/midi_patch_manager.h @@ -22,12 +22,11 @@ #define MIDI_PATCH_MANAGER_H_ #include "midi++/midnam_patch.h" + #include "pbd/signals.h" -#include "ardour/session_handle.h" +#include "pbd/search_path.h" -namespace ARDOUR { - class Session; -} +#include "ardour/libardour_visibility.h" namespace MIDI { @@ -35,7 +34,7 @@ namespace MIDI namespace Name { -class LIBARDOUR_API MidiPatchManager : public PBD::ScopedConnectionList, public ARDOUR::SessionHandlePtr +class LIBARDOUR_API MidiPatchManager { /// Singleton private: @@ -46,7 +45,8 @@ private: static MidiPatchManager* _manager; public: - typedef std::map > MidiNameDocuments; + typedef std::map > MidiNameDocuments; + typedef std::map DeviceNamesByMaker; virtual ~MidiPatchManager() { _manager = 0; } @@ -57,7 +57,9 @@ public: return *_manager; } - void set_session (ARDOUR::Session*); + void add_search_path (const PBD::Searchpath& search_path); + + void remove_search_path (const PBD::Searchpath& search_path); boost::shared_ptr document_by_model(std::string model_name) { return _documents[model_name]; } @@ -125,21 +127,30 @@ public: std::list custom_device_mode_names_by_model(std::string model_name) { if (model_name != "") { - return master_device_by_model(model_name)->custom_device_mode_names(); - } else { - return std::list(); + if (master_device_by_model(model_name)) { + return master_device_by_model(model_name)->custom_device_mode_names(); + } } + return std::list(); } const MasterDeviceNames::Models& all_models() const { return _all_models; } + const DeviceNamesByMaker& devices_by_manufacturer() const { return _devices_by_manufacturer; } + +private: + bool add_midi_name_document(const std::string& file_path); + bool remove_midi_name_document(const std::string& file_path); + + void add_midnam_files_from_directory(const std::string& directory_path); + void remove_midnam_files_from_directory(const std::string& directory_path); + private: - void session_going_away(); - void refresh(); - void add_session_patches(); + PBD::Searchpath _search_path; MidiNameDocuments _documents; MIDINameDocument::MasterDeviceNamesList _master_devices_by_model; + DeviceNamesByMaker _devices_by_manufacturer; MasterDeviceNames::Models _all_models; };