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

145 lines
5.0 KiB
C++
Raw Normal View History

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2012-06-14 17:39:53 +01:00
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
2001-02-05 08:35:57 +00:00
#include "QTableConnectionData.hxx"
#include <tools/debug.hxx>
#include "QTableWindow.hxx"
using namespace dbaui;
// class OQueryTableConnectionData
2007-11-05 08:06:13 +00:00
DBG_NAME(OQueryTableConnectionData)
2001-02-05 08:35:57 +00:00
OQueryTableConnectionData::OQueryTableConnectionData()
:OTableConnectionData()
,m_eJoinType (INNER_JOIN)
,m_bNatural(false)
2001-02-05 08:35:57 +00:00
{
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;
m_bNatural = rConnData.m_bNatural;
2001-02-05 08:35:57 +00:00
}
OQueryTableConnectionData::OQueryTableConnectionData(const TTableWindowData::value_type& _pReferencingTable
,const TTableWindowData::value_type& _pReferencedTable
,const OUString& rConnName)
:OTableConnectionData( _pReferencingTable,_pReferencedTable, rConnName )
2001-02-05 08:35:57 +00:00
,m_nFromEntryIndex(0)
,m_nDestEntryIndex(0)
,m_eJoinType (INNER_JOIN)
,m_bNatural(false)
2001-02-05 08:35:57 +00:00
,m_eFromType(TAB_NORMAL_FIELD)
,m_eDestType(TAB_NORMAL_FIELD)
{
DBG_CTOR(OQueryTableConnectionData,NULL);
}
OQueryTableConnectionData::~OQueryTableConnectionData()
{
DBG_DTOR(OQueryTableConnectionData,NULL);
}
OConnectionLineDataRef OQueryTableConnectionData::CreateLineDataObj()
2001-02-05 08:35:57 +00:00
{
DBG_CHKTHIS(OQueryTableConnectionData,NULL);
// no specializing of LineDatas, so it is an instance of standard class
2001-02-05 08:35:57 +00:00
return new OConnectionLineData();
}
OConnectionLineDataRef OQueryTableConnectionData::CreateLineDataObj( const OConnectionLineData& rConnLineData )
2001-02-05 08:35:57 +00:00
{
DBG_CHKTHIS(OQueryTableConnectionData,NULL);
return new OConnectionLineData( rConnLineData );
}
void OQueryTableConnectionData::CopyFrom(const OTableConnectionData& rSource)
{
DBG_CHKTHIS(OQueryTableConnectionData,NULL);
// same as in base class, use of (non-virtual) operator=
2001-02-05 08:35:57 +00:00
*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;
m_bNatural = rConnData.m_bNatural;
2001-02-05 08:35:57 +00:00
return *this;
}
OUString OQueryTableConnectionData::GetAliasName(EConnectionSide nWhich) const
2001-02-05 08:35:57 +00:00
{
DBG_CHKTHIS(OQueryTableConnectionData,NULL);
return nWhich == JTCS_FROM ? m_pReferencingTable->GetWinName() : m_pReferencedTable->GetWinName();
2001-02-05 08:35:57 +00:00
}
void OQueryTableConnectionData::InitFromDrag(const OTableFieldDescRef& rDragLeft, const OTableFieldDescRef& rDragRight)
2001-02-05 08:35:57 +00:00
{
DBG_CHKTHIS(OQueryTableConnectionData,NULL);
// convert Information in rDrag into parameters for the base class init
OQueryTableWindow* pSourceWin = static_cast<OQueryTableWindow*>(rDragLeft->GetTabWindow());
OQueryTableWindow* pDestWin = static_cast<OQueryTableWindow*>(rDragRight->GetTabWindow());
2001-07-19 08:29:22 +00:00
OSL_ENSURE(pSourceWin,"NO Source window found!");
OSL_ENSURE(pDestWin,"NO Dest window found!");
m_pReferencingTable = pSourceWin->GetData();
m_pReferencedTable = pDestWin->GetData();
2001-02-05 08:35:57 +00:00
// set members
SetFieldIndex(JTCS_FROM, rDragLeft->GetFieldIndex());
SetFieldIndex(JTCS_TO, rDragRight->GetFieldIndex());
2001-02-05 08:35:57 +00:00
SetFieldType(JTCS_FROM, rDragLeft->GetFieldType());
SetFieldType(JTCS_TO, rDragRight->GetFieldType());
2001-02-05 08:35:57 +00:00
AppendConnLine((OUString)rDragLeft->GetField(),(OUString)rDragRight->GetField());
2001-02-05 08:35:57 +00:00
}
2001-02-05 08:35:57 +00:00
OTableConnectionData* OQueryTableConnectionData::NewInstance() const
{
return new OQueryTableConnectionData();
}
sal_Bool OQueryTableConnectionData::Update()
{
return sal_True;
}
2001-02-05 08:35:57 +00:00
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */