1
//------------------------------------------------------------------------------
3
// This file is part of Toolkit for Conceptual Modeling (TCM).
4
// (c) copyright 1999, Vrije Universiteit Amsterdam and University of Twente.
5
// Author: Frank Dehne (frank@cs.vu.nl).
6
// Author: Henk van de Zandschulp (henkz@cs.utwente.nl).
8
// TCM is free software; you can redistribute it and/or modify
9
// it under the terms of the GNU General Public License as published by
10
// the Free Software Foundation; either version 2 of the License, or
11
// (at your option) any later version.
13
// TCM is distributed in the hope that it will be useful,
14
// but WITHOUT ANY WARRANTY; without even the implied warranty of
15
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16
// GNU General Public License for more details.
18
// You should have received a copy of the GNU General Public License
19
// along with TCM; if not, write to the Free Software Foundation, Inc.,
20
// 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
21
//-----------------------------------------------------------------------------
23
#include "ssdupdateclassboxtypecmd.h"
24
#include "ssdsingleclassbox.h"
25
#include "ssddoubleclassbox.h"
26
#include "ssdtripleclassbox.h"
27
#include "ssdsingleobjectbox.h"
28
#include "ssddoubleobjectbox.h"
30
SSDUpdateClassBoxTypeCmd::SSDUpdateClassBoxTypeCmd(
31
ShapeView *v, List<int *> *l, int n): UpdateNodeShapeTypeCmd(v, l, n) {
35
Thing *SSDUpdateClassBoxTypeCmd::Transform(Thing *thing) {
36
Box *oldShape = (Box *)thing;
37
int fromType = oldShape->GetClassType();
38
if (toType == Code::SSD_SINGLE_CLASS_BOX) {
40
oldShape->GetName()->TextBox(twidth, theight);
41
oldShape->UpdateSize(max(SSDSingleClassBox::BOX_WIDTH, twidth),
42
max(SSDSingleClassBox::BOX_HEIGHT, theight));
43
if (fromType == Code::SSD_DOUBLE_CLASS_BOX)
44
return new SSDSingleClassBox(*(SSDDoubleClassBox *)oldShape);
45
else if (fromType == Code::SSD_TRIPLE_CLASS_BOX)
46
return new SSDSingleClassBox(*(SSDTripleClassBox *)oldShape);
48
return new SSDSingleClassBox(*(SSDSingleClassBox *)oldShape);
50
else if (toType == Code::SSD_DOUBLE_CLASS_BOX) {
51
if (fromType == Code::SSD_SINGLE_CLASS_BOX)
52
return new SSDDoubleClassBox(*(SSDSingleClassBox *)oldShape);
53
else if (fromType == Code::SSD_TRIPLE_CLASS_BOX)
54
return new SSDDoubleClassBox(*(SSDTripleClassBox *)oldShape);
56
return new SSDDoubleClassBox(*(SSDDoubleClassBox *)oldShape);
58
else if (toType == Code::SSD_TRIPLE_CLASS_BOX) {
59
if (fromType == Code::SSD_SINGLE_CLASS_BOX)
60
return new SSDTripleClassBox(*(SSDSingleClassBox *)oldShape);
61
else if (fromType == Code::SSD_DOUBLE_CLASS_BOX)
62
return new SSDTripleClassBox(*(SSDDoubleClassBox *)oldShape);
64
return new SSDTripleClassBox(*(SSDTripleClassBox *)oldShape);
66
else if (toType == Code::SSD_SINGLE_OBJECT_BOX) {
68
oldShape->GetName()->TextBox(twidth, theight);
69
oldShape->UpdateSize(max(Box::BOX_WIDTH, twidth),
70
max(Box::BOX_HEIGHT, theight));
71
return new SSDSingleObjectBox(*oldShape);
73
else if (toType == Code::SSD_DOUBLE_OBJECT_BOX) {
74
return new SSDDoubleObjectBox(*oldShape);
77
error("%s, %d: cannot convert class box type %d\n",
78
__FILE__, __LINE__, oldShape->GetClassType());