annotate base/Command.cpp @ 1520:954d0cf29ca7 import-audio-data

Switch the normalisation option in WritableWaveFileModel from normalising on read to normalising on write, so that the saved file is already normalised and therefore can be read again without having to remember to normalise it
author Chris Cannam
date Wed, 12 Sep 2018 13:56:56 +0100
parents 48e9f538e6e9
children
rev   line source
Chris@49 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@19 2
Chris@19 3 /*
Chris@52 4 Sonic Visualiser
Chris@52 5 An audio file viewer and annotation editor.
Chris@52 6 Centre for Digital Music, Queen Mary, University of London.
Chris@52 7 This file copyright 2006 Chris Cannam.
Chris@19 8
Chris@52 9 This program is free software; you can redistribute it and/or
Chris@52 10 modify it under the terms of the GNU General Public License as
Chris@52 11 published by the Free Software Foundation; either version 2 of the
Chris@52 12 License, or (at your option) any later version. See the file
Chris@52 13 COPYING included with this distribution for more information.
Chris@19 14 */
Chris@19 15
Chris@19 16 #include "Command.h"
Chris@423 17 #include <QCoreApplication>
Chris@19 18
Chris@19 19 MacroCommand::MacroCommand(QString name) :
Chris@19 20 m_name(name)
Chris@19 21 {
Chris@19 22 }
Chris@19 23
Chris@19 24 MacroCommand::~MacroCommand()
Chris@19 25 {
Chris@19 26 for (size_t i = 0; i < m_commands.size(); ++i) {
Chris@1429 27 delete m_commands[i];
Chris@19 28 }
Chris@19 29 }
Chris@19 30
Chris@19 31 void
Chris@19 32 MacroCommand::addCommand(Command *command)
Chris@19 33 {
Chris@19 34 m_commands.push_back(command);
Chris@19 35 }
Chris@19 36
Chris@19 37 void
Chris@19 38 MacroCommand::deleteCommand(Command *command)
Chris@19 39 {
Chris@19 40 for (std::vector<Command *>::iterator i = m_commands.begin();
Chris@1429 41 i != m_commands.end(); ++i) {
Chris@19 42
Chris@1429 43 if (*i == command) {
Chris@1429 44 m_commands.erase(i);
Chris@1429 45 delete command;
Chris@1429 46 return;
Chris@1429 47 }
Chris@19 48 }
Chris@19 49 }
Chris@19 50
Chris@47 51 bool
Chris@47 52 MacroCommand::haveCommands() const
Chris@47 53 {
Chris@47 54 return !m_commands.empty();
Chris@47 55 }
Chris@47 56
Chris@19 57 void
Chris@19 58 MacroCommand::execute()
Chris@19 59 {
Chris@19 60 for (size_t i = 0; i < m_commands.size(); ++i) {
Chris@1429 61 m_commands[i]->execute();
Chris@19 62 }
Chris@19 63 }
Chris@19 64
Chris@19 65 void
Chris@19 66 MacroCommand::unexecute()
Chris@19 67 {
Chris@19 68 for (size_t i = 0; i < m_commands.size(); ++i) {
Chris@1429 69 m_commands[m_commands.size() - i - 1]->unexecute();
Chris@19 70 }
Chris@19 71 }
Chris@19 72
Chris@47 73 QString
Chris@47 74 MacroCommand::getName() const
Chris@47 75 {
Chris@47 76 return m_name;
Chris@47 77 }
Chris@47 78
Chris@47 79 void
Chris@47 80 MacroCommand::setName(QString name)
Chris@47 81 {
Chris@47 82 m_name = name;
Chris@47 83 }
Chris@47 84
Chris@423 85 BundleCommand::BundleCommand(QString name) :
Chris@423 86 MacroCommand(name)
Chris@423 87 {
Chris@423 88 }
Chris@423 89
Chris@423 90 BundleCommand::~BundleCommand()
Chris@423 91 {
Chris@423 92 }
Chris@423 93
Chris@423 94 QString
Chris@423 95 BundleCommand::getName() const
Chris@423 96 {
Chris@423 97 if (m_commands.size() == 1) return m_name;
Chris@1038 98 return tr("%1 (%n change(s))", "", int(m_commands.size())).arg(m_name);
Chris@423 99 }
Chris@423 100