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 "updatenodeshapetypecmd.h"
23
#include "diagramviewer.h"
25
#include "shapeview.h"
27
#include "nodeshape.h"
29
UpdateNodeShapeTypeCmd::UpdateNodeShapeTypeCmd(ShapeView *v,
30
List<int *> *l, int n): UpdateTypeCmd(v, l, n) {
31
List<GShape *> *selection = v->GetSelection();
32
for (selection->first(); !selection->done(); selection->next()) {
33
GShape *shape = selection->cur();
34
int type = shape->GetClassType();
36
for (l->first(); !l->done(); l->next()) {
37
if (*l->cur() == type) {
38
oldThings->add(shape);
45
void UpdateNodeShapeTypeCmd::Reverse(Thing *oldThing, Thing *newThing) {
46
GShape *oldShape = (GShape *)oldThing;
47
GShape *newShape = (GShape *)newThing;
48
UpdateLines(oldShape, newShape);
49
view->AddShape(newShape);
50
view->RemoveShape(oldShape);
51
newShape->AdjustSize();
52
view->GetViewer()->ShapePositionUpdate(newShape);
55
void UpdateNodeShapeTypeCmd::UpdateLines(GShape *oldshape, GShape *newshape) {
56
List<GShape *> *shapes = view->GetShapes();
57
for (shapes->first(); !shapes->done(); shapes->next()) {
58
GShape *shape = shapes->cur();
59
if (shape->IsLine()) {
60
Line *line = (Line *)shape;
61
if (line->GetFromShape() == oldshape)
62
line->SetFromShape(newshape);
63
if (line->GetToShape() == oldshape)
64
line->SetToShape(newshape);