Files
libreoffice/dbaccess/source/ui/querydesign/QTableConnectionData.cxx
Kurt Zenker 76d5fbabd9 INTEGRATION: CWS dba23a (1.9.74); FILE MERGED
2007/02/26 11:48:18 fs 1.9.74.1: remove unused code
Issue number:  #i74804#
Submitted by:  jnavrati@openoffice.org
Reviewed by:   frank.schoenheit@sun.com
2007-05-10 09:37:45 +00:00

192 lines
7.2 KiB
C++

/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: QTableConnectionData.cxx,v $
*
* $Revision: 1.10 $
*
* last change: $Author: kz $ $Date: 2007-05-10 10:37:45 $
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
*
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2005 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* This library 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 for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
************************************************************************/
// MARKER(update_precomp.py): autogen include statement, do not remove
#include "precompiled_dbaccess.hxx"
#ifndef DBAUI_QTABLECONNECTIONDATA_HXX
#include "QTableConnectionData.hxx"
#endif
#ifndef _TOOLS_DEBUG_HXX
#include <tools/debug.hxx>
#endif
#ifndef DBAUI_QTABLECONNECTIONDATA_HXX
#include "QTableConnectionData.hxx"
#endif
#ifndef DBAUI_QUERY_TABLEWINDOWDATA_HXX
#include "QTableWindow.hxx"
#endif
using namespace dbaui;
TYPEINIT1(OQueryTableConnectionData, OTableConnectionData);
//========================================================================
// class OQueryTableConnectionData
//========================================================================
DBG_NAME(OQueryTableConnectionData);
//------------------------------------------------------------------------
OQueryTableConnectionData::OQueryTableConnectionData()
:OTableConnectionData()
,m_eJoinType (INNER_JOIN)
{
DBG_CTOR(OQueryTableConnectionData,NULL);
}
//------------------------------------------------------------------------
OQueryTableConnectionData::OQueryTableConnectionData( const OQueryTableConnectionData& rConnData )
:OTableConnectionData( rConnData )
{
DBG_CTOR(OQueryTableConnectionData,NULL);
m_nFromEntryIndex = rConnData.m_nFromEntryIndex;
m_nDestEntryIndex = rConnData.m_nDestEntryIndex;
m_eFromType = rConnData.m_eFromType;
m_eDestType = rConnData.m_eDestType;
m_eJoinType = rConnData.m_eJoinType;
}
//------------------------------------------------------------------------
OQueryTableConnectionData::OQueryTableConnectionData(const ::rtl::OUString& strSourceTable, const ::rtl::OUString& strDestTable,
const ::rtl::OUString& strSourceAlias, const ::rtl::OUString& strDestAlias, const ::rtl::OUString& rConnName)
:OTableConnectionData( strSourceAlias, strDestAlias, rConnName )
,m_nFromEntryIndex(0)
,m_nDestEntryIndex(0)
,m_eJoinType (INNER_JOIN)
,m_eFromType(TAB_NORMAL_FIELD)
,m_eDestType(TAB_NORMAL_FIELD)
,m_strSourceTableName(strSourceTable)
,m_strDestTableName(strDestTable)
{
DBG_CTOR(OQueryTableConnectionData,NULL);
}
//------------------------------------------------------------------------
OQueryTableConnectionData::~OQueryTableConnectionData()
{
DBG_DTOR(OQueryTableConnectionData,NULL);
}
//------------------------------------------------------------------------
OConnectionLineDataRef OQueryTableConnectionData::CreateLineDataObj()
{
DBG_CHKTHIS(OQueryTableConnectionData,NULL);
// keine Spezialisierung bei den LineDatas, also eine Instanz der Standard-Klasse
return new OConnectionLineData();
}
//------------------------------------------------------------------------
OConnectionLineDataRef OQueryTableConnectionData::CreateLineDataObj( const OConnectionLineData& rConnLineData )
{
DBG_CHKTHIS(OQueryTableConnectionData,NULL);
return new OConnectionLineData( rConnLineData );
}
//------------------------------------------------------------------------
void OQueryTableConnectionData::CopyFrom(const OTableConnectionData& rSource)
{
DBG_CHKTHIS(OQueryTableConnectionData,NULL);
DBG_ASSERT(rSource.ISA(OQueryTableConnectionData), "QueryTabConn::CopyFrom : ungueltiger Parameter !");
// wie in der Basisklasse zurueckziehen auf das (nicht-virtuelle) operator=
*this = (const OQueryTableConnectionData&)rSource;
}
//------------------------------------------------------------------------
OQueryTableConnectionData& OQueryTableConnectionData::operator=(const OQueryTableConnectionData& rConnData)
{
DBG_CHKTHIS(OQueryTableConnectionData,NULL);
if (&rConnData == this)
return *this;
OTableConnectionData::operator=(rConnData);
m_nFromEntryIndex = rConnData.m_nFromEntryIndex;
m_nDestEntryIndex = rConnData.m_nDestEntryIndex;
m_eFromType = rConnData.m_eFromType;
m_eDestType = rConnData.m_eDestType;
m_eJoinType = rConnData.m_eJoinType;
return *this;
}
//------------------------------------------------------------------------------
::rtl::OUString OQueryTableConnectionData::GetAliasName(EConnectionSide nWhich) const
{
DBG_CHKTHIS(OQueryTableConnectionData,NULL);
return nWhich == JTCS_FROM ? GetSourceWinName() : GetDestWinName();
}
//------------------------------------------------------------------------------
void OQueryTableConnectionData::InitFromDrag(const OTableFieldDescRef& rDragLeft, const OTableFieldDescRef& rDragRight)
{
DBG_CHKTHIS(OQueryTableConnectionData,NULL);
// die Infos in rDrag in Parameter fuer das Basisklassen-Init umsetzen ...
OQueryTableWindow* pSourceWin = static_cast<OQueryTableWindow*>(rDragLeft->GetTabWindow());
OQueryTableWindow* pDestWin = static_cast<OQueryTableWindow*>(rDragRight->GetTabWindow());
OSL_ENSURE(pSourceWin,"NO Source window found!");
OSL_ENSURE(pDestWin,"NO Dest window found!");
Init(pSourceWin->GetWinName(), pDestWin->GetWinName());
// und dann meine Members setzen
SetFieldIndex(JTCS_FROM, rDragLeft->GetFieldIndex());
SetFieldIndex(JTCS_TO, rDragRight->GetFieldIndex());
SetFieldType(JTCS_FROM, rDragLeft->GetFieldType());
SetFieldType(JTCS_TO, rDragRight->GetFieldType());
m_strSourceTableName = pSourceWin->GetTableName();
m_aSourceWinName = pSourceWin->GetWinName();
m_strDestTableName = pDestWin->GetTableName();
m_aDestWinName = pDestWin->GetWinName();
AppendConnLine((::rtl::OUString)rDragLeft->GetField(),(::rtl::OUString)rDragRight->GetField());
}
// -----------------------------------------------------------------------------
OTableConnectionData* OQueryTableConnectionData::NewInstance() const
{
return new OQueryTableConnectionData();
}
// -----------------------------------------------------------------------------
BOOL OQueryTableConnectionData::Update()
{
return TRUE;
}
// -----------------------------------------------------------------------------