Files
libreoffice/sw/source/core/fields/dbfld.cxx

1077 lines
30 KiB
C++
Raw Normal View History

2000-09-18 23:08:29 +00:00
/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
2000-09-18 23:08:29 +00:00
*
* Copyright 2000, 2010 Oracle and/or its affiliates.
2000-09-18 23:08:29 +00:00
*
* OpenOffice.org - a multi-platform office productivity suite
2000-09-18 23:08:29 +00:00
*
* This file is part of OpenOffice.org.
2000-09-18 23:08:29 +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.
2000-09-18 23:08:29 +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).
2000-09-18 23:08:29 +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.
2000-09-18 23:08:29 +00:00
*
************************************************************************/
// MARKER(update_precomp.py): autogen include statement, do not remove
#include "precompiled_sw.hxx"
2000-09-18 23:08:29 +00:00
#include <float.h>
#include <sfx2/app.hxx>
#include <svl/zforlist.hxx>
#include <svx/pageitem.hxx>
#include <svx/dataaccessdescriptor.hxx>
#include <com/sun/star/sdbc/DataType.hpp>
2000-09-18 23:08:29 +00:00
#include <fmtfld.hxx>
#include <txtfld.hxx>
#include <doc.hxx>
#include <docary.hxx>
#include <frame.hxx>
#include <fldbas.hxx>
#include <pam.hxx>
#include <ndtxt.hxx>
#include <dbfld.hxx>
#ifndef _DBMGR_HXX
#include <dbmgr.hxx>
#endif
#include <docfld.hxx>
#include <expfld.hxx>
#include <txtatr.hxx>
#ifndef _UNOFLDMID_H
#include <unofldmid.h>
#endif
2000-09-18 23:08:29 +00:00
using namespace ::com::sun::star::sdbc;
using namespace ::com::sun::star;
using ::rtl::OUString;
2000-09-18 23:08:29 +00:00
/*--------------------------------------------------------------------
Beschreibung: Datenbanktrenner durch Punkte fuer Anzeige ersetzen
--------------------------------------------------------------------*/
String lcl_DBTrennConv(const String& aContent)
{
String sTmp(aContent);
sal_Unicode* pStr = sTmp.GetBufferAccess();
for( USHORT i = sTmp.Len(); i; --i, ++pStr )
if( DB_DELIM == *pStr )
*pStr = '.';
return sTmp;
}
/*--------------------------------------------------------------------
Beschreibung: DatenbankFeldTyp
--------------------------------------------------------------------*/
SwDBFieldType::SwDBFieldType(SwDoc* pDocPtr, const String& rNam, const SwDBData& rDBData ) :
2000-09-18 23:08:29 +00:00
SwValueFieldType( pDocPtr, RES_DBFLD ),
aDBData(rDBData),
sColumn(rNam),
nRefCnt(0)
2000-09-18 23:08:29 +00:00
{
2001-03-12 05:42:16 +00:00
if(aDBData.sDataSource.getLength() || aDBData.sCommand.getLength())
{
sName = aDBData.sDataSource;
sName += DB_DELIM;
sName += (String)aDBData.sCommand;
sName += DB_DELIM;
}
sName += GetColumnName();
2000-09-18 23:08:29 +00:00
}
//------------------------------------------------------------------------------
2009-08-04 12:13:41 +00:00
SwDBFieldType::~SwDBFieldType()
{
}
//------------------------------------------------------------------------------
2000-09-18 23:08:29 +00:00
SwFieldType* SwDBFieldType::Copy() const
{
SwDBFieldType* pTmp = new SwDBFieldType(GetDoc(), sColumn, aDBData);
2000-09-18 23:08:29 +00:00
return pTmp;
}
//------------------------------------------------------------------------------
const String& SwDBFieldType::GetName() const
{
return sName;
2000-09-18 23:08:29 +00:00
}
//------------------------------------------------------------------------------
void SwDBFieldType::ReleaseRef()
{
ASSERT(nRefCnt > 0, "RefCount kleiner 0!");
if (--nRefCnt <= 0)
{
USHORT nPos = GetDoc()->GetFldTypes()->GetPos(this);
if (nPos != USHRT_MAX)
{
GetDoc()->RemoveFldType(nPos);
delete this;
}
}
}
/* -----------------24.02.99 14:51-------------------
*
* --------------------------------------------------*/
BOOL SwDBFieldType::QueryValue( uno::Any& rAny, USHORT nWhichId ) const
2000-09-18 23:08:29 +00:00
{
switch( nWhichId )
{
case FIELD_PROP_PAR1:
rAny <<= aDBData.sDataSource;
break;
case FIELD_PROP_PAR2:
rAny <<= aDBData.sCommand;
break;
case FIELD_PROP_PAR3:
rAny <<= OUString(sColumn);
break;
case FIELD_PROP_SHORT1:
rAny <<= aDBData.nCommandType;
break;
default:
2001-10-26 10:10:02 +00:00
DBG_ERROR("illegal property");
}
return TRUE;
2000-09-18 23:08:29 +00:00
}
/* -----------------24.02.99 14:51-------------------
*
* --------------------------------------------------*/
BOOL SwDBFieldType::PutValue( const uno::Any& rAny, USHORT nWhichId )
2000-09-18 23:08:29 +00:00
{
switch( nWhichId )
{
case FIELD_PROP_PAR1:
rAny >>= aDBData.sDataSource;
break;
case FIELD_PROP_PAR2:
rAny >>= aDBData.sCommand;
break;
case FIELD_PROP_PAR3:
2000-09-18 23:08:29 +00:00
{
String sTmp;
::GetString( rAny, sTmp );
if( sTmp != sColumn )
2000-09-18 23:08:29 +00:00
{
sColumn = sTmp;
SwClientIter aIter( *this );
SwFmtFld* pFld = (SwFmtFld*)aIter.First( TYPE( SwFmtFld ));
while(pFld)
2000-09-18 23:08:29 +00:00
{
// Feld im Undo?
SwTxtFld *pTxtFld = pFld->GetTxtFld();
if(pTxtFld && pTxtFld->GetTxtNode().GetNodes().IsDocNodes() )
{
SwDBField* pDBField = (SwDBField*)pFld->GetFld();
pDBField->ClearInitialized();
pDBField->InitContent();
}
pFld = (SwFmtFld*)aIter.Next();
2000-09-18 23:08:29 +00:00
}
}
}
break;
case FIELD_PROP_SHORT1:
rAny >>= aDBData.nCommandType;
break;
default:
2001-10-26 10:10:02 +00:00
DBG_ERROR("illegal property");
2000-09-18 23:08:29 +00:00
}
return TRUE;
2000-09-18 23:08:29 +00:00
}
/*--------------------------------------------------------------------
Beschreibung: SwDBField
--------------------------------------------------------------------*/
SwDBField::SwDBField(SwDBFieldType* pTyp, ULONG nFmt)
: SwValueField(pTyp, nFmt),
nSubType(0),
2000-09-18 23:08:29 +00:00
bIsInBodyTxt(TRUE),
bValidValue(FALSE),
bInitialized(FALSE)
2000-09-18 23:08:29 +00:00
{
if (GetTyp())
((SwDBFieldType*)GetTyp())->AddRef();
InitContent();
}
//------------------------------------------------------------------------------
SwDBField::~SwDBField()
{
if (GetTyp())
((SwDBFieldType*)GetTyp())->ReleaseRef();
}
//------------------------------------------------------------------------------
void SwDBField::InitContent()
{
if (!IsInitialized())
{
aContent = '<';
aContent += ((SwDBFieldType*)GetTyp())->GetColumnName();
aContent += '>';
}
}
//------------------------------------------------------------------------------
void SwDBField::InitContent(const String& rExpansion)
{
if (rExpansion.Len() > 2)
{
if (rExpansion.GetChar(0) == '<' &&
rExpansion.GetChar(rExpansion.Len() - 1) == '>')
{
String sColumn( rExpansion.Copy( 1, rExpansion.Len() - 2 ) );
if( ::GetAppCmpStrIgnore().isEqual( sColumn,
((SwDBFieldType *)GetTyp())->GetColumnName() ))
2000-09-18 23:08:29 +00:00
{
InitContent();
return;
}
}
}
SetExpansion( rExpansion );
}
//------------------------------------------------------------------------------
String SwDBField::Expand() const
{
String sRet;
if(0 ==(GetSubType() & nsSwExtendedSubType::SUB_INVISIBLE))
sRet = lcl_DBTrennConv(aContent);
return sRet;
2000-09-18 23:08:29 +00:00
}
//------------------------------------------------------------------------------
SwField* SwDBField::Copy() const
{
SwDBField *pTmp = new SwDBField((SwDBFieldType*)GetTyp(), GetFormat());
pTmp->aContent = aContent;
pTmp->bIsInBodyTxt = bIsInBodyTxt;
pTmp->bValidValue = bValidValue;
pTmp->bInitialized = bInitialized;
pTmp->nSubType = nSubType;
pTmp->SetValue(GetValue());
pTmp->sFieldCode = sFieldCode;
2000-09-18 23:08:29 +00:00
return pTmp;
}
String SwDBField::GetCntnt(BOOL bName) const
{
if(bName)
{
const String& rDBName = ((SwDBFieldType*)GetTyp())->GetName();
//TODO/CLEANUP
//Funktion tut nichts!
//String sContent( SFX_APP()->LocalizeDBName(INI2NATIONAL,
// rDBName.GetToken(0, DB_DELIM)));
String sContent( rDBName.GetToken(0, DB_DELIM) );
2000-09-18 23:08:29 +00:00
if (sContent.Len() > 1)
{
sContent += DB_DELIM;
sContent += rDBName.GetToken(1, DB_DELIM);
sContent += DB_DELIM;
sContent += rDBName.GetToken(2, DB_DELIM);
}
return lcl_DBTrennConv(sContent);
}
return Expand();
}
//------------------------------------------------------------------------------
void SwDBField::ChgValue( double d, BOOL bVal )
{
bValidValue = bVal;
SetValue(d);
if( bValidValue )
aContent = ((SwValueFieldType*)GetTyp())->ExpandValue(d, GetFormat(), GetLanguage());
}
/*--------------------------------------------------------------------
Beschreibung:
--------------------------------------------------------------------*/
SwFieldType* SwDBField::ChgTyp( SwFieldType* pNewType )
{
SwFieldType* pOld = SwValueField::ChgTyp( pNewType );
((SwDBFieldType*)pNewType)->AddRef();
((SwDBFieldType*)pOld)->ReleaseRef();
return pOld;
}
/*--------------------------------------------------------------------
Beschreibung: Aktuellen Field-Value holen und chachen
--------------------------------------------------------------------*/
void SwDBField::Evaluate()
{
SwNewDBMgr* pMgr = GetDoc()->GetNewDBMgr();
// erstmal loeschen
bValidValue = FALSE;
double nValue = DBL_MAX;
const SwDBData& aTmpData = GetDBData();
2000-09-18 23:08:29 +00:00
if(!pMgr || !pMgr->IsDataSourceOpen(aTmpData.sDataSource, aTmpData.sCommand, sal_True))
2000-09-18 23:08:29 +00:00
return ;
sal_uInt32 nFmt;
2000-09-18 23:08:29 +00:00
// Passenden Spaltennamen suchen
String aColNm( ((SwDBFieldType*)GetTyp())->GetColumnName() );
SvNumberFormatter* pDocFormatter = GetDoc()->GetNumberFormatter();
pMgr->GetMergeColumnCnt(aColNm, GetLanguage(), aContent, &nValue, &nFmt);
if( !( nSubType & nsSwExtendedSubType::SUB_OWN_FMT ) )
SetFormat( nFmt = pMgr->GetColumnFmt( aTmpData.sDataSource, aTmpData.sCommand,
2001-10-30 08:04:43 +00:00
aColNm, pDocFormatter, GetLanguage() ));
2000-09-18 23:08:29 +00:00
if( DBL_MAX != nValue )
{
2001-10-30 08:04:43 +00:00
sal_Int32 nColumnType = pMgr->GetColumnType(aTmpData.sDataSource, aTmpData.sCommand, aColNm);
2000-09-18 23:08:29 +00:00
if( DataType::DATE == nColumnType || DataType::TIME == nColumnType ||
2001-10-30 08:05:23 +00:00
DataType::TIMESTAMP == nColumnType)
2000-09-18 23:08:29 +00:00
{
Date aStandard(1,1,1900);
if (*pDocFormatter->GetNullDate() != aStandard)
nValue += (aStandard - *pDocFormatter->GetNullDate());
}
bValidValue = TRUE;
SetValue(nValue);
aContent = ((SwValueFieldType*)GetTyp())->ExpandValue(nValue, GetFormat(), GetLanguage());
}
else
{
SwSbxValue aVal;
aVal.PutString( aContent );
if (aVal.IsNumeric())
{
SetValue(aVal.GetDouble());
SvNumberFormatter* pFormatter = GetDoc()->GetNumberFormatter();
if (nFmt && nFmt != SAL_MAX_UINT32 && !pFormatter->IsTextFormat(nFmt))
2000-09-18 23:08:29 +00:00
bValidValue = TRUE; // Wegen Bug #60339 nicht mehr bei allen Strings
}
else
{
// Bei Strings TRUE wenn Laenge > 0 sonst FALSE
SetValue(aContent.Len() ? 1 : 0);
}
}
bInitialized = TRUE;
}
/*--------------------------------------------------------------------
Beschreibung: Namen erfragen
--------------------------------------------------------------------*/
const String& SwDBField::GetPar1() const
{
return ((SwDBFieldType*)GetTyp())->GetName();
}
/*--------------------------------------------------------------------
Beschreibung:
--------------------------------------------------------------------*/
USHORT SwDBField::GetSubType() const
{
return nSubType;
}
/*--------------------------------------------------------------------
Beschreibung:
--------------------------------------------------------------------*/
void SwDBField::SetSubType(USHORT nType)
{
nSubType = nType;
}
/*-----------------06.03.98 16:15-------------------
--------------------------------------------------*/
BOOL SwDBField::QueryValue( uno::Any& rAny, USHORT nWhichId ) const
2000-09-18 23:08:29 +00:00
{
switch( nWhichId )
2000-09-18 23:08:29 +00:00
{
case FIELD_PROP_BOOL1:
{
BOOL bTemp = 0 == (GetSubType()&nsSwExtendedSubType::SUB_OWN_FMT);
rAny.setValue(&bTemp, ::getBooleanCppuType());
}
break;
case FIELD_PROP_BOOL2:
{
sal_Bool bVal = 0 == (GetSubType() & nsSwExtendedSubType::SUB_INVISIBLE);
rAny.setValue(&bVal, ::getBooleanCppuType());
}
break;
case FIELD_PROP_FORMAT:
2000-09-18 23:08:29 +00:00
rAny <<= (sal_Int32)GetFormat();
break;
case FIELD_PROP_PAR1:
2000-09-18 23:08:29 +00:00
rAny <<= OUString(aContent);
break;
case FIELD_PROP_PAR2:
rAny <<= OUString(sFieldCode);
break;
default:
2001-10-26 10:10:02 +00:00
DBG_ERROR("illegal property");
}
2000-09-18 23:08:29 +00:00
return TRUE;
}
/*-----------------06.03.98 16:15-------------------
--------------------------------------------------*/
BOOL SwDBField::PutValue( const uno::Any& rAny, USHORT nWhichId )
2000-09-18 23:08:29 +00:00
{
switch( nWhichId )
2000-09-18 23:08:29 +00:00
{
case FIELD_PROP_BOOL1:
if( *(sal_Bool*)rAny.getValue() )
SetSubType(GetSubType()&~nsSwExtendedSubType::SUB_OWN_FMT);
2000-09-18 23:08:29 +00:00
else
SetSubType(GetSubType()|nsSwExtendedSubType::SUB_OWN_FMT);
break;
case FIELD_PROP_BOOL2:
{
USHORT nSubTyp = GetSubType();
sal_Bool bVisible = sal_False;
if(!(rAny >>= bVisible))
return FALSE;
if(bVisible)
nSubTyp &= ~nsSwExtendedSubType::SUB_INVISIBLE;
else
nSubTyp |= nsSwExtendedSubType::SUB_INVISIBLE;
SetSubType(nSubTyp);
//invalidate text node
if(GetTyp())
{
SwClientIter aIter( *GetTyp() );
SwFmtFld* pFld = (SwFmtFld*)aIter.First( TYPE( SwFmtFld ));
while(pFld)
{
SwTxtFld *pTxtFld = pFld->GetTxtFld();
if(pTxtFld && (SwDBField*)pFld->GetFld() == this )
{
//notify the change
pTxtFld->NotifyContentChange(*pFld);
break;
}
pFld = (SwFmtFld*)aIter.Next();
}
}
}
break;
case FIELD_PROP_FORMAT:
{
sal_Int32 nTemp = 0;
rAny >>= nTemp;
SetFormat(nTemp);
}
break;
case FIELD_PROP_PAR1:
::GetString( rAny, aContent );
break;
case FIELD_PROP_PAR2:
::GetString( rAny, sFieldCode );
break;
default:
2001-10-26 10:10:02 +00:00
DBG_ERROR("illegal property");
2000-09-18 23:08:29 +00:00
}
return TRUE;
}
/*--------------------------------------------------------------------
Beschreibung: Basisklasse fuer alle weiteren Datenbankfelder
--------------------------------------------------------------------*/
SwDBNameInfField::SwDBNameInfField(SwFieldType* pTyp, const SwDBData& rDBData, ULONG nFmt) :
2000-09-18 23:08:29 +00:00
SwField(pTyp, nFmt),
aDBData(rDBData),
nSubType(0)
2000-09-18 23:08:29 +00:00
{
}
//------------------------------------------------------------------------------
SwDBData SwDBNameInfField::GetDBData(SwDoc* pDoc)
2000-09-18 23:08:29 +00:00
{
SwDBData aRet;
if(aDBData.sDataSource.getLength())
aRet = aDBData;
2000-09-18 23:08:29 +00:00
else
aRet = pDoc->GetDBData();
return aRet;
2000-09-18 23:08:29 +00:00
}
// #111840#
void SwDBNameInfField::SetDBData(const SwDBData & rDBData)
{
aDBData = rDBData;
}
2000-09-18 23:08:29 +00:00
//------------------------------------------------------------------------------
String SwDBNameInfField::GetCntnt(BOOL bName) const
{
String sStr(SwField::GetCntnt(bName));
if(bName)
{
if (aDBData.sDataSource.getLength())
2000-09-18 23:08:29 +00:00
{
sStr += ':';
sStr += String(aDBData.sDataSource);
2000-09-18 23:08:29 +00:00
sStr += DB_DELIM;
sStr += String(aDBData.sCommand);
2000-09-18 23:08:29 +00:00
}
}
return lcl_DBTrennConv(sStr);
}
/*-----------------06.03.98 16:55-------------------
--------------------------------------------------*/
BOOL SwDBNameInfField::QueryValue( uno::Any& rAny, USHORT nWhichId ) const
2000-09-18 23:08:29 +00:00
{
switch( nWhichId )
{
case FIELD_PROP_PAR1:
rAny <<= aDBData.sDataSource;
break;
case FIELD_PROP_PAR2:
rAny <<= aDBData.sCommand;
break;
case FIELD_PROP_SHORT1:
rAny <<= aDBData.nCommandType;
break;
case FIELD_PROP_BOOL2:
{
sal_Bool bVal = 0 == (GetSubType() & nsSwExtendedSubType::SUB_INVISIBLE);
rAny.setValue(&bVal, ::getBooleanCppuType());
}
break;
default:
2001-10-26 10:10:02 +00:00
DBG_ERROR("illegal property");
2000-09-18 23:08:29 +00:00
}
return TRUE;
}
/*-----------------06.03.98 16:55-------------------
--------------------------------------------------*/
BOOL SwDBNameInfField::PutValue( const uno::Any& rAny, USHORT nWhichId )
{
switch( nWhichId )
{
case FIELD_PROP_PAR1:
rAny >>= aDBData.sDataSource;
break;
case FIELD_PROP_PAR2:
rAny >>= aDBData.sCommand;
break;
case FIELD_PROP_SHORT1:
rAny >>= aDBData.nCommandType;
break;
case FIELD_PROP_BOOL2:
{
USHORT nSubTyp = GetSubType();
sal_Bool bVisible = sal_False;
if(!(rAny >>= bVisible))
return FALSE;
if(bVisible)
nSubTyp &= ~nsSwExtendedSubType::SUB_INVISIBLE;
else
nSubTyp |= nsSwExtendedSubType::SUB_INVISIBLE;
SetSubType(nSubTyp);
}
break;
default:
2001-10-26 10:10:02 +00:00
DBG_ERROR("illegal property");
}
return TRUE;
2000-09-18 23:08:29 +00:00
}
/* -----------------4/10/2003 15:03------------------
--------------------------------------------------*/
USHORT SwDBNameInfField::GetSubType() const
{
return nSubType;
}
/* -----------------4/10/2003 15:03------------------
--------------------------------------------------*/
void SwDBNameInfField::SetSubType(USHORT nType)
{
nSubType = nType;
}
2000-09-18 23:08:29 +00:00
/*--------------------------------------------------------------------
Beschreibung: NaechsterDatensatz
--------------------------------------------------------------------*/
SwDBNextSetFieldType::SwDBNextSetFieldType()
: SwFieldType( RES_DBNEXTSETFLD )
{
}
//------------------------------------------------------------------------------
SwFieldType* SwDBNextSetFieldType::Copy() const
{
SwDBNextSetFieldType* pTmp = new SwDBNextSetFieldType();
return pTmp;
}
/*--------------------------------------------------------------------
Beschreibung: SwDBSetField
--------------------------------------------------------------------*/
SwDBNextSetField::SwDBNextSetField(SwDBNextSetFieldType* pTyp,
const String& rCond,
const String& ,
const SwDBData& rDBData) :
SwDBNameInfField(pTyp, rDBData), aCond(rCond), bCondValid(TRUE)
2000-09-18 23:08:29 +00:00
{}
//------------------------------------------------------------------------------
String SwDBNextSetField::Expand() const
{
return aEmptyStr;
}
//------------------------------------------------------------------------------
SwField* SwDBNextSetField::Copy() const
{
SwDBNextSetField *pTmp = new SwDBNextSetField((SwDBNextSetFieldType*)GetTyp(),
aCond, aEmptyStr, GetDBData());
pTmp->SetSubType(GetSubType());
2000-09-18 23:08:29 +00:00
pTmp->bCondValid = bCondValid;
return pTmp;
}
//------------------------------------------------------------------------------
void SwDBNextSetField::Evaluate(SwDoc* pDoc)
{
SwNewDBMgr* pMgr = pDoc->GetNewDBMgr();
const SwDBData& rData = GetDBData();
2000-09-18 23:08:29 +00:00
if( !bCondValid ||
!pMgr || !pMgr->IsDataSourceOpen(rData.sDataSource, rData.sCommand, sal_False))
2000-09-18 23:08:29 +00:00
return ;
pMgr->ToNextRecord(rData.sDataSource, rData.sCommand);
2000-09-18 23:08:29 +00:00
}
/*--------------------------------------------------------------------
Beschreibung: Bedingung
--------------------------------------------------------------------*/
const String& SwDBNextSetField::GetPar1() const
{
return aCond;
}
void SwDBNextSetField::SetPar1(const String& rStr)
{
aCond = rStr;
}
/*-----------------06.03.98 16:16-------------------
--------------------------------------------------*/
BOOL SwDBNextSetField::QueryValue( uno::Any& rAny, USHORT nWhichId ) const
2000-09-18 23:08:29 +00:00
{
BOOL bRet = TRUE;
switch( nWhichId )
{
case FIELD_PROP_PAR3:
2000-09-18 23:08:29 +00:00
rAny <<= OUString(aCond);
break;
default:
bRet = SwDBNameInfField::QueryValue( rAny, nWhichId );
}
return bRet;
2000-09-18 23:08:29 +00:00
}
/*-----------------06.03.98 16:16-------------------
--------------------------------------------------*/
BOOL SwDBNextSetField::PutValue( const uno::Any& rAny, USHORT nWhichId )
2000-09-18 23:08:29 +00:00
{
BOOL bRet = TRUE;
switch( nWhichId )
2000-09-18 23:08:29 +00:00
{
case FIELD_PROP_PAR3:
::GetString( rAny, aCond );
break;
default:
bRet = SwDBNameInfField::PutValue( rAny, nWhichId );
2000-09-18 23:08:29 +00:00
}
return bRet;
2000-09-18 23:08:29 +00:00
}
/*--------------------------------------------------------------------
Beschreibung:
--------------------------------------------------------------------*/
/*
String SwDBNextSetField::GetPar2() const
{
return GetDBName();
}
void SwDBNextSetField::SetPar2(const String& rStr)
{
GetDBName() = rStr;
}
*/
/*--------------------------------------------------------------------
Beschreibung: Datensatz mit bestimmter ID
--------------------------------------------------------------------*/
SwDBNumSetFieldType::SwDBNumSetFieldType() :
SwFieldType( RES_DBNUMSETFLD )
{
}
//------------------------------------------------------------------------------
SwFieldType* SwDBNumSetFieldType::Copy() const
{
SwDBNumSetFieldType* pTmp = new SwDBNumSetFieldType();
return pTmp;
}
/*--------------------------------------------------------------------
Beschreibung: SwDBSetField
--------------------------------------------------------------------*/
SwDBNumSetField::SwDBNumSetField(SwDBNumSetFieldType* pTyp,
const String& rCond,
const String& rDBNum,
const SwDBData& rDBData) :
SwDBNameInfField(pTyp, rDBData),
2000-09-18 23:08:29 +00:00
aCond(rCond),
aPar2(rDBNum),
bCondValid(TRUE)
{}
//------------------------------------------------------------------------------
String SwDBNumSetField::Expand() const
{
return aEmptyStr;
}
//------------------------------------------------------------------------------
SwField* SwDBNumSetField::Copy() const
{
SwDBNumSetField *pTmp = new SwDBNumSetField((SwDBNumSetFieldType*)GetTyp(),
aCond, aPar2, GetDBData());
2000-09-18 23:08:29 +00:00
pTmp->bCondValid = bCondValid;
pTmp->SetSubType(GetSubType());
2000-09-18 23:08:29 +00:00
return pTmp;
}
void SwDBNumSetField::Evaluate(SwDoc* pDoc)
{
SwNewDBMgr* pMgr = pDoc->GetNewDBMgr();
const SwDBData& aTmpData = GetDBData();
2000-09-18 23:08:29 +00:00
if( bCondValid && pMgr && pMgr->IsInMerge() &&
pMgr->IsDataSourceOpen(aTmpData.sDataSource, aTmpData.sCommand, sal_True))
2000-09-18 23:08:29 +00:00
{ // Bedingug OK -> aktuellen Set einstellen
pMgr->ToRecordId(Max((USHORT)aPar2.ToInt32(), USHORT(1))-1);
}
}
/*--------------------------------------------------------------------
Beschreibung: LogDBName
--------------------------------------------------------------------*/
const String& SwDBNumSetField::GetPar1() const
{
return aCond;
}
void SwDBNumSetField::SetPar1(const String& rStr)
{
aCond = rStr;
}
/*--------------------------------------------------------------------
Beschreibung: Bedingung
--------------------------------------------------------------------*/
String SwDBNumSetField::GetPar2() const
{
return aPar2;
}
void SwDBNumSetField::SetPar2(const String& rStr)
{
aPar2 = rStr;
}
/*-----------------06.03.98 16:16-------------------
--------------------------------------------------*/
BOOL SwDBNumSetField::QueryValue( uno::Any& rAny, USHORT nWhichId ) const
2000-09-18 23:08:29 +00:00
{
BOOL bRet = TRUE;
switch( nWhichId )
{
case FIELD_PROP_PAR3:
2000-09-18 23:08:29 +00:00
rAny <<= OUString(aCond);
break;
case FIELD_PROP_FORMAT:
rAny <<= (sal_Int32)aPar2.ToInt32();
break;
default:
bRet = SwDBNameInfField::QueryValue(rAny, nWhichId );
}
return bRet;
2000-09-18 23:08:29 +00:00
}
/*-----------------06.03.98 16:16-------------------
--------------------------------------------------*/
BOOL SwDBNumSetField::PutValue( const uno::Any& rAny, USHORT nWhichId )
2000-09-18 23:08:29 +00:00
{
BOOL bRet = TRUE;
switch( nWhichId )
2000-09-18 23:08:29 +00:00
{
case FIELD_PROP_PAR3:
::GetString( rAny, aCond );
break;
case FIELD_PROP_FORMAT:
{
sal_Int32 nVal = 0;
rAny >>= nVal;
aPar2 = String::CreateFromInt32(nVal);
}
break;
default:
bRet = SwDBNameInfField::PutValue(rAny, nWhichId );
2000-09-18 23:08:29 +00:00
}
return bRet;
2000-09-18 23:08:29 +00:00
}
/*--------------------------------------------------------------------
Beschreibung: SwDBNameFieldType
--------------------------------------------------------------------*/
SwDBNameFieldType::SwDBNameFieldType(SwDoc* pDocument)
: SwFieldType( RES_DBNAMEFLD )
{
pDoc = pDocument;
}
//------------------------------------------------------------------------------
String SwDBNameFieldType::Expand(ULONG ) const
2000-09-18 23:08:29 +00:00
{
const SwDBData aData = pDoc->GetDBData();
String sRet(aData.sDataSource);
sRet += '.';
sRet += (String)aData.sCommand;
return sRet;
2000-09-18 23:08:29 +00:00
}
//------------------------------------------------------------------------------
SwFieldType* SwDBNameFieldType::Copy() const
{
SwDBNameFieldType *pTmp = new SwDBNameFieldType(pDoc);
return pTmp;
}
//------------------------------------------------------------------------------
/*--------------------------------------------------------------------
Beschreibung: Name der angedockten DB
--------------------------------------------------------------------*/
SwDBNameField::SwDBNameField(SwDBNameFieldType* pTyp, const SwDBData& rDBData, ULONG nFmt)
: SwDBNameInfField(pTyp, rDBData, nFmt)
2000-09-18 23:08:29 +00:00
{}
//------------------------------------------------------------------------------
String SwDBNameField::Expand() const
{
String sRet;
if(0 ==(GetSubType() & nsSwExtendedSubType::SUB_INVISIBLE))
sRet = ((SwDBNameFieldType*)GetTyp())->Expand(GetFormat());
return sRet;
2000-09-18 23:08:29 +00:00
}
//------------------------------------------------------------------------------
SwField* SwDBNameField::Copy() const
{
SwDBNameField *pTmp = new SwDBNameField((SwDBNameFieldType*)GetTyp(), GetDBData());
2000-09-18 23:08:29 +00:00
pTmp->ChangeFormat(GetFormat());
pTmp->SetLanguage(GetLanguage());
pTmp->SetSubType(GetSubType());
2000-09-18 23:08:29 +00:00
return pTmp;
}
/*-----------------06.03.98 16:16-------------------
--------------------------------------------------*/
BOOL SwDBNameField::QueryValue( uno::Any& rAny, USHORT nWhichId ) const
2000-09-18 23:08:29 +00:00
{
return SwDBNameInfField::QueryValue(rAny, nWhichId );
2000-09-18 23:08:29 +00:00
}
/*-----------------06.03.98 16:16-------------------
--------------------------------------------------*/
BOOL SwDBNameField::PutValue( const uno::Any& rAny, USHORT nWhichId )
2000-09-18 23:08:29 +00:00
{
return SwDBNameInfField::PutValue(rAny, nWhichId );
2000-09-18 23:08:29 +00:00
}
/*--------------------------------------------------------------------
Beschreibung: SwDBNameFieldType
--------------------------------------------------------------------*/
SwDBSetNumberFieldType::SwDBSetNumberFieldType()
: SwFieldType( RES_DBSETNUMBERFLD )
{
}
//------------------------------------------------------------------------------
SwFieldType* SwDBSetNumberFieldType::Copy() const
{
SwDBSetNumberFieldType *pTmp = new SwDBSetNumberFieldType;
return pTmp;
}
//------------------------------------------------------------------------------
/*--------------------------------------------------------------------
Beschreibung: SetNumber der angedockten DB
--------------------------------------------------------------------*/
SwDBSetNumberField::SwDBSetNumberField(SwDBSetNumberFieldType* pTyp,
const SwDBData& rDBData,
2000-09-18 23:08:29 +00:00
ULONG nFmt)
: SwDBNameInfField(pTyp, rDBData, nFmt), nNumber(0)
2000-09-18 23:08:29 +00:00
{}
//------------------------------------------------------------------------------
String SwDBSetNumberField::Expand() const
{
if(0 !=(GetSubType() & nsSwExtendedSubType::SUB_INVISIBLE) || nNumber == 0)
2000-09-18 23:08:29 +00:00
return aEmptyStr;
else
return FormatNumber((USHORT)nNumber, GetFormat());
//return(nNumber == 0 ? aEmptyStr : FormatNumber(nNumber, GetFormat()));
}
//------------------------------------------------------------------------------
void SwDBSetNumberField::Evaluate(SwDoc* pDoc)
{
SwNewDBMgr* pMgr = pDoc->GetNewDBMgr();
const SwDBData& aTmpData = GetDBData();
if (!pMgr || !pMgr->IsInMerge() ||
!pMgr->IsDataSourceOpen(aTmpData.sDataSource, aTmpData.sCommand, sal_False))
return;
nNumber = pMgr->GetSelectedRecordId();
2000-09-18 23:08:29 +00:00
}
//------------------------------------------------------------------------------
SwField* SwDBSetNumberField::Copy() const
{
SwDBSetNumberField *pTmp =
new SwDBSetNumberField((SwDBSetNumberFieldType*)GetTyp(), GetDBData(), GetFormat());
2000-09-18 23:08:29 +00:00
pTmp->SetLanguage(GetLanguage());
pTmp->SetSetNumber(nNumber);
pTmp->SetSubType(GetSubType());
2000-09-18 23:08:29 +00:00
return pTmp;
}
/*-----------------06.03.98 16:15-------------------
--------------------------------------------------*/
BOOL SwDBSetNumberField::QueryValue( uno::Any& rAny, USHORT nWhichId ) const
2000-09-18 23:08:29 +00:00
{
BOOL bRet = TRUE;
switch( nWhichId )
2000-09-18 23:08:29 +00:00
{
case FIELD_PROP_USHORT1:
2000-09-18 23:08:29 +00:00
rAny <<= (sal_Int16)GetFormat();
break;
case FIELD_PROP_FORMAT:
2000-09-18 23:08:29 +00:00
rAny <<= nNumber;
break;
default:
bRet = SwDBNameInfField::QueryValue( rAny, nWhichId );
}
return bRet;
2000-09-18 23:08:29 +00:00
}
/*-----------------06.03.98 16:15-------------------
--------------------------------------------------*/
BOOL SwDBSetNumberField::PutValue( const uno::Any& rAny, USHORT nWhichId )
2000-09-18 23:08:29 +00:00
{
BOOL bRet = TRUE;
switch( nWhichId )
2000-09-18 23:08:29 +00:00
{
case FIELD_PROP_USHORT1:
{
sal_Int16 nSet = 0;
rAny >>= nSet;
if(nSet < (INT16) SVX_NUMBER_NONE )
SetFormat(nSet);
else {
//exception(wrong_value)
;
}
}
break;
case FIELD_PROP_FORMAT:
2000-09-18 23:08:29 +00:00
rAny >>= nNumber;
break;
default:
bRet = SwDBNameInfField::PutValue( rAny, nWhichId );
}
return bRet;
2000-09-18 23:08:29 +00:00
}