office-gobmx/dbaccess/source/ui/querydesign/TableFieldDescription.cxx
Rüdiger Timm 568af9ac86 CWS-TOOLING: integrate CWS dba31d
2008-12-08 16:22:07 +0100 rt  r265005 : Remove DOS lineends
2008-12-05 13:56:24 +0100 fs  r264906 : #i10000# removed unreachable statement
2008-11-20 11:41:26 +0100 fs  r264037 : merged in the fix for #i95865# (it was wrongly committed to CWS dba32a, should have been here)
2008-11-20 11:34:24 +0100 fs  r264036 : line ends
2008-11-14 08:44:50 +0100 lla  r263665 : #i10000# comparsion between int and uint fixed
2008-11-13 13:31:12 +0100 lla  r263641 : #i10000# build problem fixed
2008-11-13 11:20:01 +0100 lla  r263625 : #i96130# hard code name of extension
2008-11-12 11:13:41 +0100 fs  r263582 : #i96096# when opening a SRB-report fails due to the missing SRB extension, log this as warning only, and proceed with the migration
2008-11-12 11:11:35 +0100 fs  r263581 : #i96096# ContentType handling. Now all contents deliver proper results in XContent::getContentType
2008-11-12 11:10:11 +0100 fs  r263580 : #i96096# new ctors taking UNO_QUERY_THROW
2008-11-11 10:10:13 +0100 lla  r263546 : CWS-TOOLING: rebase CWS dba31d to trunk@263288 (milestone: DEV300:m35)
2008-11-06 15:55:39 +0100 oj  r263393 : #i93452# get field from model fallbackis the name
2008-11-06 15:31:47 +0100 oj  r263392 : #i93465# remeber location of floating windows
2008-11-06 13:36:24 +0100 oj  r263381 : #i93450# check typemap for null
2008-11-06 13:28:49 +0100 oj  r263379 : #i93020# empty column list boxes when new relation should be created
2008-11-06 12:33:53 +0100 oj  r263377 : #i93012# set border to default : flat
2008-11-06 12:26:54 +0100 oj  r263375 : #i74927# do some less calls for odbc
2008-11-06 09:34:01 +0100 oj  r263362 : #i93383# grabFocus in suspend to get allmodified cells
2008-11-03 21:01:39 +0100 oj  r263308 : #i86739# check if slash can be valid for tables
2008-11-03 14:40:21 +0100 oj  r263287 : #i86739# check if slash can be valid for tables
2008-11-03 14:32:17 +0100 oj  r263286 : #i95227# column width 
2008-11-03 14:27:26 +0100 oj  r263285 : link fwe
2008-11-03 14:24:54 +0100 oj  r263284 : #i95235# changed to hold no ref only weak
2008-10-31 11:21:48 +0100 oj  r262859 : #i93459# set images add menu entry
2008-10-31 09:06:37 +0100 oj  r262851 : #i88629# correct fileopen filter for database odb files
2008-10-30 15:01:04 +0100 oj  r262828 : #i95229# set filter at the composer
2008-10-29 15:57:41 +0100 oj  r262817 : #i95235# changed to hold no ref only weak
2008-10-29 15:57:19 +0100 oj  r262816 : #i95235# changed to hold no ref only weak
2008-10-29 15:57:03 +0100 oj  r262815 : #i95235# changed to hold no ref only weak
2008-10-29 15:56:15 +0100 oj  r262814 : #i95235# filtermanger changed to hold no ref only weak
2008-10-29 10:32:39 +0100 oj  r262773 : #i93474# use correct table name
2008-10-28 13:49:33 +0100 lla  r262744 : #i95524# make an Invalidate and refresh on Tables
2008-10-28 10:45:02 +0100 fs  r262707 : line ends
2008-10-28 10:34:42 +0100 fs  r262706 : #i95522# don't expect the component to live in a TopWindow
2008-10-28 08:30:40 +0100 lla  r262696 : #i93176# set preview mode on view
2008-10-28 07:56:57 +0100 oj  r262694 : merge cvs svn
2008-10-27 14:13:51 +0100 oj  r262673 : #i94129# use dummy data
2008-10-27 12:38:45 +0100 fs  r262669 : #i94125# rework ScrollColumns
2008-10-23 15:53:57 +0200 oj  r262624 : #i94568# do not load the embeddedobj just copy the storage
2008-10-23 14:39:14 +0200 oj  r262622 : #i94129# handle chart correctly
2008-10-22 10:51:19 +0200 lla  r262582 : #i94115# problem with left walk chart shape fixed
2008-10-22 07:47:48 +0200 oj  r262576 : #i94455# rename now do not use remove insert
2008-10-22 07:47:27 +0200 oj  r262575 : #i94455# rename now do not use remove insert
2008-10-21 12:46:26 +0200 lla  r262567 : #i93845# extra check if default schema doesn't exists, fix assertion
2008-12-09 07:25:38 +00:00

