2001-06-19 09:54:55 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2008-04-10 14:34:06 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
2001-06-19 09:54:55 +00:00
|
|
|
*
|
2010-02-12 15:01:35 +01:00
|
|
|
* Copyright 2000, 2010 Oracle and/or its affiliates.
|
2001-06-19 09:54:55 +00:00
|
|
|
*
|
2008-04-10 14:34:06 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2001-06-19 09:54:55 +00:00
|
|
|
*
|
2008-04-10 14:34:06 +00:00
|
|
|
* This file is part of OpenOffice.org.
|
2001-06-19 09:54:55 +00:00
|
|
|
*
|
2008-04-10 14:34:06 +00:00
|
|
|
* OpenOffice.org is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Lesser General Public License version 3
|
|
|
|
* only, as published by the Free Software Foundation.
|
2001-06-19 09:54:55 +00:00
|
|
|
*
|
2008-04-10 14:34:06 +00:00
|
|
|
* OpenOffice.org 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 Lesser General Public License version 3 for more details
|
|
|
|
* (a copy is included in the LICENSE file that accompanied this code).
|
2001-06-19 09:54:55 +00:00
|
|
|
*
|
2008-04-10 14:34:06 +00:00
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* version 3 along with OpenOffice.org. If not, see
|
|
|
|
* <http://www.openoffice.org/license.html>
|
|
|
|
* for a copy of the LGPLv3 License.
|
2001-06-19 09:54:55 +00:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
#ifndef _DBACCESS_UI_DIRECTSQL_HXX_
|
|
|
|
#define _DBACCESS_UI_DIRECTSQL_HXX_
|
|
|
|
|
|
|
|
#include <vcl/dialog.hxx>
|
2008-11-28 11:39:37 +00:00
|
|
|
#include <svtools/editsyntaxhighlighter.hxx>
|
2001-06-19 09:54:55 +00:00
|
|
|
#include <vcl/fixed.hxx>
|
|
|
|
#include <vcl/lstbox.hxx>
|
|
|
|
#include <vcl/button.hxx>
|
|
|
|
#include <comphelper/stl_types.hxx>
|
2001-06-22 13:17:03 +00:00
|
|
|
#include <deque>
|
2001-06-19 09:54:55 +00:00
|
|
|
|
|
|
|
#include <com/sun/star/sdbc/XConnection.hpp>
|
|
|
|
#include <unotools/eventlisteneradapter.hxx>
|
2007-07-06 07:28:58 +00:00
|
|
|
#include "moduledbu.hxx"
|
2001-06-19 09:54:55 +00:00
|
|
|
#include <osl/mutex.hxx>
|
|
|
|
|
|
|
|
//........................................................................
|
|
|
|
namespace dbaui
|
|
|
|
{
|
|
|
|
//........................................................................
|
|
|
|
|
|
|
|
//====================================================================
|
|
|
|
//= DirectSQLDialog
|
|
|
|
//====================================================================
|
|
|
|
class DirectSQLDialog
|
|
|
|
:public ModalDialog
|
|
|
|
,public ::utl::OEventListenerAdapter
|
|
|
|
{
|
|
|
|
protected:
|
2007-07-06 07:28:58 +00:00
|
|
|
OModuleClient m_aModuleClient;
|
2001-06-19 09:54:55 +00:00
|
|
|
::osl::Mutex m_aMutex;
|
|
|
|
|
|
|
|
FixedLine m_aFrame;
|
|
|
|
FixedText m_aSQLLabel;
|
2008-11-28 11:39:37 +00:00
|
|
|
MultiLineEditSyntaxHighlight m_aSQL;
|
2001-06-19 09:54:55 +00:00
|
|
|
PushButton m_aExecute;
|
|
|
|
FixedText m_aHistoryLabel;
|
|
|
|
ListBox* m_pSQLHistory;
|
|
|
|
FixedLine m_aStatusFrame;
|
|
|
|
MultiLineEdit m_aStatus;
|
|
|
|
FixedLine m_aButtonSeparator;
|
|
|
|
HelpButton m_aHelp;
|
|
|
|
PushButton m_aClose;
|
|
|
|
|
|
|
|
typedef ::std::deque< String > StringQueue;
|
|
|
|
StringQueue m_aStatementHistory; // previous statements
|
|
|
|
StringQueue m_aNormalizedHistory; // previous statements, normalized to be used in the list box
|
|
|
|
|
|
|
|
sal_Int32 m_nHistoryLimit;
|
|
|
|
sal_Int32 m_nStatusCount;
|
|
|
|
|
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XConnection >
|
|
|
|
m_xConnection;
|
|
|
|
|
|
|
|
public:
|
|
|
|
DirectSQLDialog(
|
|
|
|
Window* _pParent,
|
|
|
|
const ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XConnection >& _rxConn);
|
|
|
|
~DirectSQLDialog();
|
|
|
|
|
|
|
|
/// number of history entries
|
|
|
|
sal_Int32 getHistorySize() const;
|
|
|
|
|
|
|
|
protected:
|
|
|
|
void executeCurrent();
|
|
|
|
void switchToHistory(sal_Int32 _nHistoryPos, sal_Bool _bUpdateListBox = sal_True);
|
|
|
|
|
|
|
|
// OEventListenerAdapter
|
|
|
|
virtual void _disposing( const ::com::sun::star::lang::EventObject& _rSource );
|
|
|
|
|
|
|
|
protected:
|
|
|
|
DECL_LINK( OnExecute, void* );
|
|
|
|
DECL_LINK( OnClose, void* );
|
|
|
|
DECL_LINK( OnListEntrySelected, void* );
|
|
|
|
DECL_LINK( OnStatementModified, void* );
|
|
|
|
|
|
|
|
private:
|
|
|
|
/// adds a statement to the statement history
|
|
|
|
void implAddToStatementHistory(const String& _rStatement);
|
|
|
|
|
|
|
|
/// ensures that our history has at most m_nHistoryLimit entries
|
|
|
|
void implEnsureHistoryLimit();
|
|
|
|
|
|
|
|
/// executes the statement given, adds the status to the status list
|
|
|
|
void implExecuteStatement(const String& _rStatement);
|
|
|
|
|
|
|
|
/// adds a status text to the status list
|
|
|
|
void addStatusText(const String& _rMessage);
|
|
|
|
|
|
|
|
#ifdef DBG_UTIL
|
|
|
|
const sal_Char* impl_CheckInvariants() const;
|
|
|
|
#endif
|
|
|
|
};
|
|
|
|
|
|
|
|
//====================================================================
|
|
|
|
#ifdef DBG_UTIL
|
|
|
|
#define CHECK_INVARIANTS(methodname) \
|
|
|
|
{ \
|
|
|
|
const sal_Char* pError = impl_CheckInvariants(); \
|
|
|
|
if (pError) \
|
|
|
|
OSL_ENSURE(sal_False, (ByteString(methodname) += ByteString(": ") += ByteString(pError)).GetBuffer()); \
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
#define CHECK_INVARIANTS(methodname)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
//........................................................................
|
|
|
|
} // namespace dbaui
|
|
|
|
//........................................................................
|
|
|
|
|
|
|
|
#endif // _DBACCESS_UI_DIRECTSQL_HXX_
|
|
|
|
|