1*f6e50924SAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3*f6e50924SAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4*f6e50924SAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5*f6e50924SAndrew Rist  * distributed with this work for additional information
6*f6e50924SAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7*f6e50924SAndrew Rist  * to you under the Apache License, Version 2.0 (the
8*f6e50924SAndrew Rist  * "License"); you may not use this file except in compliance
9*f6e50924SAndrew Rist  * with the License.  You may obtain a copy of the License at
10*f6e50924SAndrew Rist  *
11*f6e50924SAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12*f6e50924SAndrew Rist  *
13*f6e50924SAndrew Rist  * Unless required by applicable law or agreed to in writing,
14*f6e50924SAndrew Rist  * software distributed under the License is distributed on an
15*f6e50924SAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*f6e50924SAndrew Rist  * KIND, either express or implied.  See the License for the
17*f6e50924SAndrew Rist  * specific language governing permissions and limitations
18*f6e50924SAndrew Rist  * under the License.
19*f6e50924SAndrew Rist  *
20*f6e50924SAndrew Rist  *************************************************************/
21*f6e50924SAndrew Rist 
22*f6e50924SAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
25cdf0e10cSrcweir #include "precompiled_svx.hxx"
26cdf0e10cSrcweir 
27cdf0e10cSrcweir #include <vector>
28cdf0e10cSrcweir #include <boost/shared_ptr.hpp>
29cdf0e10cSrcweir 
30cdf0e10cSrcweir #include <com/sun/star/table/XTable.hpp>
31cdf0e10cSrcweir 
32cdf0e10cSrcweir #include <tools/stream.hxx>
33cdf0e10cSrcweir #include <svtools/rtftoken.h>
34cdf0e10cSrcweir 
35cdf0e10cSrcweir #include <editeng/eeitem.hxx>
36cdf0e10cSrcweir #include <svx/svdetc.hxx>
37cdf0e10cSrcweir #include <editeng/fhgtitem.hxx>
38cdf0e10cSrcweir #include <editeng/outlobj.hxx>
39cdf0e10cSrcweir 
40cdf0e10cSrcweir #include "cell.hxx"
41cdf0e10cSrcweir #include "celltypes.hxx"
42cdf0e10cSrcweir #include "svx/svdotable.hxx"
43cdf0e10cSrcweir #include "svx/svdoutl.hxx"
44cdf0e10cSrcweir #include "editeng/editeng.hxx"
45cdf0e10cSrcweir #include "editeng/editdata.hxx"
46cdf0e10cSrcweir #include "svx/svdmodel.hxx"
47cdf0e10cSrcweir #include "editeng/svxrtf.hxx"
48cdf0e10cSrcweir 
49cdf0e10cSrcweir using ::rtl::OUString;
50cdf0e10cSrcweir using namespace ::com::sun::star::uno;
51cdf0e10cSrcweir using namespace ::com::sun::star::table;
52cdf0e10cSrcweir using namespace ::com::sun::star::container;
53cdf0e10cSrcweir using namespace ::com::sun::star::beans;
54cdf0e10cSrcweir 
55cdf0e10cSrcweir namespace sdr { namespace table {
56cdf0e10cSrcweir 
57cdf0e10cSrcweir struct RTFCellDefault
58cdf0e10cSrcweir {
59cdf0e10cSrcweir 	SfxItemSet			maItemSet;
60cdf0e10cSrcweir 	sal_Int32			mnCol;
61cdf0e10cSrcweir 	sal_uInt16				mnTwips;         // right border of the cell
62cdf0e10cSrcweir 	sal_Int32			mnColSpan;	 // MergeCell if >1, merged cells if 0
63cdf0e10cSrcweir 
RTFCellDefaultsdr::table::RTFCellDefault64cdf0e10cSrcweir 	RTFCellDefault( SfxItemPool* pPool ) : maItemSet( *pPool ), mnCol(0), mnTwips(0 ), mnColSpan(1) {}
65cdf0e10cSrcweir };
66cdf0e10cSrcweir 
67cdf0e10cSrcweir typedef std::vector< boost::shared_ptr< RTFCellDefault > > RTFCellDefaultVector;
68cdf0e10cSrcweir 
69cdf0e10cSrcweir struct RTFCellInfo
70cdf0e10cSrcweir {
71cdf0e10cSrcweir 	SfxItemSet			maItemSet;
72cdf0e10cSrcweir 	sal_Int32			mnStartPara;
73cdf0e10cSrcweir 	sal_Int32			mnParaCount;
74cdf0e10cSrcweir 	sal_Int32			mnColSpan;
75cdf0e10cSrcweir 
RTFCellInfosdr::table::RTFCellInfo76cdf0e10cSrcweir 	RTFCellInfo( SfxItemPool& rPool ) : maItemSet(  rPool ), mnStartPara(0), mnParaCount(0), mnColSpan(0) {}
77cdf0e10cSrcweir };
78cdf0e10cSrcweir 
79cdf0e10cSrcweir typedef boost::shared_ptr< RTFCellInfo > RTFCellInfoPtr;
80cdf0e10cSrcweir typedef std::vector< RTFCellInfoPtr > RTFColumnVector;
81cdf0e10cSrcweir 
82cdf0e10cSrcweir typedef boost::shared_ptr< RTFColumnVector > RTFColumnVectorPtr;
83cdf0e10cSrcweir 
84cdf0e10cSrcweir typedef std::vector< RTFColumnVectorPtr > RTFRowVector;
85cdf0e10cSrcweir 
86cdf0e10cSrcweir class SdrTableRTFParser
87cdf0e10cSrcweir {
88cdf0e10cSrcweir public:
89cdf0e10cSrcweir 	SdrTableRTFParser( SdrTableObj& rTableObj );
90cdf0e10cSrcweir 	~SdrTableRTFParser();
91cdf0e10cSrcweir 
92cdf0e10cSrcweir 	void Read( SvStream& rStream );
93cdf0e10cSrcweir 
94cdf0e10cSrcweir 	void ProcToken( ImportInfo* pInfo );
95cdf0e10cSrcweir 
96cdf0e10cSrcweir 	void NextRow();
97cdf0e10cSrcweir 	void NextColumn();
98cdf0e10cSrcweir 	void NewCellRow();
99cdf0e10cSrcweir 
100cdf0e10cSrcweir 	void InsertCell( ImportInfo* pInfo );
101cdf0e10cSrcweir 
102cdf0e10cSrcweir 	void FillTable();
103cdf0e10cSrcweir 
104cdf0e10cSrcweir 	DECL_LINK( RTFImportHdl, ImportInfo* );
105cdf0e10cSrcweir 
106cdf0e10cSrcweir private:
107cdf0e10cSrcweir 	SdrTableObj&	mrTableObj;
108cdf0e10cSrcweir 	SdrOutliner*	mpOutliner;
109cdf0e10cSrcweir 	SfxItemPool&	mrItemPool;
110cdf0e10cSrcweir 
111cdf0e10cSrcweir 	RTFCellDefaultVector maDefaultList;
112cdf0e10cSrcweir 	RTFCellDefaultVector::iterator maDefaultIterator;
113cdf0e10cSrcweir 
114cdf0e10cSrcweir 	int				mnLastToken;
115cdf0e10cSrcweir 	sal_Int32		mnLastWidth;
116cdf0e10cSrcweir 	bool			mbNewDef;
117cdf0e10cSrcweir 
118cdf0e10cSrcweir 	sal_uInt16			mnStartPara;
119cdf0e10cSrcweir 
120cdf0e10cSrcweir 	sal_Int32		mnColCnt;
121cdf0e10cSrcweir 	sal_Int32		mnRowCnt;
122cdf0e10cSrcweir 	sal_Int32		mnColMax;
123cdf0e10cSrcweir 
124cdf0e10cSrcweir 	std::vector< sal_Int32 > maColumnEdges;
125cdf0e10cSrcweir 
126cdf0e10cSrcweir 	RTFRowVector	maRows;
127cdf0e10cSrcweir 
128cdf0e10cSrcweir 	RTFCellDefault*	mpInsDefault;
129cdf0e10cSrcweir 	RTFCellDefault*	mpActDefault;
130cdf0e10cSrcweir 	RTFCellDefault*	mpDefMerge;
131cdf0e10cSrcweir 
132cdf0e10cSrcweir 	Reference< XTable > mxTable;
133cdf0e10cSrcweir };
134cdf0e10cSrcweir 
SdrTableRTFParser(SdrTableObj & rTableObj)135cdf0e10cSrcweir SdrTableRTFParser::SdrTableRTFParser( SdrTableObj& rTableObj )
136cdf0e10cSrcweir : mrTableObj( rTableObj )
137cdf0e10cSrcweir , mpOutliner( SdrMakeOutliner( OUTLINERMODE_TEXTOBJECT, rTableObj.GetModel() ) )
138cdf0e10cSrcweir , mrItemPool( rTableObj.GetModel()->GetItemPool() )
139cdf0e10cSrcweir , mnLastToken( 0 )
140cdf0e10cSrcweir , mnLastWidth( 0 )
141cdf0e10cSrcweir , mbNewDef( false )
142cdf0e10cSrcweir , mnStartPara( 0 )
143cdf0e10cSrcweir , mnColCnt( 0 )
144cdf0e10cSrcweir , mnRowCnt( 0 )
145cdf0e10cSrcweir , mnColMax( 0 )
146cdf0e10cSrcweir , mpActDefault( 0 )
147cdf0e10cSrcweir , mpDefMerge( 0 )
148cdf0e10cSrcweir , mxTable( rTableObj.getTable() )
149cdf0e10cSrcweir {
150cdf0e10cSrcweir 	mpOutliner->SetUpdateMode(sal_True);
151cdf0e10cSrcweir 	mpOutliner->SetStyleSheet( 0, mrTableObj.GetStyleSheet() );
152cdf0e10cSrcweir 	mpInsDefault = new RTFCellDefault( &mrItemPool );
153cdf0e10cSrcweir }
154cdf0e10cSrcweir 
~SdrTableRTFParser()155cdf0e10cSrcweir SdrTableRTFParser::~SdrTableRTFParser()
156cdf0e10cSrcweir {
157cdf0e10cSrcweir 	delete mpOutliner;
158cdf0e10cSrcweir 	delete mpInsDefault;
159cdf0e10cSrcweir }
160cdf0e10cSrcweir 
Read(SvStream & rStream)161cdf0e10cSrcweir void SdrTableRTFParser::Read( SvStream& rStream )
162cdf0e10cSrcweir {
163cdf0e10cSrcweir 	EditEngine& rEdit = const_cast< EditEngine& >( mpOutliner->GetEditEngine() );
164cdf0e10cSrcweir 
165cdf0e10cSrcweir 	Link aOldLink( rEdit.GetImportHdl() );
166cdf0e10cSrcweir 	rEdit.SetImportHdl( LINK( this, SdrTableRTFParser, RTFImportHdl ) );
167cdf0e10cSrcweir 	mpOutliner->Read( rStream, String(), EE_FORMAT_RTF );
168cdf0e10cSrcweir 	rEdit.SetImportHdl( aOldLink );
169cdf0e10cSrcweir 
170cdf0e10cSrcweir 	FillTable();
171cdf0e10cSrcweir }
172cdf0e10cSrcweir 
IMPL_LINK(SdrTableRTFParser,RTFImportHdl,ImportInfo *,pInfo)173cdf0e10cSrcweir IMPL_LINK( SdrTableRTFParser, RTFImportHdl, ImportInfo*, pInfo )
174cdf0e10cSrcweir {
175cdf0e10cSrcweir 	switch ( pInfo->eState )
176cdf0e10cSrcweir 	{
177cdf0e10cSrcweir 		case RTFIMP_NEXTTOKEN:
178cdf0e10cSrcweir 			ProcToken( pInfo );
179cdf0e10cSrcweir 			break;
180cdf0e10cSrcweir 		case RTFIMP_UNKNOWNATTR:
181cdf0e10cSrcweir 			ProcToken( pInfo );
182cdf0e10cSrcweir 			break;
183cdf0e10cSrcweir 		case RTFIMP_START:
184cdf0e10cSrcweir 		{
185cdf0e10cSrcweir 			SvxRTFParser* pParser = (SvxRTFParser*) pInfo->pParser;
186cdf0e10cSrcweir 			pParser->SetAttrPool( &mrItemPool );
187cdf0e10cSrcweir 			RTFPardAttrMapIds& rMap = pParser->GetPardMap();
188cdf0e10cSrcweir 			rMap.nBox = SDRATTR_TABLE_BORDER;
189cdf0e10cSrcweir 		}
190cdf0e10cSrcweir 			break;
191cdf0e10cSrcweir 		case RTFIMP_END:
192cdf0e10cSrcweir 			if ( pInfo->aSelection.nEndPos )
193cdf0e10cSrcweir 			{
194cdf0e10cSrcweir 				mpActDefault = NULL;
195cdf0e10cSrcweir 				pInfo->nToken = RTF_PAR;
196cdf0e10cSrcweir 				pInfo->aSelection.nEndPara++;
197cdf0e10cSrcweir 				ProcToken( pInfo );
198cdf0e10cSrcweir 			}
199cdf0e10cSrcweir 			break;
200cdf0e10cSrcweir 		case RTFIMP_SETATTR:
201cdf0e10cSrcweir 			break;
202cdf0e10cSrcweir 		case RTFIMP_INSERTTEXT:
203cdf0e10cSrcweir 			break;
204cdf0e10cSrcweir 		case RTFIMP_INSERTPARA:
205cdf0e10cSrcweir 			break;
206cdf0e10cSrcweir 		default:
207cdf0e10cSrcweir 			DBG_ERRORFILE("unknown ImportInfo.eState");
208cdf0e10cSrcweir 	}
209cdf0e10cSrcweir 	return 0;
210cdf0e10cSrcweir }
211cdf0e10cSrcweir 
NextRow()212cdf0e10cSrcweir void SdrTableRTFParser::NextRow()
213cdf0e10cSrcweir {
214cdf0e10cSrcweir 	++mnRowCnt;
215cdf0e10cSrcweir }
216cdf0e10cSrcweir 
InsertCell(ImportInfo * pInfo)217cdf0e10cSrcweir void SdrTableRTFParser::InsertCell( ImportInfo* pInfo )
218cdf0e10cSrcweir {
219cdf0e10cSrcweir 	sal_Int32 nCol = mpActDefault->mnCol;
220cdf0e10cSrcweir 
221cdf0e10cSrcweir 	RTFCellInfoPtr xCellInfo( new RTFCellInfo(mrItemPool) );
222cdf0e10cSrcweir 
223cdf0e10cSrcweir 	xCellInfo->mnStartPara = mnStartPara;
224cdf0e10cSrcweir 	xCellInfo->mnParaCount = pInfo->aSelection.nEndPara - 1 - mnStartPara;
225cdf0e10cSrcweir 
226cdf0e10cSrcweir 	if( !maRows.empty() )
227cdf0e10cSrcweir 	{
228cdf0e10cSrcweir 		RTFColumnVectorPtr xColumn( maRows.back() );
229cdf0e10cSrcweir 
230cdf0e10cSrcweir 		if( xColumn->size() <= (size_t)nCol )
231cdf0e10cSrcweir 			xColumn->resize( nCol+1 );
232cdf0e10cSrcweir 
233cdf0e10cSrcweir 		(*xColumn)[nCol] = xCellInfo;
234cdf0e10cSrcweir 	}
235cdf0e10cSrcweir 
236cdf0e10cSrcweir 	mnStartPara = pInfo->aSelection.nEndPara - 1;
237cdf0e10cSrcweir }
238cdf0e10cSrcweir 
FillTable()239cdf0e10cSrcweir void SdrTableRTFParser::FillTable()
240cdf0e10cSrcweir {
241cdf0e10cSrcweir 	try
242cdf0e10cSrcweir 	{
243cdf0e10cSrcweir 		sal_Int32 nColCount = mxTable->getColumnCount();
244cdf0e10cSrcweir 		Reference< XTableColumns > xCols( mxTable->getColumns(), UNO_QUERY_THROW );
245cdf0e10cSrcweir 
246cdf0e10cSrcweir 		if( nColCount < mnColMax )
247cdf0e10cSrcweir 		{
248cdf0e10cSrcweir 			xCols->insertByIndex( nColCount, mnColMax - nColCount );
249cdf0e10cSrcweir 			nColCount = mxTable->getColumnCount();
250cdf0e10cSrcweir 		}
251cdf0e10cSrcweir 
252cdf0e10cSrcweir 		const OUString sWidth( RTL_CONSTASCII_USTRINGPARAM("Width") );
253cdf0e10cSrcweir 		sal_Int32 nCol, nLastEdge = 0;
254cdf0e10cSrcweir 		for( nCol = 0; nCol < nColCount; nCol++ )
255cdf0e10cSrcweir 		{
256cdf0e10cSrcweir 			Reference< XPropertySet > xSet( xCols->getByIndex( nCol ), UNO_QUERY_THROW );
257cdf0e10cSrcweir 			sal_Int32 nWidth = maColumnEdges[nCol] - nLastEdge;
258cdf0e10cSrcweir 
259cdf0e10cSrcweir 			xSet->setPropertyValue( sWidth, Any( nWidth ) );
260cdf0e10cSrcweir 			nLastEdge += nWidth;
261cdf0e10cSrcweir 		}
262cdf0e10cSrcweir 
263cdf0e10cSrcweir 		const sal_Int32 nRowCount = mxTable->getRowCount();
264cdf0e10cSrcweir 		if( nRowCount < mnRowCnt )
265cdf0e10cSrcweir 		{
266cdf0e10cSrcweir 			Reference< XTableRows > xRows( mxTable->getRows(), UNO_QUERY_THROW );
267cdf0e10cSrcweir 			xRows->insertByIndex( nRowCount, mnRowCnt - nRowCount );
268cdf0e10cSrcweir 		}
269cdf0e10cSrcweir 
270cdf0e10cSrcweir 		for( sal_Int32 nRow = 0; nRow < (sal_Int32)maRows.size(); nRow++ )
271cdf0e10cSrcweir 		{
272cdf0e10cSrcweir 			RTFColumnVectorPtr xColumn( maRows[nRow] );
273cdf0e10cSrcweir 			for( nCol = 0; nCol < (sal_Int32)xColumn->size(); nCol++ )
274cdf0e10cSrcweir 			{
275cdf0e10cSrcweir 				RTFCellInfoPtr xCellInfo( (*xColumn)[nCol] );
276cdf0e10cSrcweir 
277cdf0e10cSrcweir 				CellRef xCell( dynamic_cast< Cell* >( mxTable->getCellByPosition( nCol, nRow ).get() ) );
278cdf0e10cSrcweir 				if( xCell.is() && xCellInfo.get() )
279cdf0e10cSrcweir 				{
280cdf0e10cSrcweir 					const SfxPoolItem *pPoolItem = 0;
281cdf0e10cSrcweir 					if( xCellInfo->maItemSet.GetItemState(SDRATTR_TABLE_BORDER,sal_False,&pPoolItem)==SFX_ITEM_SET)
282cdf0e10cSrcweir 						xCell->SetMergedItem( *pPoolItem );
283cdf0e10cSrcweir 
284cdf0e10cSrcweir 					String sDebug = mpOutliner->GetText( mpOutliner->GetParagraph( xCellInfo->mnStartPara ), xCellInfo->mnParaCount );
285cdf0e10cSrcweir 
286cdf0e10cSrcweir 					OutlinerParaObject* pTextObject = mpOutliner->CreateParaObject( (sal_uInt16)xCellInfo->mnStartPara, (sal_uInt16)xCellInfo->mnParaCount );
287cdf0e10cSrcweir 					if( pTextObject )
288cdf0e10cSrcweir 					{
289cdf0e10cSrcweir 						SdrOutliner& rOutliner=mrTableObj.ImpGetDrawOutliner();
290cdf0e10cSrcweir 						rOutliner.SetUpdateMode(sal_True);
291cdf0e10cSrcweir 						rOutliner.SetText( *pTextObject );
292cdf0e10cSrcweir 						mrTableObj.NbcSetOutlinerParaObjectForText( rOutliner.CreateParaObject(), xCell.get() );
293cdf0e10cSrcweir 						delete pTextObject;
294cdf0e10cSrcweir 					}
295cdf0e10cSrcweir 				}
296cdf0e10cSrcweir 			}
297cdf0e10cSrcweir 		}
298cdf0e10cSrcweir 
299cdf0e10cSrcweir 		Rectangle aRect( mrTableObj.GetSnapRect() );
300cdf0e10cSrcweir 		aRect.nRight = aRect.nLeft + nLastEdge;
301cdf0e10cSrcweir 		mrTableObj.NbcSetSnapRect( aRect );
302cdf0e10cSrcweir 
303cdf0e10cSrcweir 	}
304cdf0e10cSrcweir 	catch( Exception& e )
305cdf0e10cSrcweir 	{
306cdf0e10cSrcweir 		(void)e;
307cdf0e10cSrcweir 		DBG_ERROR("sdr::table::SdrTableRTFParser::InsertCell(), exception caught!" );
308cdf0e10cSrcweir 	}
309cdf0e10cSrcweir }
310cdf0e10cSrcweir 
NewCellRow()311cdf0e10cSrcweir void SdrTableRTFParser::NewCellRow()
312cdf0e10cSrcweir {
313cdf0e10cSrcweir 	if( mbNewDef )
314cdf0e10cSrcweir 	{
315cdf0e10cSrcweir 		mbNewDef = sal_False;
316cdf0e10cSrcweir 
317cdf0e10cSrcweir 		maRows.push_back( RTFColumnVectorPtr( new RTFColumnVector() ) );
318cdf0e10cSrcweir 	}
319cdf0e10cSrcweir 	mpDefMerge = NULL;
320cdf0e10cSrcweir 	maDefaultIterator = maDefaultList.begin();
321cdf0e10cSrcweir 
322cdf0e10cSrcweir 	NextColumn();
323cdf0e10cSrcweir 
324cdf0e10cSrcweir 	DBG_ASSERT( mpActDefault, "NewCellRow: pActDefault==0" );
325cdf0e10cSrcweir }
326cdf0e10cSrcweir 
NextColumn()327cdf0e10cSrcweir void SdrTableRTFParser::NextColumn()
328cdf0e10cSrcweir {
329cdf0e10cSrcweir 	if( maDefaultIterator != maDefaultList.end() )
330cdf0e10cSrcweir 		mpActDefault = (*maDefaultIterator++).get();
331cdf0e10cSrcweir 	else
332cdf0e10cSrcweir 		mpActDefault = 0;
333cdf0e10cSrcweir }
334cdf0e10cSrcweir 
TwipsToHundMM(long nIn)335cdf0e10cSrcweir long TwipsToHundMM( long nIn )
336cdf0e10cSrcweir {
337cdf0e10cSrcweir 	long nRet = OutputDevice::LogicToLogic( nIn, MAP_TWIP, MAP_100TH_MM );
338cdf0e10cSrcweir 	return nRet;
339cdf0e10cSrcweir }
340cdf0e10cSrcweir 
ProcToken(ImportInfo * pInfo)341cdf0e10cSrcweir void SdrTableRTFParser::ProcToken( ImportInfo* pInfo )
342cdf0e10cSrcweir {
343cdf0e10cSrcweir 	switch ( pInfo->nToken )
344cdf0e10cSrcweir 	{
345cdf0e10cSrcweir 		case RTF_TROWD:			// denotes table row defauls, before RTF_CELLX
346cdf0e10cSrcweir 		{
347cdf0e10cSrcweir 			mnColCnt = 0;
348cdf0e10cSrcweir 			maDefaultList.clear();
349cdf0e10cSrcweir 			mpDefMerge = NULL;
350cdf0e10cSrcweir 			mnLastToken = pInfo->nToken;
351cdf0e10cSrcweir 		}
352cdf0e10cSrcweir 		break;
353cdf0e10cSrcweir 		case RTF_CLMGF:			// The first cell of cells to be merged
354cdf0e10cSrcweir 		{
355cdf0e10cSrcweir 			mpDefMerge = mpInsDefault;
356cdf0e10cSrcweir 			mnLastToken = pInfo->nToken;
357cdf0e10cSrcweir 		}
358cdf0e10cSrcweir 		break;
359cdf0e10cSrcweir 		case RTF_CLMRG:			// A cell to be merged with the preceding cell
360cdf0e10cSrcweir 		{
361cdf0e10cSrcweir 			if ( !mpDefMerge )
362cdf0e10cSrcweir 				mpDefMerge = maDefaultList.back().get();
363cdf0e10cSrcweir 			DBG_ASSERT( mpDefMerge, "RTF_CLMRG: pDefMerge==0" );
364cdf0e10cSrcweir 			if( mpDefMerge )
365cdf0e10cSrcweir 				mpDefMerge->mnColSpan++;
366cdf0e10cSrcweir 			mpInsDefault->mnColSpan = 0;
367cdf0e10cSrcweir 			mnLastToken = pInfo->nToken;
368cdf0e10cSrcweir 		}
369cdf0e10cSrcweir 		break;
370cdf0e10cSrcweir 		case RTF_CELLX:			// closes cell default
371cdf0e10cSrcweir 		{
372cdf0e10cSrcweir 			mbNewDef = sal_True;
373cdf0e10cSrcweir 			mpInsDefault->mnCol = mnColCnt;
374cdf0e10cSrcweir 			maDefaultList.push_back( boost::shared_ptr< RTFCellDefault >( mpInsDefault ) );
375cdf0e10cSrcweir 
376cdf0e10cSrcweir 			if( (sal_Int32)maColumnEdges.size() <= mnColCnt )
377cdf0e10cSrcweir 				maColumnEdges.resize( mnColCnt + 1 );
378cdf0e10cSrcweir 
379cdf0e10cSrcweir 			const sal_Int32 nSize = TwipsToHundMM( pInfo->nTokenValue );
380cdf0e10cSrcweir 			maColumnEdges[mnColCnt] = std::max( maColumnEdges[mnColCnt], nSize );
381cdf0e10cSrcweir 
382cdf0e10cSrcweir 			mpInsDefault = new RTFCellDefault( &mrItemPool );
383cdf0e10cSrcweir 			if ( ++mnColCnt > mnColMax )
384cdf0e10cSrcweir 				mnColMax = mnColCnt;
385cdf0e10cSrcweir 			mnLastToken = pInfo->nToken;
386cdf0e10cSrcweir 		}
387cdf0e10cSrcweir 		break;
388cdf0e10cSrcweir 		case RTF_INTBL:			// before the first RTF_CELL
389cdf0e10cSrcweir 		{
390cdf0e10cSrcweir 			if ( mnLastToken != RTF_INTBL && mnLastToken != RTF_CELL && mnLastToken != RTF_PAR )
391cdf0e10cSrcweir 			{
392cdf0e10cSrcweir 				NewCellRow();
393cdf0e10cSrcweir 				mnLastToken = pInfo->nToken;
394cdf0e10cSrcweir 			}
395cdf0e10cSrcweir 		}
396cdf0e10cSrcweir 		break;
397cdf0e10cSrcweir 		case RTF_CELL:			// denotes the end of a cell.
398cdf0e10cSrcweir 		{
399cdf0e10cSrcweir 			DBG_ASSERT( mpActDefault, "RTF_CELL: pActDefault==0" );
400cdf0e10cSrcweir 			if ( mbNewDef || !mpActDefault )
401cdf0e10cSrcweir 				NewCellRow();
402cdf0e10cSrcweir 			if ( !mpActDefault )
403cdf0e10cSrcweir 				mpActDefault = mpInsDefault;
404cdf0e10cSrcweir 			if ( mpActDefault->mnColSpan > 0 )
405cdf0e10cSrcweir 			{
406cdf0e10cSrcweir 				InsertCell(pInfo);
407cdf0e10cSrcweir 			}
408cdf0e10cSrcweir 			NextColumn();
409cdf0e10cSrcweir 			mnLastToken = pInfo->nToken;
410cdf0e10cSrcweir 		}
411cdf0e10cSrcweir 		break;
412cdf0e10cSrcweir 		case RTF_ROW:			// means the end of a row
413cdf0e10cSrcweir 		{
414cdf0e10cSrcweir 			NextRow();
415cdf0e10cSrcweir 			mnLastToken = pInfo->nToken;
416cdf0e10cSrcweir 		}
417cdf0e10cSrcweir 		break;
418cdf0e10cSrcweir 		case RTF_PAR:			// Paragraph
419cdf0e10cSrcweir 			mnLastToken = pInfo->nToken;
420cdf0e10cSrcweir 			break;
421cdf0e10cSrcweir 		default:
422cdf0e10cSrcweir 		{	// do not set nLastToken
423cdf0e10cSrcweir 			switch ( pInfo->nToken & ~(0xff | RTF_TABLEDEF) )
424cdf0e10cSrcweir 			{
425cdf0e10cSrcweir 				case RTF_SHADINGDEF:
426cdf0e10cSrcweir //					((SvxRTFParser*)pInfo->pParser)->ReadBackgroundAttr(pInfo->nToken, mpInsDefault->maItemSet, sal_True );
427cdf0e10cSrcweir 				break;
428cdf0e10cSrcweir 				case RTF_BRDRDEF:
429cdf0e10cSrcweir 					((SvxRTFParser*)pInfo->pParser)->ReadBorderAttr(pInfo->nToken, mpInsDefault->maItemSet, sal_True );
430cdf0e10cSrcweir 				break;
431cdf0e10cSrcweir 			}
432cdf0e10cSrcweir 		}
433cdf0e10cSrcweir 	}
434cdf0e10cSrcweir }
435cdf0e10cSrcweir 
ImportAsRTF(SvStream & rStream,SdrTableObj & rObj)436cdf0e10cSrcweir void SdrTableObj::ImportAsRTF( SvStream& rStream, SdrTableObj& rObj )
437cdf0e10cSrcweir {
438cdf0e10cSrcweir 	SdrTableRTFParser aParser( rObj );
439cdf0e10cSrcweir 	aParser.Read( rStream );
440cdf0e10cSrcweir }
441cdf0e10cSrcweir 
442cdf0e10cSrcweir } }
443cdf0e10cSrcweir 
444