open un-writable sessions without complaining, and desensitize all/most actions that...
[ardour.git] / gtk2_ardour / editor_keyboard.cc
index 8eb0d1a6e4fbd266a6c7048a5e3916f85b14215f..257ebc487aee69ec48164f8492d05f7e9ff7ad8d 100644 (file)
@@ -39,7 +39,7 @@ Editor::kbd_driver (sigc::slot<void,GdkEvent*> theslot, bool use_track_canvas, b
        double worldx, worldy;
        GdkEvent ev;
        Gdk::ModifierType mask;
-       Glib::RefPtr<Gdk::Window> evw = track_canvas.get_window()->get_pointer (x, y, mask);
+       Glib::RefPtr<Gdk::Window> evw = track_canvas->get_window()->get_pointer (x, y, mask);
        bool doit = false;
 
        if (use_track_canvas && track_canvas_event_box.get_window()->get_pointer(x, y, mask) != 0) {
@@ -62,7 +62,7 @@ Editor::kbd_driver (sigc::slot<void,GdkEvent*> theslot, bool use_track_canvas, b
                        selection->set (entered_regionview);
                }
 
-               track_canvas.window_to_world (x, y, worldx, worldy);
+               track_canvas->window_to_world (x, y, worldx, worldy);
                worldx += horizontal_adjustment.get_value();
                worldy += vertical_adjustment.get_value();
 
@@ -76,94 +76,30 @@ Editor::kbd_driver (sigc::slot<void,GdkEvent*> theslot, bool use_track_canvas, b
 }
 
 void
-Editor::set_edit_point (GdkEvent* event)
+Editor::kbd_mute_unmute_region ()
 {
-       if (selection->markers.empty()) {
-               nframes64_t where = event_frame (event);
-
-               snap_to (where);
-               mouse_add_new_marker (where);
-
-       } else {
-               bool ignored;
-
-               Location* loc = find_location_from_marker (selection->markers.front(), ignored);
-
-               if (loc) {
-                       nframes64_t where = event_frame (event);
-                       snap_to (where);
-                       loc->move_to (where);
-               }
-       }
-}
+       if (!selection->regions.empty ()) {
 
-void
-Editor::set_playhead_cursor (GdkEvent* event)
-{
-       if (entered_marker) {
-               session->request_locate (entered_marker->position(), session->transport_rolling());
-       } else {
-               nframes_t pointer_frame = event_frame (event);
-               
-               if (!Keyboard::modifier_state_contains (event->button.state, Keyboard::snap_modifier())) {
-                       snap_to (pointer_frame);
-               }
-               
-               if (session) {
-                       session->request_locate (pointer_frame, session->transport_rolling());
+               if (selection->regions.size() > 1) {
+                       begin_reversible_command (_("mute regions"));
+               } else {
+                       begin_reversible_command (_("mute region"));
                }
-       }
-}
-
-void
-Editor::kbd_set_edit_point ()
-{
-       kbd_driver (mem_fun(*this, &Editor::set_edit_point), true, true, false);
-}      
 
-void
-Editor::kbd_set_playhead_cursor ()
-{
-       kbd_driver (mem_fun(*this, &Editor::set_playhead_cursor), true, true, false);
-}
+               for (RegionSelection::iterator i = selection->regions.begin(); i != selection->regions.end(); ++i) {
 
-void
-Editor::kbd_do_split (GdkEvent* ev)
-{
-       if (entered_regionview) {
+                       XMLNode &before = (*i)->region()->playlist()->get_state ();
+                       (*i)->region()->set_muted (!(*i)->region()->muted ());
+                       XMLNode &after = (*i)->region()->playlist()->get_state ();
 
-               nframes_t where = get_preferred_edit_position();
+                       session->add_command (new MementoCommand<ARDOUR::Playlist>(*((*i)->region()->playlist()), &before, &after));
 
-               if (selection->regions.contains (entered_regionview)) {
-                       split_regions_at (where, selection->regions);
-               } else {
-                       RegionSelection s;
-                       s.add (entered_regionview);
-                       split_regions_at (where, s);
-               }
-
-       } else if (entered_marker) {
-
-               if (!selection->regions.empty()) {
-                       split_regions_at (entered_marker->position(), selection->regions);
-               } else {
-                       RegionSelection rs;
-                       rs = get_regions_at (entered_marker->position(), selection->tracks);
-                       split_regions_at (entered_marker->position(), rs);
                }
-       }
-}
 
-void
-Editor::kbd_split ()
-{
-       kbd_driver (mem_fun(*this, &Editor::kbd_do_split), true, true, false);
-}
+               commit_reversible_command ();
 
-void
-Editor::kbd_mute_unmute_region ()
-{
-       if (entered_regionview) {
+       } else if (entered_regionview) {
+               
                begin_reversible_command (_("mute region"));
                XMLNode &before = entered_regionview->region()->playlist()->get_state();
                
@@ -172,100 +108,10 @@ Editor::kbd_mute_unmute_region ()
                XMLNode &after = entered_regionview->region()->playlist()->get_state();
                session->add_command (new MementoCommand<ARDOUR::Playlist>(*(entered_regionview->region()->playlist()), &before, &after));
                commit_reversible_command();
+               
        }
 }
 
-void
-Editor::kbd_set_sync_position ()
-{
-       kbd_driver (mem_fun(*this, &Editor::kbd_do_set_sync_position), true, true, false);
-}
-
-void
-Editor::kbd_do_set_sync_position (GdkEvent* ev)
-{
-       if (entered_regionview) {
-               nframes64_t where = event_frame (ev);
-               snap_to (where);
-
-               set_a_regions_sync_position (entered_regionview->region(), where);
-
-       } else if (entered_marker) {
-
-               if (!selection->regions.empty()) {
-                       set_a_regions_sync_position (selection->regions.front()->region(), entered_marker->position());
-               }
-       }
-}
-
-void
-Editor::kbd_do_align (GdkEvent* ev, ARDOUR::RegionPoint what)
-{
-       if (entered_regionview) {
-
-               nframes_t where = event_frame (ev);
-               snap_to (where);
-
-               if (selection->regions.contains (entered_regionview)) {
-                       align_selection (what, where, selection->regions);
-               } else {
-                       RegionSelection s;
-                       s.add (entered_regionview);
-                       align_selection (what, where, s);
-               }
-
-       } else if (entered_marker) {
-
-               if (!selection->regions.empty()) {
-                       align_selection (what, entered_marker->position(), selection->regions);
-               } else {
-                       RegionSelection rs;
-                       rs = get_regions_at (entered_marker->position(), selection->tracks);
-                       align_selection (what, entered_marker->position(), rs);
-               }
-       }
-}
-
-void
-Editor::kbd_do_align_relative (GdkEvent* ev, ARDOUR::RegionPoint what)
-{
-       if (entered_regionview) {
-
-               nframes_t where = event_frame (ev);
-               snap_to (where);
-
-               if (selection->regions.contains (entered_regionview)) {
-                       align_selection_relative (what, where, selection->regions);
-               } else {
-                       RegionSelection s;
-                       s.add (entered_regionview);
-                       align_selection_relative (what, where, s);
-               }
-
-       } else if (entered_marker) {
-
-               if (!selection->regions.empty()) {
-                       align_selection_relative (what, entered_marker->position(), selection->regions);
-               } else {
-                       RegionSelection rs;
-                       rs = get_regions_at (entered_marker->position(), selection->tracks);
-                       align_selection_relative (what, entered_marker->position(), rs);
-               }
-       }
-}
-
-void
-Editor::kbd_align (ARDOUR::RegionPoint what)
-{
-       kbd_driver (bind (mem_fun(*this, &Editor::kbd_do_align), what));
-}
-
-void
-Editor::kbd_align_relative (ARDOUR::RegionPoint what)
-{
-       kbd_driver (bind (mem_fun(*this, &Editor::kbd_do_align), what), true, true, false);
-}
-
 void
 Editor::kbd_do_brush (GdkEvent *ev)
 {
@@ -278,14 +124,3 @@ Editor::kbd_brush ()
        kbd_driver (mem_fun(*this, &Editor::kbd_do_brush), true, true, false);
 }
 
-void
-Editor::kbd_do_audition (GdkEvent *ignored)
-{
-       audition_selected_region ();
-}
-
-void
-Editor::kbd_audition ()
-{
-       kbd_driver (mem_fun(*this, &Editor::kbd_do_audition), true, false, true);
-}