1113 lines
32 KiB
C++
1113 lines
32 KiB
C++
/*************************************************************************
|
|
*
|
|
* $RCSfile: dbfld.cxx,v $
|
|
*
|
|
* $Revision: 1.1.1.1 $
|
|
*
|
|
* last change: $Author: hr $ $Date: 2000-09-19 00:08:19 $
|
|
*
|
|
* The Contents of this file are made available subject to the terms of
|
|
* either of the following licenses
|
|
*
|
|
* - GNU Lesser General Public License Version 2.1
|
|
* - Sun Industry Standards Source License Version 1.1
|
|
*
|
|
* Sun Microsystems Inc., October, 2000
|
|
*
|
|
* GNU Lesser General Public License Version 2.1
|
|
* =============================================
|
|
* Copyright 2000 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
|
|
*
|
|
*
|
|
* Sun Industry Standards Source License Version 1.1
|
|
* =================================================
|
|
* The contents of this file are subject to the Sun Industry Standards
|
|
* Source License Version 1.1 (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.openoffice.org/license.html.
|
|
*
|
|
* Software provided under this License is provided on an "AS IS" basis,
|
|
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
|
|
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
|
|
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
|
|
* See the License for the specific provisions governing your rights and
|
|
* obligations concerning the Software.
|
|
*
|
|
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
|
|
*
|
|
* Copyright: 2000 by Sun Microsystems, Inc.
|
|
*
|
|
* All Rights Reserved.
|
|
*
|
|
* Contributor(s): _______________________________________
|
|
*
|
|
*
|
|
************************************************************************/
|
|
|
|
#ifdef PRECOMPILED
|
|
#include "core_pch.hxx"
|
|
#endif
|
|
|
|
#pragma hdrstop
|
|
|
|
#include <float.h>
|
|
|
|
#ifndef _SFXAPP_HXX //autogen
|
|
#include <sfx2/app.hxx>
|
|
#endif
|
|
#ifndef _ZFORLIST_HXX //autogen
|
|
#include <svtools/zforlist.hxx>
|
|
#endif
|
|
#ifndef _UNOPRNMS_HXX
|
|
#include <unoprnms.hxx>
|
|
#endif
|
|
#ifndef _SVX_PAGEITEM_HXX //autogen
|
|
#include <svx/pageitem.hxx>
|
|
#endif
|
|
#ifndef _FMTFLD_HXX
|
|
#include <fmtfld.hxx>
|
|
#endif
|
|
#ifndef _TXTFLD_HXX
|
|
#include <txtfld.hxx>
|
|
#endif
|
|
|
|
#include "doc.hxx"
|
|
#include "docary.hxx"
|
|
#include "frame.hxx"
|
|
#include "fldbas.hxx"
|
|
#include "pam.hxx"
|
|
#include "ndtxt.hxx"
|
|
#include "dbfld.hxx"
|
|
#include "dbmgr.hxx"
|
|
#include "docfld.hxx"
|
|
#include "expfld.hxx"
|
|
#include "txtatr.hxx"
|
|
|
|
#ifdef REPLACE_OFADBMGR
|
|
#ifndef _COM_SUN_STAR_SDBC_DATATYPE_HPP_
|
|
#include <com/sun/star/sdbc/DataType.hpp>
|
|
#endif
|
|
|
|
using namespace ::com::sun::star::sdbc;
|
|
#endif
|
|
|
|
using namespace ::com::sun::star;
|
|
using namespace ::rtl;
|
|
|
|
/*--------------------------------------------------------------------
|
|
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 String& rDBNam ) :
|
|
SwValueFieldType( pDocPtr, RES_DBFLD ),
|
|
nRefCnt(0),
|
|
aName(rNam)
|
|
{
|
|
if (rDBNam.Len())
|
|
{
|
|
String sNewName(rDBNam);// Datenbankname muss nicht unbedingt in rNam enthalten sein!
|
|
if (rDBNam.Len())
|
|
sNewName += DB_DELIM;
|
|
sNewName += GetColumnName();
|
|
aName = sNewName;
|
|
}
|
|
else // Entweder kein Datenbankname, oder er ist in rNam bereits enthalten
|
|
aName = rNam;
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
SwFieldType* SwDBFieldType::Copy() const
|
|
{
|
|
SwDBFieldType* pTmp = new SwDBFieldType(GetDoc(), aName, aEmptyStr);
|
|
return pTmp;
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
const String& SwDBFieldType::GetName() const
|
|
{
|
|
return aName;
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
String SwDBFieldType::GetColumnName()
|
|
{
|
|
USHORT nPos = aName.Len();
|
|
|
|
// Letztes Token zuruekliefern
|
|
while( nPos )
|
|
if( DB_DELIM == (BYTE)aName.GetChar( --nPos ) )
|
|
{
|
|
++nPos;
|
|
break;
|
|
}
|
|
|
|
return aName.Copy( nPos );
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
String SwDBFieldType::GetDBName()
|
|
{
|
|
USHORT nPos;
|
|
|
|
if ((nPos = aName.Search(DB_DELIM)) != STRING_NOTFOUND)
|
|
{
|
|
if ((nPos = aName.Search(DB_DELIM, nPos + 1)) != STRING_NOTFOUND)
|
|
return aName.Copy(0, nPos);
|
|
}
|
|
return aEmptyStr;
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
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( com::sun::star::uno::Any& rAny, const String& rProperty ) const
|
|
{
|
|
USHORT nToken = USHRT_MAX;
|
|
if(rProperty.EqualsAscii(UNO_NAME_DATA_BASE_NAME ))
|
|
nToken = 0;
|
|
else if(rProperty.EqualsAscii(UNO_NAME_DATA_TABLE_NAME))
|
|
nToken = 1;
|
|
else if(rProperty.EqualsAscii(UNO_NAME_DATA_COLUMN_NAME))
|
|
nToken = 2;
|
|
if(nToken != USHRT_MAX)
|
|
{
|
|
String sRet = aName.GetToken(nToken, DB_DELIM);
|
|
rAny <<= OUString(sRet);
|
|
}
|
|
return nToken != USHRT_MAX;
|
|
}
|
|
|
|
BOOL SwDBFieldType::PutValue( const com::sun::star::uno::Any& rAny, const String& rProperty )
|
|
{
|
|
USHORT nToken = USHRT_MAX;
|
|
BOOL bReInitClients = FALSE;
|
|
if(rProperty.EqualsAscii(UNO_NAME_DATA_BASE_NAME ))
|
|
nToken = 0;
|
|
else if(rProperty.EqualsAscii(UNO_NAME_DATA_TABLE_NAME))
|
|
nToken = 1;
|
|
else if(rProperty.EqualsAscii(UNO_NAME_DATA_COLUMN_NAME))
|
|
{
|
|
nToken = 2;
|
|
bReInitClients = TRUE;
|
|
}
|
|
if(nToken != USHRT_MAX)
|
|
{
|
|
const String sOld = aName.GetToken(nToken, DB_DELIM);
|
|
|
|
OUString sSet;
|
|
rAny >>= sSet;
|
|
aName.SetToken(nToken, DB_DELIM, sSet);
|
|
if(bReInitClients && !sOld.Equals(String(sSet)))
|
|
{
|
|
SwClientIter aIter( *this );
|
|
SwFmtFld* pFld = (SwFmtFld*)aIter.First( TYPE( SwFmtFld ));
|
|
while(pFld)
|
|
{
|
|
// 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();
|
|
}
|
|
}
|
|
}
|
|
return nToken != USHRT_MAX;
|
|
}
|
|
/*--------------------------------------------------------------------
|
|
Beschreibung: SwDBField
|
|
--------------------------------------------------------------------*/
|
|
|
|
SwDBField::SwDBField(SwDBFieldType* pTyp, ULONG nFmt)
|
|
: SwValueField(pTyp, nFmt),
|
|
bValidValue(FALSE),
|
|
bIsInBodyTxt(TRUE),
|
|
bInitialized(FALSE),
|
|
nSubType(0)
|
|
{
|
|
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));
|
|
const International rInt = Application::GetAppInternational();
|
|
if( rInt.CompareEqual( sColumn,
|
|
((SwDBFieldType *)GetTyp())->GetColumnName(),
|
|
INTN_COMPARE_IGNORECASE))
|
|
{
|
|
InitContent();
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
SetExpansion( rExpansion );
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
String SwDBField::GetOldContent()
|
|
{
|
|
String sOldExpand = Expand();
|
|
String sNewExpand = sOldExpand;
|
|
BOOL bOldInit = bInitialized;
|
|
|
|
bInitialized = FALSE;
|
|
InitContent();
|
|
bInitialized = bOldInit;
|
|
|
|
const International rInt = Application::GetAppInternational();
|
|
|
|
if( rInt.CompareEqual( sNewExpand, Expand(), INTN_COMPARE_IGNORECASE))
|
|
{
|
|
sNewExpand = '<';
|
|
sNewExpand += ((SwDBFieldType *)GetTyp())->GetColumnName();
|
|
sNewExpand += '>';
|
|
}
|
|
SetExpansion( sOldExpand );
|
|
|
|
return sNewExpand;
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
String SwDBField::Expand() const
|
|
{
|
|
return lcl_DBTrennConv(aContent);
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
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());
|
|
|
|
return pTmp;
|
|
}
|
|
|
|
String SwDBField::GetCntnt(BOOL bName) const
|
|
{
|
|
if(bName)
|
|
{
|
|
const String& rDBName = ((SwDBFieldType*)GetTyp())->GetName();
|
|
String sContent( SFX_APP()->LocalizeDBName(INI2NATIONAL,
|
|
rDBName.GetToken(0, DB_DELIM)));
|
|
|
|
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;
|
|
String sTmpName(GetDBName());
|
|
|
|
#ifdef REPLACE_OFADBMGR
|
|
String sDataSource(sTmpName.GetToken(0, DB_DELIM));
|
|
String sDataTableOrQuery(sTmpName.GetToken(1, DB_DELIM));
|
|
if(!pMgr || !pMgr->IsDataSourceOpen(sDataSource, sDataTableOrQuery))
|
|
return ;
|
|
#else
|
|
if(!pMgr || !pMgr->IsDBOpen(DBMGR_STD, sTmpName) || !pMgr->IsInMerge())
|
|
{
|
|
return;
|
|
}
|
|
#endif
|
|
|
|
ULONG nFmt;
|
|
|
|
// Passenden Spaltennamen suchen
|
|
String aColNm( ((SwDBFieldType*)GetTyp())->GetColumnName() );
|
|
|
|
SvNumberFormatter* pDocFormatter = GetDoc()->GetNumberFormatter();
|
|
#ifdef REPLACE_OFADBMGR
|
|
pMgr->GetMergeColumnCnt(aColNm, GetLanguage(), aContent, &nValue, &nFmt);
|
|
if( !( nSubType & SUB_OWN_FMT ) )
|
|
SetFormat( nFmt = pMgr->GetColumnFmt( sDataSource, sDataTableOrQuery,
|
|
aContent, pDocFormatter, GetLanguage() ));
|
|
#else
|
|
pMgr->GetColumnCnt( DBMGR_STD, aColNm,
|
|
pMgr->GetCurRecordId( DBMGR_STD ), aContent,
|
|
&nValue, &nFmt );
|
|
if( !( nSubType & SUB_OWN_FMT ) )
|
|
SetFormat( nFmt = pMgr->GetRealColumnFmt( aColNm, nFmt,
|
|
*pDocFormatter ) );
|
|
#endif
|
|
|
|
if( DBL_MAX != nValue )
|
|
{
|
|
#ifdef REPLACE_OFADBMGR
|
|
sal_Int32 nColumnType = pMgr->GetColumnType(sDataSource, sDataTableOrQuery, aContent);
|
|
if( DataType::DATE == nColumnType || DataType::TIME == nColumnType ||
|
|
DataType::TIMESTAMP )
|
|
|
|
#else
|
|
int nColumnPos = pMgr->GetColumnPos(FALSE, aColNm);
|
|
String sColumnType = pMgr->GetColumnType(FALSE, nColumnPos, FALSE);
|
|
if(sColumnType.EqualsAscii("DATE/TIME") || sColumnType.EqualsAscii("DATE"))
|
|
#endif
|
|
{
|
|
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 != ULONG_MAX && !pFormatter->IsTextFormat(nFmt))
|
|
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( com::sun::star::uno::Any& rAny, const String& rProperty ) const
|
|
{
|
|
if(rProperty.EqualsAscii(UNO_NAME_IS_DATA_BASE_FORMAT))
|
|
{
|
|
BOOL bTemp = 0 == (GetSubType()&SUB_OWN_FMT);
|
|
rAny.setValue(&bTemp, ::getBooleanCppuType());
|
|
}
|
|
else if(rProperty.EqualsAscii(UNO_NAME_NUMBER_FORMAT))
|
|
rAny <<= (sal_Int32)GetFormat();
|
|
else if(rProperty.EqualsAscii(UNO_NAME_CONTENT)||
|
|
rProperty.EqualsAscii(UNO_NAME_CURRENT_PRESENTATION))
|
|
rAny <<= OUString(aContent);
|
|
#ifdef DBG_UTIL
|
|
else
|
|
DBG_ERROR("Was war das fuer ein Typ?")
|
|
#endif
|
|
return TRUE;
|
|
|
|
}
|
|
/*-----------------06.03.98 16:15-------------------
|
|
|
|
--------------------------------------------------*/
|
|
BOOL SwDBField::PutValue( const com::sun::star::uno::Any& rAny, const String& rProperty )
|
|
{
|
|
if(rProperty.EqualsAscii(UNO_NAME_IS_DATA_BASE_FORMAT))
|
|
{
|
|
sal_Bool bTemp = *(sal_Bool*)rAny.getValue();
|
|
if(bTemp)
|
|
SetSubType(GetSubType()&~SUB_OWN_FMT);
|
|
else
|
|
SetSubType(GetSubType()|SUB_OWN_FMT);
|
|
}
|
|
else if(rProperty.EqualsAscii(UNO_NAME_NUMBER_FORMAT))
|
|
{
|
|
sal_Int32 nTemp;
|
|
rAny >>= nTemp;
|
|
SetFormat(nTemp);
|
|
}
|
|
else if( rProperty.EqualsAscii( UNO_NAME_CONTENT )||
|
|
rProperty.EqualsAscii(UNO_NAME_CURRENT_PRESENTATION))
|
|
{
|
|
OUString uTmp;
|
|
rAny >>= uTmp;
|
|
aContent = uTmp;
|
|
}
|
|
#ifdef DBG_UTIL
|
|
else
|
|
DBG_ERROR("Was war das fuer ein Typ?")
|
|
#endif
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
/*--------------------------------------------------------------------
|
|
Beschreibung: Basisklasse fuer alle weiteren Datenbankfelder
|
|
--------------------------------------------------------------------*/
|
|
|
|
SwDBNameInfField::SwDBNameInfField(SwFieldType* pTyp, const String& rDBName, ULONG nFmt) :
|
|
SwField(pTyp, nFmt),
|
|
sDBName(rDBName)
|
|
{
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
String SwDBNameInfField::GetDBName(SwDoc* pDoc)
|
|
{
|
|
String sTmp;
|
|
if (sDBName.Len())
|
|
sTmp=sDBName;
|
|
else
|
|
sTmp=pDoc->GetDBName();
|
|
return (sTmp);
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
String SwDBNameInfField::GetCntnt(BOOL bName) const
|
|
{
|
|
String sStr(SwField::GetCntnt(bName));
|
|
|
|
if(bName)
|
|
{
|
|
if (sDBName.Len())
|
|
{
|
|
sStr += ':';
|
|
sStr += SFX_APP()->LocalizeDBName(INI2NATIONAL, sDBName.GetToken(0, DB_DELIM));
|
|
sStr += DB_DELIM;
|
|
sStr += sDBName.GetToken(1, DB_DELIM);
|
|
}
|
|
}
|
|
return lcl_DBTrennConv(sStr);
|
|
}
|
|
|
|
/*-----------------06.03.98 16:55-------------------
|
|
|
|
--------------------------------------------------*/
|
|
BOOL SwDBNameInfField::QueryValue( com::sun::star::uno::Any& rAny, const String& rProperty ) const
|
|
{
|
|
if(rProperty.EqualsAscii(UNO_NAME_DATA_BASE_NAME))
|
|
{
|
|
rAny <<= OUString(sDBName.GetToken(0, DB_DELIM));
|
|
}
|
|
else if(rProperty.EqualsAscii(UNO_NAME_DATA_TABLE_NAME))
|
|
{
|
|
rAny <<= OUString(sDBName.GetToken(1, DB_DELIM));
|
|
}
|
|
else
|
|
{
|
|
DBG_ERROR("was war das fuer ein Typ?")
|
|
return FALSE;
|
|
}
|
|
return TRUE;
|
|
}
|
|
/*-----------------06.03.98 16:55-------------------
|
|
|
|
--------------------------------------------------*/
|
|
BOOL SwDBNameInfField::PutValue( const com::sun::star::uno::Any& rAny, const String& rProperty )
|
|
{
|
|
OUString uTemp;
|
|
if(rProperty.EqualsAscii(UNO_NAME_DATA_BASE_NAME))
|
|
{
|
|
rAny >>= uTemp;
|
|
sDBName.SetToken(0, DB_DELIM, uTemp);
|
|
}
|
|
else if(rProperty.EqualsAscii(UNO_NAME_DATA_TABLE_NAME))
|
|
{
|
|
rAny >>= uTemp;
|
|
sDBName.SetToken(1, DB_DELIM, uTemp);
|
|
}
|
|
else
|
|
return FALSE;
|
|
return TRUE;
|
|
}
|
|
|
|
/*--------------------------------------------------------------------
|
|
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& rDummy,
|
|
const String& rDBName) :
|
|
SwDBNameInfField(pTyp, rDBName), aCond(rCond), bCondValid(TRUE)
|
|
{}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
String SwDBNextSetField::Expand() const
|
|
{
|
|
return aEmptyStr;
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
SwField* SwDBNextSetField::Copy() const
|
|
{
|
|
SwDBNextSetField *pTmp = new SwDBNextSetField((SwDBNextSetFieldType*)GetTyp(),
|
|
aCond, aEmptyStr, GetDBName());
|
|
pTmp->bCondValid = bCondValid;
|
|
return pTmp;
|
|
}
|
|
//------------------------------------------------------------------------------
|
|
|
|
void SwDBNextSetField::Evaluate(SwDoc* pDoc)
|
|
{
|
|
#ifdef REPLACE_OFADBMGR
|
|
SwNewDBMgr* pMgr = pDoc->GetNewDBMgr();
|
|
String sTmpName(GetDBName());
|
|
String sDataSource(sTmpName.GetToken(0, DB_DELIM));
|
|
String sDataTableOrQuery(sTmpName.GetToken(1, DB_DELIM));
|
|
if( !bCondValid ||
|
|
!pMgr || !pMgr->IsDataSourceOpen(sDataSource, sDataTableOrQuery))
|
|
return ;
|
|
pMgr->ToNextMergeRecord();
|
|
#else
|
|
if( bCondValid && pDoc->GetNewDBMgr() &&
|
|
pDoc->GetNewDBMgr()->IsDBOpen(DBMGR_STD, GetDBName()) )
|
|
{
|
|
// Bedingung OK -> naechste selektierter Record ist der aktuelle
|
|
pDoc->GetNewDBMgr()->ToNextSelectedRecord(DBMGR_STD);
|
|
}
|
|
#endif
|
|
}
|
|
|
|
/*--------------------------------------------------------------------
|
|
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, const String& rProperty ) const
|
|
{
|
|
if(rProperty.EqualsAscii(UNO_NAME_CONDITION))
|
|
rAny <<= OUString(aCond);
|
|
else
|
|
return SwDBNameInfField::QueryValue(rAny, rProperty);
|
|
return TRUE;
|
|
}
|
|
/*-----------------06.03.98 16:16-------------------
|
|
|
|
--------------------------------------------------*/
|
|
BOOL SwDBNextSetField::PutValue( const com::sun::star::uno::Any& rAny, const String& rProperty )
|
|
{
|
|
if(rProperty.EqualsAscii(UNO_NAME_CONDITION))
|
|
{
|
|
OUString uTemp;
|
|
rAny >>= uTemp;
|
|
aCond = String(uTemp);
|
|
}
|
|
else
|
|
return SwDBNameInfField::PutValue(rAny, rProperty);
|
|
return TRUE;
|
|
}
|
|
|
|
/*--------------------------------------------------------------------
|
|
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 String& rDBName) :
|
|
SwDBNameInfField(pTyp, rDBName),
|
|
aCond(rCond),
|
|
aPar2(rDBNum),
|
|
bCondValid(TRUE)
|
|
{}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
String SwDBNumSetField::Expand() const
|
|
{
|
|
return aEmptyStr;
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
SwField* SwDBNumSetField::Copy() const
|
|
{
|
|
SwDBNumSetField *pTmp = new SwDBNumSetField((SwDBNumSetFieldType*)GetTyp(),
|
|
aCond, aPar2, GetDBName());
|
|
pTmp->bCondValid = bCondValid;
|
|
return pTmp;
|
|
}
|
|
|
|
void SwDBNumSetField::Evaluate(SwDoc* pDoc)
|
|
{
|
|
SwNewDBMgr* pMgr = pDoc->GetNewDBMgr();
|
|
#ifdef REPLACE_OFADBMGR
|
|
String sTmpName(GetDBName());
|
|
String sDataSource(sTmpName.GetToken(0, DB_DELIM));
|
|
String sDataTableOrQuery(sTmpName.GetToken(1, DB_DELIM));
|
|
if( bCondValid && pMgr && pMgr->IsInMerge() &&
|
|
pMgr->IsDataSourceOpen(sDataSource, sDataTableOrQuery))
|
|
{ // Bedingug OK -> aktuellen Set einstellen
|
|
pMgr->ToRecordId(Max((USHORT)aPar2.ToInt32(), USHORT(1))-1);
|
|
}
|
|
#else
|
|
if( bCondValid && pMgr && pMgr->IsDBOpen(DBMGR_STD, GetDBName())
|
|
&& pMgr->IsInMerge() )
|
|
{ // Bedingug OK -> aktuellen Set einstellen
|
|
pMgr->ToSelectedRecord(DBMGR_STD, Max((USHORT)aPar2.ToInt32(), USHORT(1))-1);
|
|
}
|
|
#endif
|
|
}
|
|
|
|
/*--------------------------------------------------------------------
|
|
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( com::sun::star::uno::Any& rAny, const String& rProperty ) const
|
|
{
|
|
if(rProperty.EqualsAscii(UNO_NAME_SET_NUMBER))
|
|
rAny <<= (sal_Int32)aPar2.ToInt32();
|
|
else if(rProperty.EqualsAscii(UNO_NAME_CONDITION))
|
|
rAny <<= OUString(aCond);
|
|
else
|
|
return SwDBNameInfField::QueryValue(rAny, rProperty);
|
|
return TRUE;
|
|
}
|
|
/*-----------------06.03.98 16:16-------------------
|
|
|
|
--------------------------------------------------*/
|
|
BOOL SwDBNumSetField::PutValue( const com::sun::star::uno::Any& rAny, const String& rProperty )
|
|
{
|
|
if(rProperty.EqualsAscii(UNO_NAME_SET_NUMBER))
|
|
{
|
|
sal_Int32 nVal;
|
|
rAny >>= nVal;
|
|
aPar2 = String::CreateFromInt32(nVal);
|
|
}
|
|
else if(rProperty.EqualsAscii(UNO_NAME_CONDITION))
|
|
{
|
|
OUString uTemp;
|
|
rAny >>= uTemp;
|
|
aCond = String(uTemp);
|
|
}
|
|
else
|
|
return SwDBNameInfField::PutValue(rAny, rProperty);
|
|
return TRUE;
|
|
}
|
|
|
|
/*--------------------------------------------------------------------
|
|
Beschreibung: SwDBNameFieldType
|
|
--------------------------------------------------------------------*/
|
|
|
|
SwDBNameFieldType::SwDBNameFieldType(SwDoc* pDocument)
|
|
: SwFieldType( RES_DBNAMEFLD )
|
|
{
|
|
pDoc = pDocument;
|
|
}
|
|
//------------------------------------------------------------------------------
|
|
|
|
String SwDBNameFieldType::Expand(ULONG nFmt) const
|
|
{
|
|
ASSERT( nFmt >= FF_BEGIN && nFmt < FF_END, "Expand: kein guelt. Fmt!" );
|
|
|
|
return(pDoc->GetDBName());
|
|
}
|
|
//------------------------------------------------------------------------------
|
|
|
|
SwFieldType* SwDBNameFieldType::Copy() const
|
|
{
|
|
SwDBNameFieldType *pTmp = new SwDBNameFieldType(pDoc);
|
|
return pTmp;
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
/*--------------------------------------------------------------------
|
|
Beschreibung: Name der angedockten DB
|
|
--------------------------------------------------------------------*/
|
|
|
|
SwDBNameField::SwDBNameField(SwDBNameFieldType* pTyp, const String& rDBName, ULONG nFmt)
|
|
: SwDBNameInfField(pTyp, rDBName, nFmt)
|
|
{}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
String SwDBNameField::Expand() const
|
|
{
|
|
return((SwDBNameFieldType*)GetTyp())->Expand(GetFormat());
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
SwField* SwDBNameField::Copy() const
|
|
{
|
|
SwDBNameField *pTmp = new SwDBNameField((SwDBNameFieldType*)GetTyp(), GetDBName());
|
|
pTmp->ChangeFormat(GetFormat());
|
|
pTmp->SetLanguage(GetLanguage());
|
|
return pTmp;
|
|
}
|
|
|
|
/*-----------------06.03.98 16:16-------------------
|
|
|
|
--------------------------------------------------*/
|
|
BOOL SwDBNameField::QueryValue( com::sun::star::uno::Any& rAny, const String& rProperty ) const
|
|
{
|
|
return SwDBNameInfField::QueryValue(rAny, rProperty);
|
|
}
|
|
/*-----------------06.03.98 16:16-------------------
|
|
|
|
--------------------------------------------------*/
|
|
BOOL SwDBNameField::PutValue( const com::sun::star::uno::Any& rAny, const String& rProperty )
|
|
{
|
|
return SwDBNameInfField::PutValue(rAny, rProperty);
|
|
}
|
|
/*--------------------------------------------------------------------
|
|
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 String& rDBName,
|
|
ULONG nFmt)
|
|
: SwDBNameInfField(pTyp, rDBName, nFmt), nNumber(0)
|
|
{}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
String SwDBSetNumberField::Expand() const
|
|
{
|
|
if (nNumber == 0)
|
|
return aEmptyStr;
|
|
else
|
|
return FormatNumber((USHORT)nNumber, GetFormat());
|
|
//return(nNumber == 0 ? aEmptyStr : FormatNumber(nNumber, GetFormat()));
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
void SwDBSetNumberField::Evaluate(SwDoc* pDoc)
|
|
{
|
|
SwNewDBMgr* pMgr = pDoc->GetNewDBMgr();
|
|
|
|
if (!pMgr->IsInMerge())
|
|
return;
|
|
|
|
#ifdef REPLACE_OFADBMGR
|
|
String sTmpName(GetDBName());
|
|
String sDataSource(sTmpName.GetToken(0, DB_DELIM));
|
|
String sDataTableOrQuery(sTmpName.GetToken(1, DB_DELIM));
|
|
if(!pMgr || !pMgr->IsDataSourceOpen(sDataSource, sDataTableOrQuery))
|
|
{
|
|
nNumber = 0;
|
|
return ;
|
|
}
|
|
nNumber = pMgr->GetSelectedRecordId() + 1;
|
|
#else
|
|
if(!(pMgr && pMgr->IsDBOpen(DBMGR_STD, GetDBName())))
|
|
{
|
|
nNumber = 0;
|
|
return;
|
|
}
|
|
nNumber = pMgr->GetCurSelectedRecordId(DBMGR_STD) + 1;
|
|
#endif
|
|
}
|
|
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
SwField* SwDBSetNumberField::Copy() const
|
|
{
|
|
SwDBSetNumberField *pTmp =
|
|
new SwDBSetNumberField((SwDBSetNumberFieldType*)GetTyp(), GetDBName(), GetFormat());
|
|
pTmp->SetLanguage(GetLanguage());
|
|
pTmp->SetSetNumber(nNumber);
|
|
return pTmp;
|
|
}
|
|
/*-----------------06.03.98 16:15-------------------
|
|
|
|
--------------------------------------------------*/
|
|
BOOL SwDBSetNumberField::QueryValue( com::sun::star::uno::Any& rAny, const String& rProperty ) const
|
|
{
|
|
if(rProperty.EqualsAscii(UNO_NAME_NUMBERING_TYPE))
|
|
{
|
|
rAny <<= (sal_Int16)GetFormat();
|
|
}
|
|
else if(rProperty.EqualsAscii(UNO_NAME_SET_NUMBER))
|
|
rAny <<= nNumber;
|
|
else
|
|
return SwDBNameInfField::QueryValue(rAny, rProperty);
|
|
return TRUE;
|
|
}
|
|
/*-----------------06.03.98 16:15-------------------
|
|
|
|
--------------------------------------------------*/
|
|
BOOL SwDBSetNumberField::PutValue( const com::sun::star::uno::Any& rAny, const String& rProperty )
|
|
{
|
|
if(rProperty.EqualsAscii(UNO_NAME_NUMBERING_TYPE))
|
|
{
|
|
sal_Int16 nSet;
|
|
rAny >>= nSet;
|
|
if(nSet < (INT16) SVX_NUMBER_NONE )
|
|
SetFormat(nSet);
|
|
else
|
|
//exception(wrong_value)
|
|
;
|
|
}
|
|
if(rProperty.EqualsAscii(UNO_NAME_SET_NUMBER))
|
|
rAny >>= nNumber;
|
|
else
|
|
return SwDBNameInfField::PutValue(rAny, rProperty);
|
|
return TRUE;
|
|
}
|
|
|
|
|