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 "psdiagram.h"
24
#include "urlabeledbox.h"
25
#include "psprocess.h"
29
PSViewer::PSViewer(Config *c, PSWindow *d): DiagramViewer(c, d) {
33
void PSViewer::SetShowSequences(int set) {
34
SetStatus("action: Show sequences");
35
if (set == 0 && showSequence != 0) {
36
UpdateSequenceLabels(set);
38
else if ((set == 1 || set == 2)) {
39
((PSDiagram *)GetDiagram())->TraverseTree(False);
40
UpdateSequenceLabels(set);
45
void PSViewer::UpdateSequenceLabels(int set) {
46
List<GShape *> *shapes = GetCurView()->GetShapes();
50
for (shapes->first(); !shapes->done(); shapes->next()) {
51
Shape *shape = shapes->cur();
52
if (shape->GetClassType() == Code::UR_LABELED_BOX) {
53
URLabeledBox *urbox = (URLabeledBox *)shape;
54
urbox->UpdateIndexLabel(&s);
59
for (shapes->first(); !shapes->done(); shapes->next()) {
60
Shape *shape = shapes->cur();
61
if (shape->GetClassType() == Code::UR_LABELED_BOX) {
63
(PSProcess *)shape->GetSubject();
66
sequence = process->GetActionSequence();
68
sequence = process->GetTreeSequence();
74
URLabeledBox *urbox = (URLabeledBox *)shape;
75
urbox->UpdateIndexLabel(&s);