01: package net.sourceforge.squirrel_sql.client.session.action;
02:
03: /*
04: * Copyright (C) 2001-2004 Colin Bell
05: * colbell@users.sourceforge.net
06: *
07: * Modifications Copyright (C) 2003-2004 Jason Height
08: *
09: * This library is free software; you can redistribute it and/or
10: * modify it under the terms of the GNU Lesser General Public
11: * License as published by the Free Software Foundation; either
12: * version 2.1 of the License, or (at your option) any later version.
13: *
14: * This library is distributed in the hope that it will be useful,
15: * but WITHOUT ANY WARRANTY; without even the implied warranty of
16: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17: * Lesser General Public License for more details.
18: *
19: * You should have received a copy of the GNU Lesser General Public
20: * License along with this library; if not, write to the Free Software
21: * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
22: */
23: import java.sql.Connection;
24: import java.sql.SQLException;
25:
26: import net.sourceforge.squirrel_sql.client.session.ISQLPanelAPI;
27: import net.sourceforge.squirrel_sql.client.session.ISession;
28: import net.sourceforge.squirrel_sql.fw.util.ICommand;
29:
30: /**
31: * This command will convert the current SQL into native
32: * format and append it to the SQL entry area.
33: *
34: * @author <A HREF="mailto:colbell@users.sourceforge.net">Colin Bell</A>
35: */
36: public class ShowNativeSQLCommand implements ICommand {
37: /** Current panel. */
38: private final ISQLPanelAPI _panel;
39:
40: /**
41: * Ctor.
42: *
43: * @param panel
44: *
45: * @throws IllegalArgumentException
46: * Thrown if a <TT>null</TT> <TT>ISQLPanelAPI</TT> passed.
47: */
48: public ShowNativeSQLCommand(ISQLPanelAPI panel) {
49: super ();
50: if (panel == null) {
51: throw new IllegalArgumentException("ISQLPanelAPI == null");
52: }
53:
54: _panel = panel;
55: }
56:
57: public void execute() {
58: final ISession session = _panel.getSession();
59: final Connection conn = session.getSQLConnection()
60: .getConnection();
61: try {
62: final String sql = conn.nativeSQL(_panel
63: .getSQLScriptToBeExecuted());
64: if (sql.length() > 0) {
65: _panel.appendSQLScript("\n" + sql, true);
66: }
67: } catch (SQLException ex) {
68: session.showErrorMessage(ex);
69: }
70: }
71: }
|