UdpRingNode.java :  » Net » JGroups-2.4.1-sp3 » org » jgroups » protocols » ring » Java Open Source

Java Open Source » Net » JGroups 2.4.1 sp3 
JGroups 2.4.1 sp3 » org » jgroups » protocols » ring » UdpRingNode.java
//$Id: UdpRingNode.java,v 1.5 2004/09/23 16:29:40 belaban Exp $

package org.jgroups.protocols.ring;

import org.jgroups.Address;
import org.jgroups.Event;
import org.jgroups.Message;
import org.jgroups.protocols.TOTAL_TOKEN;
import org.jgroups.stack.IpAddress;
import org.jgroups.stack.RpcProtocol;

import java.io.Serializable;
import java.util.Vector;


public class UdpRingNode implements RingNode
{

   final Address thisNode;
     Address nextNode;
   final RpcProtocol rpcProtocol;
   Object token;
   final Object mutex = new Object();
   final TOTAL_TOKEN.RingTokenHeader tokenHeader;
   boolean tokenInStack = false;


   public UdpRingNode(RpcProtocol owner, Address memberAddress)
   {
      rpcProtocol = owner;
      thisNode = memberAddress;
      nextNode = null;
      tokenHeader = new TOTAL_TOKEN.RingTokenHeader();
   }

   public IpAddress getTokenReceiverAddress()
   {
      return (IpAddress) thisNode;
   }

   public synchronized void tokenArrived(Object token)
   {
      tokenInStack = true;
      this.token = token;
      this.notifyAll();
   }

   public Object receiveToken(int timeout) throws TokenLostException
   {
      Address wasNext = nextNode;

      try
      {

         synchronized (this)
         {
            while (!tokenInStack)
            {
               wait(timeout);
               break;
            }

            //we haven't received token for the time of timeout
            if (!tokenInStack)
            {
               throw new TokenLostException("Token wait timout expired", null,
                                            wasNext, TokenLostException.WHILE_RECEIVING);
            }
         }
      }
      catch (InterruptedException ie)
      {
         throw new TokenLostException("Token thread interrupted", ie,
                                      wasNext, TokenLostException.WHILE_RECEIVING);
      }
      return token;
   }

   public Object receiveToken() throws TokenLostException
   {
      return receiveToken(0);
   }

   public synchronized void passToken(Object token)
   {
       Message t = new Message(nextNode, thisNode, (Serializable) token);
       t.putHeader(TOTAL_TOKEN.prot_name, tokenHeader);
       rpcProtocol.passDown(new Event(Event.MSG, t));
       tokenInStack = false;
   }


   public synchronized void reconfigure(Vector newMembers)
   {
      if (isNextNeighbourChanged(newMembers))
      {
         nextNode = getNextNode(newMembers);
      }
   }

   private boolean isNextNeighbourChanged(Vector newMembers)
   {
      Address oldNeighbour = nextNode;
      Address newNeighbour = getNextNode(newMembers);
      return !(newNeighbour.equals(oldNeighbour));
   }

   private Address getNextNode(Vector otherNodes)
   {
      int myIndex = otherNodes.indexOf(thisNode);
      return (myIndex == otherNodes.size() - 1)?
              (Address) otherNodes.firstElement():
              (Address) otherNodes.elementAt(myIndex + 1);

   }
}
java2s.com  | Contact Us | Privacy Policy
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.