X-Git-Url: http://wamblee.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=system%2Fgeneral%2Fsrc%2Fmain%2Fjava%2Forg%2Fwamblee%2Fsystem%2Fgraph%2Fcomponent%2FCheckRequiredProvidedMultiplicityVisitor.java;h=ae14ead872ea65d6f662819a43afa0efbe12f4be;hb=HEAD;hp=608dfc16dff4714f39c9fb3ab0c9e58f2de88797;hpb=531559394b56b0dbf817d52c8c596216550a5cbb;p=utils
diff --git a/system/general/src/main/java/org/wamblee/system/graph/component/CheckRequiredProvidedMultiplicityVisitor.java b/system/general/src/main/java/org/wamblee/system/graph/component/CheckRequiredProvidedMultiplicityVisitor.java
index 608dfc16..ae14ead8 100644
--- a/system/general/src/main/java/org/wamblee/system/graph/component/CheckRequiredProvidedMultiplicityVisitor.java
+++ b/system/general/src/main/java/org/wamblee/system/graph/component/CheckRequiredProvidedMultiplicityVisitor.java
@@ -1,5 +1,5 @@
/*
- * Copyright 2008 the original author or authors.
+ * Copyright 2005-2010 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@@ -15,33 +15,34 @@
*/
package org.wamblee.system.graph.component;
-import java.util.List;
-
import org.wamblee.system.core.SystemAssemblyException;
import org.wamblee.system.graph.Edge;
import org.wamblee.system.graph.Graph;
import org.wamblee.system.graph.Node;
import org.wamblee.system.graph.Visitor;
+import java.util.List;
+
/**
* Visitor that checks whether required and provided interfaces are matched
* appropriately:
*
- * - Each required interface is connected to at most one provided interface
- *
+ * - Each required interface is connected to at most one provided interface
* - Required interfaces that are not optional must be connected to precisely
* one provided interface
*
*
* @author Erik Brakkee
- *
*/
public class CheckRequiredProvidedMultiplicityVisitor implements Visitor {
+ private Graph graph;
- private Graph _graph;
-
+ /**
+ * Creates a new CheckRequiredProvidedMultiplicityVisitor object.
+ *
+ */
public CheckRequiredProvidedMultiplicityVisitor(Graph aGraph) {
- _graph = aGraph;
+ graph = aGraph;
}
@Override
@@ -53,34 +54,44 @@ public class CheckRequiredProvidedMultiplicityVisitor implements Visitor {
public void visitNode(Node aNode) {
if (aNode instanceof RequiredInterfaceNode) {
RequiredInterfaceNode required = (RequiredInterfaceNode) aNode;
- List edges = _graph.findOutgoing(aNode);
+ List edges = graph.findOutgoing(aNode);
+
if (edges.size() > 1) {
- createDuplicateException("Multiple providers of required interface found", aNode, edges);
+ createDuplicateException(
+ "Multiple providers of required interface found", aNode,
+ edges);
}
- if (edges.size() == 0 && !required.getRequired().isOptional()) {
+
+ if ((edges.size() == 0) && !required.getRequired().isOptional()) {
throw new SystemAssemblyException(
- aNode
- + ": mandatpory required interface not provided by other components started earlier");
+ aNode +
+ ": mandatpory required interface not provided by other components started earlier");
}
- } else if ( aNode instanceof ExternalProvidedInterfaceNode) {
- List edges = _graph.findOutgoing(aNode);
- if ( edges.size() > 1) {
- createDuplicateException("multiple internal matches for externally provided interface", aNode, edges);
+ } else if (aNode instanceof ExternalProvidedInterfaceNode) {
+ List edges = graph.findOutgoing(aNode);
+
+ if (edges.size() > 1) {
+ createDuplicateException(
+ "multiple internal matches for externally provided interface",
+ aNode, edges);
}
- if ( edges.size() == 0 ) {
- throw new SystemAssemblyException(aNode + ": external provided interface is not provided internally");
+
+ if (edges.size() == 0) {
+ throw new SystemAssemblyException(aNode +
+ ": external provided interface is not provided internally");
}
}
}
- private void createDuplicateException(String aMsg, Node aNode, List edges) {
+ private void createDuplicateException(String aMsg, Node aNode,
+ List aEdges) {
StringBuffer buf = new StringBuffer();
- buf.append(aNode
- + ": " + aMsg + ": ");
- for (Edge edge : edges) {
+ buf.append(aNode + ": " + aMsg + ": ");
+
+ for (Edge edge : aEdges) {
buf.append(edge.getTo() + "/ ");
}
+
throw new SystemAssemblyException(buf.toString());
}
-
}