~brian-thomason/+junk/ha-jdbc

« back to all changes in this revision

Viewing changes to src/net/sf/hajdbc/sql/SavepointInvocationStrategy.java

  • Committer: Brian Thomason
  • Date: 2011-12-20 17:34:21 UTC
  • Revision ID: brian.thomason@canonical.com-20111220173421-p9jg95iq91jgdihh
Initial import

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 * HA-JDBC: High-Availability JDBC
 
3
 * Copyright (c) 2004-2007 Paul Ferraro
 
4
 * 
 
5
 * This library is free software; you can redistribute it and/or modify it 
 
6
 * under the terms of the GNU Lesser General Public License as published by the 
 
7
 * Free Software Foundation; either version 2.1 of the License, or (at your 
 
8
 * option) any later version.
 
9
 * 
 
10
 * This library is distributed in the hope that it will be useful, but WITHOUT
 
11
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 
 
12
 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License 
 
13
 * for more details.
 
14
 * 
 
15
 * You should have received a copy of the GNU Lesser General Public License
 
16
 * along with this library; if not, write to the Free Software Foundation, 
 
17
 * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
 
18
 * 
 
19
 * Contact: ferraro@users.sourceforge.net
 
20
 */
 
21
package net.sf.hajdbc.sql;
 
22
 
 
23
import java.sql.Connection;
 
24
import java.sql.Savepoint;
 
25
 
 
26
import net.sf.hajdbc.DatabaseCluster;
 
27
import net.sf.hajdbc.util.reflect.ProxyFactory;
 
28
 
 
29
/**
 
30
 * @author Paul Ferraro
 
31
 * @param <D> 
 
32
 */
 
33
public class SavepointInvocationStrategy<D> extends DatabaseWriteInvocationStrategy<D, Connection, Savepoint>
 
34
{
 
35
        private Connection connection;
 
36
        
 
37
        /**
 
38
         * @param cluster 
 
39
         * @param connection the connection from which to create savepoints
 
40
         */
 
41
        public SavepointInvocationStrategy(DatabaseCluster<D> cluster, Connection connection)
 
42
        {
 
43
                super(cluster.getTransactionalExecutor());
 
44
                
 
45
                this.connection = connection;
 
46
        }
 
47
        
 
48
        /**
 
49
         * @see net.sf.hajdbc.sql.DatabaseWriteInvocationStrategy#invoke(net.sf.hajdbc.sql.SQLProxy, net.sf.hajdbc.sql.Invoker)
 
50
         */
 
51
        @Override
 
52
        public Savepoint invoke(SQLProxy<D, Connection> proxy, Invoker<D, Connection, Savepoint> invoker) throws Exception
 
53
        {
 
54
                return ProxyFactory.createProxy(Savepoint.class, new SavepointInvocationHandler<D>(this.connection, proxy, invoker, this.invokeAll(proxy, invoker)));
 
55
        }
 
56
}