annotate base/CommandHistory.cpp @ 282:d9319859a4cf tip

(none)
author benoitrigolleau
date Fri, 31 Oct 2008 11:00:24 +0000
parents fc9323a41f5a
children
rev   line source
lbajardsilogic@0 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
lbajardsilogic@0 2
lbajardsilogic@0 3 /*
lbajardsilogic@0 4 Sonic Visualiser
lbajardsilogic@0 5 An audio file viewer and annotation editor.
lbajardsilogic@0 6 Centre for Digital Music, Queen Mary, University of London.
lbajardsilogic@0 7
lbajardsilogic@0 8 This program is free software; you can redistribute it and/or
lbajardsilogic@0 9 modify it under the terms of the GNU General Public License as
lbajardsilogic@0 10 published by the Free Software Foundation; either version 2 of the
lbajardsilogic@0 11 License, or (at your option) any later version. See the file
lbajardsilogic@0 12 COPYING included with this distribution for more information.
lbajardsilogic@0 13 */
lbajardsilogic@0 14
lbajardsilogic@0 15 /*
lbajardsilogic@0 16 This is a modified version of a source file from the Rosegarden
lbajardsilogic@0 17 MIDI and audio sequencer and notation editor, copyright 2000-2006
lbajardsilogic@0 18 Chris Cannam, distributed under the GNU General Public License.
lbajardsilogic@0 19
lbajardsilogic@0 20 This file contains traces of the KCommandHistory class from the KDE
lbajardsilogic@0 21 project, copyright 2000 Werner Trobin and David Faure and
lbajardsilogic@0 22 distributed under the GNU Lesser General Public License.
lbajardsilogic@0 23 */
lbajardsilogic@0 24
lbajardsilogic@0 25 #include "CommandHistory.h"
lbajardsilogic@0 26
lbajardsilogic@0 27 #include "Command.h"
lbajardsilogic@0 28
lbajardsilogic@0 29 #include <QRegExp>
lbajardsilogic@0 30 #include <QMenu>
lbajardsilogic@0 31 #include <QToolBar>
lbajardsilogic@0 32 #include <QString>
lbajardsilogic@0 33 #include <QTimer>
lbajardsilogic@0 34
lbajardsilogic@0 35 #include <iostream>
lbajardsilogic@0 36
lbajardsilogic@0 37 CommandHistory *CommandHistory::m_instance = 0;
lbajardsilogic@0 38
lbajardsilogic@0 39 CommandHistory::CommandHistory() :
lbajardsilogic@0 40 m_undoLimit(50),
lbajardsilogic@0 41 m_redoLimit(50),
lbajardsilogic@0 42 m_menuLimit(15),
lbajardsilogic@0 43 m_savedAt(0),
lbajardsilogic@0 44 m_currentCompound(0),
lbajardsilogic@0 45 m_executeCompound(false),
lbajardsilogic@0 46 m_currentBundle(0),
lbajardsilogic@0 47 m_bundleTimer(0),
lbajardsilogic@0 48 m_bundleTimeout(5000)
lbajardsilogic@0 49 {
lbajardsilogic@0 50 m_undoAction = new QAction(QIcon(":/icons/undo.png"), tr("&Undo"), this);
lbajardsilogic@0 51 m_undoAction->setShortcut(tr("Ctrl+Z"));
lbajardsilogic@0 52 m_undoAction->setStatusTip(tr("Undo the last editing operation"));
lbajardsilogic@0 53 connect(m_undoAction, SIGNAL(triggered()), this, SLOT(undo()));
lbajardsilogic@0 54
lbajardsilogic@0 55 m_undoMenuAction = new QAction(QIcon(":/icons/undo.png"), tr("&Undo"), this);
lbajardsilogic@0 56 connect(m_undoMenuAction, SIGNAL(triggered()), this, SLOT(undo()));
lbajardsilogic@0 57
lbajardsilogic@0 58 m_undoMenu = new QMenu(tr("&Undo"));
lbajardsilogic@0 59 m_undoMenuAction->setMenu(m_undoMenu);
lbajardsilogic@0 60 connect(m_undoMenu, SIGNAL(triggered(QAction *)),
lbajardsilogic@0 61 this, SLOT(undoActivated(QAction*)));
lbajardsilogic@0 62
lbajardsilogic@0 63 m_redoAction = new QAction(QIcon(":/icons/redo.png"), tr("Re&do"), this);
lbajardsilogic@0 64 m_redoAction->setShortcut(tr("Ctrl+Shift+Z"));
lbajardsilogic@0 65 m_redoAction->setStatusTip(tr("Redo the last operation that was undone"));
lbajardsilogic@0 66 connect(m_redoAction, SIGNAL(triggered()), this, SLOT(redo()));
lbajardsilogic@0 67
lbajardsilogic@0 68 m_redoMenuAction = new QAction(QIcon(":/icons/redo.png"), tr("Re&do"), this);
lbajardsilogic@0 69 connect(m_redoMenuAction, SIGNAL(triggered()), this, SLOT(redo()));
lbajardsilogic@0 70
lbajardsilogic@0 71 m_redoMenu = new QMenu(tr("Re&do"));
lbajardsilogic@0 72 m_redoMenuAction->setMenu(m_redoMenu);
lbajardsilogic@0 73 connect(m_redoMenu, SIGNAL(triggered(QAction *)),
lbajardsilogic@0 74 this, SLOT(redoActivated(QAction*)));
lbajardsilogic@0 75 }
lbajardsilogic@0 76
lbajardsilogic@0 77 CommandHistory::~CommandHistory()
lbajardsilogic@0 78 {
lbajardsilogic@0 79 m_savedAt = -1;
lbajardsilogic@0 80 clearStack(m_undoStack);
lbajardsilogic@0 81 clearStack(m_redoStack);
lbajardsilogic@0 82
lbajardsilogic@0 83 delete m_undoMenu;
lbajardsilogic@0 84 delete m_redoMenu;
lbajardsilogic@0 85 }
lbajardsilogic@0 86
lbajardsilogic@0 87 CommandHistory *
lbajardsilogic@0 88 CommandHistory::getInstance()
lbajardsilogic@0 89 {
lbajardsilogic@0 90 if (!m_instance) m_instance = new CommandHistory();
lbajardsilogic@0 91 return m_instance;
lbajardsilogic@0 92 }
lbajardsilogic@0 93
lbajardsilogic@0 94 void
lbajardsilogic@0 95 CommandHistory::clear()
lbajardsilogic@0 96 {
lbajardsilogic@0 97 // std::cerr << "CommandHistory::clear()" << std::endl;
lbajardsilogic@0 98 closeBundle();
lbajardsilogic@0 99 m_savedAt = -1;
lbajardsilogic@0 100 clearStack(m_undoStack);
lbajardsilogic@0 101 clearStack(m_redoStack);
lbajardsilogic@0 102 updateActions();
lbajardsilogic@0 103 }
lbajardsilogic@0 104
lbajardsilogic@0 105 void
lbajardsilogic@0 106 CommandHistory::registerMenu(QMenu *menu)
lbajardsilogic@0 107 {
lbajardsilogic@0 108 menu->addAction(m_undoAction);
lbajardsilogic@0 109 menu->addAction(m_redoAction);
lbajardsilogic@0 110 }
lbajardsilogic@0 111
lbajardsilogic@0 112 void
lbajardsilogic@0 113 CommandHistory::registerToolbar(QToolBar *toolbar)
lbajardsilogic@0 114 {
lbajardsilogic@0 115 toolbar->addAction(m_undoMenuAction);
lbajardsilogic@0 116 toolbar->addAction(m_redoMenuAction);
lbajardsilogic@0 117 }
lbajardsilogic@0 118
lbajardsilogic@0 119 void
lbajardsilogic@0 120 CommandHistory::addCommand(Command *command)
lbajardsilogic@0 121 {
lbajardsilogic@0 122 if (!command) return;
lbajardsilogic@0 123
lbajardsilogic@0 124 if (m_currentCompound) {
lbajardsilogic@0 125 addToCompound(command, m_executeCompound);
lbajardsilogic@0 126 return;
lbajardsilogic@0 127 }
lbajardsilogic@0 128
lbajardsilogic@0 129 addCommand(command, true);
lbajardsilogic@0 130 }
lbajardsilogic@0 131
lbajardsilogic@0 132 void
lbajardsilogic@0 133 CommandHistory::addCommand(Command *command, bool execute, bool bundle)
lbajardsilogic@0 134 {
lbajardsilogic@0 135 if (!command) return;
lbajardsilogic@0 136
lbajardsilogic@0 137 if (m_currentCompound) {
lbajardsilogic@0 138 addToCompound(command, execute);
lbajardsilogic@0 139 return;
lbajardsilogic@0 140 }
lbajardsilogic@0 141
lbajardsilogic@0 142 if (bundle) {
lbajardsilogic@0 143 addToBundle(command, execute);
lbajardsilogic@0 144 return;
lbajardsilogic@0 145 } else if (m_currentBundle) {
lbajardsilogic@0 146 closeBundle();
lbajardsilogic@0 147 }
lbajardsilogic@0 148
lbajardsilogic@0 149 // std::cerr << "CommandHistory::addCommand: " << command->getName().toLocal8Bit().data() << " at " << command << std::endl;
lbajardsilogic@0 150
lbajardsilogic@0 151 // We can't redo after adding a command
lbajardsilogic@0 152 // std::cerr << "CommandHistory::clearing redo stack" << std::endl;
lbajardsilogic@0 153 clearStack(m_redoStack);
lbajardsilogic@0 154
lbajardsilogic@0 155 // can we reach savedAt?
lbajardsilogic@0 156 if ((int)m_undoStack.size() < m_savedAt) m_savedAt = -1; // nope
lbajardsilogic@0 157
lbajardsilogic@0 158 m_undoStack.push(command);
lbajardsilogic@0 159 clipCommands();
lbajardsilogic@0 160
lbajardsilogic@0 161 if (execute) {
lbajardsilogic@0 162 command->execute();
lbajardsilogic@0 163 }
lbajardsilogic@0 164
lbajardsilogic@0 165 // Emit even if we aren't executing the command, because
lbajardsilogic@0 166 // someone must have executed it for this to make any sense
lbajardsilogic@0 167 emit commandExecuted();
lbajardsilogic@0 168 emit commandExecuted(command);
lbajardsilogic@0 169
lbajardsilogic@0 170 updateActions();
lbajardsilogic@0 171 }
lbajardsilogic@0 172
lbajardsilogic@0 173 void
lbajardsilogic@0 174 CommandHistory::addToBundle(Command *command, bool execute)
lbajardsilogic@0 175 {
lbajardsilogic@0 176 if (m_currentBundle) {
lbajardsilogic@0 177 if (!command || (command->getName() != m_currentBundleName)) {
lbajardsilogic@0 178 closeBundle();
lbajardsilogic@0 179 }
lbajardsilogic@0 180 }
lbajardsilogic@0 181
lbajardsilogic@0 182 if (!command) return;
lbajardsilogic@0 183
lbajardsilogic@0 184 if (!m_currentBundle) {
lbajardsilogic@0 185 // need to addCommand before setting m_currentBundle, as addCommand
lbajardsilogic@0 186 // with bundle false will reset m_currentBundle to 0
lbajardsilogic@0 187 MacroCommand *mc = new MacroCommand(command->getName());
lbajardsilogic@0 188 addCommand(mc, false);
lbajardsilogic@0 189 m_currentBundle = mc;
lbajardsilogic@0 190 m_currentBundleName = command->getName();
lbajardsilogic@0 191 }
lbajardsilogic@0 192
lbajardsilogic@0 193 if (execute) command->execute();
lbajardsilogic@0 194 m_currentBundle->addCommand(command);
lbajardsilogic@0 195
lbajardsilogic@0 196 delete m_bundleTimer;
lbajardsilogic@0 197 m_bundleTimer = new QTimer(this);
lbajardsilogic@0 198 connect(m_bundleTimer, SIGNAL(timeout()), this, SLOT(bundleTimerTimeout()));
lbajardsilogic@0 199 m_bundleTimer->start(m_bundleTimeout);
lbajardsilogic@0 200 }
lbajardsilogic@0 201
lbajardsilogic@0 202 void
lbajardsilogic@0 203 CommandHistory::closeBundle()
lbajardsilogic@0 204 {
lbajardsilogic@0 205 m_currentBundle = 0;
lbajardsilogic@0 206 m_currentBundleName = "";
lbajardsilogic@0 207 }
lbajardsilogic@0 208
lbajardsilogic@0 209 void
lbajardsilogic@0 210 CommandHistory::bundleTimerTimeout()
lbajardsilogic@0 211 {
lbajardsilogic@0 212 closeBundle();
lbajardsilogic@0 213 }
lbajardsilogic@0 214
lbajardsilogic@0 215 void
lbajardsilogic@0 216 CommandHistory::addToCompound(Command *command, bool execute)
lbajardsilogic@0 217 {
lbajardsilogic@0 218 // std::cerr << "CommandHistory::addToCompound: " << command->getName().toLocal8Bit().data() << std::endl;
lbajardsilogic@0 219
lbajardsilogic@0 220 if (execute) command->execute();
lbajardsilogic@0 221 m_currentCompound->addCommand(command);
lbajardsilogic@0 222 }
lbajardsilogic@0 223
lbajardsilogic@0 224 void
lbajardsilogic@0 225 CommandHistory::startCompoundOperation(QString name, bool execute)
lbajardsilogic@0 226 {
lbajardsilogic@0 227 if (m_currentCompound) {
lbajardsilogic@0 228 std::cerr << "CommandHistory::startCompoundOperation: ERROR: compound operation already in progress!" << std::endl;
lbajardsilogic@0 229 std::cerr << "(name is " << m_currentCompound->getName().toLocal8Bit().data() << ")" << std::endl;
lbajardsilogic@0 230 }
lbajardsilogic@0 231
lbajardsilogic@0 232 closeBundle();
lbajardsilogic@0 233
lbajardsilogic@0 234 m_currentCompound = new MacroCommand(name);
lbajardsilogic@0 235 m_executeCompound = execute;
lbajardsilogic@0 236 }
lbajardsilogic@0 237
lbajardsilogic@0 238 void
lbajardsilogic@0 239 CommandHistory::endCompoundOperation()
lbajardsilogic@0 240 {
lbajardsilogic@0 241 if (!m_currentCompound) {
lbajardsilogic@0 242 std::cerr << "CommandHistory::endCompoundOperation: ERROR: no compound operation in progress!" << std::endl;
lbajardsilogic@0 243 }
lbajardsilogic@0 244
lbajardsilogic@0 245 MacroCommand *toAdd = m_currentCompound;
lbajardsilogic@0 246 m_currentCompound = 0;
lbajardsilogic@0 247
lbajardsilogic@0 248 if (toAdd->haveCommands()) {
lbajardsilogic@0 249
lbajardsilogic@0 250 // We don't execute the macro command here, because we have
lbajardsilogic@0 251 // been executing the individual commands as we went along if
lbajardsilogic@0 252 // m_executeCompound was true.
lbajardsilogic@0 253 addCommand(toAdd, false);
lbajardsilogic@0 254 }
lbajardsilogic@0 255 }
lbajardsilogic@0 256
lbajardsilogic@0 257 void
lbajardsilogic@0 258 CommandHistory::addExecutedCommand(Command *command)
lbajardsilogic@0 259 {
lbajardsilogic@0 260 addCommand(command, false);
lbajardsilogic@0 261 }
lbajardsilogic@0 262
lbajardsilogic@0 263 void
lbajardsilogic@0 264 CommandHistory::addCommandAndExecute(Command *command)
lbajardsilogic@0 265 {
lbajardsilogic@0 266 addCommand(command, true);
lbajardsilogic@0 267 }
lbajardsilogic@0 268
lbajardsilogic@0 269 void
lbajardsilogic@0 270 CommandHistory::undo()
lbajardsilogic@0 271 {
lbajardsilogic@0 272 if (m_undoStack.empty()) return;
lbajardsilogic@0 273
lbajardsilogic@0 274 closeBundle();
lbajardsilogic@0 275
lbajardsilogic@0 276 Command *command = m_undoStack.top();
lbajardsilogic@0 277 command->unexecute();
lbajardsilogic@0 278 emit commandExecuted();
lbajardsilogic@0 279 emit commandUnexecuted(command);
lbajardsilogic@0 280
lbajardsilogic@0 281 m_redoStack.push(command);
lbajardsilogic@0 282 m_undoStack.pop();
lbajardsilogic@0 283
lbajardsilogic@0 284 clipCommands();
lbajardsilogic@0 285 updateActions();
lbajardsilogic@0 286
lbajardsilogic@0 287 if ((int)m_undoStack.size() == m_savedAt) emit documentRestored();
lbajardsilogic@0 288 }
lbajardsilogic@0 289
lbajardsilogic@0 290 void
lbajardsilogic@0 291 CommandHistory::redo()
lbajardsilogic@0 292 {
lbajardsilogic@0 293 if (m_redoStack.empty()) return;
lbajardsilogic@0 294
lbajardsilogic@0 295 closeBundle();
lbajardsilogic@0 296
lbajardsilogic@0 297 Command *command = m_redoStack.top();
lbajardsilogic@0 298 command->execute();
lbajardsilogic@0 299 emit commandExecuted();
lbajardsilogic@0 300 emit commandExecuted(command);
lbajardsilogic@0 301
lbajardsilogic@0 302 m_undoStack.push(command);
lbajardsilogic@0 303 m_redoStack.pop();
lbajardsilogic@0 304 // no need to clip
lbajardsilogic@0 305
lbajardsilogic@0 306 updateActions();
lbajardsilogic@0 307
lbajardsilogic@0 308 if ((int)m_undoStack.size() == m_savedAt) emit documentRestored();
lbajardsilogic@0 309 }
lbajardsilogic@0 310
lbajardsilogic@0 311 void
lbajardsilogic@0 312 CommandHistory::setUndoLimit(int limit)
lbajardsilogic@0 313 {
lbajardsilogic@0 314 if (limit > 0 && limit != m_undoLimit) {
lbajardsilogic@0 315 m_undoLimit = limit;
lbajardsilogic@0 316 clipCommands();
lbajardsilogic@0 317 }
lbajardsilogic@0 318 }
lbajardsilogic@0 319
lbajardsilogic@0 320 void
lbajardsilogic@0 321 CommandHistory::setRedoLimit(int limit)
lbajardsilogic@0 322 {
lbajardsilogic@0 323 if (limit > 0 && limit != m_redoLimit) {
lbajardsilogic@0 324 m_redoLimit = limit;
lbajardsilogic@0 325 clipCommands();
lbajardsilogic@0 326 }
lbajardsilogic@0 327 }
lbajardsilogic@0 328
lbajardsilogic@0 329 void
lbajardsilogic@0 330 CommandHistory::setMenuLimit(int limit)
lbajardsilogic@0 331 {
lbajardsilogic@0 332 m_menuLimit = limit;
lbajardsilogic@0 333 updateActions();
lbajardsilogic@0 334 }
lbajardsilogic@0 335
lbajardsilogic@0 336 void
lbajardsilogic@0 337 CommandHistory::setBundleTimeout(int ms)
lbajardsilogic@0 338 {
lbajardsilogic@0 339 m_bundleTimeout = ms;
lbajardsilogic@0 340 }
lbajardsilogic@0 341
lbajardsilogic@0 342 void
lbajardsilogic@0 343 CommandHistory::documentSaved()
lbajardsilogic@0 344 {
lbajardsilogic@0 345 closeBundle();
lbajardsilogic@0 346 m_savedAt = m_undoStack.size();
lbajardsilogic@0 347 }
lbajardsilogic@0 348
lbajardsilogic@0 349 void
lbajardsilogic@0 350 CommandHistory::clipCommands()
lbajardsilogic@0 351 {
lbajardsilogic@0 352 if ((int)m_undoStack.size() > m_undoLimit) {
lbajardsilogic@0 353 m_savedAt -= (m_undoStack.size() - m_undoLimit);
lbajardsilogic@0 354 }
lbajardsilogic@0 355
lbajardsilogic@0 356 clipStack(m_undoStack, m_undoLimit);
lbajardsilogic@0 357 clipStack(m_redoStack, m_redoLimit);
lbajardsilogic@0 358 }
lbajardsilogic@0 359
lbajardsilogic@0 360 void
lbajardsilogic@0 361 CommandHistory::clipStack(CommandStack &stack, int limit)
lbajardsilogic@0 362 {
lbajardsilogic@0 363 int i;
lbajardsilogic@0 364
lbajardsilogic@0 365 if ((int)stack.size() > limit) {
lbajardsilogic@0 366
lbajardsilogic@0 367 CommandStack tempStack;
lbajardsilogic@0 368
lbajardsilogic@0 369 for (i = 0; i < limit; ++i) {
lbajardsilogic@0 370 // Command *command = stack.top();
lbajardsilogic@0 371 // std::cerr << "CommandHistory::clipStack: Saving recent command: " << command->getName().toLocal8Bit().data() << " at " << command << std::endl;
lbajardsilogic@0 372 tempStack.push(stack.top());
lbajardsilogic@0 373 stack.pop();
lbajardsilogic@0 374 }
lbajardsilogic@0 375
lbajardsilogic@0 376 clearStack(stack);
lbajardsilogic@0 377
lbajardsilogic@0 378 for (i = 0; i < m_undoLimit; ++i) {
lbajardsilogic@0 379 stack.push(tempStack.top());
lbajardsilogic@0 380 tempStack.pop();
lbajardsilogic@0 381 }
lbajardsilogic@0 382 }
lbajardsilogic@0 383 }
lbajardsilogic@0 384
lbajardsilogic@0 385 void
lbajardsilogic@0 386 CommandHistory::clearStack(CommandStack &stack)
lbajardsilogic@0 387 {
lbajardsilogic@0 388 while (!stack.empty()) {
lbajardsilogic@0 389 Command *command = stack.top();
lbajardsilogic@0 390 // Not safe to call getName() on a command about to be deleted
lbajardsilogic@0 391 // std::cerr << "CommandHistory::clearStack: About to delete command " << command << std::endl;
lbajardsilogic@0 392 delete command;
lbajardsilogic@0 393 stack.pop();
lbajardsilogic@0 394 }
lbajardsilogic@0 395 }
lbajardsilogic@0 396
lbajardsilogic@0 397 void
lbajardsilogic@0 398 CommandHistory::undoActivated(QAction *action)
lbajardsilogic@0 399 {
lbajardsilogic@0 400 int pos = m_actionCounts[action];
lbajardsilogic@0 401 for (int i = 0; i <= pos; ++i) {
lbajardsilogic@0 402 undo();
lbajardsilogic@0 403 }
lbajardsilogic@0 404 }
lbajardsilogic@0 405
lbajardsilogic@0 406 void
lbajardsilogic@0 407 CommandHistory::redoActivated(QAction *action)
lbajardsilogic@0 408 {
lbajardsilogic@0 409 int pos = m_actionCounts[action];
lbajardsilogic@0 410 for (int i = 0; i <= pos; ++i) {
lbajardsilogic@0 411 redo();
lbajardsilogic@0 412 }
lbajardsilogic@0 413 }
lbajardsilogic@0 414
lbajardsilogic@0 415 void
lbajardsilogic@0 416 CommandHistory::updateActions()
lbajardsilogic@0 417 {
lbajardsilogic@0 418 m_actionCounts.clear();
lbajardsilogic@0 419
lbajardsilogic@0 420 for (int undo = 0; undo <= 1; ++undo) {
lbajardsilogic@0 421
lbajardsilogic@0 422 QAction *action(undo ? m_undoAction : m_redoAction);
lbajardsilogic@0 423 QAction *menuAction(undo ? m_undoMenuAction : m_redoMenuAction);
lbajardsilogic@0 424 QMenu *menu(undo ? m_undoMenu : m_redoMenu);
lbajardsilogic@0 425 CommandStack &stack(undo ? m_undoStack : m_redoStack);
lbajardsilogic@0 426
lbajardsilogic@0 427 if (stack.empty()) {
lbajardsilogic@0 428
lbajardsilogic@0 429 QString text(undo ? tr("Nothing to undo") : tr("Nothing to redo"));
lbajardsilogic@0 430
lbajardsilogic@0 431 action->setEnabled(false);
lbajardsilogic@0 432 action->setText(text);
lbajardsilogic@0 433
lbajardsilogic@0 434 menuAction->setEnabled(false);
lbajardsilogic@0 435 menuAction->setText(text);
lbajardsilogic@0 436
lbajardsilogic@0 437 } else {
lbajardsilogic@0 438
lbajardsilogic@0 439 action->setEnabled(true);
lbajardsilogic@0 440 menuAction->setEnabled(true);
lbajardsilogic@0 441
lbajardsilogic@0 442 QString commandName = stack.top()->getName();
lbajardsilogic@0 443 commandName.replace(QRegExp("&"), "");
lbajardsilogic@0 444
lbajardsilogic@0 445 QString text = (undo ? tr("&Undo %1") : tr("Re&do %1"))
lbajardsilogic@0 446 .arg(commandName);
lbajardsilogic@0 447
lbajardsilogic@0 448 action->setText(text);
lbajardsilogic@0 449 menuAction->setText(text);
lbajardsilogic@0 450 }
lbajardsilogic@0 451
lbajardsilogic@0 452 menu->clear();
lbajardsilogic@0 453
lbajardsilogic@0 454 CommandStack tempStack;
lbajardsilogic@0 455 int j = 0;
lbajardsilogic@0 456
lbajardsilogic@0 457 while (j < m_menuLimit && !stack.empty()) {
lbajardsilogic@0 458
lbajardsilogic@0 459 Command *command = stack.top();
lbajardsilogic@0 460 tempStack.push(command);
lbajardsilogic@0 461 stack.pop();
lbajardsilogic@0 462
lbajardsilogic@0 463 QString commandName = command->getName();
lbajardsilogic@0 464 commandName.replace(QRegExp("&"), "");
lbajardsilogic@0 465
lbajardsilogic@0 466 QString text;
lbajardsilogic@0 467 if (undo) text = tr("&Undo %1").arg(commandName);
lbajardsilogic@0 468 else text = tr("Re&do %1").arg(commandName);
lbajardsilogic@0 469
lbajardsilogic@0 470 QAction *action = menu->addAction(text);
lbajardsilogic@0 471 m_actionCounts[action] = j++;
lbajardsilogic@0 472 }
lbajardsilogic@0 473
lbajardsilogic@0 474 while (!tempStack.empty()) {
lbajardsilogic@0 475 stack.push(tempStack.top());
lbajardsilogic@0 476 tempStack.pop();
lbajardsilogic@0 477 }
lbajardsilogic@0 478 }
lbajardsilogic@0 479 }
lbajardsilogic@0 480