diff options
Diffstat (limited to 'binfilter/bf_sw/source/filter/writer/sw_wrt_fn.cxx')
-rw-r--r-- | binfilter/bf_sw/source/filter/writer/sw_wrt_fn.cxx | 131 |
1 files changed, 131 insertions, 0 deletions
diff --git a/binfilter/bf_sw/source/filter/writer/sw_wrt_fn.cxx b/binfilter/bf_sw/source/filter/writer/sw_wrt_fn.cxx new file mode 100644 index 000000000000..101bbe55ac64 --- /dev/null +++ b/binfilter/bf_sw/source/filter/writer/sw_wrt_fn.cxx @@ -0,0 +1,131 @@ +/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/************************************************************************* + * + * 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 + * <http://www.openoffice.org/license.html> + * for a copy of the LGPLv3 License. + * + ************************************************************************/ + + +#ifdef _MSC_VER +#pragma hdrstop +#endif + +#include <bf_svtools/itemiter.hxx> +#include <bf_svtools/whiter.hxx> + + +#include "shellio.hxx" +#include "wrt_fn.hxx" + +#include <errhdl.hxx> + +#include "node.hxx" +namespace binfilter { + + + +Writer& Out( const SwAttrFnTab pTab, const SfxPoolItem& rHt, Writer & rWrt ) +{ + USHORT nId = rHt.Which(); + ASSERT( nId < POOLATTR_END && nId >= POOLATTR_BEGIN, "SwAttrFnTab::Out()" ); + FnAttrOut pOut; + if( 0 != ( pOut = pTab[ nId - RES_CHRATR_BEGIN] )) + (*pOut)( rWrt, rHt ); + return rWrt; + +} + +Writer& Out_SfxItemSet( const SwAttrFnTab pTab, Writer& rWrt, + const SfxItemSet& rSet, BOOL bDeep, + BOOL bTstForDefault ) +{ + // erst die eigenen Attribute ausgeben + const SfxItemPool& rPool = *rSet.GetPool(); + const SfxItemSet* pSet = &rSet; + if( !pSet->Count() ) // Optimierung - leere Sets + { + if( !bDeep ) + return rWrt; + while( 0 != ( pSet = pSet->GetParent() ) && !pSet->Count() ) + ; + if( !pSet ) + return rWrt; + } + const SfxPoolItem* pItem; + FnAttrOut pOut; + if( !bDeep || !pSet->GetParent() ) + { + ASSERT( rSet.Count(), "Wurde doch schon behandelt oder?" ); + SfxItemIter aIter( *pSet ); + pItem = aIter.GetCurItem(); + do { + if( 0 != ( pOut = pTab[ pItem->Which() - RES_CHRATR_BEGIN] )) + (*pOut)( rWrt, *pItem ); + } while( !aIter.IsAtEnd() && 0 != ( pItem = aIter.NextItem() ) ); + } + else + { + SfxWhichIter aIter( *pSet ); + register USHORT nWhich = aIter.FirstWhich(); + while( nWhich ) + { + if( SFX_ITEM_SET == pSet->GetItemState( nWhich, bDeep, &pItem ) && + ( !bTstForDefault || ( + *pItem != rPool.GetDefaultItem( nWhich ) + || ( pSet->GetParent() && + *pItem != pSet->GetParent()->Get( nWhich )) + )) && 0 != ( pOut = pTab[ nWhich - RES_CHRATR_BEGIN] )) + (*pOut)( rWrt, *pItem ); + nWhich = aIter.NextWhich(); + } + } + return rWrt; +} + +/*N*/ Writer& Out( const SwNodeFnTab pTab, SwNode& rNode, Writer & rWrt ) +/*N*/ { +/*N*/ // es muss ein CntntNode sein !! +/*N*/ SwCntntNode * pCNd = rNode.GetCntntNode(); +/*N*/ if( !pCNd ) +/*?*/ return rWrt; +/*N*/ +/*N*/ USHORT nId = RES_TXTNODE; +/*N*/ switch( pCNd->GetNodeType() ) +/*N*/ { +/*N*/ case ND_TEXTNODE: nId = RES_TXTNODE; break; +/*?*/ case ND_GRFNODE: nId = RES_GRFNODE; break; +/*?*/ case ND_OLENODE: nId = RES_OLENODE; break; +/*?*/ default: +/*?*/ ASSERT( FALSE, "was fuer ein Node ist es denn nun?" ); +/*N*/ } +/*N*/ FnNodeOut pOut; +/*N*/ if( 0 != ( pOut = pTab[ nId - RES_NODE_BEGIN ] )) +/*N*/ (*pOut)( rWrt, *pCNd ); +/*N*/ return rWrt; +/*N*/ } + + +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |