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 "dataprocess.h"
27
DFGraph::DFGraph(): Graph() {
30
nodeTypes[i++] = Code::COMMENT;
31
nodeTypes[i++] = Code::DATA_PROCESS;
32
nodeTypes[i++] = Code::DATA_STORE;
33
nodeTypes[i++] = Code::EXTERNAL_ENTITY;
34
nodeTypes[i++] = Code::SPLIT_MERGE_NODE;
37
edgeTypes[j++] = Code::DATA_FLOW;
38
edgeTypes[j++] = Code::BIDIRECTIONAL_DATA_FLOW;
42
void DFGraph::InitConnections() {
43
int DTF=Code::GetIndex(Code::DATA_PROCESS, nodeTypes);
44
int STO=Code::GetIndex(Code::DATA_STORE, nodeTypes);
45
int EXT=Code::GetIndex(Code::EXTERNAL_ENTITY, nodeTypes);
46
int SMN=Code::GetIndex(Code::SPLIT_MERGE_NODE, nodeTypes);
48
int DFL=Code::GetIndex(Code::DATA_FLOW, edgeTypes);
49
int BDF=Code::GetIndex(Code::BIDIRECTIONAL_DATA_FLOW, edgeTypes);
51
connections[EXT][EXT][DFL] = True;
52
connections[EXT][EXT][BDF] = True;
54
connections[DTF][DTF][DFL] = True;
55
connections[DTF][STO][DFL] = True;
56
connections[STO][DTF][DFL] = True;
57
connections[DTF][EXT][DFL] = True;
58
connections[EXT][DTF][DFL] = True;
59
connections[STO][DTF][BDF] = True;
60
connections[DTF][STO][BDF] = True;
61
connections[DTF][SMN][DFL] = True;
62
connections[SMN][DTF][DFL] = True;
63
// connections[SMN][SMN][DFL] = True;