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

281 lines
7.4 KiB
C++
Raw Normal View History

2000-09-18 23:08:29 +00:00
/*************************************************************************
*
* $RCSfile: tblcalc.cxx,v $
*
2001-06-13 10:09:20 +00:00
* $Revision: 1.2 $
2000-09-18 23:08:29 +00:00
*
2001-06-13 10:09:20 +00:00
* last change: $Author: jp $ $Date: 2001-06-13 11:09:20 $
2000-09-18 23:08:29 +00:00
*
* 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 "cntfrm.hxx"
#include "doc.hxx"
#include "pam.hxx" // fuer GetBodyTxtNode
#include "ndtxt.hxx"
#ifndef _UNOPRNMS_HXX
#include <unoprnms.hxx>
#endif
#ifndef _FMTFLD_HXX //autogen
#include <fmtfld.hxx>
#endif
#ifndef _TXTFLD_HXX //autogen
#include <txtfld.hxx>
#endif
#include "expfld.hxx"
#include "hints.hxx" // fuer Modify()
#include "docfld.hxx" // fuer _SetGetExpFld
using namespace ::com::sun::star;
using namespace ::rtl;
SwTblFieldType::SwTblFieldType(SwDoc* pDocPtr)
: SwValueFieldType( pDocPtr, RES_TABLEFLD )
{}
SwFieldType* SwTblFieldType::Copy() const
{
return new SwTblFieldType(GetDoc());
}
void SwTblField::CalcField( SwTblCalcPara& rCalcPara )
{
if( rCalcPara.rCalc.IsCalcError() ) // ist schon Fehler gesetzt ?
return;
// erzeuge aus den BoxNamen die Pointer
BoxNmToPtr( rCalcPara.pTbl );
String sFml( MakeFormel( rCalcPara ));
SetValue( rCalcPara.rCalc.Calculate( sFml ).GetDouble() );
ChgValid( !rCalcPara.IsStackOverFlow() ); // ist der Wert wieder gueltig?
}
SwTblField::SwTblField( SwTblFieldType* pType, const String& rFormel,
USHORT nType, ULONG nFmt )
: SwValueField( pType, nFmt ), SwTableFormula( rFormel ),
nSubType(nType), sExpand( '0' )
{
}
SwField* SwTblField::Copy() const
{
SwTblField* pTmp = new SwTblField( (SwTblFieldType*)GetTyp(),
SwTableFormula::GetFormula(), nSubType, GetFormat() );
pTmp->sExpand = sExpand;
pTmp->SwValueField::SetValue(GetValue());
pTmp->SwTableFormula::operator=( *this );
return pTmp;
}
String SwTblField::GetCntnt(BOOL bName) const
{
if( bName )
{
// suche die richtige Tabelle
String sFml;
const SwNode* pNode;
if( IsIntrnlName() && GetTyp()->GetDepends() &&
0 != ( pNode = GetNodeOfFormula() ))
{
const SwTableNode* pTblNd = pNode->FindTableNode();
((SwTblField*)this)->PtrToBoxNm( &pTblNd->GetTable() );
sFml = GetPar2();
}
else
sFml = GetPar2();
String aStr(GetTyp()->GetName());
aStr += ' ';
aStr += sFml;
return aStr;
}
return Expand();
}
// suche den TextNode, in dem das Feld steht
const SwNode* SwTblField::GetNodeOfFormula() const
{
if( !GetTyp()->GetDepends() )
return 0;
SwClientIter aIter( *GetTyp() );
SwClient * pLast = aIter.GoStart();
if( pLast ) // konnte zum Anfang gesprungen werden ??
do {
const SwFmtFld* pFmtFld = (SwFmtFld*)pLast;
if( this == pFmtFld->GetFld() )
return (SwTxtNode*)&pFmtFld->GetTxtFld()->GetTxtNode();
} while( 0 != ( pLast = aIter++ ));
return 0;
}
String SwTblField::Expand() const
{
String aStr;
if (nSubType & SUB_CMD)
{
if( EXTRNL_NAME != GetNameType() )
{
const SwNode* pNd = GetNodeOfFormula();
const SwTableNode* pTblNd = pNd ? pNd->FindTableNode() : 0;
if( pTblNd )
((SwTblField*)this)->PtrToBoxNm( &pTblNd->GetTable() );
}
if( EXTRNL_NAME == GetNameType() )
aStr = SwTableFormula::GetFormula();
}
else
{
aStr = sExpand;
if(nSubType & GSE_STRING)
{
// es ist ein String
aStr = sExpand;
aStr.Erase( 0,1 );
aStr.Erase( aStr.Len()-1, 1 );
}
}
return aStr;
}
USHORT SwTblField::GetSubType() const
{
return nSubType;
}
void SwTblField::SetSubType(USHORT nType)
{
nSubType = nType;
}
void SwTblField::SetValue( const double& rVal )
{
SwValueField::SetValue(rVal);
sExpand = ((SwValueFieldType*)GetTyp())->ExpandValue(rVal, GetFormat(), GetLanguage());
}
/*--------------------------------------------------------------------
Beschreibung: Parameter setzen
--------------------------------------------------------------------*/
String SwTblField::GetPar2() const
{
return SwTableFormula::GetFormula();
}
void SwTblField::SetPar2(const String& rStr)
{
SetFormula( rStr );
}
/*-----------------04.03.98 10:33-------------------
--------------------------------------------------*/
BOOL SwTblField::QueryValue( uno::Any& rAny, const String& rProperty ) const
{
BOOL bRet = TRUE;
2001-06-13 10:09:20 +00:00
if(rProperty.EqualsAscii(SW_PRPNM_EQLASCI(UNO_NAME_FORMULA)))
2000-09-18 23:08:29 +00:00
{
rAny <<= rtl::OUString(SwTableFormula::GetFormula());
}
else
bRet = FALSE;
return bRet;
}
/*-----------------04.03.98 10:33-------------------
--------------------------------------------------*/
BOOL SwTblField::PutValue( const uno::Any& rAny, const String& rProperty )
{
BOOL bRet = TRUE;
2001-06-13 10:09:20 +00:00
if(rProperty.EqualsAscii(SW_PRPNM_EQLASCI(UNO_NAME_FORMULA)))
2000-09-18 23:08:29 +00:00
{
OUString uTmp;
rAny >>= uTmp;
SetFormula( uTmp );
}
else
{
//exception(wrong_param)
bRet = FALSE;
}
return bRet;
}