1 | //This class has been generated automatically. Do not modify it by hand! |
---|
2 | package org.etsi.t3d.visitor; |
---|
3 | import java.util.Iterator; |
---|
4 | import java.util.LinkedList; |
---|
5 | import java.util.Queue; |
---|
6 | import de.ugoe.cs.swe.trex.core.analyzer.rfparser.LocationAST; |
---|
7 | import de.ugoe.cs.swe.trex.core.analyzer.rfparser.TTCN3ParserTokenTypes; |
---|
8 | //import de.ugoe.cs.swe.t3simexec.exceptions.TTCN3BehaviorException; |
---|
9 | import org.etsi.t3d.exceptions.TTCN3BehaviorException; |
---|
10 | |
---|
11 | public abstract class AbstractVisitor { |
---|
12 | |
---|
13 | public int visitedNodeCount; |
---|
14 | |
---|
15 | $nodeType:VisitMethod(); separator="\n"$ |
---|
16 | |
---|
17 | public ContinueStatus visit(LocationAST node) throws TTCN3BehaviorException { |
---|
18 | visitedNodeCount++; |
---|
19 | ContinueStatus continueStatus; |
---|
20 | switch(node.getType()) { |
---|
21 | $nodeType:VisitCase(); separator="\n"$ |
---|
22 | } |
---|
23 | return new ContinueStatus(); |
---|
24 | } |
---|
25 | |
---|
26 | public abstract void init(); |
---|
27 | public abstract void finish(); |
---|
28 | |
---|
29 | public void acceptDFS(LocationAST node) throws TTCN3BehaviorException { |
---|
30 | init(); |
---|
31 | searchASTDepthFirst(node); |
---|
32 | finish(); |
---|
33 | } |
---|
34 | |
---|
35 | public void acceptBFS(LocationAST node) throws TTCN3BehaviorException { |
---|
36 | init(); |
---|
37 | searchASTBreadthFirst(node); |
---|
38 | finish(); |
---|
39 | } |
---|
40 | |
---|
41 | protected ContinueStatus searchASTDepthFirst(LocationAST node) throws TTCN3BehaviorException { |
---|
42 | if (node == null) |
---|
43 | return ContinueStatus.getInstance(true, true); |
---|
44 | |
---|
45 | LocationAST next = node; |
---|
46 | while (next != null) { |
---|
47 | ContinueStatus continueStatus = visit(next); |
---|
48 | if (!continueStatus.continueSearch) |
---|
49 | return ContinueStatus.getInstance(false, false); |
---|
50 | if (continueStatus.goDeeper) |
---|
51 | searchASTDepthFirst(next.getFirstChild()); |
---|
52 | next = next.getNextSibling(); |
---|
53 | } |
---|
54 | return ContinueStatus.getInstance(true, true); |
---|
55 | } |
---|
56 | |
---|
57 | protected ContinueStatus searchASTBreadthFirst(LocationAST node) throws TTCN3BehaviorException { |
---|
58 | if (node == null) |
---|
59 | return ContinueStatus.getInstance(true, true); |
---|
60 | |
---|
61 | Queue<LocationAST> open = new LinkedList<LocationAST>(); |
---|
62 | open.add(node); |
---|
63 | searchASTBreadthFirst(open); |
---|
64 | return ContinueStatus.getInstance(true, true); |
---|
65 | } |
---|
66 | |
---|
67 | private ContinueStatus searchASTBreadthFirst(Queue<LocationAST> nodes) throws TTCN3BehaviorException { |
---|
68 | Queue<LocationAST> open = new LinkedList<LocationAST>(); |
---|
69 | Iterator<LocationAST> it = nodes.iterator(); |
---|
70 | while (it.hasNext()) { |
---|
71 | LocationAST item = it.next(); |
---|
72 | while (item != null) { |
---|
73 | ContinueStatus continueStatus = visit(item); |
---|
74 | if (!continueStatus.continueSearch) |
---|
75 | return ContinueStatus.getInstance(false, false); |
---|
76 | if ( (item.getFirstChild() != null) && (continueStatus.goDeeper) ) |
---|
77 | open.add(item.getFirstChild()); |
---|
78 | item = item.getNextSibling(); |
---|
79 | } |
---|
80 | } |
---|
81 | if (open.size() > 0) |
---|
82 | searchASTBreadthFirst(open); |
---|
83 | return ContinueStatus.getInstance(true, true); |
---|
84 | } |
---|
85 | |
---|
86 | static class ContinueStatus { |
---|
87 | public boolean continueSearch = true; |
---|
88 | public boolean goDeeper = true; |
---|
89 | private static ContinueStatus truetrue = new ContinueStatus(true, true); |
---|
90 | private static ContinueStatus truefalse = new ContinueStatus(true, false); |
---|
91 | private static ContinueStatus falsetrue = new ContinueStatus(false, true); |
---|
92 | private static ContinueStatus falsefalse = new ContinueStatus(false, false); |
---|
93 | |
---|
94 | private ContinueStatus() { |
---|
95 | this.continueSearch = true; |
---|
96 | this.goDeeper = true; |
---|
97 | } |
---|
98 | |
---|
99 | private ContinueStatus(boolean continueSearch, boolean goDeeper) { |
---|
100 | this.continueSearch = continueSearch; |
---|
101 | this.goDeeper = goDeeper; |
---|
102 | } |
---|
103 | |
---|
104 | public static ContinueStatus getInstance(boolean continueSearch, boolean goDeeper) { |
---|
105 | if (continueSearch && goDeeper) { |
---|
106 | return truetrue; |
---|
107 | } else if (!continueSearch && goDeeper) { |
---|
108 | return falsetrue; |
---|
109 | } else if (continueSearch && !goDeeper) { |
---|
110 | return truefalse; |
---|
111 | } else { |
---|
112 | return falsefalse; |
---|
113 | } |
---|
114 | } |
---|
115 | } |
---|
116 | |
---|
117 | |
---|
118 | } |
---|