1
////////////////////////////////////////////////////////////////////////////////
3
// This file is part of Toolkit for Conceptual Modeling (TCM).
4
// (c) copyright 1999, Vrije Universiteit Amsterdam.
5
// Author: Frank Dehne (frank@cs.vu.nl).
7
// TCM is free software; you can redistribute it and/or modify
8
// it under the terms of the GNU General Public License as published by
9
// the Free Software Foundation; either version 2 of the License, or
10
// (at your option) any later version.
12
// TCM is distributed in the hope that it will be useful,
13
// but WITHOUT ANY WARRANTY; without even the implied warranty of
14
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
// GNU General Public License for more details.
17
// You should have received a copy of the GNU General Public License
18
// along with TCM; if not, write to the Free Software
19
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
21
////////////////////////////////////////////////////////////////////////////////
22
#include "updatetypecmd.h"
23
#include "shapeview.h"
26
UpdateTypeCmd::UpdateTypeCmd(ShapeView *v, List<int *> *l, int n):
27
Command(v->GetViewer()->GetDiagram(), v->GetViewer()) {
31
diagram = v->GetViewer()->GetDiagram();
32
oldThings = new List<Thing *>;
33
newThings = new List<Thing *>;
36
UpdateTypeCmd::~UpdateTypeCmd() {
45
void UpdateTypeCmd::TransformAll() {
46
for (oldThings->first(); !oldThings->done(); oldThings->next()) {
47
Thing *oldThing = oldThings->cur();
48
Thing *newThing = Transform(oldThing);
50
newThings->add(newThing);
54
void UpdateTypeCmd::Execute() {
55
if (oldThings->count() == 0) {
56
GetMainWindow()->SetStatus(
57
"aborted: nothing has to be changed");
61
if (oldThings->count() != newThings->count()) {
65
for (unsigned i=0; i<oldThings->count(); i++) {
66
Thing *oldThing = (*oldThings)[i];
67
Thing *newThing = (*newThings)[i];
68
Reverse(oldThing, newThing);
73
void UpdateTypeCmd::UnExecute() {
74
for (unsigned i=0; i<oldThings->count(); i++) {
75
Thing *oldThing = (*oldThings)[i];
76
Thing *newThing = (*newThings)[i];
77
Reverse(newThing, oldThing);