1/*
2 * Licensed to the Apache Software Foundation (ASF) under one or more
3 * contributor license agreements.  See the NOTICE file distributed with
4 * this work for additional information regarding copyright ownership.
5 * The ASF licenses this file to You under the Apache License, Version 2.0
6 * (the "License"); you may not use this file except in compliance with
7 * the License.  You may obtain a copy of the License at
8 *
9 *     http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17
18package javax.sql;
19
20import java.sql.PreparedStatement;
21import java.sql.SQLException;
22import java.util.EventObject;
23
24/**
25 * A statement event that a PreparedStatement is closed
26 *
27 * @since 1.6
28 */
29public class StatementEvent extends EventObject {
30
31    private static final long serialVersionUID = -8089573731826608315L;
32
33    private SQLException exception;
34
35    private PreparedStatement statement;
36
37    /**
38     * the constructor
39     *
40     * @param con
41     *            the statment related connection
42     * @param statement
43     *            the statement to be closed
44     * @param exception
45     *            the exception to throw
46     */
47    public StatementEvent(PooledConnection con, PreparedStatement statement,
48            SQLException exception) {
49        super(con);
50        this.statement = statement;
51        this.exception = exception;
52    }
53
54    /**
55     * the constructor with null exception
56     *
57     * @param con
58     *            the statment related connection
59     * @param statement
60     *            the statement to be closed
61     */
62    public StatementEvent(PooledConnection con, PreparedStatement statement) {
63        this(con, statement, null);
64    }
65
66    /**
67     * Returns the statement of this event
68     */
69    public PreparedStatement getStatement() {
70        return this.statement;
71    }
72
73    /**
74     * Returns the exception to be thrown
75     *
76     * @return the exception of this event
77     */
78    public SQLException getSQLException() {
79        return this.exception;
80    }
81}