All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.ibm.as400.access.ConnectionPoolEventSupport Maven / Gradle / Ivy

The newest version!
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: ConnectionPoolEventSupport.java
//                                                                             
// The source code contained herein is licensed under the IBM Public License   
// Version 1.0, which has been approved by the Open Source Initiative.         
// Copyright (C) 1997-2000 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.access;

import java.util.Vector;

/**
*  The ConnectionPoolEventSupport class represents an event support 
*  facility for maintaining and notifying listeners of connection pool events.
**/
class ConnectionPoolEventSupport
{
  private static final String copyright = "Copyright (C) 1997-2000 International Business Machines Corporation and others.";

   private Vector connectionListeners_;              // The listener list.
   
   /**
   *  Constructs a default ConnectionPoolEventSupport object.
   **/
   public ConnectionPoolEventSupport()
   {
      connectionListeners_ = new Vector();
   }


   /**
   *  Adds a ConnectionPoolListener to the internal list.
   *  @param listener The listener.
   **/
   public void addConnectionPoolListener(ConnectionPoolListener listener)
   {
      if (listener == null)
         throw new NullPointerException("listener");
      connectionListeners_.addElement(listener);
   }

   /**
   *  Fires the connection pool closed event.
   *  @param event The ConnectionPoolEvent.
   **/
   public void fireClosedEvent(ConnectionPoolEvent event)
   {
      Vector targets = (Vector) connectionListeners_.clone();
      for (int i=0; i< targets.size(); i++) 
      {
         ConnectionPoolListener target = (ConnectionPoolListener) targets.elementAt(i);
         target.connectionPoolClosed(event);
      }
   }
   
   /**
   *  Fires the connection created event.
   *  @param event The ConnectionPoolEvent.
   **/
   public void fireConnectionCreatedEvent(ConnectionPoolEvent event)
   {
      Vector targets = (Vector) connectionListeners_.clone();
      for (int i=0; i< targets.size(); i++) 
      {
         ConnectionPoolListener target = (ConnectionPoolListener) targets.elementAt(i);
         target.connectionCreated(event);
      }
   }


   /**
   *  Fires the connection expired event.
   *  @param event The ConnectionPoolEvent.
   **/
   public void fireConnectionExpiredEvent(ConnectionPoolEvent event)
   {
      Vector targets = (Vector) connectionListeners_.clone();
      for (int i=0; i< targets.size(); i++) 
      {
         ConnectionPoolListener target = (ConnectionPoolListener) targets.elementAt(i);
         target.connectionExpired(event);
      }
   }
   

   /**
   *  Fires the maintenance thread run event.
   *  @param event The ConnectionPoolEvent.
   **/
   public void fireMaintenanceThreadRun(ConnectionPoolEvent event)
   {
      Vector targets = (Vector) connectionListeners_.clone();
      for (int i=0; i< targets.size(); i++) 
      {
         ConnectionPoolListener target = (ConnectionPoolListener) targets.elementAt(i);
         target.maintenanceThreadRun(event);
      }
   }

   /**
   *  Fires the connection released event.
   *  @param event The ConnectionPoolEvent.
   **/
   public void fireConnectionReleasedEvent(ConnectionPoolEvent event)
   {
      Vector targets = (Vector) connectionListeners_.clone();
      for (int i=0; i< targets.size(); i++) 
      {
         ConnectionPoolListener target = (ConnectionPoolListener) targets.elementAt(i);
         target.connectionReleased(event);
      }
   }


    /**
   *  Fires the connection returned event.
   *  @param event The ConnectionPoolEvent.
   **/
   public void fireConnectionReturnedEvent(ConnectionPoolEvent event)
   {
      Vector targets = (Vector) connectionListeners_.clone();
      for (int i=0; i< targets.size(); i++) 
      {
         ConnectionPoolListener target = (ConnectionPoolListener) targets.elementAt(i);
         target.connectionReturned(event);
      }
   }


   /**
   *  Removes a ConnectionPoolListener from the internal list.
   *  @param listener The listener to be removed.
   **/
   public void removeConnectionPoolListener(ConnectionPoolListener listener)
   {
      if (listener == null)
         throw new NullPointerException("listener");
      connectionListeners_.removeElement(listener);
   }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy