X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Feditor_keys.cc;h=930c5a229d6997cc82ed4a629863956c48e0075a;hb=9d70b725a326ad1cb3425ef27e165bf8117f9bdd;hp=b3081e8c8add34b17ca5d1720c45965c1db540b0;hpb=99904735e066804358f1d0bd138a84f1e9ecda91;p=ardour.git diff --git a/gtk2_ardour/editor_keys.cc b/gtk2_ardour/editor_keys.cc index b3081e8c8a..930c5a229d 100644 --- a/gtk2_ardour/editor_keys.cc +++ b/gtk2_ardour/editor_keys.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2000 Paul Davis + Copyright (C) 2000 Paul Davis This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -21,10 +21,11 @@ #include #include -#include +#include "pbd/error.h" -#include -#include +#include "ardour/session.h" +#include "ardour/region.h" +#include #include "ardour_ui.h" #include "editor.h" @@ -36,19 +37,29 @@ using namespace ARDOUR; using namespace PBD; -using namespace sigc; void Editor::keyboard_selection_finish (bool add) { - if (session && have_pending_keyboard_selection) { - begin_reversible_command (_("keyboard selection")); + 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, session->audible_frame()); + selection->add (pending_keyboard_selection_start, end); } else { - selection->set (0, pending_keyboard_selection_start, session->audible_frame()); + selection->set (pending_keyboard_selection_start, end); } - commit_reversible_command (); + have_pending_keyboard_selection = false; } } @@ -56,70 +67,32 @@ Editor::keyboard_selection_finish (bool add) void Editor::keyboard_selection_begin () { - if (session) { - pending_keyboard_selection_start = session->audible_frame(); - have_pending_keyboard_selection = true; - } -} - -void -Editor::keyboard_duplicate_region () -{ - if (selection->regions.empty()) { - return; - } - - float prefix = 0; - bool was_floating; - - if (get_prefix (prefix, was_floating) == 0) { - duplicate_some_regions (selection->regions, prefix); - } else { - duplicate_some_regions (selection->regions, 1); - } -} + 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 -void -Editor::keyboard_duplicate_selection () -{ - float prefix = 0; - bool was_floating; + if (mouse_frame (where, ignored)) { + pending_keyboard_selection_start = where; + have_pending_keyboard_selection = true; + } - if (get_prefix (prefix, was_floating) == 0) { - duplicate_selection (prefix); - } else { - duplicate_selection (1); + } } } void Editor::keyboard_paste () { - float prefix = 0; - bool was_floating; - - if (get_prefix (prefix, was_floating) == 0) { - paste (prefix); - } else { - paste (1); - } -} - -void -Editor::keyboard_insert_region_list_selection () -{ - float prefix = 0; - bool was_floating; - - if (get_prefix (prefix, was_floating) == 0) { - insert_region_list_selection (prefix); - } else { - insert_region_list_selection (1); - } + ensure_entered_track_selected (true); + paste (1); } int -Editor::get_prefix (float& val, bool& was_floating) +Editor::get_prefix (float& /*val*/, bool& was_floating) { was_floating = false; return 1;