1 package org.wamblee.system;
3 import java.util.ArrayList;
4 import java.util.Arrays;
7 import org.apache.commons.logging.Log;
8 import org.apache.commons.logging.LogFactory;
10 import sun.util.LocaleServiceProviderPool.LocalizedObjectGetter;
13 * Composite system consisting of multiple subsystems.
15 * @author Erik Brakkee
17 public class CompositeSystem extends AbstractSubSystem {
19 private static final Log LOG = LogFactory.getLog(CompositeSystem.class);
21 private SubSystem[] _systems;
24 * Construcst the composite system.
25 * @param aName Name of the system.
26 * @param aRegistry Service registry.
27 * @param aSystems Subsystems.
28 * @param aProvided Provided services of the system.
29 * @param aRequired Required services by the system.
31 public CompositeSystem(String aName, ServiceRegistry aRegistry, SubSystem[] aSystems,
32 ServiceDescriptor[] aProvided, ServiceDescriptor[] aRequired) {
33 super(aName, aRegistry, aProvided, aRequired);
39 * Validates the subsystems together to check that there are
40 * no required services not in the required list and
41 * no services in the provided list that cannot be provided.
42 * Also logs a warning in case of superfluous requirements.
44 private void validate() {
45 List<ServiceDescriptor> provided = new ArrayList<ServiceDescriptor>();
46 for (SubSystem system : _systems) {
47 provided.addAll(Arrays.asList(system.getProvidedServices()));
50 List<ServiceDescriptor> required = new ArrayList<ServiceDescriptor>();
51 for (SubSystem system : _systems) {
52 required.addAll(Arrays.asList(system.getRequiredServices()));
55 for (ServiceDescriptor service : getProvidedServices()) {
56 if (!(provided.contains(service))) {
57 throw new SystemAssemblyException(getName() + ": Service '" + service
58 + "' is not provided by any of the subsystems");
62 for (ServiceDescriptor service : getRequiredServices()) {
63 if (!(required.contains(service))) {
66 + "' indicated as required is not actually required by any of the subsystems");
70 List<ServiceDescriptor> reallyRequired = new ArrayList<ServiceDescriptor>(
72 for (ServiceDescriptor service : provided) {
73 reallyRequired.remove(service);
75 for (ServiceDescriptor service: getRequiredServices()) {
76 reallyRequired.remove(service);
78 for (ServiceDescriptor service: reallyRequired) {
79 throw new SystemAssemblyException(getName() + ": " + "Service '" + service + "' is not provided internally and is not indicated as required for this sub system");
84 protected void doStart(String aContext, Service[] aRequiredServices) {
85 List<ProvidedServiceDescriptor> descriptors = new ArrayList<ProvidedServiceDescriptor>();
86 for (Service service : aRequiredServices) {
87 descriptors.add(service.getDescriptor());
89 SystemAssembler assembler = new SystemAssembler(aContext + "." + getName(), _systems,
90 descriptors.toArray(new ProvidedServiceDescriptor[0]));
91 assembler.start(getRegistry(), aRequiredServices);
95 protected void doStop() {
99 private void info(String aMsg) {
100 LOG.info(getName() + ": " + aMsg);