variable plugin port config.
[ardour.git] / libs / ardour / ardour / midi_patch_manager.h
index a48c9ddfe7d0601c884eb4e91835254c26f8418e..3c10a3a149047e2200a1e846ac31af044953f8d2 100644 (file)
 
 #include "midi++/midnam_patch.h"
 
-namespace ARDOUR {
-       class Session;
-}
+#include "pbd/signals.h"
+#include "pbd/search_path.h"
+
+#include "ardour/libardour_visibility.h"
 
 namespace MIDI
 {
@@ -33,18 +34,19 @@ namespace MIDI
 namespace Name
 {
 
-class MidiPatchManager
+class LIBARDOUR_API MidiPatchManager
 {
        /// Singleton
 private:
-       MidiPatchManager() {};
+       MidiPatchManager();
        MidiPatchManager( const MidiPatchManager& );
        MidiPatchManager& operator= (const MidiPatchManager&);
 
        static MidiPatchManager* _manager;
 
 public:
-       typedef std::map<std::string, boost::shared_ptr<MIDINameDocument> > MidiNameDocuments;
+       typedef std::map<std::string, boost::shared_ptr<MIDINameDocument> >    MidiNameDocuments;
+       typedef std::map<std::string, MIDINameDocument::MasterDeviceNamesList> DeviceNamesByMaker;
 
        virtual ~MidiPatchManager() { _manager = 0; }
 
@@ -55,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<MIDINameDocument> document_by_model(std::string model_name)
                { return _documents[model_name]; }
@@ -70,13 +74,12 @@ public:
                boost::shared_ptr<MIDI::Name::MasterDeviceNames> master_device = master_device_by_model(model);
 
                if (master_device != 0 && custom_device_mode != "") {
-                       return master_device->channel_name_set_by_device_mode_and_channel(custom_device_mode, channel);
+                       return master_device->channel_name_set_by_channel(custom_device_mode, channel);
                } else {
                        return boost::shared_ptr<ChannelNameSet>();
                }
        }
 
-
        boost::shared_ptr<Patch> find_patch(
                        std::string model,
                        std::string custom_device_mode,
@@ -124,25 +127,35 @@ public:
 
        std::list<std::string> 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<std::string>();
+                       if (master_device_by_model(model_name)) {
+                               return master_device_by_model(model_name)->custom_device_mode_names();
+                       }
                }
+               return std::list<std::string>();
        }
 
        const MasterDeviceNames::Models& all_models() const { return _all_models; }
 
+       const DeviceNamesByMaker& devices_by_manufacturer() const { return _devices_by_manufacturer; }
+
 private:
-       void drop_session();
-       void refresh();
+       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:
+       PBD::Searchpath                         _search_path;
 
-       ARDOUR::Session*                        _session;
        MidiNameDocuments                       _documents;
        MIDINameDocument::MasterDeviceNamesList _master_devices_by_model;
+       DeviceNamesByMaker                      _devices_by_manufacturer;
        MasterDeviceNames::Models               _all_models;
 };
 
 } // namespace Name
 
 } // namespace MIDI
+
 #endif /* MIDI_PATCH_MANAGER_H_ */