Fix various issues when the engine disconnects:
[ardour.git] / libs / ardour / plugin.cc
index e0ba0f00f7fabc31a9e2dcd8c7c20fd1b726ac68..f3d66971b813e1618eb76389cca38b86e6a7468e 100644 (file)
@@ -87,12 +87,6 @@ PluginInfo::needs_midi_input () const
        return (n_inputs.n_midi() != 0);
 }
 
-bool
-PluginInfo::is_instrument () const
-{
-       return (n_inputs.n_midi() != 0) && (n_outputs.n_audio() > 0) && (n_inputs.n_audio() == 0);
-}
-
 Plugin::Plugin (AudioEngine& e, Session& s)
        : _engine (e)
        , _session (s)
@@ -359,7 +353,7 @@ Plugin::write_immediate_event (size_t size, const uint8_t* buf)
 int
 Plugin::connect_and_run (BufferSet& bufs,
                samplepos_t /*start*/, samplepos_t /*end*/, double /*speed*/,
-               ChanMapping /*in_map*/, ChanMapping /*out_map*/,
+               ChanMapping const& /*in_map*/, ChanMapping const& /*out_map*/,
                pframes_t nframes, samplecnt_t /*offset*/)
 {
        if (bufs.count().n_midi() > 0) {
@@ -526,3 +520,33 @@ Plugin::parameter_label (uint32_t which) const
        get_parameter_descriptor (which, pd);
        return pd.label;
 }
+
+bool
+PluginInfo::is_effect () const
+{
+       return (!is_instrument () && !is_utility ()  && !is_analyzer ());
+}
+
+bool
+PluginInfo::is_instrument () const
+{
+       if (category == "Instrument") {
+               return true;
+       }
+
+       // second check: if we have  midi input and audio output, we're likely an instrument
+       return (n_inputs.n_midi() != 0) && (n_outputs.n_audio() > 0) && (n_inputs.n_audio() == 0);
+}
+
+bool
+PluginInfo::is_utility () const
+{
+       /* XXX beware of translations, e.g. LV2 categories */
+       return (category == "Utility" || category == "MIDI" || category == "Generator");
+}
+
+bool
+PluginInfo::is_analyzer () const
+{
+       return (category == "Analyser" || category == "Anaylsis" || category == "Analyzer");
+}