/************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2000, 2010 Oracle and/or its affiliates. * * OpenOffice.org - a multi-platform office productivity suite * * 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 * * for a copy of the LGPLv3 License. * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_sw.hxx" #include #include #include // fuer RES_.. #include #include #include #include #include #include #include #include #include //TYPEINIT1( SwFmt, SwClient ); //rtti fuer SwFmt /************************************************************************* |* *************************************************************************/ SwTblBoxNumFormat::SwTblBoxNumFormat( sal_uInt32 nFormat, sal_Bool bFlag ) : SfxUInt32Item( RES_BOXATR_FORMAT, nFormat ), bAuto( bFlag ) { } int SwTblBoxNumFormat::operator==( const SfxPoolItem& rAttr ) const { ASSERT( SfxPoolItem::operator==( rAttr ), "keine gleichen Attribute" ); return GetValue() == ((SwTblBoxNumFormat&)rAttr).GetValue() && bAuto == ((SwTblBoxNumFormat&)rAttr).bAuto; } SfxPoolItem* SwTblBoxNumFormat::Clone( SfxItemPool* ) const { return new SwTblBoxNumFormat( GetValue(), bAuto ); } /************************************************************************* |* *************************************************************************/ SwTblBoxFormula::SwTblBoxFormula( const String& rFormula ) : SfxPoolItem( RES_BOXATR_FORMULA ), SwTableFormula( rFormula ), pDefinedIn( 0 ) { } int SwTblBoxFormula::operator==( const SfxPoolItem& rAttr ) const { ASSERT( SfxPoolItem::operator==( rAttr ), "keine gleichen Attribute" ); return GetFormula() == ((SwTblBoxFormula&)rAttr).GetFormula() && pDefinedIn == ((SwTblBoxFormula&)rAttr).pDefinedIn; } SfxPoolItem* SwTblBoxFormula::Clone( SfxItemPool* ) const { // auf externe Darstellung umschalten!! SwTblBoxFormula* pNew = new SwTblBoxFormula( GetFormula() ); pNew->SwTableFormula::operator=( *this ); return pNew; } // suche den Node, in dem die Formel steht: // TextFeld -> TextNode, // BoxAttribut -> BoxStartNode // !!! MUSS VON JEDER ABLEITUNG UEBERLADEN WERDEN !!! const SwNode* SwTblBoxFormula::GetNodeOfFormula() const { const SwNode* pRet = 0; if( pDefinedIn ) { SwTableBox* pBox = SwIterator::FirstElement( *pDefinedIn ); if( pBox ) pRet = pBox->GetSttNd(); } return pRet; } SwTableBox* SwTblBoxFormula::GetTableBox() { SwTableBox* pBox = 0; if( pDefinedIn ) pBox = SwIterator::FirstElement( *pDefinedIn ); return pBox; } void SwTblBoxFormula::ChangeState( const SfxPoolItem* pItem ) { if( !pDefinedIn ) return ; SwTableFmlUpdate* pUpdtFld; if( !pItem || RES_TABLEFML_UPDATE != pItem->Which() ) { // setze bei allen das Value-Flag zurueck ChgValid( sal_False ); return ; } pUpdtFld = (SwTableFmlUpdate*)pItem; // bestimme die Tabelle, in der das Attribut steht const SwTableNode* pTblNd; const SwNode* pNd = GetNodeOfFormula(); if( pNd && &pNd->GetNodes() == &pNd->GetDoc()->GetNodes() && 0 != ( pTblNd = pNd->FindTableNode() )) { switch( pUpdtFld->eFlags ) { case TBL_CALC: // setze das Value-Flag zurueck // JP 17.06.96: interne Darstellung auf alle Formeln // (Referenzen auf andere Tabellen!!!) // if( VF_CMD & pFld->GetFormat() ) // pFld->PtrToBoxNm( pUpdtFld->pTbl ); // else ChgValid( sal_False ); break; case TBL_BOXNAME: // ist es die gesuchte Tabelle ?? if( &pTblNd->GetTable() == pUpdtFld->pTbl ) // zur externen Darstellung PtrToBoxNm( pUpdtFld->pTbl ); break; case TBL_BOXPTR: // zur internen Darstellung // JP 17.06.96: interne Darstellung auf alle Formeln // (Referenzen auf andere Tabellen!!!) BoxNmToPtr( &pTblNd->GetTable() ); break; case TBL_RELBOXNAME: // ist es die gesuchte Tabelle ?? if( &pTblNd->GetTable() == pUpdtFld->pTbl ) // zur relativen Darstellung ToRelBoxNm( pUpdtFld->pTbl ); break; case TBL_SPLITTBL: if( &pTblNd->GetTable() == pUpdtFld->pTbl ) { sal_uInt16 nLnPos = SwTableFormula::GetLnPosInTbl( pTblNd->GetTable(), GetTableBox() ); pUpdtFld->bBehindSplitLine = USHRT_MAX != nLnPos && pUpdtFld->nSplitLine <= nLnPos; } else pUpdtFld->bBehindSplitLine = sal_False; // kein break case TBL_MERGETBL: if( pUpdtFld->pHistory ) { // fuer die History brauche ich aber die unveraenderte Formel SwTblBoxFormula aCopy( *this ); pUpdtFld->bModified = sal_False; ToSplitMergeBoxNm( *pUpdtFld ); if( pUpdtFld->bModified ) { // und dann in der externen Darstellung aCopy.PtrToBoxNm( &pTblNd->GetTable() ); pUpdtFld->pHistory->Add( &aCopy, &aCopy, pNd->FindTableBoxStartNode()->GetIndex() ); } } else ToSplitMergeBoxNm( *pUpdtFld ); break; } } } void SwTblBoxFormula::Calc( SwTblCalcPara& rCalcPara, double& rValue ) { if( !rCalcPara.rCalc.IsCalcError() ) // ist schon Fehler gesetzt ? { // erzeuge aus den BoxNamen die Pointer BoxNmToPtr( rCalcPara.pTbl ); String sFml( MakeFormel( rCalcPara )); if( !rCalcPara.rCalc.IsCalcError() ) rValue = rCalcPara.rCalc.Calculate( sFml ).GetDouble(); else rValue = DBL_MAX; ChgValid( !rCalcPara.IsStackOverFlow() ); // der Wert ist wieder gueltig } } /************************************************************************* |* *************************************************************************/ SwTblBoxValue::SwTblBoxValue() : SfxPoolItem( RES_BOXATR_VALUE ), nValue( 0 ) { } SwTblBoxValue::SwTblBoxValue( const double nVal ) : SfxPoolItem( RES_BOXATR_VALUE ), nValue( nVal ) { } int SwTblBoxValue::operator==( const SfxPoolItem& rAttr ) const { ASSERT(SfxPoolItem::operator==(rAttr), "SwTblBoxValue: item not equal"); SwTblBoxValue const& rOther( static_cast(rAttr) ); // items with NaN should be equal to enable pooling return ::rtl::math::isNan(nValue) ? ::rtl::math::isNan(rOther.nValue) : (nValue == rOther.nValue); } SfxPoolItem* SwTblBoxValue::Clone( SfxItemPool* ) const { return new SwTblBoxValue( nValue ); }