X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Feditor_keys.cc;h=acf7d2a14308b95c04dd4659bcbdcbc5f6aa52cb;hb=6b1b72a247bf04c81292fc41af4f69c9b7f90379;hp=2900e28c2a48a5fc1235aebc4a1a45f0b4ed86d2;hpb=0f1c7b1d71078a25c1df80e7c95d59229f613414;p=ardour.git diff --git a/gtk2_ardour/editor_keys.cc b/gtk2_ardour/editor_keys.cc index 2900e28c2a..acf7d2a143 100644 --- a/gtk2_ardour/editor_keys.cc +++ b/gtk2_ardour/editor_keys.cc @@ -27,135 +27,81 @@ #include "ardour/session.h" -#include "ardour_ui.h" #include "editor.h" #include "region_view.h" #include "selection.h" #include "time_axis_view.h" -#include "i18n.h" +#include "pbd/i18n.h" using namespace ARDOUR; using namespace PBD; using namespace Editing; void -Editor::keyboard_selection_finish (bool add) +Editor::keyboard_selection_finish (bool /*add*/, Editing::EditIgnoreOption ign) { if (_session) { - framepos_t start = selection->time.start(); - framepos_t end; - + MusicSample start (selection->time.start(), 0); + samplepos_t end; if ((_edit_point == EditAtPlayhead) && _session->transport_rolling()) { - end = _session->audible_frame(); + end = _session->audible_sample(); } else { - end = get_preferred_edit_position(); + end = get_preferred_edit_position(ign); } - //snap the selection start/end - snap_to(start); - //if no tracks are selected and we're working from the keyboard, enable all tracks (_something_ has to be selected for any range selection) if ( (_edit_point == EditAtPlayhead) && selection->tracks.empty() ) select_all_tracks(); - selection->set (start, end); + selection->set (start.sample, end); //if session is playing a range, cancel that -// if (_session->get_play_range()) -// _session->request_cancel_play_range(); + if (_session->get_play_range()) + _session->request_cancel_play_range(); } } void -Editor::keyboard_selection_begin () +Editor::keyboard_selection_begin (Editing::EditIgnoreOption ign) { if (_session) { - framepos_t start; - framepos_t end = selection->time.end_frame(); //0 if no current selection - + MusicSample start (0, 0); + MusicSample end (selection->time.end_sample(), 0); if ((_edit_point == EditAtPlayhead) && _session->transport_rolling()) { - start = _session->audible_frame(); + start.sample = _session->audible_sample(); } else { - start = get_preferred_edit_position(); + start.sample = get_preferred_edit_position(ign); } - - //snap the selection start/end - snap_to(start); - + //if there's not already a sensible selection endpoint, go "forever" - if ( start > end ) { - end = max_framepos; + if (start.sample > end.sample) { +#ifdef MIXBUS + // 4hours at most. + // This works around a visual glitch in red-bordered selection rect. + end.sample = start.sample + _session->nominal_sample_rate() * 60 * 60 * 4; +#else + end.sample = max_samplepos; +#endif } - + //if no tracks are selected and we're working from the keyboard, enable all tracks (_something_ has to be selected for any range selection) if ( selection->tracks.empty() ) select_all_tracks(); - - selection->set (start, end); + + selection->set (start.sample, end.sample); //if session is playing a range, cancel that if (_session->get_play_range()) - _session->request_transport_speed ( 1.0 ); - - //if join playhead, locate to the newly selected start -// if ( !_session->transport_rolling() && Config->get_join_play_range() ) -// _session->request_cancel_play_range(); + _session->request_cancel_play_range(); } } -/* -void -Editor::keyboard_selection_finish (bool add) -{ - if (_session && have_pending_keyboard_selection) { - - framepos_t end; - bool ignored; - - if (_session->transport_rolling()) { - end = _session->audible_frame(); - } else { - if (!mouse_frame (end, ignored)) { - return; - } - } - - if (add) { - selection->add (pending_keyboard_selection_start, end); - } else { - selection->set (pending_keyboard_selection_start, end); - } - - have_pending_keyboard_selection = false; - } -} - -void -Editor::keyboard_selection_begin () -{ - if (_session) { - if (_session->transport_rolling()) { - pending_keyboard_selection_start = _session->audible_frame(); - have_pending_keyboard_selection = true; - } else { - bool ignored; - framepos_t where; // XXX fix me - - if (mouse_frame (where, ignored)) { - pending_keyboard_selection_start = where; - have_pending_keyboard_selection = true; - } - - } - } -}*/ - void Editor::keyboard_paste () { - paste (1); + paste (1, false); }