237 lines
9.2 KiB
C++

/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* Copyright 2008 by Sun Microsystems, Inc.
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: TableFieldDescription.cxx,v $
* $Revision: 1.12 $
*
* This file is part of OpenOffice.org.
*
* 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.
*
* 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).
*
* 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.
*
************************************************************************/
// MARKER(update_precomp.py): autogen include statement, do not remove
#include "precompiled_dbaccess.hxx"
#ifndef DBAUI_TABLEFIELDDESC_HXX
#include "TableFieldDescription.hxx"
#endif
#ifndef _TOOLS_DEBUG_HXX
#include <tools/debug.hxx>
#endif
#ifndef _COM_SUN_STAR_SDBC_DATATYPE_HPP_
#include <com/sun/star/sdbc/DataType.hpp>
#endif
#ifndef _COMPHELPER_STREAMSECTION_HXX_
#include <comphelper/streamsection.hxx>
#endif
using namespace ::com::sun::star::sdbc;
using namespace ::com::sun::star::uno;
using namespace ::com::sun::star::beans;
using namespace comphelper;
using namespace dbaui;
DBG_NAME(OTableFieldDesc)
//==============================================================================
OTableFieldDesc::OTableFieldDesc()
:m_pTabWindow(0)
,m_eDataType(1000)
,m_eFunctionType( FKT_NONE )
,m_eFieldType(TAB_NORMAL_FIELD)
,m_eOrderDir( ORDER_NONE )
,m_nIndex(0)
,m_nColWidth(0)
,m_nColumnId((sal_uInt16)-1)
,m_bGroupBy(sal_False)
,m_bVisible(sal_False)
{
DBG_CTOR(OTableFieldDesc,NULL);
}
//------------------------------------------------------------------------------
OTableFieldDesc::OTableFieldDesc(const OTableFieldDesc& rRS)
: ::vos::OReference()
,m_vecCriteria( rRS.m_vecCriteria)
,m_aTableName(rRS.GetTable())
,m_aAliasName(rRS.GetAlias()) // table range
,m_aFieldName(rRS.GetField()) // column
,m_aFieldAlias(rRS.GetFieldAlias()) // column alias
,m_aFunctionName(rRS.GetFunction()) // Funktionsname
,m_pTabWindow(rRS.GetTabWindow())
,m_eDataType(rRS.GetDataType())
,m_eFunctionType( rRS.GetFunctionType() )
,m_eFieldType(rRS.GetFieldType())
,m_eOrderDir(rRS.GetOrderDir())
,m_nIndex(rRS.GetFieldIndex())
,m_nColWidth(rRS.GetColWidth())
,m_nColumnId( rRS.m_nColumnId)
,m_bGroupBy(rRS.IsGroupBy())
,m_bVisible(rRS.IsVisible())
{
DBG_CTOR(OTableFieldDesc,NULL);
}
//------------------------------------------------------------------------------
OTableFieldDesc::OTableFieldDesc(const ::rtl::OUString& rT, const ::rtl::OUString& rF )
:m_pTabWindow(0)
,m_eFunctionType( FKT_NONE )
,m_eOrderDir( ORDER_NONE )
,m_nColumnId((sal_uInt16)-1)
,m_bGroupBy(sal_False)
,m_bVisible(sal_False)
{
DBG_CTOR(OTableFieldDesc,NULL);
SetField( rF ); SetTable( rT );
}
//------------------------------------------------------------------------------
OTableFieldDesc::~OTableFieldDesc()
{
DBG_DTOR(OTableFieldDesc,NULL);
}
//------------------------------------------------------------------------------
sal_Bool OTableFieldDesc::operator==( const OTableFieldDesc& rDesc )
{
DBG_CHKTHIS(OTableFieldDesc,NULL);
return ( m_eOrderDir != rDesc.GetOrderDir() ||
m_eDataType != rDesc.GetDataType() ||
m_aAliasName != rDesc.GetAlias() ||
m_aFunctionName != rDesc.GetFunction() ||
m_aFieldName != rDesc.GetField() ||
m_aTableName != rDesc.GetTable() ||
m_bGroupBy != rDesc.IsGroupBy() ||
m_vecCriteria != rDesc.GetCriteria() ||
m_bVisible != rDesc.IsVisible() );
}
//------------------------------------------------------------------------------
void OTableFieldDesc::SetCriteria( sal_uInt16 nIdx, const ::rtl::OUString& rCrit)
{
DBG_CHKTHIS(OTableFieldDesc,NULL);
if (nIdx < m_vecCriteria.size())
m_vecCriteria[nIdx] = rCrit;
else
{
for(sal_Int32 i=m_vecCriteria.size();i<nIdx;++i)
m_vecCriteria.push_back( ::rtl::OUString());
m_vecCriteria.push_back(rCrit);
}
}
//------------------------------------------------------------------------------
::rtl::OUString OTableFieldDesc::GetCriteria( sal_uInt16 nIdx ) const
{
DBG_CHKTHIS(OTableFieldDesc,NULL);
::rtl::OUString aRetStr;
if( nIdx < m_vecCriteria.size())
aRetStr = m_vecCriteria[nIdx];
return aRetStr;
}
// -----------------------------------------------------------------------------
void OTableFieldDesc::Load(const ::com::sun::star::beans::PropertyValue& _rProperty)
{
DBG_CHKTHIS(OTableFieldDesc,NULL);
Sequence<PropertyValue> aFieldDesc;
_rProperty.Value >>= aFieldDesc;
//if ( aFieldDesc.getLength() == 12 )
{
sal_Int32 nCount = aFieldDesc.getLength();
for (sal_Int32 nPos = 0; nPos < nCount; ++nPos)
{
if ( aFieldDesc[nPos].Name.equalsAscii("AliasName") )
aFieldDesc[nPos].Value >>= m_aAliasName;
else if ( aFieldDesc[nPos].Name.equalsAscii("TableName") )
aFieldDesc[nPos].Value >>= m_aTableName;
else if ( aFieldDesc[nPos].Name.equalsAscii("FieldName") )
aFieldDesc[nPos].Value >>= m_aFieldName;
else if ( aFieldDesc[nPos].Name.equalsAscii("FieldAlias") )
aFieldDesc[nPos].Value >>= m_aFieldAlias;
else if ( aFieldDesc[nPos].Name.equalsAscii("FunctionName") )
aFieldDesc[nPos].Value >>= m_aFunctionName;
else if ( aFieldDesc[nPos].Name.equalsAscii("DataType") )
aFieldDesc[nPos].Value >>= m_eDataType;
else if ( aFieldDesc[nPos].Name.equalsAscii("FunctionType") )
aFieldDesc[nPos].Value >>= m_eFunctionType;
else if ( aFieldDesc[nPos].Name.equalsAscii("FieldType") )
{
sal_Int32 nTemp = 0;
aFieldDesc[nPos].Value >>= nTemp;
m_eFieldType = static_cast<ETableFieldType>(nTemp);
}
else if ( aFieldDesc[nPos].Name.equalsAscii("OrderDir") )
{
sal_Int32 nTemp = 0;
aFieldDesc[nPos].Value >>= nTemp;
m_eOrderDir = static_cast<EOrderDir>(nTemp);
}
else if ( aFieldDesc[nPos].Name.equalsAscii("ColWidth") )
aFieldDesc[nPos].Value >>= m_nColWidth;
else if ( aFieldDesc[nPos].Name.equalsAscii("GroupBy") )
aFieldDesc[nPos].Value >>= m_bGroupBy;
else if ( aFieldDesc[nPos].Name.equalsAscii("Visible") )
aFieldDesc[nPos].Value >>= m_bVisible;
}
}
}
//------------------------------------------------------------------------------
void OTableFieldDesc::Save(::com::sun::star::beans::PropertyValue& _rProperty)
{
DBG_CHKTHIS(OTableFieldDesc,NULL);
Sequence<PropertyValue> aFieldDesc(13);
sal_Int32 nPos = 0;
aFieldDesc[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("AliasName"));
aFieldDesc[nPos++].Value <<= m_aAliasName;
aFieldDesc[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("TableName"));
aFieldDesc[nPos++].Value <<= m_aTableName;
aFieldDesc[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("FieldName"));
aFieldDesc[nPos++].Value <<= m_aFieldName;
aFieldDesc[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("FieldAlias"));
aFieldDesc[nPos++].Value <<= m_aFieldAlias;
aFieldDesc[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("FunctionName"));
aFieldDesc[nPos++].Value <<= m_aFunctionName;
aFieldDesc[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("DataType"));
aFieldDesc[nPos++].Value <<= m_eDataType;
aFieldDesc[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("FunctionType"));
aFieldDesc[nPos++].Value <<= (sal_Int32)m_eFunctionType;
aFieldDesc[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("FieldType"));
aFieldDesc[nPos++].Value <<= (sal_Int32)m_eFieldType;
aFieldDesc[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("OrderDir"));
aFieldDesc[nPos++].Value <<= (sal_Int32)m_eOrderDir;
aFieldDesc[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("ColWidth"));
aFieldDesc[nPos++].Value <<= m_nColWidth;
aFieldDesc[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("GroupBy"));
aFieldDesc[nPos++].Value <<= m_bGroupBy;
aFieldDesc[nPos].Name = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("Visible"));
aFieldDesc[nPos++].Value <<= m_bVisible;
_rProperty.Value <<= aFieldDesc;
}
// -----------------------------------------------------------------------------