1
////////////////////////////////////////////////////////////////////////////////
3
// This file is part of Toolkit for Conceptual Modeling (TCM).
4
// (c) copyright 1995, 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
////////////////////////////////////////////////////////////////////////////////
23
#include "shapeview.h"
25
#include "diagramviewer.h"
26
#include "drawwindow.h"
27
#include "messagedialog.h"
28
#include "samesizecmd.h"
30
SameSizeCmd::SameSizeCmd(ShapeView *v):
31
Command(v->GetViewer()->GetDiagram(), v->GetViewer()) {
32
diagram = v->GetViewer()->GetDiagram();
33
shapes = new List<GShape *>(*v->GetSelection());
34
oldSizes = new List<Point *>;
35
for (shapes->first(); !shapes->done(); shapes->next()) {
36
Shape *shape = shapes->cur();
37
Point *pt = new Point(shape->GetWidth(), shape->GetHeight());
42
SameSizeCmd::~SameSizeCmd() {
48
void SameSizeCmd::Execute() {
51
// the first shape determines the size.
52
GShape *shape = shapes->cur();
53
int w = shape->GetWidth();
54
int h = shape->GetHeight();
55
if ( ! shape->IsNodeShape() ) {
56
(new MessageDialog(GetMainWindow()->GetWidget(),
57
MessageDialog::ERROR))->Show("Error",
58
"The first selected shape should not be a line");
59
GetMainWindow()->SetStatus("aborted: first selected is a line");
63
bool nodesFound = False;
64
while(shapes->next()) {
65
shape = shapes->cur();
66
if ( shape->IsNodeShape() ) {
68
shape->UpdateSize(w, h);
69
shape->GetView()->GetViewer()->
70
ShapePositionUpdate(shape);
74
(new MessageDialog(GetMainWindow()->GetWidget(),
75
MessageDialog::ERROR))->Show("Error",
76
"The selection should contain at least two node shapes");
77
GetMainWindow()->SetStatus(
78
"aborted: too few nodes are selected");
83
GetMainWindow()->FitDocument();
86
void SameSizeCmd::UnExecute() {
87
// restore old positions.
88
if (shapes->first() && oldSizes->first()) {
90
GShape *shape = shapes->cur();
91
Point *pt = oldSizes->cur();
92
shape->UpdateSize(pt->x, pt->y);
93
if ( shape->IsNodeShape() )
94
shape->GetView()->GetViewer()->
95
ShapePositionUpdate(shape);
96
} while (shapes->next() && oldSizes->next());