Now basing the implementation on a component graph.
[utils] / system / general / src / main / java / org / wamblee / system / graph / component / CheckStartupDependenciesVisitor.java
1 /*
2  * Copyright 2008 the original author or authors.
3  * 
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  * 
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  * 
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */ 
16 package org.wamblee.system.graph.component;
17
18 import java.util.ArrayList;
19 import java.util.List;
20
21 import org.wamblee.system.core.SystemAssemblyException;
22 import org.wamblee.system.graph.Edge;
23 import org.wamblee.system.graph.Graph;
24 import org.wamblee.system.graph.Node;
25 import org.wamblee.system.graph.Visitor;
26
27 public class CheckStartupDependenciesVisitor implements Visitor {
28     
29     private Graph _graph; 
30     private List<Node> _available; 
31     
32     public CheckStartupDependenciesVisitor(Graph aGraph) { 
33         _graph = aGraph; 
34         _available = new ArrayList<Node>();
35     }
36
37     @Override
38     public void visitEdge(Edge aEdge) {
39         // Empty
40     }
41
42     @Override
43     public void visitNode(Node aNode) {
44         List<Edge> edges = _graph.findOutgoing(aNode);
45         
46         // check dependencies.
47         for (Edge edge: edges) { 
48             Node dep = edge.getTo();
49             if ( !_available.contains(dep)) { 
50                 throw new SystemAssemblyException(aNode + ": required dependency '" + dep + "' was not started");
51             }
52         }
53         
54         _available.add(aNode);
55     }
56
57 }