fix another logic error in PresentationInfo::flag_match()
[ardour.git] / libs / ardour / ardour / plugin_manager.h
index 2cf0efcd85573d831d878f25183462f7ad2b33d5..1a925432a08a1dfc5a6aa35ae439f250d2f31706 100644 (file)
@@ -50,18 +50,21 @@ class LIBARDOUR_API PluginManager : public boost::noncopyable {
        ARDOUR::PluginInfoList &ladspa_plugin_info ();
        ARDOUR::PluginInfoList &lv2_plugin_info ();
        ARDOUR::PluginInfoList &au_plugin_info ();
+       ARDOUR::PluginInfoList &lua_plugin_info ();
 
        void refresh (bool cache_only = false);
        void cancel_plugin_scan();
+       void cancel_plugin_timeout();
        void clear_vst_cache ();
        void clear_vst_blacklist ();
+       void clear_au_cache ();
+       void clear_au_blacklist ();
 
-       const std::string get_windows_vst_path() const { return windows_vst_path; }
-       const std::string get_lxvst_path() const { return lxvst_path; }
-       const std::string windows_vst_search_path() const;
-       const std::string lxvst_search_path() const;
+       const std::string get_default_windows_vst_path() const { return windows_vst_path; }
+       const std::string get_default_lxvst_path() const { return lxvst_path; }
 
-       bool cancelled () { return cancel_scan; }
+       bool cancelled () { return _cancel_scan; }
+       bool no_timeout () { return _cancel_timeout; }
 
        enum PluginStatusType {
                Normal = 0,
@@ -76,6 +79,8 @@ class LIBARDOUR_API PluginManager : public boost::noncopyable {
 
        /** plugins were added to or removed from one of the PluginInfoLists */
        PBD::Signal0<void> PluginListChanged;
+       /** Plugin Hidden/Favorite status changed */
+       PBD::Signal0<void> PluginStatusesChanged;
 
   private:
        struct PluginStatus {
@@ -108,15 +113,19 @@ class LIBARDOUR_API PluginManager : public boost::noncopyable {
        ARDOUR::PluginInfoList* _ladspa_plugin_info;
        ARDOUR::PluginInfoList* _lv2_plugin_info;
        ARDOUR::PluginInfoList* _au_plugin_info;
+       ARDOUR::PluginInfoList* _lua_plugin_info;
 
        std::map<uint32_t, std::string> rdf_type;
 
        std::string windows_vst_path;
        std::string lxvst_path;
 
-       bool cancel_scan;
+       bool _cancel_scan;
+       bool _cancel_timeout;
 
        void ladspa_refresh ();
+       void lua_refresh ();
+       void lua_refresh_cb ();
        void windows_vst_refresh (bool cache_only = false);
        void lxvst_refresh (bool cache_only = false);
 
@@ -126,13 +135,13 @@ class LIBARDOUR_API PluginManager : public boost::noncopyable {
        void add_lxvst_presets ();
        void add_presets (std::string domain);
 
-       void au_refresh ();
+       void au_refresh (bool cache_only = false);
 
        void lv2_refresh ();
 
        int windows_vst_discover_from_path (std::string path, bool cache_only = false);
        int windows_vst_discover (std::string path, bool cache_only = false);
-       
+
        int lxvst_discover_from_path (std::string path, bool cache_only = false);
        int lxvst_discover (std::string path, bool cache_only = false);
 
@@ -141,6 +150,9 @@ class LIBARDOUR_API PluginManager : public boost::noncopyable {
        std::string get_ladspa_category (uint32_t id);
        std::vector<uint32_t> ladspa_plugin_whitelist;
 
+       PBD::ScopedConnection lua_refresh_connection;
+       Glib::Threads::Mutex _lock;
+
        static PluginManager* _instance; // singleton
        PluginManager ();
 };