Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * Copyright (c) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014 David Berkman
   * 
   * This file is part of the SmallMind Code Project.
   * 
   * The SmallMind Code Project is free software, you can redistribute
   * it and/or modify it under the terms of GNU Affero General Public
   * License as published by the Free Software Foundation, either version 3
   * of the License, or (at your option) any later version.
  * 
  * The SmallMind Code Project is distributed in the hope that it will
  * be useful, but WITHOUT ANY WARRANTY; without even the implied warranty
  * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  * General Public License for more details.
  * 
  * You should have received a copy of the the GNU Affero General Public
  * License, along with the SmallMind Code Project. If not, see
  * <http://www.gnu.org/licenses/>.
  * 
  * Additional permission under the GNU Affero GPL version 3 section 7
  * ------------------------------------------------------------------
  * If you modify this Program, or any covered work, by linking or
  * combining it with other code, such other code is not for that reason
  * alone subject to any of the requirements of the GNU Affero GPL
  * version 3.
  */
 package org.smallmind.persistence.sql.pool;
 
 
 
   private final ComponentPool<P> componentPool;
   private final P pooledConnection;
   private final AtomicBoolean closed = new AtomicBoolean(false);
 
 
   public PooledConnectionComponentInstance (ComponentPool<P> componentPool, P pooledConnection)
     throws SQLException {
 
     this. = componentPool;
     this. = pooledConnection;
 
     pooledConnection.addConnectionEventListener(this);
   }
 
   public PooledConnectionComponentInstance (ComponentPool<P> componentPool, P pooledConnectionString validationQuery)
     throws SQLException {
 
     this(componentPoolpooledConnection);
 
     if ((validationQuery != null) && (validationQuery.length() > 0)) {
        = pooledConnection.getConnection().prepareStatement(validationQuery);
     }
     else {
        = null;
     }
   }
 
 
     return .get();
   }
 
   public boolean validate () {
 
     if ( != null) {
       try {
         .execute();
       }
       catch (SQLException sqlException) {
         return false;
       }
     }
 
     return true;
   }
 
   public void connectionClosed (ConnectionEvent connectionEvent) {
 
     try {
       .returnInstance(this);
     }
     catch (Exception exception) {
       LoggerManager.getLogger(PooledConnectionComponentInstance.class).error(exception);
     }
   }
 
  public void connectionErrorOccurred (ConnectionEvent connectionEvent) {
    Exception reportedException = connectionEvent.getSQLException();
    try {
      if (reportedException != null) {
        .reportErrorOccurred(reportedException);
      }
    }
    catch (Exception exception) {
      LoggerManager.getLogger(PooledConnectionComponentInstance.class).error(exception);
    }
    finally {
      try {
        .terminateInstance(this);
      }
      catch (Exception exception) {
        if ((reportedException != null) && (exception.getCause() == exception)) {
          exception.initCause(reportedException);
        }
        LoggerManager.getLogger(PooledConnectionComponentInstance.class).error(exception);
      }
    }
  }
  public P serve () {
    }
    return ;
  }
  public void close ()
    throws SQLException {
    if (.compareAndSet(falsetrue)) {
      SQLException validationCloseException = null;
        .set(null);
      }
      if ( != null) {
        try {
          .close();
        }
        catch (SQLException sqlException) {
          validationCloseException = sqlException;
        }
      }
      if ( != null) {
        try {
          .close();
        }
        catch (SQLException sqlException) {
          if ((validationCloseException != null) && (sqlException.getCause() != sqlException)) {
            sqlException.initCause(validationCloseException);
          }
          throw sqlException;
        }
        finally {
        }
      }
      if (validationCloseException != null) {
        throw validationCloseException;
      }
    }
  }
New to GrepCode? Check out our FAQ X