xref: /aoo41x/main/sw/source/filter/writer/wrt_fn.cxx (revision efeef26f)
1*efeef26fSAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3*efeef26fSAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4*efeef26fSAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5*efeef26fSAndrew Rist  * distributed with this work for additional information
6*efeef26fSAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7*efeef26fSAndrew Rist  * to you under the Apache License, Version 2.0 (the
8*efeef26fSAndrew Rist  * "License"); you may not use this file except in compliance
9*efeef26fSAndrew Rist  * with the License.  You may obtain a copy of the License at
10*efeef26fSAndrew Rist  *
11*efeef26fSAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12*efeef26fSAndrew Rist  *
13*efeef26fSAndrew Rist  * Unless required by applicable law or agreed to in writing,
14*efeef26fSAndrew Rist  * software distributed under the License is distributed on an
15*efeef26fSAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*efeef26fSAndrew Rist  * KIND, either express or implied.  See the License for the
17*efeef26fSAndrew Rist  * specific language governing permissions and limitations
18*efeef26fSAndrew Rist  * under the License.
19*efeef26fSAndrew Rist  *
20*efeef26fSAndrew Rist  *************************************************************/
21*efeef26fSAndrew Rist 
22*efeef26fSAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
25cdf0e10cSrcweir #include "precompiled_sw.hxx"
26cdf0e10cSrcweir #include <svl/itemiter.hxx>
27cdf0e10cSrcweir #include <svl/whiter.hxx>
28cdf0e10cSrcweir 
29cdf0e10cSrcweir 
30cdf0e10cSrcweir #include "shellio.hxx"
31cdf0e10cSrcweir #include "wrt_fn.hxx"
32cdf0e10cSrcweir #include "pam.hxx"
33cdf0e10cSrcweir #include "node.hxx"
34cdf0e10cSrcweir #include "format.hxx"
35cdf0e10cSrcweir 
36cdf0e10cSrcweir 
37cdf0e10cSrcweir 
Out(const SwAttrFnTab pTab,const SfxPoolItem & rHt,Writer & rWrt)38cdf0e10cSrcweir Writer& Out( const SwAttrFnTab pTab, const SfxPoolItem& rHt, Writer & rWrt )
39cdf0e10cSrcweir {
40cdf0e10cSrcweir 	sal_uInt16 nId = rHt.Which();
41cdf0e10cSrcweir 	ASSERT(  nId < POOLATTR_END && nId >= POOLATTR_BEGIN, "SwAttrFnTab::Out()" );
42cdf0e10cSrcweir 	FnAttrOut pOut;
43cdf0e10cSrcweir 	if( 0 != ( pOut = pTab[ nId - RES_CHRATR_BEGIN] ))
44cdf0e10cSrcweir 		(*pOut)( rWrt, rHt );
45cdf0e10cSrcweir 	return rWrt;
46cdf0e10cSrcweir 
47cdf0e10cSrcweir }
48cdf0e10cSrcweir 
Out_SfxItemSet(const SwAttrFnTab pTab,Writer & rWrt,const SfxItemSet & rSet,sal_Bool bDeep,sal_Bool bTstForDefault)49cdf0e10cSrcweir Writer& Out_SfxItemSet( const SwAttrFnTab pTab, Writer& rWrt,
50cdf0e10cSrcweir 						const SfxItemSet& rSet, sal_Bool bDeep,
51cdf0e10cSrcweir 						sal_Bool bTstForDefault )
52cdf0e10cSrcweir {
53cdf0e10cSrcweir 	// erst die eigenen Attribute ausgeben
54cdf0e10cSrcweir 	const SfxItemPool& rPool = *rSet.GetPool();
55cdf0e10cSrcweir 	const SfxItemSet* pSet = &rSet;
56cdf0e10cSrcweir 	if( !pSet->Count() )        // Optimierung - leere Sets
57cdf0e10cSrcweir 	{
58cdf0e10cSrcweir 		if( !bDeep )
59cdf0e10cSrcweir 			return rWrt;
60cdf0e10cSrcweir 		while( 0 != ( pSet = pSet->GetParent() ) && !pSet->Count() )
61cdf0e10cSrcweir 			;
62cdf0e10cSrcweir 		if( !pSet )
63cdf0e10cSrcweir 			return rWrt;
64cdf0e10cSrcweir 	}
65cdf0e10cSrcweir 	const SfxPoolItem* pItem;
66cdf0e10cSrcweir 	FnAttrOut pOut;
67cdf0e10cSrcweir 	if( !bDeep || !pSet->GetParent() )
68cdf0e10cSrcweir 	{
69cdf0e10cSrcweir 		ASSERT( rSet.Count(), "Wurde doch schon behandelt oder?" );
70cdf0e10cSrcweir 		SfxItemIter aIter( *pSet );
71cdf0e10cSrcweir 		pItem = aIter.GetCurItem();
72cdf0e10cSrcweir 		do {
73cdf0e10cSrcweir 			if( 0 != ( pOut = pTab[ pItem->Which() - RES_CHRATR_BEGIN] ))
74cdf0e10cSrcweir 					(*pOut)( rWrt, *pItem );
75cdf0e10cSrcweir 		} while( !aIter.IsAtEnd() && 0 != ( pItem = aIter.NextItem() ) );
76cdf0e10cSrcweir 	}
77cdf0e10cSrcweir 	else
78cdf0e10cSrcweir 	{
79cdf0e10cSrcweir 		SfxWhichIter aIter( *pSet );
80cdf0e10cSrcweir 		sal_uInt16 nWhich = aIter.FirstWhich();
81cdf0e10cSrcweir 		while( nWhich )
82cdf0e10cSrcweir 		{
83cdf0e10cSrcweir 			if( SFX_ITEM_SET == pSet->GetItemState( nWhich, bDeep, &pItem ) &&
84cdf0e10cSrcweir 				( !bTstForDefault || (
85cdf0e10cSrcweir 					*pItem != rPool.GetDefaultItem( nWhich )
86cdf0e10cSrcweir 					|| ( pSet->GetParent() &&
87cdf0e10cSrcweir 						*pItem != pSet->GetParent()->Get( nWhich ))
88cdf0e10cSrcweir 				)) && 0 != ( pOut = pTab[ nWhich - RES_CHRATR_BEGIN] ))
89cdf0e10cSrcweir 					(*pOut)( rWrt, *pItem );
90cdf0e10cSrcweir 			nWhich = aIter.NextWhich();
91cdf0e10cSrcweir 		}
92cdf0e10cSrcweir 	}
93cdf0e10cSrcweir 	return rWrt;
94cdf0e10cSrcweir }
95cdf0e10cSrcweir 
96cdf0e10cSrcweir 
97cdf0e10cSrcweir 
Out(const SwNodeFnTab pTab,SwNode & rNode,Writer & rWrt)98cdf0e10cSrcweir Writer& Out( const SwNodeFnTab pTab, SwNode& rNode, Writer & rWrt )
99cdf0e10cSrcweir {
100cdf0e10cSrcweir 	// es muss ein CntntNode sein !!
101cdf0e10cSrcweir 	SwCntntNode * pCNd = rNode.GetCntntNode();
102cdf0e10cSrcweir 	if( !pCNd )
103cdf0e10cSrcweir 		return rWrt;
104cdf0e10cSrcweir 
105cdf0e10cSrcweir 	sal_uInt16 nId = RES_TXTNODE;
106cdf0e10cSrcweir 	switch (pCNd->GetNodeType())
107cdf0e10cSrcweir 	{
108cdf0e10cSrcweir 		case ND_TEXTNODE:
109cdf0e10cSrcweir 			nId = RES_TXTNODE;
110cdf0e10cSrcweir 			 break;
111cdf0e10cSrcweir 		case ND_GRFNODE:
112cdf0e10cSrcweir 			nId = RES_GRFNODE;
113cdf0e10cSrcweir 			break;
114cdf0e10cSrcweir 		case ND_OLENODE:
115cdf0e10cSrcweir 			nId = RES_OLENODE;
116cdf0e10cSrcweir 			break;
117cdf0e10cSrcweir 		default:
118cdf0e10cSrcweir 			ASSERT(false, "was fuer ein Node ist es denn nun?");
119cdf0e10cSrcweir 			break;
120cdf0e10cSrcweir 	}
121cdf0e10cSrcweir 	FnNodeOut pOut;
122cdf0e10cSrcweir 	if( 0 != ( pOut = pTab[ nId - RES_NODE_BEGIN ] ))
123cdf0e10cSrcweir 		(*pOut)( rWrt, *pCNd );
124cdf0e10cSrcweir 	return rWrt;
125cdf0e10cSrcweir }
126cdf0e10cSrcweir 
127cdf0e10cSrcweir 
128