00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031 package org.objectweb.proactive.scheduler;
00032
00033 import java.util.Vector;
00034
00035 import org.apache.log4j.Logger;
00036 import org.objectweb.proactive.ProActive;
00037 import org.objectweb.proactive.core.descriptor.data.ProActiveDescriptor;
00038 import org.objectweb.proactive.core.descriptor.data.VirtualNode;
00039 import org.objectweb.proactive.core.descriptor.data.VirtualNodeImpl;
00040 import org.objectweb.proactive.core.event.NodeCreationEvent;
00041 import org.objectweb.proactive.core.event.NodeCreationEventListener;
00042 import org.objectweb.proactive.core.node.Node;
00043 import org.objectweb.proactive.core.util.log.Loggers;
00044 import org.objectweb.proactive.core.util.log.ProActiveLogger;
00045
00046
00055 public class RessourceListener implements NodeCreationEventListener {
00056 private static Logger logger = ProActiveLogger.getLogger(Loggers.RESSOURCE_LISTENER);
00057
00058
00059 private Vector unusedNodes;
00060
00061 public RessourceListener(Vector unusedNodes, String xmlURL, Vector vnNames) {
00062 ProActiveDescriptor pad = null;
00063 this.unusedNodes = unusedNodes;
00064
00065 try {
00066 pad = ProActive.getProactiveDescriptor(xmlURL);
00067 } catch (Exception e) {
00068 logger.error("error starting ressource listener");
00069 throw new RuntimeException(e);
00070 }
00071
00072 for (int i = 0; i < vnNames.size(); ++i) {
00073
00074 VirtualNode vn = pad.getVirtualNode((String) vnNames.get(i));
00075
00076
00077 ((VirtualNodeImpl) vn).addNodeCreationEventListener(this);
00078
00079 vn.activate();
00080 }
00081 logger.debug("starting ressource listener");
00082 }
00083
00087 public void nodeCreated(NodeCreationEvent event) {
00088
00089 Node newNode = event.getNode();
00090
00091 newNode.getNodeInformation().setJobID("-");
00092 this.unusedNodes.add(newNode);
00093 logger.debug("new node acquired " +
00094 newNode.getNodeInformation().getURL());
00095 }
00096 }