Files
libreoffice/dbaccess/source/ui/querydesign/TableConnectionData.cxx

228 lines
7.8 KiB
C++
Raw Normal View History

2001-02-05 08:35:57 +00:00
/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
2001-02-05 08:35:57 +00:00
*
* $RCSfile: TableConnectionData.cxx,v $
2001-02-05 08:35:57 +00:00
*
* $Revision: 1.7 $
2001-02-05 08:35:57 +00:00
*
* last change: $Author: hr $ $Date: 2006-06-20 03:28:01 $
2001-02-05 08:35:57 +00:00
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
2001-02-05 08:35:57 +00:00
*
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2005 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
2001-02-05 08:35:57 +00:00
*
* 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.
2001-02-05 08:35:57 +00:00
*
* 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.
2001-02-05 08:35:57 +00:00
*
* 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
2001-02-05 08:35:57 +00:00
*
************************************************************************/
#ifndef DBAUI_TABLECONNECTIONDATA_HXX
#include "TableConnectionData.hxx"
#endif
#ifndef _TOOLS_DEBUG_HXX
#include <tools/debug.hxx>
#endif
#ifndef _COMPHELPER_STLTYPES_HXX_
#include <comphelper/stl_types.hxx>
#endif
using namespace dbaui;
using namespace comphelper;
//==================================================================
// class OTableConnectionData
//==================================================================
DBG_NAME(OTableConnectionData)
2001-02-05 08:35:57 +00:00
TYPEINIT0(OTableConnectionData);
//------------------------------------------------------------------------
OTableConnectionData::OTableConnectionData()
{
DBG_CTOR(OTableConnectionData,NULL);
Init();
}
//------------------------------------------------------------------------
OTableConnectionData::OTableConnectionData( const String& rSourceWinName, const String& rDestWinName, const String& rConnName )
:m_aSourceWinName( rSourceWinName )
,m_aDestWinName( rDestWinName )
,m_aConnName( rConnName )
{
DBG_CTOR(OTableConnectionData,NULL);
Init();
}
//------------------------------------------------------------------------
void OTableConnectionData::Init()
{
//////////////////////////////////////////////////////////////////////
// LineDataList mit Defaults initialisieren
DBG_ASSERT(m_vConnLineData.size() == 0, "OTableConnectionData::Init() : nur mit leere Linienliste aufzurufen !");
ResetConnLines(TRUE);
// das legt Defaults an
}
//------------------------------------------------------------------------
void OTableConnectionData::Init(const String& rSourceWinName, const String& rDestWinName, const String& rConnName)
{
// erst mal alle LineDatas loeschen
OConnectionLineDataVec().swap(m_vConnLineData);
2001-02-05 08:35:57 +00:00
// dann die Strings
m_aSourceWinName = rSourceWinName;
m_aDestWinName = rDestWinName;
m_aConnName = rConnName;
// den Rest erledigt das andere Init
Init();
}
//------------------------------------------------------------------------
OTableConnectionData::OTableConnectionData( const OTableConnectionData& rConnData )
{
DBG_CTOR(OTableConnectionData,NULL);
*this = rConnData;
}
//------------------------------------------------------------------------
void OTableConnectionData::CopyFrom(const OTableConnectionData& rSource)
{
*this = rSource;
// hier ziehe ich mich auf das (nicht-virtuelle) operator= zurueck, das nur meine Members kopiert
}
//------------------------------------------------------------------------
OTableConnectionData::~OTableConnectionData()
{
DBG_DTOR(OTableConnectionData,NULL);
2001-02-05 08:35:57 +00:00
// LineDataList loeschen
ResetConnLines(FALSE);
}
//------------------------------------------------------------------------
OTableConnectionData& OTableConnectionData::operator=( const OTableConnectionData& rConnData )
{
if (&rConnData == this)
return *this;
m_aSourceWinName = rConnData.GetSourceWinName();
m_aDestWinName = rConnData.GetDestWinName();
m_aConnName = rConnData.GetConnName();
// clear line list
ResetConnLines(FALSE);
// und kopieren
OConnectionLineDataVec* pLineData = const_cast<OTableConnectionData*>(&rConnData)->GetConnLineDataList();
2001-02-05 08:35:57 +00:00
OConnectionLineDataVec::const_iterator aIter = pLineData->begin();
2001-02-05 08:35:57 +00:00
for(;aIter != pLineData->end();++aIter)
m_vConnLineData.push_back(new OConnectionLineData(**aIter));
return *this;
}
//------------------------------------------------------------------------
BOOL OTableConnectionData::SetConnLine( USHORT nIndex, const String& rSourceFieldName, const String& rDestFieldName )
{
if (USHORT(m_vConnLineData.size()) < nIndex)
return FALSE;
// == ist noch erlaubt, das entspricht einem Append
if (m_vConnLineData.size() == nIndex)
return AppendConnLine(rSourceFieldName, rDestFieldName);
OConnectionLineDataRef pConnLineData = m_vConnLineData[nIndex];
2001-02-05 08:35:57 +00:00
DBG_ASSERT(pConnLineData != NULL, "OTableConnectionData::SetConnLine : habe ungueltiges LineData-Objekt");
pConnLineData->SetSourceFieldName( rSourceFieldName );
pConnLineData->SetDestFieldName( rDestFieldName );
return TRUE;
}
//------------------------------------------------------------------------
2001-02-05 15:17:40 +00:00
BOOL OTableConnectionData::AppendConnLine( const ::rtl::OUString& rSourceFieldName, const ::rtl::OUString& rDestFieldName )
2001-02-05 08:35:57 +00:00
{
OConnectionLineDataVec::iterator aIter = m_vConnLineData.begin();
2001-02-05 15:17:40 +00:00
for(;aIter != m_vConnLineData.end();++aIter)
{
if((*aIter)->GetDestFieldName() == rDestFieldName && (*aIter)->GetSourceFieldName() == rSourceFieldName)
break;
}
if(aIter == m_vConnLineData.end())
{
OConnectionLineDataRef pNew = new OConnectionLineData(rSourceFieldName, rDestFieldName);
if (!pNew.isValid())
2001-02-05 15:17:40 +00:00
return FALSE;
m_vConnLineData.push_back(pNew);
}
2001-02-05 08:35:57 +00:00
return TRUE;
}
//------------------------------------------------------------------------
void OTableConnectionData::ResetConnLines( BOOL bUseDefaults )
{
OConnectionLineDataVec().swap(m_vConnLineData);
2001-02-05 08:35:57 +00:00
if (bUseDefaults)
{
for (USHORT i=0; i<MAX_CONN_COUNT; i++)
m_vConnLineData.push_back( new OConnectionLineData());
}
}
//------------------------------------------------------------------------
OConnectionLineDataRef OTableConnectionData::CreateLineDataObj()
2001-02-05 08:35:57 +00:00
{
return new OConnectionLineData();
}
//------------------------------------------------------------------------
OConnectionLineDataRef OTableConnectionData::CreateLineDataObj( const OConnectionLineData& rConnLineData )
2001-02-05 08:35:57 +00:00
{
return new OConnectionLineData( rConnLineData );
}
// -----------------------------------------------------------------------------
OTableConnectionData* OTableConnectionData::NewInstance() const
{
return new OTableConnectionData();
}
// -----------------------------------------------------------------------------
void OTableConnectionData::normalizeLines()
{
// noch ein wenig Normalisierung auf den LineDatas : leere Lines vom Anfang an das Ende verschieben
sal_Int32 nCount = m_vConnLineData.size();
for(sal_Int32 i=0;i<nCount;)
{
if(!m_vConnLineData[i]->GetSourceFieldName().getLength() && !m_vConnLineData[i]->GetDestFieldName().getLength())
{
OConnectionLineDataRef pData = m_vConnLineData[i];
m_vConnLineData.erase(m_vConnLineData.begin()+i);
m_vConnLineData.push_back(pData);
--nCount;
}
else
++i;
}
}
// -----------------------------------------------------------------------------
2001-02-05 08:35:57 +00:00