use platform-specific modifier name for tooltip
[ardour.git] / gtk2_ardour / selection.cc
index 784f646f39a651583ceb2eff43eef0c1d5200efd..baf424669f48b47482810feb6779b1577d148295 100644 (file)
 #include "ardour/playlist.h"
 #include "ardour/rc_configuration.h"
 
+#include "audio_region_view.h"
 #include "gui_thread.h"
 #include "midi_cut_buffer.h"
+#include "region_gain_line.h"
 #include "region_view.h"
 #include "selection.h"
 #include "selection_templates.h"
@@ -1113,7 +1115,7 @@ Selection::set (ControlPoint* cp)
        clear_time ();  //enforce region/object exclusivity
        clear_tracks();  //enforce object/track exclusivity
 
-       if (cp->get_selected()) {
+       if (cp->get_selected () && points.size () == 1) {
                return;
        }
 
@@ -1278,8 +1280,18 @@ Selection::get_state () const
 
                        snprintf(buf, sizeof(buf), "%d", (*i)->view_index());
                        r->add_property (X_("view-index"), string(buf));
+                       continue;
+               }
 
+               AudioRegionGainLine* argl = dynamic_cast<AudioRegionGainLine*> (&(*i)->line());
+               if (argl) {
+                       XMLNode* r = node->add_child (X_("ControlPoint"));
+                       r->add_property (X_("type"), "region");
+                       r->add_property (X_("region-id"), atoi (argl->region_view ().region ()->id ().to_s ().c_str()));
+                       snprintf(buf, sizeof(buf), "%d", (*i)->view_index());
+                       r->add_property (X_("view-index"), string(buf));
                }
+
        }
 
        for (TimeSelection::const_iterator i = time.begin(); i != time.end(); ++i) {
@@ -1412,7 +1424,6 @@ Selection::set_state (XMLNode const & node, int)
                                XMLProperty* prop_parameter = (*i)->property (X_("parameter"));
                                XMLProperty* prop_view_index = (*i)->property (X_("view-index"));
 
-                               assert (prop_type);
                                assert (prop_route_id);
                                assert (prop_alist_id);
                                assert (prop_parameter);
@@ -1440,6 +1451,35 @@ Selection::set_state (XMLNode const & node, int)
                                if (!cps.empty()) {
                                        add (cps);
                                }
+                       } else if (prop_type->value () == "region") {
+                               XMLProperty* prop_region_id = (*i)->property (X_("region-id"));
+                               XMLProperty* prop_view_index = (*i)->property (X_("view-index"));
+
+                               if (!prop_region_id || !prop_view_index) {
+                                       continue;
+                               }
+
+                               PBD::ID region_id (prop_region_id->value ());
+                               RegionSelection rs;
+                               editor->get_regionviews_by_id (region_id, rs);
+
+                               if (!rs.empty ()) {
+                                       vector <ControlPoint *> cps;
+                                       for (RegionSelection::iterator rsi = rs.begin(); rsi != rs.end(); ++rsi) {
+                                               AudioRegionView* arv = dynamic_cast<AudioRegionView*> (*rsi);
+                                               if (arv) {
+                                                       boost::shared_ptr<AudioRegionGainLine> gl = arv->get_gain_line ();
+                                                       ControlPoint* cp = gl->nth(atol(prop_view_index->value().c_str()));
+                                                       if (cp) {
+                                                               cps.push_back (cp);
+                                                               cp->show();
+                                                       }
+                                               }
+                                       }
+                                       if (!cps.empty()) {
+                                               add (cps);
+                                       }
+                               }
                        }
 
                } else if  ((*i)->name() == X_("AudioRange")) {