*/
-#include <ardour/audioregion.h>
-#include <ardour/playlist.h>
-#include <ardour/location.h>
+#include "ardour/audioregion.h"
+#include "ardour/playlist.h"
+#include "ardour/location.h"
-#include <pbd/memento_command.h>
+#include "pbd/memento_command.h"
#include "editor.h"
#include "region_view.h"
#include "selection.h"
#include "keyboard.h"
+#include "editor_drag.h"
#include "i18n.h"
/* any use of "keyboard mouse buttons" invalidates an existing grab
*/
- if (drag_info.item) {
- drag_info.item->ungrab (GDK_CURRENT_TIME);
- drag_info.item = 0;
+ if (_drag) {
+ _drag->item()->ungrab (GDK_CURRENT_TIME);
+ delete _drag;
+ _drag = 0;
}
if (doit) {
void
Editor::kbd_mute_unmute_region ()
{
- if (entered_regionview) {
+ if (!selection->regions.empty ()) {
+
+ if (selection->regions.size() > 1) {
+ begin_reversible_command (_("mute regions"));
+ } else {
+ begin_reversible_command (_("mute region"));
+ }
+
+ for (RegionSelection::iterator i = selection->regions.begin(); i != selection->regions.end(); ++i) {
+
+ XMLNode &before = (*i)->region()->playlist()->get_state ();
+ (*i)->region()->set_muted (!(*i)->region()->muted ());
+ XMLNode &after = (*i)->region()->playlist()->get_state ();
+
+ session->add_command (new MementoCommand<ARDOUR::Playlist>(*((*i)->region()->playlist()), &before, &after));
+
+ }
+
+ commit_reversible_command ();
+
+ } else if (entered_regionview) {
+
begin_reversible_command (_("mute region"));
XMLNode &before = entered_regionview->region()->playlist()->get_state();
XMLNode &after = entered_regionview->region()->playlist()->get_state();
session->add_command (new MementoCommand<ARDOUR::Playlist>(*(entered_regionview->region()->playlist()), &before, &after));
commit_reversible_command();
+
}
}