xref: /aoo41x/main/sc/source/core/data/table2.cxx (revision 17ebb29c)
1b3f79822SAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3b3f79822SAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4b3f79822SAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5b3f79822SAndrew Rist  * distributed with this work for additional information
6b3f79822SAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7b3f79822SAndrew Rist  * to you under the Apache License, Version 2.0 (the
8b3f79822SAndrew Rist  * "License"); you may not use this file except in compliance
9b3f79822SAndrew Rist  * with the License.  You may obtain a copy of the License at
10b3f79822SAndrew Rist  *
11b3f79822SAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12b3f79822SAndrew Rist  *
13b3f79822SAndrew Rist  * Unless required by applicable law or agreed to in writing,
14b3f79822SAndrew Rist  * software distributed under the License is distributed on an
15b3f79822SAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16b3f79822SAndrew Rist  * KIND, either express or implied.  See the License for the
17b3f79822SAndrew Rist  * specific language governing permissions and limitations
18b3f79822SAndrew Rist  * under the License.
19b3f79822SAndrew Rist  *
20b3f79822SAndrew Rist  *************************************************************/
21b3f79822SAndrew Rist 
22b3f79822SAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
25cdf0e10cSrcweir #include "precompiled_sc.hxx"
26cdf0e10cSrcweir 
27cdf0e10cSrcweir // INCLUDE ---------------------------------------------------------------
28cdf0e10cSrcweir 
29cdf0e10cSrcweir #include "scitems.hxx"
30cdf0e10cSrcweir #include <editeng/boxitem.hxx>
31cdf0e10cSrcweir #include <tools/urlobj.hxx>
32cdf0e10cSrcweir #include <svl/poolcach.hxx>
33cdf0e10cSrcweir #include <unotools/charclass.hxx>
34cdf0e10cSrcweir #include <math.h>
35cdf0e10cSrcweir #include <svl/PasswordHelper.hxx>
36cdf0e10cSrcweir #include <unotools/transliterationwrapper.hxx>
37cdf0e10cSrcweir 
38cdf0e10cSrcweir #include "patattr.hxx"
39cdf0e10cSrcweir #include "docpool.hxx"
40cdf0e10cSrcweir #include "cell.hxx"
41cdf0e10cSrcweir #include "document.hxx"
42cdf0e10cSrcweir #include "drwlayer.hxx"
43cdf0e10cSrcweir #include "olinetab.hxx"
44cdf0e10cSrcweir #include "rechead.hxx"
45cdf0e10cSrcweir #include "stlpool.hxx"
46cdf0e10cSrcweir #include "attarray.hxx"		// Iterator
47cdf0e10cSrcweir #include "markdata.hxx"
48cdf0e10cSrcweir #include "progress.hxx"
49cdf0e10cSrcweir #include "dociter.hxx"
50cdf0e10cSrcweir #include "conditio.hxx"
51cdf0e10cSrcweir #include "chartlis.hxx"
52cdf0e10cSrcweir #include "fillinfo.hxx"
53cdf0e10cSrcweir #include "bcaslot.hxx"
54cdf0e10cSrcweir #include "postit.hxx"
55cdf0e10cSrcweir #include "sheetevents.hxx"
56cdf0e10cSrcweir #include "globstr.hrc"
57cdf0e10cSrcweir #include "segmenttree.hxx"
58cdf0e10cSrcweir #include "dbcolect.hxx"
59cdf0e10cSrcweir 
60cdf0e10cSrcweir #include <math.h>
61cdf0e10cSrcweir 
62cdf0e10cSrcweir // STATIC DATA -----------------------------------------------------------
63cdf0e10cSrcweir 
64cdf0e10cSrcweir 
SetOutlineTable(const ScOutlineTable * pNewOutline)65cdf0e10cSrcweir sal_Bool ScTable::SetOutlineTable( const ScOutlineTable* pNewOutline )
66cdf0e10cSrcweir {
67cdf0e10cSrcweir 	sal_uInt16 nOldSizeX = 0;
68cdf0e10cSrcweir 	sal_uInt16 nOldSizeY = 0;
69cdf0e10cSrcweir 	sal_uInt16 nNewSizeX = 0;
70cdf0e10cSrcweir 	sal_uInt16 nNewSizeY = 0;
71cdf0e10cSrcweir 
72cdf0e10cSrcweir 	if (pOutlineTable)
73cdf0e10cSrcweir 	{
74cdf0e10cSrcweir 		nOldSizeX = pOutlineTable->GetColArray()->GetDepth();
75cdf0e10cSrcweir 		nOldSizeY = pOutlineTable->GetRowArray()->GetDepth();
76cdf0e10cSrcweir 		delete pOutlineTable;
77cdf0e10cSrcweir 	}
78cdf0e10cSrcweir 
79cdf0e10cSrcweir 	if (pNewOutline)
80cdf0e10cSrcweir 	{
81cdf0e10cSrcweir 		pOutlineTable = new ScOutlineTable( *pNewOutline );
82cdf0e10cSrcweir 		nNewSizeX = pOutlineTable->GetColArray()->GetDepth();
83cdf0e10cSrcweir 		nNewSizeY = pOutlineTable->GetRowArray()->GetDepth();
84cdf0e10cSrcweir 	}
85cdf0e10cSrcweir 	else
86cdf0e10cSrcweir 		pOutlineTable = NULL;
87cdf0e10cSrcweir 
88cdf0e10cSrcweir 	return ( nNewSizeX != nOldSizeX || nNewSizeY != nOldSizeY );		// Groesse geaendert ?
89cdf0e10cSrcweir }
90cdf0e10cSrcweir 
91cdf0e10cSrcweir 
StartOutlineTable()92cdf0e10cSrcweir void ScTable::StartOutlineTable()
93cdf0e10cSrcweir {
94cdf0e10cSrcweir 	if (!pOutlineTable)
95cdf0e10cSrcweir 		pOutlineTable = new ScOutlineTable;
96cdf0e10cSrcweir }
97cdf0e10cSrcweir 
98cdf0e10cSrcweir 
SetSheetEvents(const ScSheetEvents * pNew)99cdf0e10cSrcweir void ScTable::SetSheetEvents( const ScSheetEvents* pNew )
100cdf0e10cSrcweir {
101cdf0e10cSrcweir     delete pSheetEvents;
102cdf0e10cSrcweir     if (pNew)
103cdf0e10cSrcweir         pSheetEvents = new ScSheetEvents(*pNew);
104cdf0e10cSrcweir     else
105cdf0e10cSrcweir         pSheetEvents = NULL;
106cdf0e10cSrcweir 
107cdf0e10cSrcweir     SetCalcNotification( sal_False );       // discard notifications before the events were set
108cdf0e10cSrcweir 
109cdf0e10cSrcweir     if (IsStreamValid())
110cdf0e10cSrcweir         SetStreamValid(sal_False);
111cdf0e10cSrcweir }
112cdf0e10cSrcweir 
113cdf0e10cSrcweir 
SetCalcNotification(sal_Bool bSet)114cdf0e10cSrcweir void ScTable::SetCalcNotification( sal_Bool bSet )
115cdf0e10cSrcweir {
116cdf0e10cSrcweir     bCalcNotification = bSet;
117cdf0e10cSrcweir }
118cdf0e10cSrcweir 
119cdf0e10cSrcweir 
TestInsertRow(SCCOL nStartCol,SCCOL nEndCol,SCSIZE nSize)120cdf0e10cSrcweir sal_Bool ScTable::TestInsertRow( SCCOL nStartCol, SCCOL nEndCol, SCSIZE nSize )
121cdf0e10cSrcweir {
122cdf0e10cSrcweir 	sal_Bool bTest = sal_True;
123cdf0e10cSrcweir 
124cdf0e10cSrcweir 	if ( nStartCol==0 && nEndCol==MAXCOL && pOutlineTable )
125cdf0e10cSrcweir 		bTest = pOutlineTable->TestInsertRow(nSize);
126cdf0e10cSrcweir 
127cdf0e10cSrcweir 	for (SCCOL i=nStartCol; (i<=nEndCol) && bTest; i++)
128cdf0e10cSrcweir 		bTest = aCol[i].TestInsertRow( nSize );
129cdf0e10cSrcweir 
130cdf0e10cSrcweir 	return bTest;
131cdf0e10cSrcweir }
132cdf0e10cSrcweir 
133cdf0e10cSrcweir 
InsertRow(SCCOL nStartCol,SCCOL nEndCol,SCROW nStartRow,SCSIZE nSize)134cdf0e10cSrcweir void ScTable::InsertRow( SCCOL nStartCol, SCCOL nEndCol, SCROW nStartRow, SCSIZE nSize )
135cdf0e10cSrcweir {
136cdf0e10cSrcweir 	IncRecalcLevel();
137cdf0e10cSrcweir     InitializeNoteCaptions();
138cdf0e10cSrcweir 	if (nStartCol==0 && nEndCol==MAXCOL)
139cdf0e10cSrcweir 	{
140cdf0e10cSrcweir         if (mpRowHeights && pRowFlags)
141cdf0e10cSrcweir 		{
142cdf0e10cSrcweir             mpRowHeights->insertSegment(nStartRow, nSize, false);
143cdf0e10cSrcweir             sal_uInt8 nNewFlags = pRowFlags->Insert( nStartRow, nSize);
144cdf0e10cSrcweir             // only copy manual size flag, clear all others
145cdf0e10cSrcweir             if (nNewFlags && (nNewFlags != CR_MANUALSIZE))
146cdf0e10cSrcweir                 pRowFlags->SetValue( nStartRow, nStartRow + nSize - 1,
147cdf0e10cSrcweir                         nNewFlags & CR_MANUALSIZE);
148cdf0e10cSrcweir 		}
149cdf0e10cSrcweir 
150cdf0e10cSrcweir 		if (pOutlineTable)
151cdf0e10cSrcweir 			pOutlineTable->InsertRow( nStartRow, nSize );
152cdf0e10cSrcweir 
153cdf0e10cSrcweir         mpFilteredRows->insertSegment(nStartRow, nSize, true);
154cdf0e10cSrcweir         mpHiddenRows->insertSegment(nStartRow, nSize, true);
155cdf0e10cSrcweir 
156cdf0e10cSrcweir         if (!maRowManualBreaks.empty())
157cdf0e10cSrcweir         {
158a54c2933SAndre Fischer             std::vector<SCROW> aUpdatedBreaks;
159a54c2933SAndre Fischer 
160a54c2933SAndre Fischer             while ( ! maRowManualBreaks.empty())
161cdf0e10cSrcweir             {
162a54c2933SAndre Fischer                 std::set<SCROW>::iterator aLast (--maRowManualBreaks.end());
163a54c2933SAndre Fischer 
164a54c2933SAndre Fischer                 // Check if there are more entries that have to be processed.
165a54c2933SAndre Fischer                 if (*aLast < nStartRow)
166a54c2933SAndre Fischer                     break;
167a54c2933SAndre Fischer 
168a54c2933SAndre Fischer                 // Remember the updated break location and erase the entry.
169a54c2933SAndre Fischer                 aUpdatedBreaks.push_back(static_cast<SCROW>(*aLast + nSize));
170a54c2933SAndre Fischer                 maRowManualBreaks.erase(aLast);
171cdf0e10cSrcweir             }
172a54c2933SAndre Fischer 
173a54c2933SAndre Fischer             // Insert the updated break locations.
174a54c2933SAndre Fischer             if ( ! aUpdatedBreaks.empty())
175a54c2933SAndre Fischer                 maRowManualBreaks.insert(aUpdatedBreaks.begin(), aUpdatedBreaks.end());
176cdf0e10cSrcweir         }
177cdf0e10cSrcweir 	}
178cdf0e10cSrcweir 
179cdf0e10cSrcweir 	for (SCCOL j=nStartCol; j<=nEndCol; j++)
180cdf0e10cSrcweir 		aCol[j].InsertRow( nStartRow, nSize );
181cdf0e10cSrcweir 	DecRecalcLevel( false );
182cdf0e10cSrcweir 
183cdf0e10cSrcweir     InvalidatePageBreaks();
184cdf0e10cSrcweir }
185cdf0e10cSrcweir 
186cdf0e10cSrcweir 
DeleteRow(SCCOL nStartCol,SCCOL nEndCol,SCROW nStartRow,SCSIZE nSize,sal_Bool * pUndoOutline)187cdf0e10cSrcweir void ScTable::DeleteRow( SCCOL nStartCol, SCCOL nEndCol, SCROW nStartRow, SCSIZE nSize,
188cdf0e10cSrcweir 							sal_Bool* pUndoOutline )
189cdf0e10cSrcweir {
190cdf0e10cSrcweir 	IncRecalcLevel();
191cdf0e10cSrcweir     InitializeNoteCaptions();
192cdf0e10cSrcweir 	if (nStartCol==0 && nEndCol==MAXCOL)
193cdf0e10cSrcweir 	{
194cdf0e10cSrcweir         if (pRowFlags)
195cdf0e10cSrcweir             pRowFlags->Remove( nStartRow, nSize);
196cdf0e10cSrcweir 
197cdf0e10cSrcweir         if (mpRowHeights)
198cdf0e10cSrcweir             mpRowHeights->removeSegment(nStartRow, nStartRow+nSize);
199cdf0e10cSrcweir 
200cdf0e10cSrcweir 		if (pOutlineTable)
201cdf0e10cSrcweir 			if (pOutlineTable->DeleteRow( nStartRow, nSize ))
202cdf0e10cSrcweir 				if (pUndoOutline)
203cdf0e10cSrcweir 					*pUndoOutline = sal_True;
204cdf0e10cSrcweir 
205cdf0e10cSrcweir         mpFilteredRows->removeSegment(nStartRow, nStartRow+nSize);
206cdf0e10cSrcweir         mpHiddenRows->removeSegment(nStartRow, nStartRow+nSize);
207cdf0e10cSrcweir 
208cdf0e10cSrcweir         if (!maRowManualBreaks.empty())
209cdf0e10cSrcweir         {
210cdf0e10cSrcweir             std::set<SCROW>::iterator it = maRowManualBreaks.upper_bound( static_cast<SCROW>( nStartRow + nSize - 1));
211cdf0e10cSrcweir             maRowManualBreaks.erase( maRowManualBreaks.lower_bound( nStartRow), it);
212cdf0e10cSrcweir             while (it != maRowManualBreaks.end())
213cdf0e10cSrcweir             {
214cdf0e10cSrcweir                 SCROW nRow = *it;
215cdf0e10cSrcweir                 maRowManualBreaks.erase( it++);
216cdf0e10cSrcweir                 maRowManualBreaks.insert( static_cast<SCROW>( nRow - nSize));
217cdf0e10cSrcweir             }
218cdf0e10cSrcweir         }
219cdf0e10cSrcweir 	}
220cdf0e10cSrcweir 
221cdf0e10cSrcweir     {   // scope for bulk broadcast
222cdf0e10cSrcweir         ScBulkBroadcast aBulkBroadcast( pDocument->GetBASM());
223cdf0e10cSrcweir         for (SCCOL j=nStartCol; j<=nEndCol; j++)
224cdf0e10cSrcweir             aCol[j].DeleteRow( nStartRow, nSize );
225cdf0e10cSrcweir     }
226cdf0e10cSrcweir 	DecRecalcLevel();
227cdf0e10cSrcweir 
228cdf0e10cSrcweir     InvalidatePageBreaks();
229cdf0e10cSrcweir }
230cdf0e10cSrcweir 
231cdf0e10cSrcweir 
TestInsertCol(SCROW nStartRow,SCROW nEndRow,SCSIZE nSize)232cdf0e10cSrcweir sal_Bool ScTable::TestInsertCol( SCROW nStartRow, SCROW nEndRow, SCSIZE nSize )
233cdf0e10cSrcweir {
234cdf0e10cSrcweir 	sal_Bool bTest = sal_True;
235cdf0e10cSrcweir 
236cdf0e10cSrcweir 	if ( nStartRow==0 && nEndRow==MAXROW && pOutlineTable )
237cdf0e10cSrcweir 		bTest = pOutlineTable->TestInsertCol(nSize);
238cdf0e10cSrcweir 
239cdf0e10cSrcweir 	if ( nSize > static_cast<SCSIZE>(MAXCOL) )
240cdf0e10cSrcweir 		bTest = sal_False;
241cdf0e10cSrcweir 
242cdf0e10cSrcweir 	for (SCCOL i=MAXCOL; (i+static_cast<SCCOL>(nSize)>MAXCOL) && bTest; i--)
243cdf0e10cSrcweir 		bTest = aCol[i].TestInsertCol(nStartRow, nEndRow);
244cdf0e10cSrcweir 
245cdf0e10cSrcweir 	return bTest;
246cdf0e10cSrcweir }
247cdf0e10cSrcweir 
248cdf0e10cSrcweir 
InsertCol(SCCOL nStartCol,SCROW nStartRow,SCROW nEndRow,SCSIZE nSize)249cdf0e10cSrcweir void ScTable::InsertCol( SCCOL nStartCol, SCROW nStartRow, SCROW nEndRow, SCSIZE nSize )
250cdf0e10cSrcweir {
251cdf0e10cSrcweir 	IncRecalcLevel();
252cdf0e10cSrcweir     InitializeNoteCaptions();
253cdf0e10cSrcweir 	if (nStartRow==0 && nEndRow==MAXROW)
254cdf0e10cSrcweir 	{
255cdf0e10cSrcweir 		if (pColWidth && pColFlags)
256cdf0e10cSrcweir         {
257cdf0e10cSrcweir             memmove( &pColWidth[nStartCol+nSize], &pColWidth[nStartCol],
258cdf0e10cSrcweir                     (MAXCOL - nStartCol + 1 - nSize) * sizeof(pColWidth[0]) );
259cdf0e10cSrcweir             memmove( &pColFlags[nStartCol+nSize], &pColFlags[nStartCol],
260cdf0e10cSrcweir                     (MAXCOL - nStartCol + 1 - nSize) * sizeof(pColFlags[0]) );
261cdf0e10cSrcweir         }
262cdf0e10cSrcweir 		if (pOutlineTable)
263cdf0e10cSrcweir 			pOutlineTable->InsertCol( nStartCol, nSize );
264cdf0e10cSrcweir 
265cdf0e10cSrcweir         mpHiddenCols->insertSegment(nStartCol, static_cast<SCCOL>(nSize), true);
266cdf0e10cSrcweir         mpFilteredCols->insertSegment(nStartCol, static_cast<SCCOL>(nSize), true);
267cdf0e10cSrcweir 
268cdf0e10cSrcweir         if (!maColManualBreaks.empty())
269cdf0e10cSrcweir         {
270*17ebb29cSAndre Fischer             std::vector<SCCOL> aUpdatedBreaks;
271*17ebb29cSAndre Fischer 
272*17ebb29cSAndre Fischer             while ( ! maColManualBreaks.empty())
273cdf0e10cSrcweir             {
274*17ebb29cSAndre Fischer                 std::set<SCCOL>::iterator aLast (--maColManualBreaks.end());
275*17ebb29cSAndre Fischer 
276*17ebb29cSAndre Fischer                 // Check if there are more entries that have to be processed.
277*17ebb29cSAndre Fischer                 if (*aLast < nStartRow)
278*17ebb29cSAndre Fischer                     break;
279*17ebb29cSAndre Fischer 
280*17ebb29cSAndre Fischer                 // Remember the updated break location and erase the entry.
281*17ebb29cSAndre Fischer                 aUpdatedBreaks.push_back(static_cast<SCCOL>(*aLast + nSize));
282*17ebb29cSAndre Fischer                 maColManualBreaks.erase(aLast);
283cdf0e10cSrcweir             }
284*17ebb29cSAndre Fischer 
285*17ebb29cSAndre Fischer             // Insert the updated break locations.
286*17ebb29cSAndre Fischer             if ( ! aUpdatedBreaks.empty())
287*17ebb29cSAndre Fischer                 maColManualBreaks.insert(aUpdatedBreaks.begin(), aUpdatedBreaks.end());
288cdf0e10cSrcweir         }
289cdf0e10cSrcweir 	}
290cdf0e10cSrcweir 
291cdf0e10cSrcweir 
292cdf0e10cSrcweir 	if ((nStartRow == 0) && (nEndRow == MAXROW))
293cdf0e10cSrcweir 	{
294cdf0e10cSrcweir 		for (SCSIZE i=0; i < nSize; i++)
295cdf0e10cSrcweir 			for (SCCOL nCol = MAXCOL; nCol > nStartCol; nCol--)
296cdf0e10cSrcweir 				aCol[nCol].SwapCol(aCol[nCol-1]);
297cdf0e10cSrcweir 	}
298cdf0e10cSrcweir 	else
299cdf0e10cSrcweir 	{
300cdf0e10cSrcweir 		for (SCSIZE i=0; static_cast<SCCOL>(i+nSize)+nStartCol <= MAXCOL; i++)
301cdf0e10cSrcweir 			aCol[MAXCOL - nSize - i].MoveTo(nStartRow, nEndRow, aCol[MAXCOL - i]);
302cdf0e10cSrcweir 	}
303cdf0e10cSrcweir 
304cdf0e10cSrcweir 	if (nStartCol>0)						// copy old attributes
305cdf0e10cSrcweir 	{
306cdf0e10cSrcweir 		sal_uInt16 nWhichArray[2];
307cdf0e10cSrcweir 		nWhichArray[0] = ATTR_MERGE;
308cdf0e10cSrcweir 		nWhichArray[1] = 0;
309cdf0e10cSrcweir 
310cdf0e10cSrcweir 		for (SCSIZE i=0; i<nSize; i++)
311cdf0e10cSrcweir 		{
312cdf0e10cSrcweir 			aCol[nStartCol-1].CopyToColumn( nStartRow, nEndRow, IDF_ATTRIB,
313cdf0e10cSrcweir 												sal_False, aCol[nStartCol+i] );
314cdf0e10cSrcweir 			aCol[nStartCol+i].RemoveFlags( nStartRow, nEndRow,
315cdf0e10cSrcweir 												SC_MF_HOR | SC_MF_VER | SC_MF_AUTO );
316cdf0e10cSrcweir 			aCol[nStartCol+i].ClearItems( nStartRow, nEndRow, nWhichArray );
317cdf0e10cSrcweir 		}
318cdf0e10cSrcweir 	}
319cdf0e10cSrcweir 	DecRecalcLevel();
320cdf0e10cSrcweir 
321cdf0e10cSrcweir     InvalidatePageBreaks();
322cdf0e10cSrcweir }
323cdf0e10cSrcweir 
324cdf0e10cSrcweir 
DeleteCol(SCCOL nStartCol,SCROW nStartRow,SCROW nEndRow,SCSIZE nSize,sal_Bool * pUndoOutline)325cdf0e10cSrcweir void ScTable::DeleteCol( SCCOL nStartCol, SCROW nStartRow, SCROW nEndRow, SCSIZE nSize,
326cdf0e10cSrcweir 							sal_Bool* pUndoOutline )
327cdf0e10cSrcweir {
328cdf0e10cSrcweir 	IncRecalcLevel();
329cdf0e10cSrcweir     InitializeNoteCaptions();
330cdf0e10cSrcweir 	if (nStartRow==0 && nEndRow==MAXROW)
331cdf0e10cSrcweir 	{
332cdf0e10cSrcweir 		if (pColWidth && pColFlags)
333cdf0e10cSrcweir         {
334cdf0e10cSrcweir             memmove( &pColWidth[nStartCol], &pColWidth[nStartCol+nSize],
335cdf0e10cSrcweir                     (MAXCOL - nStartCol + 1 - nSize) * sizeof(pColWidth[0]) );
336cdf0e10cSrcweir             memmove( &pColFlags[nStartCol], &pColFlags[nStartCol+nSize],
337cdf0e10cSrcweir                     (MAXCOL - nStartCol + 1 - nSize) * sizeof(pColFlags[0]) );
338cdf0e10cSrcweir         }
339cdf0e10cSrcweir 		if (pOutlineTable)
340cdf0e10cSrcweir 			if (pOutlineTable->DeleteCol( nStartCol, nSize ))
341cdf0e10cSrcweir 				if (pUndoOutline)
342cdf0e10cSrcweir 					*pUndoOutline = sal_True;
343cdf0e10cSrcweir 
344cdf0e10cSrcweir         SCCOL nRmSize = nStartCol + static_cast<SCCOL>(nSize);
345cdf0e10cSrcweir         mpHiddenCols->removeSegment(nStartCol, nRmSize);
346cdf0e10cSrcweir         mpFilteredCols->removeSegment(nStartCol, nRmSize);
347cdf0e10cSrcweir 
348cdf0e10cSrcweir         if (!maColManualBreaks.empty())
349cdf0e10cSrcweir         {
350cdf0e10cSrcweir             std::set<SCCOL>::iterator it = maColManualBreaks.upper_bound( static_cast<SCCOL>( nStartCol + nSize - 1));
351cdf0e10cSrcweir             maColManualBreaks.erase( maColManualBreaks.lower_bound( nStartCol), it);
352cdf0e10cSrcweir             while (it != maColManualBreaks.end())
353cdf0e10cSrcweir             {
354cdf0e10cSrcweir                 SCCOL nCol = *it;
355cdf0e10cSrcweir                 maColManualBreaks.erase( it++);
356cdf0e10cSrcweir                 maColManualBreaks.insert( static_cast<SCCOL>( nCol - nSize));
357cdf0e10cSrcweir             }
358cdf0e10cSrcweir         }
359cdf0e10cSrcweir 	}
360cdf0e10cSrcweir 
361cdf0e10cSrcweir 
362cdf0e10cSrcweir     {   // scope for bulk broadcast
363cdf0e10cSrcweir         ScBulkBroadcast aBulkBroadcast( pDocument->GetBASM());
364cdf0e10cSrcweir         for (SCSIZE i = 0; i < nSize; i++)
365cdf0e10cSrcweir             aCol[nStartCol + i].DeleteArea(nStartRow, nEndRow, IDF_ALL);
366cdf0e10cSrcweir     }
367cdf0e10cSrcweir 
368cdf0e10cSrcweir 	if ((nStartRow == 0) && (nEndRow == MAXROW))
369cdf0e10cSrcweir 	{
370cdf0e10cSrcweir 		for (SCSIZE i=0; i < nSize; i++)
371cdf0e10cSrcweir 			for (SCCOL nCol = nStartCol; nCol < MAXCOL; nCol++)
372cdf0e10cSrcweir 				aCol[nCol].SwapCol(aCol[nCol+1]);
373cdf0e10cSrcweir 	}
374cdf0e10cSrcweir 	else
375cdf0e10cSrcweir 	{
376cdf0e10cSrcweir 		for (SCSIZE i=0; static_cast<SCCOL>(i+nSize)+nStartCol <= MAXCOL; i++)
377cdf0e10cSrcweir 			aCol[nStartCol + nSize + i].MoveTo(nStartRow, nEndRow, aCol[nStartCol + i]);
378cdf0e10cSrcweir 	}
379cdf0e10cSrcweir 	DecRecalcLevel();
380cdf0e10cSrcweir 
381cdf0e10cSrcweir     InvalidatePageBreaks();
382cdf0e10cSrcweir }
383cdf0e10cSrcweir 
384cdf0e10cSrcweir 
DeleteArea(SCCOL nCol1,SCROW nRow1,SCCOL nCol2,SCROW nRow2,sal_uInt16 nDelFlag)385cdf0e10cSrcweir void ScTable::DeleteArea(SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2, sal_uInt16 nDelFlag)
386cdf0e10cSrcweir {
387cdf0e10cSrcweir 	if (nCol2 > MAXCOL) nCol2 = MAXCOL;
388cdf0e10cSrcweir 	if (nRow2 > MAXROW) nRow2 = MAXROW;
389cdf0e10cSrcweir 	if (ValidColRow(nCol1, nRow1) && ValidColRow(nCol2, nRow2))
390cdf0e10cSrcweir 	{
391cdf0e10cSrcweir //		IncRecalcLevel();
392cdf0e10cSrcweir 
393cdf0e10cSrcweir         {   // scope for bulk broadcast
394cdf0e10cSrcweir             ScBulkBroadcast aBulkBroadcast( pDocument->GetBASM());
395cdf0e10cSrcweir             for (SCCOL i = nCol1; i <= nCol2; i++)
396cdf0e10cSrcweir                 aCol[i].DeleteArea(nRow1, nRow2, nDelFlag);
397cdf0e10cSrcweir         }
398cdf0e10cSrcweir 
399cdf0e10cSrcweir 			//
400cdf0e10cSrcweir 			// Zellschutz auf geschuetzter Tabelle nicht setzen
401cdf0e10cSrcweir 			//
402cdf0e10cSrcweir 
403cdf0e10cSrcweir 		if ( IsProtected() && (nDelFlag & IDF_ATTRIB) )
404cdf0e10cSrcweir 		{
405cdf0e10cSrcweir 			ScPatternAttr aPattern(pDocument->GetPool());
406cdf0e10cSrcweir 			aPattern.GetItemSet().Put( ScProtectionAttr( sal_False ) );
407cdf0e10cSrcweir 			ApplyPatternArea( nCol1, nRow1, nCol2, nRow2, aPattern );
408cdf0e10cSrcweir 		}
409cdf0e10cSrcweir 
410cdf0e10cSrcweir //		DecRecalcLevel();
411cdf0e10cSrcweir 	}
412cdf0e10cSrcweir }
413cdf0e10cSrcweir 
414cdf0e10cSrcweir 
DeleteSelection(sal_uInt16 nDelFlag,const ScMarkData & rMark)415cdf0e10cSrcweir void ScTable::DeleteSelection( sal_uInt16 nDelFlag, const ScMarkData& rMark )
416cdf0e10cSrcweir {
417cdf0e10cSrcweir     {   // scope for bulk broadcast
418cdf0e10cSrcweir         ScBulkBroadcast aBulkBroadcast( pDocument->GetBASM());
419cdf0e10cSrcweir         for (SCCOL i=0; i<=MAXCOL; i++)
420cdf0e10cSrcweir             aCol[i].DeleteSelection( nDelFlag, rMark );
421cdf0e10cSrcweir     }
422cdf0e10cSrcweir 
423cdf0e10cSrcweir 		//
424cdf0e10cSrcweir 		// Zellschutz auf geschuetzter Tabelle nicht setzen
425cdf0e10cSrcweir 		//
426cdf0e10cSrcweir 
427cdf0e10cSrcweir 	if ( IsProtected() && (nDelFlag & IDF_ATTRIB) )
428cdf0e10cSrcweir 	{
429cdf0e10cSrcweir 		ScDocumentPool* pPool = pDocument->GetPool();
430cdf0e10cSrcweir 		SfxItemSet aSet( *pPool, ATTR_PATTERN_START, ATTR_PATTERN_END );
431cdf0e10cSrcweir 		aSet.Put( ScProtectionAttr( sal_False ) );
432cdf0e10cSrcweir 		SfxItemPoolCache aCache( pPool, &aSet );
433cdf0e10cSrcweir 		ApplySelectionCache( &aCache, rMark );
434cdf0e10cSrcweir 	}
435cdf0e10cSrcweir }
436cdf0e10cSrcweir 
437cdf0e10cSrcweir 
438cdf0e10cSrcweir //	pTable = Clipboard
CopyToClip(SCCOL nCol1,SCROW nRow1,SCCOL nCol2,SCROW nRow2,ScTable * pTable,sal_Bool bKeepScenarioFlags,sal_Bool bCloneNoteCaptions)439cdf0e10cSrcweir void ScTable::CopyToClip(SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2,
440cdf0e10cSrcweir                         ScTable* pTable, sal_Bool bKeepScenarioFlags, sal_Bool bCloneNoteCaptions)
441cdf0e10cSrcweir {
442cdf0e10cSrcweir 	if (ValidColRow(nCol1, nRow1) && ValidColRow(nCol2, nRow2))
443cdf0e10cSrcweir 	{
444cdf0e10cSrcweir 		//	Inhalte kopieren
445cdf0e10cSrcweir 		SCCOL i;
446cdf0e10cSrcweir 
447cdf0e10cSrcweir 		for ( i = nCol1; i <= nCol2; i++)
448cdf0e10cSrcweir             aCol[i].CopyToClip(nRow1, nRow2, pTable->aCol[i], bKeepScenarioFlags, bCloneNoteCaptions);
449cdf0e10cSrcweir 
450cdf0e10cSrcweir 		//	copy widths/heights, and only "hidden", "filtered" and "manual" flags
451cdf0e10cSrcweir 		//	also for all preceding columns/rows, to have valid positions for drawing objects
452cdf0e10cSrcweir 
453cdf0e10cSrcweir 		if (pColWidth && pTable->pColWidth)
454cdf0e10cSrcweir 			for (i=0; i<=nCol2; i++)
455cdf0e10cSrcweir 				pTable->pColWidth[i] = pColWidth[i];
456cdf0e10cSrcweir 
457cdf0e10cSrcweir         pTable->CopyColHidden(*this, 0, nCol2);
458cdf0e10cSrcweir         pTable->CopyColFiltered(*this, 0, nCol2);
459cdf0e10cSrcweir 
460cdf0e10cSrcweir         if (pRowFlags && pTable->pRowFlags && mpRowHeights && pTable->mpRowHeights)
461cdf0e10cSrcweir         {
462cdf0e10cSrcweir             pTable->pRowFlags->CopyFromAnded( *pRowFlags, 0, nRow2, CR_MANUALSIZE);
463cdf0e10cSrcweir             pTable->CopyRowHeight(*this, 0, nRow2, 0);
464cdf0e10cSrcweir         }
465cdf0e10cSrcweir 
466cdf0e10cSrcweir         pTable->CopyRowHidden(*this, 0, nRow2);
467cdf0e10cSrcweir         pTable->CopyRowFiltered(*this, 0, nRow2);
468cdf0e10cSrcweir 
469cdf0e10cSrcweir 		//	ggf. Formeln durch Werte ersetzen
470cdf0e10cSrcweir 
471cdf0e10cSrcweir 		if ( IsProtected() )
472cdf0e10cSrcweir 			for (i = nCol1; i <= nCol2; i++)
473cdf0e10cSrcweir 				pTable->aCol[i].RemoveProtected(nRow1, nRow2);
474cdf0e10cSrcweir 	}
475cdf0e10cSrcweir }
476cdf0e10cSrcweir 
CopyToClip(const ScRangeList & rRanges,ScTable * pTable,bool bKeepScenarioFlags,bool bCloneNoteCaptions)477cdf0e10cSrcweir void ScTable::CopyToClip(const ScRangeList& rRanges, ScTable* pTable,
478cdf0e10cSrcweir                          bool bKeepScenarioFlags, bool bCloneNoteCaptions)
479cdf0e10cSrcweir {
480cdf0e10cSrcweir     ScRangeList aRanges(rRanges);
481cdf0e10cSrcweir     for (ScRangePtr p = aRanges.First(); p; p = aRanges.Next())
482cdf0e10cSrcweir     {
483cdf0e10cSrcweir         CopyToClip(p->aStart.Col(), p->aStart.Row(), p->aEnd.Col(), p->aEnd.Row(),
484cdf0e10cSrcweir                    pTable, bKeepScenarioFlags, bCloneNoteCaptions);
485cdf0e10cSrcweir     }
486cdf0e10cSrcweir }
487cdf0e10cSrcweir 
CopyFromClip(SCCOL nCol1,SCROW nRow1,SCCOL nCol2,SCROW nRow2,SCsCOL nDx,SCsROW nDy,sal_uInt16 nInsFlag,sal_Bool bAsLink,sal_Bool bSkipAttrForEmpty,ScTable * pTable)488cdf0e10cSrcweir void ScTable::CopyFromClip(SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2,
489cdf0e10cSrcweir 							SCsCOL nDx, SCsROW nDy, sal_uInt16 nInsFlag,
490cdf0e10cSrcweir 							sal_Bool bAsLink, sal_Bool bSkipAttrForEmpty, ScTable* pTable)
491cdf0e10cSrcweir {
492cdf0e10cSrcweir 	SCCOL i;
493cdf0e10cSrcweir 
494cdf0e10cSrcweir 	if (nCol2 > MAXCOL) nCol2 = MAXCOL;
495cdf0e10cSrcweir 	if (nRow2 > MAXROW) nRow2 = MAXROW;
496cdf0e10cSrcweir 	if (ValidColRow(nCol1, nRow1) && ValidColRow(nCol2, nRow2))
497cdf0e10cSrcweir 	{
498cdf0e10cSrcweir 		IncRecalcLevel();
499cdf0e10cSrcweir 		for ( i = nCol1; i <= nCol2; i++)
500cdf0e10cSrcweir 			aCol[i].CopyFromClip(nRow1, nRow2, nDy, nInsFlag, bAsLink, bSkipAttrForEmpty, pTable->aCol[i - nDx]);
501cdf0e10cSrcweir 
502cdf0e10cSrcweir 		if ((nInsFlag & IDF_ATTRIB) != 0)
503cdf0e10cSrcweir 		{
504cdf0e10cSrcweir 			if (nRow1==0 && nRow2==MAXROW && pColWidth && pTable->pColWidth)
505cdf0e10cSrcweir 				for (i=nCol1; i<=nCol2; i++)
506cdf0e10cSrcweir 					pColWidth[i] = pTable->pColWidth[i-nDx];
507cdf0e10cSrcweir 
508cdf0e10cSrcweir             if (nCol1==0 && nCol2==MAXCOL && mpRowHeights && pTable->mpRowHeights &&
509cdf0e10cSrcweir 											 pRowFlags && pTable->pRowFlags)
510cdf0e10cSrcweir             {
511cdf0e10cSrcweir                 CopyRowHeight(*pTable, nRow1, nRow2, -nDy);
512cdf0e10cSrcweir                 // Must copy CR_MANUALSIZE bit too, otherwise pRowHeight doesn't make sense
513cdf0e10cSrcweir 				for (SCROW j=nRow1; j<=nRow2; j++)
514cdf0e10cSrcweir 				{
515cdf0e10cSrcweir 					if ( pTable->pRowFlags->GetValue(j-nDy) & CR_MANUALSIZE )
516cdf0e10cSrcweir 						pRowFlags->OrValue( j, CR_MANUALSIZE);
517cdf0e10cSrcweir 					else
518cdf0e10cSrcweir                         pRowFlags->AndValue( j, sal::static_int_cast<sal_uInt8>(~CR_MANUALSIZE));
519cdf0e10cSrcweir 				}
520cdf0e10cSrcweir             }
521cdf0e10cSrcweir 
522cdf0e10cSrcweir 				//
523cdf0e10cSrcweir 				// Zellschutz auf geschuetzter Tabelle nicht setzen
524cdf0e10cSrcweir 				//
525cdf0e10cSrcweir 
526cdf0e10cSrcweir 			if ( IsProtected() && (nInsFlag & IDF_ATTRIB) )
527cdf0e10cSrcweir 			{
528cdf0e10cSrcweir 				ScPatternAttr aPattern(pDocument->GetPool());
529cdf0e10cSrcweir 				aPattern.GetItemSet().Put( ScProtectionAttr( sal_False ) );
530cdf0e10cSrcweir 				ApplyPatternArea( nCol1, nRow1, nCol2, nRow2, aPattern );
531cdf0e10cSrcweir 			}
532cdf0e10cSrcweir 		}
533cdf0e10cSrcweir 		DecRecalcLevel();
534cdf0e10cSrcweir 	}
535cdf0e10cSrcweir }
536cdf0e10cSrcweir 
537cdf0e10cSrcweir 
MixData(SCCOL nCol1,SCROW nRow1,SCCOL nCol2,SCROW nRow2,sal_uInt16 nFunction,sal_Bool bSkipEmpty,ScTable * pSrcTab)538cdf0e10cSrcweir void ScTable::MixData( SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2,
539cdf0e10cSrcweir 							sal_uInt16 nFunction, sal_Bool bSkipEmpty, ScTable* pSrcTab )
540cdf0e10cSrcweir {
541cdf0e10cSrcweir 	for (SCCOL i=nCol1; i<=nCol2; i++)
542cdf0e10cSrcweir 		aCol[i].MixData( nRow1, nRow2, nFunction, bSkipEmpty, pSrcTab->aCol[i] );
543cdf0e10cSrcweir }
544cdf0e10cSrcweir 
545cdf0e10cSrcweir 
546cdf0e10cSrcweir //	Markierung von diesem Dokument
MixMarked(const ScMarkData & rMark,sal_uInt16 nFunction,sal_Bool bSkipEmpty,ScTable * pSrcTab)547cdf0e10cSrcweir void ScTable::MixMarked( const ScMarkData& rMark, sal_uInt16 nFunction,
548cdf0e10cSrcweir 						sal_Bool bSkipEmpty, ScTable* pSrcTab )
549cdf0e10cSrcweir {
550cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL; i++)
551cdf0e10cSrcweir 		aCol[i].MixMarked( rMark, nFunction, bSkipEmpty, pSrcTab->aCol[i] );
552cdf0e10cSrcweir }
553cdf0e10cSrcweir 
554cdf0e10cSrcweir 
TransposeClip(SCCOL nCol1,SCROW nRow1,SCCOL nCol2,SCROW nRow2,ScTable * pTransClip,sal_uInt16 nFlags,sal_Bool bAsLink)555cdf0e10cSrcweir void ScTable::TransposeClip( SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2,
556cdf0e10cSrcweir 								ScTable* pTransClip, sal_uInt16 nFlags, sal_Bool bAsLink )
557cdf0e10cSrcweir {
558cdf0e10cSrcweir 	sal_Bool bWasCut = pDocument->IsCutMode();
559cdf0e10cSrcweir 
560cdf0e10cSrcweir 	ScDocument* pDestDoc = pTransClip->pDocument;
561cdf0e10cSrcweir 
562cdf0e10cSrcweir 	for (SCCOL nCol=nCol1; nCol<=nCol2; nCol++)
563cdf0e10cSrcweir 	{
564cdf0e10cSrcweir 		SCROW nRow;
565cdf0e10cSrcweir 		ScBaseCell* pCell;
566cdf0e10cSrcweir 
567cdf0e10cSrcweir 		if ( bAsLink && nFlags == IDF_ALL )
568cdf0e10cSrcweir 		{
569cdf0e10cSrcweir 			//	#68989# with IDF_ALL, also create links (formulas) for empty cells
570cdf0e10cSrcweir 
571cdf0e10cSrcweir 			for ( nRow=nRow1; nRow<=nRow2; nRow++ )
572cdf0e10cSrcweir 			{
573cdf0e10cSrcweir 				//	create simple formula, as in ScColumn::CreateRefCell
574cdf0e10cSrcweir 
575cdf0e10cSrcweir 				ScAddress aDestPos( static_cast<SCCOL>(nRow-nRow1), static_cast<SCROW>(nCol-nCol1), pTransClip->nTab );
576cdf0e10cSrcweir 				ScSingleRefData aRef;
577cdf0e10cSrcweir 				aRef.nCol = nCol;
578cdf0e10cSrcweir 				aRef.nRow = nRow;
579cdf0e10cSrcweir 				aRef.nTab = nTab;
580cdf0e10cSrcweir 				aRef.InitFlags();							// -> all absolute
581cdf0e10cSrcweir 				aRef.SetFlag3D(sal_True);
582cdf0e10cSrcweir 				aRef.CalcRelFromAbs( aDestPos );
583cdf0e10cSrcweir 				ScTokenArray aArr;
584cdf0e10cSrcweir 				aArr.AddSingleReference( aRef );
585cdf0e10cSrcweir 
586cdf0e10cSrcweir 				ScBaseCell* pNew = new ScFormulaCell( pDestDoc, aDestPos, &aArr );
587cdf0e10cSrcweir 				pTransClip->PutCell( static_cast<SCCOL>(nRow-nRow1), static_cast<SCROW>(nCol-nCol1), pNew );
588cdf0e10cSrcweir 			}
589cdf0e10cSrcweir 		}
590cdf0e10cSrcweir 		else
591cdf0e10cSrcweir 		{
592cdf0e10cSrcweir 			ScColumnIterator aIter( &aCol[nCol], nRow1, nRow2 );
593cdf0e10cSrcweir 			while (aIter.Next( nRow, pCell ))
594cdf0e10cSrcweir 			{
595cdf0e10cSrcweir                 ScAddress aDestPos( static_cast<SCCOL>(nRow-nRow1), static_cast<SCROW>(nCol-nCol1), pTransClip->nTab );
596cdf0e10cSrcweir 				ScBaseCell* pNew;
597cdf0e10cSrcweir 				if ( bAsLink )					// Referenz erzeugen ?
598cdf0e10cSrcweir 				{
599cdf0e10cSrcweir 					pNew = aCol[nCol].CreateRefCell( pDestDoc, aDestPos, aIter.GetIndex(), nFlags );
600cdf0e10cSrcweir 				}
601cdf0e10cSrcweir 				else							// kopieren
602cdf0e10cSrcweir 				{
603cdf0e10cSrcweir                     ScAddress aOwnPos( nCol, nRow, nTab );
604cdf0e10cSrcweir 					if (pCell->GetCellType() == CELLTYPE_FORMULA)
605cdf0e10cSrcweir 					{
606cdf0e10cSrcweir                         pNew = pCell->CloneWithNote( aOwnPos, *pDestDoc, aDestPos, SC_CLONECELL_STARTLISTENING );
607cdf0e10cSrcweir 
608cdf0e10cSrcweir 						//	Referenzen drehen
609cdf0e10cSrcweir 						//	bei Cut werden Referenzen spaeter per UpdateTranspose angepasst
610cdf0e10cSrcweir 
611cdf0e10cSrcweir 						if (!bWasCut)
612cdf0e10cSrcweir 							((ScFormulaCell*)pNew)->TransposeReference();
613cdf0e10cSrcweir 					}
614cdf0e10cSrcweir 					else
615cdf0e10cSrcweir                     {
616cdf0e10cSrcweir                         pNew = pCell->CloneWithNote( aOwnPos, *pDestDoc, aDestPos );
617cdf0e10cSrcweir                     }
618cdf0e10cSrcweir 				}
619cdf0e10cSrcweir 				pTransClip->PutCell( static_cast<SCCOL>(nRow-nRow1), static_cast<SCROW>(nCol-nCol1), pNew );
620cdf0e10cSrcweir 			}
621cdf0e10cSrcweir 		}
622cdf0e10cSrcweir 
623cdf0e10cSrcweir 		//	Attribute
624cdf0e10cSrcweir 
625cdf0e10cSrcweir 		SCROW nAttrRow1;
626cdf0e10cSrcweir 		SCROW nAttrRow2;
627cdf0e10cSrcweir 		const ScPatternAttr* pPattern;
628cdf0e10cSrcweir 		ScAttrIterator* pAttrIter = aCol[nCol].CreateAttrIterator( nRow1, nRow2 );
629cdf0e10cSrcweir 		while ( (pPattern = pAttrIter->Next( nAttrRow1, nAttrRow2 )) != 0 )
630cdf0e10cSrcweir 		{
631cdf0e10cSrcweir 			if ( !IsDefaultItem( pPattern ) )
632cdf0e10cSrcweir 			{
633cdf0e10cSrcweir 				const SfxItemSet& rSet = pPattern->GetItemSet();
634cdf0e10cSrcweir 				if ( rSet.GetItemState( ATTR_MERGE, sal_False ) == SFX_ITEM_DEFAULT &&
635cdf0e10cSrcweir 					 rSet.GetItemState( ATTR_MERGE_FLAG, sal_False ) == SFX_ITEM_DEFAULT &&
636cdf0e10cSrcweir 					 rSet.GetItemState( ATTR_BORDER, sal_False ) == SFX_ITEM_DEFAULT )
637cdf0e10cSrcweir 				{
638cdf0e10cSrcweir 					// no borders or merge items involved - use pattern as-is
639cdf0e10cSrcweir 					for (nRow = nAttrRow1; nRow<=nAttrRow2; nRow++)
640cdf0e10cSrcweir 						pTransClip->SetPattern( static_cast<SCCOL>(nRow-nRow1), static_cast<SCROW>(nCol-nCol1), *pPattern, sal_True );
641cdf0e10cSrcweir 				}
642cdf0e10cSrcweir 				else
643cdf0e10cSrcweir 				{
644cdf0e10cSrcweir 					// transpose borders and merge values, remove merge flags (refreshed after pasting)
645cdf0e10cSrcweir 					ScPatternAttr aNewPattern( *pPattern );
646cdf0e10cSrcweir 					SfxItemSet& rNewSet = aNewPattern.GetItemSet();
647cdf0e10cSrcweir 
648cdf0e10cSrcweir 					const SvxBoxItem& rOldBox = (const SvxBoxItem&)rSet.Get(ATTR_BORDER);
649cdf0e10cSrcweir 					if ( rOldBox.GetTop() || rOldBox.GetBottom() || rOldBox.GetLeft() || rOldBox.GetRight() )
650cdf0e10cSrcweir 					{
651cdf0e10cSrcweir 						SvxBoxItem aNew( ATTR_BORDER );
652cdf0e10cSrcweir 						aNew.SetLine( rOldBox.GetLine( BOX_LINE_TOP ), BOX_LINE_LEFT );
653cdf0e10cSrcweir 						aNew.SetLine( rOldBox.GetLine( BOX_LINE_LEFT ), BOX_LINE_TOP );
654cdf0e10cSrcweir 						aNew.SetLine( rOldBox.GetLine( BOX_LINE_BOTTOM ), BOX_LINE_RIGHT );
655cdf0e10cSrcweir 						aNew.SetLine( rOldBox.GetLine( BOX_LINE_RIGHT ), BOX_LINE_BOTTOM );
656cdf0e10cSrcweir 						aNew.SetDistance( rOldBox.GetDistance( BOX_LINE_TOP ), BOX_LINE_LEFT );
657cdf0e10cSrcweir 						aNew.SetDistance( rOldBox.GetDistance( BOX_LINE_LEFT ), BOX_LINE_TOP );
658cdf0e10cSrcweir 						aNew.SetDistance( rOldBox.GetDistance( BOX_LINE_BOTTOM ), BOX_LINE_RIGHT );
659cdf0e10cSrcweir 						aNew.SetDistance( rOldBox.GetDistance( BOX_LINE_RIGHT ), BOX_LINE_BOTTOM );
660cdf0e10cSrcweir 						rNewSet.Put( aNew );
661cdf0e10cSrcweir 					}
662cdf0e10cSrcweir 
663cdf0e10cSrcweir 					const ScMergeAttr& rOldMerge = (const ScMergeAttr&)rSet.Get(ATTR_MERGE);
664cdf0e10cSrcweir 					if (rOldMerge.IsMerged())
665cdf0e10cSrcweir                         rNewSet.Put( ScMergeAttr( Min(
666cdf0e10cSrcweir                                         static_cast<SCsCOL>(rOldMerge.GetRowMerge()),
667cdf0e10cSrcweir                                         static_cast<SCsCOL>(MAXCOL+1 - (nAttrRow2-nRow1))),
668cdf0e10cSrcweir                                     Min(
669cdf0e10cSrcweir                                         static_cast<SCsROW>(rOldMerge.GetColMerge()),
670cdf0e10cSrcweir                                         static_cast<SCsROW>(MAXROW+1 - (nCol-nCol1)))));
671cdf0e10cSrcweir 					const ScMergeFlagAttr& rOldFlag = (const ScMergeFlagAttr&)rSet.Get(ATTR_MERGE_FLAG);
672cdf0e10cSrcweir 					if (rOldFlag.IsOverlapped())
673cdf0e10cSrcweir 					{
674cdf0e10cSrcweir 						sal_Int16 nNewFlags = rOldFlag.GetValue() & ~( SC_MF_HOR | SC_MF_VER );
675cdf0e10cSrcweir 						if ( nNewFlags )
676cdf0e10cSrcweir 							rNewSet.Put( ScMergeFlagAttr( nNewFlags ) );
677cdf0e10cSrcweir 						else
678cdf0e10cSrcweir 							rNewSet.ClearItem( ATTR_MERGE_FLAG );
679cdf0e10cSrcweir 					}
680cdf0e10cSrcweir 
681cdf0e10cSrcweir 					for (nRow = nAttrRow1; nRow<=nAttrRow2; nRow++)
682cdf0e10cSrcweir                         pTransClip->SetPattern( static_cast<SCCOL>(nRow-nRow1),
683cdf0e10cSrcweir                                 static_cast<SCROW>(nCol-nCol1), aNewPattern, sal_True);
684cdf0e10cSrcweir 				}
685cdf0e10cSrcweir 			}
686cdf0e10cSrcweir 		}
687cdf0e10cSrcweir 
688cdf0e10cSrcweir 		delete pAttrIter;
689cdf0e10cSrcweir 	}
690cdf0e10cSrcweir }
691cdf0e10cSrcweir 
692cdf0e10cSrcweir 
StartAllListeners()693cdf0e10cSrcweir void ScTable::StartAllListeners()
694cdf0e10cSrcweir {
695cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL; i++)
696cdf0e10cSrcweir 		aCol[i].StartAllListeners();
697cdf0e10cSrcweir }
698cdf0e10cSrcweir 
699cdf0e10cSrcweir 
StartNeededListeners()700cdf0e10cSrcweir void ScTable::StartNeededListeners()
701cdf0e10cSrcweir {
702cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL; i++)
703cdf0e10cSrcweir         aCol[i].StartNeededListeners();
704cdf0e10cSrcweir }
705cdf0e10cSrcweir 
706cdf0e10cSrcweir 
BroadcastInArea(SCCOL nCol1,SCROW nRow1,SCCOL nCol2,SCROW nRow2)707cdf0e10cSrcweir void ScTable::BroadcastInArea( SCCOL nCol1, SCROW nRow1,
708cdf0e10cSrcweir 		SCCOL nCol2, SCROW nRow2 )
709cdf0e10cSrcweir {
710cdf0e10cSrcweir 	if (nCol2 > MAXCOL) nCol2 = MAXCOL;
711cdf0e10cSrcweir 	if (nRow2 > MAXROW) nRow2 = MAXROW;
712cdf0e10cSrcweir 	if (ValidColRow(nCol1, nRow1) && ValidColRow(nCol2, nRow2))
713cdf0e10cSrcweir 		for (SCCOL i = nCol1; i <= nCol2; i++)
714cdf0e10cSrcweir 			aCol[i].BroadcastInArea( nRow1, nRow2 );
715cdf0e10cSrcweir }
716cdf0e10cSrcweir 
717cdf0e10cSrcweir 
StartListeningInArea(SCCOL nCol1,SCROW nRow1,SCCOL nCol2,SCROW nRow2)718cdf0e10cSrcweir void ScTable::StartListeningInArea( SCCOL nCol1, SCROW nRow1,
719cdf0e10cSrcweir 		SCCOL nCol2, SCROW nRow2 )
720cdf0e10cSrcweir {
721cdf0e10cSrcweir 	if (nCol2 > MAXCOL) nCol2 = MAXCOL;
722cdf0e10cSrcweir 	if (nRow2 > MAXROW) nRow2 = MAXROW;
723cdf0e10cSrcweir 	if (ValidColRow(nCol1, nRow1) && ValidColRow(nCol2, nRow2))
724cdf0e10cSrcweir 		for (SCCOL i = nCol1; i <= nCol2; i++)
725cdf0e10cSrcweir 			aCol[i].StartListeningInArea( nRow1, nRow2 );
726cdf0e10cSrcweir }
727cdf0e10cSrcweir 
728cdf0e10cSrcweir 
CopyToTable(SCCOL nCol1,SCROW nRow1,SCCOL nCol2,SCROW nRow2,sal_uInt16 nFlags,sal_Bool bMarked,ScTable * pDestTab,const ScMarkData * pMarkData,sal_Bool bAsLink,sal_Bool bColRowFlags)729cdf0e10cSrcweir void ScTable::CopyToTable(SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2,
730cdf0e10cSrcweir 							sal_uInt16 nFlags, sal_Bool bMarked, ScTable* pDestTab,
731cdf0e10cSrcweir 							const ScMarkData* pMarkData,
732cdf0e10cSrcweir 							sal_Bool bAsLink, sal_Bool bColRowFlags)
733cdf0e10cSrcweir {
734cdf0e10cSrcweir 	if (ValidColRow(nCol1, nRow1) && ValidColRow(nCol2, nRow2))
735cdf0e10cSrcweir 	{
736cdf0e10cSrcweir 		if (nFlags)
737cdf0e10cSrcweir 			for (SCCOL i = nCol1; i <= nCol2; i++)
738cdf0e10cSrcweir 				aCol[i].CopyToColumn(nRow1, nRow2, nFlags, bMarked,
739cdf0e10cSrcweir 								pDestTab->aCol[i], pMarkData, bAsLink);
740cdf0e10cSrcweir 
741cdf0e10cSrcweir 		if (bColRowFlags)		// Spaltenbreiten/Zeilenhoehen/Flags
742cdf0e10cSrcweir 		{
743cdf0e10cSrcweir 			//	Charts muessen beim Ein-/Ausblenden angepasst werden
744cdf0e10cSrcweir 			ScChartListenerCollection* pCharts = pDestTab->pDocument->GetChartListenerCollection();
745cdf0e10cSrcweir 
746cdf0e10cSrcweir             bool bFlagChange = false;
747cdf0e10cSrcweir 
748cdf0e10cSrcweir 			sal_Bool bWidth  = (nRow1==0 && nRow2==MAXROW && pColWidth && pDestTab->pColWidth);
749cdf0e10cSrcweir             sal_Bool bHeight = (nCol1==0 && nCol2==MAXCOL && mpRowHeights && pDestTab->mpRowHeights);
750cdf0e10cSrcweir 
751cdf0e10cSrcweir 			if (bWidth||bHeight)
752cdf0e10cSrcweir 			{
753cdf0e10cSrcweir 				pDestTab->IncRecalcLevel();
754cdf0e10cSrcweir 
755cdf0e10cSrcweir 				if (bWidth)
756cdf0e10cSrcweir                 {
757cdf0e10cSrcweir 					for (SCCOL i=nCol1; i<=nCol2; i++)
758cdf0e10cSrcweir 					{
759cdf0e10cSrcweir                         bool bThisHidden = ColHidden(i);
760cdf0e10cSrcweir                         bool bHiddenChange = (pDestTab->ColHidden(i) != bThisHidden);
761cdf0e10cSrcweir                         bool bChange = bHiddenChange || (pDestTab->pColWidth[i] != pColWidth[i]);
762cdf0e10cSrcweir 						pDestTab->pColWidth[i] = pColWidth[i];
763cdf0e10cSrcweir 						pDestTab->pColFlags[i] = pColFlags[i];
764cdf0e10cSrcweir                         pDestTab->SetColHidden(i, i, bThisHidden);
765cdf0e10cSrcweir 						//!	Aenderungen zusammenfassen?
766cdf0e10cSrcweir                         if (bHiddenChange && pCharts)
767cdf0e10cSrcweir                             pCharts->SetRangeDirty(ScRange( i, 0, nTab, i, MAXROW, nTab ));
768cdf0e10cSrcweir 
769cdf0e10cSrcweir                         if (bChange)
770cdf0e10cSrcweir                             bFlagChange = true;
771cdf0e10cSrcweir 					}
772cdf0e10cSrcweir                     pDestTab->SetColManualBreaks( maColManualBreaks);
773cdf0e10cSrcweir                 }
774cdf0e10cSrcweir 
775cdf0e10cSrcweir 				if (bHeight)
776cdf0e10cSrcweir 				{
777cdf0e10cSrcweir                     bool bChange = pDestTab->GetRowHeight(nRow1, nRow2) != GetRowHeight(nRow1, nRow2);
778cdf0e10cSrcweir 
779cdf0e10cSrcweir                     if (bChange)
780cdf0e10cSrcweir                         bFlagChange = true;
781cdf0e10cSrcweir 
782cdf0e10cSrcweir                     pDestTab->CopyRowHeight(*this, nRow1, nRow2, 0);
783cdf0e10cSrcweir                     pDestTab->pRowFlags->CopyFrom(*pRowFlags, nRow1, nRow2);
784cdf0e10cSrcweir 
785cdf0e10cSrcweir                     // Hidden flags.
786cdf0e10cSrcweir                     // #i116164# Collect information first, then apply the changes,
787cdf0e10cSrcweir                     // so RowHidden doesn't rebuild the tree for each row range.
788cdf0e10cSrcweir                     std::vector<ScShowRowsEntry> aEntries;
789cdf0e10cSrcweir                     for (SCROW i = nRow1; i <= nRow2; ++i)
790cdf0e10cSrcweir                     {
791cdf0e10cSrcweir                         SCROW nThisLastRow, nDestLastRow;
792cdf0e10cSrcweir                         bool bThisHidden = RowHidden(i, NULL, &nThisLastRow);
793cdf0e10cSrcweir                         bool bDestHidden = pDestTab->RowHidden(i, NULL, &nDestLastRow);
794cdf0e10cSrcweir 
795cdf0e10cSrcweir                         // If the segment sizes differ, we take the shorter segment of the two.
796cdf0e10cSrcweir                         SCROW nLastRow = ::std::min(nThisLastRow, nDestLastRow);
797cdf0e10cSrcweir                         if (nLastRow >= nRow2)
798cdf0e10cSrcweir                             // the last row shouldn't exceed the upper bound the caller specified.
799cdf0e10cSrcweir                             nLastRow = nRow2;
800cdf0e10cSrcweir 
801cdf0e10cSrcweir                         //pDestTab->SetRowHidden(i, nLastRow, bThisHidden);
802cdf0e10cSrcweir                         aEntries.push_back(ScShowRowsEntry(i, nLastRow, !bThisHidden));
803cdf0e10cSrcweir 
804cdf0e10cSrcweir                         bool bThisHiddenChange = (bThisHidden != bDestHidden);
805cdf0e10cSrcweir                         if (bThisHiddenChange && pCharts)
806cdf0e10cSrcweir                         {
807cdf0e10cSrcweir                             // Hidden flags differ.
808cdf0e10cSrcweir                             pCharts->SetRangeDirty(ScRange(0, i, nTab, MAXCOL, nLastRow, nTab));
809cdf0e10cSrcweir                         }
810cdf0e10cSrcweir 
811cdf0e10cSrcweir                         if (bThisHiddenChange)
812cdf0e10cSrcweir                             bFlagChange = true;
813cdf0e10cSrcweir 
814cdf0e10cSrcweir                         // Jump to the last row of the identical flag segment.
815cdf0e10cSrcweir                         i = nLastRow;
816cdf0e10cSrcweir 					}
817cdf0e10cSrcweir 
818cdf0e10cSrcweir                     std::vector<ScShowRowsEntry>::const_iterator aEnd = aEntries.end();
819cdf0e10cSrcweir                     std::vector<ScShowRowsEntry>::const_iterator aIter = aEntries.begin();
820cdf0e10cSrcweir                     if ( aIter != aEnd )
821cdf0e10cSrcweir                     {
822cdf0e10cSrcweir                         pDestTab->mpHiddenRows->setInsertFromBack(true);    // important for undo document
823cdf0e10cSrcweir                         while (aIter != aEnd)
824cdf0e10cSrcweir                         {
825cdf0e10cSrcweir                             pDestTab->SetRowHidden(aIter->mnRow1, aIter->mnRow2, !aIter->mbShow);
826cdf0e10cSrcweir                             ++aIter;
827cdf0e10cSrcweir                         }
828cdf0e10cSrcweir                         pDestTab->mpHiddenRows->setInsertFromBack(false);
829cdf0e10cSrcweir                     }
830cdf0e10cSrcweir 
831cdf0e10cSrcweir                     // Filtered flags.
832cdf0e10cSrcweir                     for (SCROW i = nRow1; i <= nRow2; ++i)
833cdf0e10cSrcweir                     {
834cdf0e10cSrcweir                         SCROW nLastRow;
835cdf0e10cSrcweir                         bool bFiltered = RowFiltered(i, NULL, &nLastRow);
836cdf0e10cSrcweir                         if (nLastRow >= nRow2)
837cdf0e10cSrcweir                             // the last row shouldn't exceed the upper bound the caller specified.
838cdf0e10cSrcweir                             nLastRow = nRow2;
839cdf0e10cSrcweir                         pDestTab->SetRowFiltered(i, nLastRow, bFiltered);
840cdf0e10cSrcweir                         i = nLastRow;
841cdf0e10cSrcweir                     }
842cdf0e10cSrcweir                     pDestTab->SetRowManualBreaks( maRowManualBreaks);
843cdf0e10cSrcweir 				}
844cdf0e10cSrcweir 				pDestTab->DecRecalcLevel();
845cdf0e10cSrcweir 			}
846cdf0e10cSrcweir 
847cdf0e10cSrcweir             if (bFlagChange)
848cdf0e10cSrcweir                 pDestTab->InvalidatePageBreaks();
849cdf0e10cSrcweir 
850cdf0e10cSrcweir 			pDestTab->SetOutlineTable( pOutlineTable );		// auch nur wenn bColRowFlags
851cdf0e10cSrcweir 		}
852cdf0e10cSrcweir 	}
853cdf0e10cSrcweir }
854cdf0e10cSrcweir 
855cdf0e10cSrcweir 
UndoToTable(SCCOL nCol1,SCROW nRow1,SCCOL nCol2,SCROW nRow2,sal_uInt16 nFlags,sal_Bool bMarked,ScTable * pDestTab,const ScMarkData * pMarkData)856cdf0e10cSrcweir void ScTable::UndoToTable(SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2,
857cdf0e10cSrcweir 							sal_uInt16 nFlags, sal_Bool bMarked, ScTable* pDestTab,
858cdf0e10cSrcweir 							const ScMarkData* pMarkData)
859cdf0e10cSrcweir {
860cdf0e10cSrcweir 	if (ValidColRow(nCol1, nRow1) && ValidColRow(nCol2, nRow2))
861cdf0e10cSrcweir 	{
862cdf0e10cSrcweir 		sal_Bool bWidth  = (nRow1==0 && nRow2==MAXROW && pColWidth && pDestTab->pColWidth);
863cdf0e10cSrcweir         sal_Bool bHeight = (nCol1==0 && nCol2==MAXCOL && mpRowHeights && pDestTab->mpRowHeights);
864cdf0e10cSrcweir 
865cdf0e10cSrcweir 		if (bWidth||bHeight)
866cdf0e10cSrcweir 			IncRecalcLevel();
867cdf0e10cSrcweir 
868cdf0e10cSrcweir 		for ( SCCOL i = 0; i <= MAXCOL; i++)
869cdf0e10cSrcweir 		{
870cdf0e10cSrcweir 			if ( i >= nCol1 && i <= nCol2 )
871cdf0e10cSrcweir 				aCol[i].UndoToColumn(nRow1, nRow2, nFlags, bMarked, pDestTab->aCol[i],
872cdf0e10cSrcweir 										pMarkData);
873cdf0e10cSrcweir 			else
874cdf0e10cSrcweir 				aCol[i].CopyToColumn(0, MAXROW, IDF_FORMULA, sal_False, pDestTab->aCol[i]);
875cdf0e10cSrcweir 		}
876cdf0e10cSrcweir 
877cdf0e10cSrcweir 		if (bWidth||bHeight)
878cdf0e10cSrcweir 		{
879cdf0e10cSrcweir             if (bWidth)
880cdf0e10cSrcweir             {
881cdf0e10cSrcweir                 for (SCCOL i=nCol1; i<=nCol2; i++)
882cdf0e10cSrcweir                     pDestTab->pColWidth[i] = pColWidth[i];
883cdf0e10cSrcweir                 pDestTab->SetColManualBreaks( maColManualBreaks);
884cdf0e10cSrcweir             }
885cdf0e10cSrcweir             if (bHeight)
886cdf0e10cSrcweir             {
887cdf0e10cSrcweir                 pDestTab->CopyRowHeight(*this, nRow1, nRow2, 0);
888cdf0e10cSrcweir                 pDestTab->SetRowManualBreaks( maRowManualBreaks);
889cdf0e10cSrcweir             }
890cdf0e10cSrcweir             DecRecalcLevel();
891cdf0e10cSrcweir 		}
892cdf0e10cSrcweir 	}
893cdf0e10cSrcweir }
894cdf0e10cSrcweir 
895cdf0e10cSrcweir 
CopyUpdated(const ScTable * pPosTab,ScTable * pDestTab) const896cdf0e10cSrcweir void ScTable::CopyUpdated( const ScTable* pPosTab, ScTable* pDestTab ) const
897cdf0e10cSrcweir {
898cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL; i++)
899cdf0e10cSrcweir 		aCol[i].CopyUpdated( pPosTab->aCol[i], pDestTab->aCol[i] );
900cdf0e10cSrcweir }
901cdf0e10cSrcweir 
InvalidateTableArea()902cdf0e10cSrcweir void ScTable::InvalidateTableArea()
903cdf0e10cSrcweir {
904cdf0e10cSrcweir     bTableAreaValid = sal_False;
905cdf0e10cSrcweir }
906cdf0e10cSrcweir 
InvalidatePageBreaks()907cdf0e10cSrcweir void ScTable::InvalidatePageBreaks()
908cdf0e10cSrcweir {
909cdf0e10cSrcweir     mbPageBreaksValid = false;
910cdf0e10cSrcweir }
911cdf0e10cSrcweir 
CopyScenarioTo(ScTable * pDestTab) const912cdf0e10cSrcweir void ScTable::CopyScenarioTo( ScTable* pDestTab ) const
913cdf0e10cSrcweir {
914cdf0e10cSrcweir 	DBG_ASSERT( bScenario, "bScenario == FALSE" );
915cdf0e10cSrcweir 
916cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL; i++)
917cdf0e10cSrcweir 		aCol[i].CopyScenarioTo( pDestTab->aCol[i] );
918cdf0e10cSrcweir }
919cdf0e10cSrcweir 
CopyScenarioFrom(const ScTable * pSrcTab)920cdf0e10cSrcweir void ScTable::CopyScenarioFrom( const ScTable* pSrcTab )
921cdf0e10cSrcweir {
922cdf0e10cSrcweir 	DBG_ASSERT( bScenario, "bScenario == FALSE" );
923cdf0e10cSrcweir 
924cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL; i++)
925cdf0e10cSrcweir 		aCol[i].CopyScenarioFrom( pSrcTab->aCol[i] );
926cdf0e10cSrcweir }
927cdf0e10cSrcweir 
MarkScenarioIn(ScMarkData & rDestMark,sal_uInt16 nNeededBits) const928cdf0e10cSrcweir void ScTable::MarkScenarioIn( ScMarkData& rDestMark, sal_uInt16 nNeededBits ) const
929cdf0e10cSrcweir {
930cdf0e10cSrcweir 	DBG_ASSERT( bScenario, "bScenario == FALSE" );
931cdf0e10cSrcweir 
932cdf0e10cSrcweir 	if ( ( nScenarioFlags & nNeededBits ) != nNeededBits )	// alle Bits gesetzt?
933cdf0e10cSrcweir 		return;
934cdf0e10cSrcweir 
935cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL; i++)
936cdf0e10cSrcweir 		aCol[i].MarkScenarioIn( rDestMark );
937cdf0e10cSrcweir }
938cdf0e10cSrcweir 
HasScenarioRange(const ScRange & rRange) const939cdf0e10cSrcweir sal_Bool ScTable::HasScenarioRange( const ScRange& rRange ) const
940cdf0e10cSrcweir {
941cdf0e10cSrcweir 	DBG_ASSERT( bScenario, "bScenario == FALSE" );
942cdf0e10cSrcweir 
943cdf0e10cSrcweir //	ScMarkData aMark;
944cdf0e10cSrcweir //	MarkScenarioIn( aMark, 0 );				//! Bits als Parameter von HasScenarioRange?
945cdf0e10cSrcweir //	return aMark.IsAllMarked( rRange );
946cdf0e10cSrcweir 
947cdf0e10cSrcweir 	ScRange aTabRange = rRange;
948cdf0e10cSrcweir 	aTabRange.aStart.SetTab( nTab );
949cdf0e10cSrcweir 	aTabRange.aEnd.SetTab( nTab );
950cdf0e10cSrcweir 
951cdf0e10cSrcweir 	const ScRangeList* pList = GetScenarioRanges();
952cdf0e10cSrcweir //	return ( pList && pList->Find( aTabRange ) );
953cdf0e10cSrcweir 
954cdf0e10cSrcweir 	if (pList)
955cdf0e10cSrcweir 	{
956cdf0e10cSrcweir 		sal_uLong nCount = pList->Count();
957cdf0e10cSrcweir 		for ( sal_uLong j = 0; j < nCount; j++ )
958cdf0e10cSrcweir 		{
959cdf0e10cSrcweir 			ScRange* pR = pList->GetObject( j );
960cdf0e10cSrcweir 			if ( pR->Intersects( aTabRange ) )
961cdf0e10cSrcweir 				return sal_True;
962cdf0e10cSrcweir 		}
963cdf0e10cSrcweir 	}
964cdf0e10cSrcweir 
965cdf0e10cSrcweir 	return sal_False;
966cdf0e10cSrcweir }
967cdf0e10cSrcweir 
InvalidateScenarioRanges()968cdf0e10cSrcweir void ScTable::InvalidateScenarioRanges()
969cdf0e10cSrcweir {
970cdf0e10cSrcweir 	delete pScenarioRanges;
971cdf0e10cSrcweir 	pScenarioRanges = NULL;
972cdf0e10cSrcweir }
973cdf0e10cSrcweir 
GetScenarioRanges() const974cdf0e10cSrcweir const ScRangeList* ScTable::GetScenarioRanges() const
975cdf0e10cSrcweir {
976cdf0e10cSrcweir 	DBG_ASSERT( bScenario, "bScenario == FALSE" );
977cdf0e10cSrcweir 
978cdf0e10cSrcweir 	if (!pScenarioRanges)
979cdf0e10cSrcweir 	{
980cdf0e10cSrcweir 		((ScTable*)this)->pScenarioRanges = new ScRangeList;
981cdf0e10cSrcweir 		ScMarkData aMark;
982cdf0e10cSrcweir 		MarkScenarioIn( aMark, 0 );		// immer
983cdf0e10cSrcweir 		aMark.FillRangeListWithMarks( pScenarioRanges, sal_False );
984cdf0e10cSrcweir 	}
985cdf0e10cSrcweir 	return pScenarioRanges;
986cdf0e10cSrcweir }
987cdf0e10cSrcweir 
TestCopyScenarioTo(const ScTable * pDestTab) const988cdf0e10cSrcweir sal_Bool ScTable::TestCopyScenarioTo( const ScTable* pDestTab ) const
989cdf0e10cSrcweir {
990cdf0e10cSrcweir 	DBG_ASSERT( bScenario, "bScenario == FALSE" );
991cdf0e10cSrcweir 
992cdf0e10cSrcweir 	if (!pDestTab->IsProtected())
993cdf0e10cSrcweir 		return sal_True;
994cdf0e10cSrcweir 
995cdf0e10cSrcweir 	sal_Bool bOk = sal_True;
996cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL && bOk; i++)
997cdf0e10cSrcweir 		bOk = aCol[i].TestCopyScenarioTo( pDestTab->aCol[i] );
998cdf0e10cSrcweir 	return bOk;
999cdf0e10cSrcweir }
1000cdf0e10cSrcweir 
PutCell(SCCOL nCol,SCROW nRow,ScBaseCell * pCell)1001cdf0e10cSrcweir void ScTable::PutCell( SCCOL nCol, SCROW nRow, ScBaseCell* pCell )
1002cdf0e10cSrcweir {
1003cdf0e10cSrcweir 	if (ValidColRow(nCol,nRow))
1004cdf0e10cSrcweir 	{
1005cdf0e10cSrcweir 		if (pCell)
1006cdf0e10cSrcweir 			aCol[nCol].Insert( nRow, pCell );
1007cdf0e10cSrcweir 		else
1008cdf0e10cSrcweir 			aCol[nCol].Delete( nRow );
1009cdf0e10cSrcweir 	}
1010cdf0e10cSrcweir }
1011cdf0e10cSrcweir 
1012cdf0e10cSrcweir 
PutCell(SCCOL nCol,SCROW nRow,sal_uLong nFormatIndex,ScBaseCell * pCell)1013cdf0e10cSrcweir void ScTable::PutCell( SCCOL nCol, SCROW nRow, sal_uLong nFormatIndex, ScBaseCell* pCell )
1014cdf0e10cSrcweir {
1015cdf0e10cSrcweir 	if (ValidColRow(nCol,nRow))
1016cdf0e10cSrcweir 	{
1017cdf0e10cSrcweir 		if (pCell)
1018cdf0e10cSrcweir 			aCol[nCol].Insert( nRow, nFormatIndex, pCell );
1019cdf0e10cSrcweir 		else
1020cdf0e10cSrcweir 			aCol[nCol].Delete( nRow );
1021cdf0e10cSrcweir 	}
1022cdf0e10cSrcweir }
1023cdf0e10cSrcweir 
1024cdf0e10cSrcweir 
PutCell(const ScAddress & rPos,ScBaseCell * pCell)1025cdf0e10cSrcweir void ScTable::PutCell( const ScAddress& rPos, ScBaseCell* pCell )
1026cdf0e10cSrcweir {
1027cdf0e10cSrcweir 	if (pCell)
1028cdf0e10cSrcweir 		aCol[rPos.Col()].Insert( rPos.Row(), pCell );
1029cdf0e10cSrcweir 	else
1030cdf0e10cSrcweir 		aCol[rPos.Col()].Delete( rPos.Row() );
1031cdf0e10cSrcweir }
1032cdf0e10cSrcweir 
1033cdf0e10cSrcweir 
1034cdf0e10cSrcweir //UNUSED2009-05 void ScTable::PutCell( const ScAddress& rPos, sal_uLong nFormatIndex, ScBaseCell* pCell )
1035cdf0e10cSrcweir //UNUSED2009-05 {
1036cdf0e10cSrcweir //UNUSED2009-05     if (pCell)
1037cdf0e10cSrcweir //UNUSED2009-05         aCol[rPos.Col()].Insert( rPos.Row(), nFormatIndex, pCell );
1038cdf0e10cSrcweir //UNUSED2009-05     else
1039cdf0e10cSrcweir //UNUSED2009-05         aCol[rPos.Col()].Delete( rPos.Row() );
1040cdf0e10cSrcweir //UNUSED2009-05 }
1041cdf0e10cSrcweir 
1042cdf0e10cSrcweir 
SetString(SCCOL nCol,SCROW nRow,SCTAB nTabP,const String & rString,SvNumberFormatter * pFormatter,bool bDetectNumberFormat)1043cdf0e10cSrcweir sal_Bool ScTable::SetString( SCCOL nCol, SCROW nRow, SCTAB nTabP, const String& rString,
1044cdf0e10cSrcweir                          SvNumberFormatter* pFormatter, bool bDetectNumberFormat )
1045cdf0e10cSrcweir {
1046cdf0e10cSrcweir 	if (ValidColRow(nCol,nRow))
1047cdf0e10cSrcweir         return aCol[nCol].SetString(
1048cdf0e10cSrcweir             nRow, nTabP, rString, pDocument->GetAddressConvention(), pFormatter, bDetectNumberFormat );
1049cdf0e10cSrcweir 	else
1050cdf0e10cSrcweir 		return sal_False;
1051cdf0e10cSrcweir }
1052cdf0e10cSrcweir 
1053cdf0e10cSrcweir 
SetValue(SCCOL nCol,SCROW nRow,const double & rVal)1054cdf0e10cSrcweir void ScTable::SetValue( SCCOL nCol, SCROW nRow, const double& rVal )
1055cdf0e10cSrcweir {
1056cdf0e10cSrcweir 	if (ValidColRow(nCol, nRow))
1057cdf0e10cSrcweir 		aCol[nCol].SetValue( nRow, rVal );
1058cdf0e10cSrcweir }
1059cdf0e10cSrcweir 
1060cdf0e10cSrcweir 
GetString(SCCOL nCol,SCROW nRow,String & rString)1061cdf0e10cSrcweir void ScTable::GetString( SCCOL nCol, SCROW nRow, String& rString )
1062cdf0e10cSrcweir {
1063cdf0e10cSrcweir 	if (ValidColRow(nCol,nRow))
1064cdf0e10cSrcweir 		aCol[nCol].GetString( nRow, rString );
1065cdf0e10cSrcweir 	else
1066cdf0e10cSrcweir 		rString.Erase();
1067cdf0e10cSrcweir }
1068cdf0e10cSrcweir 
FillDPCache(ScDPTableDataCache * pCache,SCCOL nStartCol,SCCOL nEndCol,SCROW nStartRow,SCROW nEndRow)1069b4df81e3SWang Lei void  ScTable::FillDPCache( ScDPTableDataCache * pCache, SCCOL nStartCol, SCCOL nEndCol, SCROW nStartRow, SCROW nEndRow )
1070b4df81e3SWang Lei {
1071b4df81e3SWang Lei     for ( sal_uInt16 nCol = nStartCol; nCol <= nEndCol; nCol++ )
1072b4df81e3SWang Lei         if( ValidCol( nCol ) )
1073b4df81e3SWang Lei             aCol[nCol].FillDPCache( pCache, nCol - nStartCol, nStartRow, nEndRow );
1074b4df81e3SWang Lei }
1075b4df81e3SWang Lei 
1076cdf0e10cSrcweir 
GetInputString(SCCOL nCol,SCROW nRow,String & rString)1077cdf0e10cSrcweir void ScTable::GetInputString( SCCOL nCol, SCROW nRow, String& rString )
1078cdf0e10cSrcweir {
1079cdf0e10cSrcweir 	if (ValidColRow(nCol,nRow))
1080cdf0e10cSrcweir 		aCol[nCol].GetInputString( nRow, rString );
1081cdf0e10cSrcweir 	else
1082cdf0e10cSrcweir 		rString.Erase();
1083cdf0e10cSrcweir }
1084cdf0e10cSrcweir 
1085cdf0e10cSrcweir 
GetValue(SCCOL nCol,SCROW nRow)1086cdf0e10cSrcweir double ScTable::GetValue( SCCOL nCol, SCROW nRow )
1087cdf0e10cSrcweir {
1088cdf0e10cSrcweir 	if (ValidColRow( nCol, nRow ))
1089cdf0e10cSrcweir 		return aCol[nCol].GetValue( nRow );
1090cdf0e10cSrcweir 	return 0.0;
1091cdf0e10cSrcweir }
1092cdf0e10cSrcweir 
1093cdf0e10cSrcweir 
GetFormula(SCCOL nCol,SCROW nRow,String & rFormula,sal_Bool bAsciiExport)1094cdf0e10cSrcweir void ScTable::GetFormula( SCCOL nCol, SCROW nRow, String& rFormula,
1095cdf0e10cSrcweir 						  sal_Bool bAsciiExport )
1096cdf0e10cSrcweir {
1097cdf0e10cSrcweir 	if (ValidColRow(nCol,nRow))
1098cdf0e10cSrcweir 		aCol[nCol].GetFormula( nRow, rFormula, bAsciiExport );
1099cdf0e10cSrcweir 	else
1100cdf0e10cSrcweir 		rFormula.Erase();
1101cdf0e10cSrcweir }
1102cdf0e10cSrcweir 
1103cdf0e10cSrcweir 
GetNote(SCCOL nCol,SCROW nRow)1104cdf0e10cSrcweir ScPostIt* ScTable::GetNote( SCCOL nCol, SCROW nRow )
1105cdf0e10cSrcweir {
1106cdf0e10cSrcweir 	return ValidColRow( nCol, nRow ) ? aCol[ nCol ].GetNote( nRow ) : 0;
1107cdf0e10cSrcweir }
1108cdf0e10cSrcweir 
1109cdf0e10cSrcweir 
TakeNote(SCCOL nCol,SCROW nRow,ScPostIt * & rpNote)1110cdf0e10cSrcweir void ScTable::TakeNote( SCCOL nCol, SCROW nRow, ScPostIt*& rpNote )
1111cdf0e10cSrcweir {
1112cdf0e10cSrcweir 	if( ValidColRow( nCol, nRow ) )
1113cdf0e10cSrcweir     {
1114cdf0e10cSrcweir         aCol[ nCol ].TakeNote( nRow, rpNote );
1115cdf0e10cSrcweir         if( rpNote && rpNote->GetNoteData().mxInitData.get() )
1116cdf0e10cSrcweir         {
1117cdf0e10cSrcweir             if( !mxUninitNotes.get() )
1118cdf0e10cSrcweir                 mxUninitNotes.reset( new ScAddress2DVec );
1119cdf0e10cSrcweir             mxUninitNotes->push_back( ScAddress2D( nCol, nRow ) );
1120cdf0e10cSrcweir         }
1121cdf0e10cSrcweir     }
1122cdf0e10cSrcweir     else
1123cdf0e10cSrcweir         DELETEZ( rpNote );
1124cdf0e10cSrcweir }
1125cdf0e10cSrcweir 
1126cdf0e10cSrcweir 
ReleaseNote(SCCOL nCol,SCROW nRow)1127cdf0e10cSrcweir ScPostIt* ScTable::ReleaseNote( SCCOL nCol, SCROW nRow )
1128cdf0e10cSrcweir {
1129cdf0e10cSrcweir 	return ValidColRow( nCol, nRow ) ? aCol[ nCol ].ReleaseNote( nRow ) : 0;
1130cdf0e10cSrcweir }
1131cdf0e10cSrcweir 
1132cdf0e10cSrcweir 
DeleteNote(SCCOL nCol,SCROW nRow)1133cdf0e10cSrcweir void ScTable::DeleteNote( SCCOL nCol, SCROW nRow )
1134cdf0e10cSrcweir {
1135cdf0e10cSrcweir 	if( ValidColRow( nCol, nRow ) )
1136cdf0e10cSrcweir         aCol[ nCol ].DeleteNote( nRow );
1137cdf0e10cSrcweir }
1138cdf0e10cSrcweir 
1139cdf0e10cSrcweir 
InitializeNoteCaptions(bool bForced)1140cdf0e10cSrcweir void ScTable::InitializeNoteCaptions( bool bForced )
1141cdf0e10cSrcweir {
1142cdf0e10cSrcweir     if( mxUninitNotes.get() && (bForced || pDocument->IsUndoEnabled()) )
1143cdf0e10cSrcweir     {
1144cdf0e10cSrcweir         for( ScAddress2DVec::iterator aIt = mxUninitNotes->begin(), aEnd = mxUninitNotes->end(); aIt != aEnd; ++aIt )
1145cdf0e10cSrcweir             if( ScPostIt* pNote = GetNote( aIt->first, aIt->second ) )
1146cdf0e10cSrcweir                 pNote->GetOrCreateCaption( ScAddress( aIt->first, aIt->second, nTab ) );
1147cdf0e10cSrcweir         mxUninitNotes.reset();
1148cdf0e10cSrcweir     }
1149cdf0e10cSrcweir }
1150cdf0e10cSrcweir 
GetCellType(SCCOL nCol,SCROW nRow) const1151cdf0e10cSrcweir CellType ScTable::GetCellType( SCCOL nCol, SCROW nRow ) const
1152cdf0e10cSrcweir {
1153cdf0e10cSrcweir 	if (ValidColRow( nCol, nRow ))
1154cdf0e10cSrcweir 		return aCol[nCol].GetCellType( nRow );
1155cdf0e10cSrcweir 	return CELLTYPE_NONE;
1156cdf0e10cSrcweir }
1157cdf0e10cSrcweir 
1158cdf0e10cSrcweir 
GetCell(SCCOL nCol,SCROW nRow) const1159cdf0e10cSrcweir ScBaseCell* ScTable::GetCell( SCCOL nCol, SCROW nRow ) const
1160cdf0e10cSrcweir {
1161cdf0e10cSrcweir 	if (ValidColRow( nCol, nRow ))
1162cdf0e10cSrcweir 		return aCol[nCol].GetCell( nRow );
1163cdf0e10cSrcweir 
1164cdf0e10cSrcweir 	DBG_ERROR("GetCell ausserhalb");
1165cdf0e10cSrcweir 	return NULL;
1166cdf0e10cSrcweir }
1167cdf0e10cSrcweir 
GetFirstDataPos(SCCOL & rCol,SCROW & rRow) const1168cdf0e10cSrcweir void ScTable::GetFirstDataPos(SCCOL& rCol, SCROW& rRow) const
1169cdf0e10cSrcweir {
1170cdf0e10cSrcweir     rCol = 0;
1171cdf0e10cSrcweir     rRow = MAXROW+1;
1172cdf0e10cSrcweir     while (aCol[rCol].IsEmptyData() && rCol < MAXCOL)
1173cdf0e10cSrcweir         ++rCol;
1174cdf0e10cSrcweir     SCCOL nCol = rCol;
1175cdf0e10cSrcweir     while (nCol <= MAXCOL && rRow > 0)
1176cdf0e10cSrcweir     {
1177cdf0e10cSrcweir         if (!aCol[nCol].IsEmptyData())
1178cdf0e10cSrcweir             rRow = ::std::min( rRow, aCol[nCol].GetFirstDataPos());
1179cdf0e10cSrcweir         ++nCol;
1180cdf0e10cSrcweir     }
1181cdf0e10cSrcweir }
1182cdf0e10cSrcweir 
GetLastDataPos(SCCOL & rCol,SCROW & rRow) const1183cdf0e10cSrcweir void ScTable::GetLastDataPos(SCCOL& rCol, SCROW& rRow) const
1184cdf0e10cSrcweir {
1185cdf0e10cSrcweir     rCol = MAXCOL;
1186cdf0e10cSrcweir     rRow = 0;
1187cdf0e10cSrcweir     while (aCol[rCol].IsEmptyData() && (rCol > 0))
1188cdf0e10cSrcweir         rCol--;
1189cdf0e10cSrcweir     SCCOL nCol = rCol;
1190cdf0e10cSrcweir     while (nCol >= 0 && rRow < MAXROW)
1191cdf0e10cSrcweir         rRow = ::std::max( rRow, aCol[nCol--].GetLastDataPos());
1192cdf0e10cSrcweir }
1193cdf0e10cSrcweir 
1194cdf0e10cSrcweir 
HasData(SCCOL nCol,SCROW nRow)1195cdf0e10cSrcweir sal_Bool ScTable::HasData( SCCOL nCol, SCROW nRow )
1196cdf0e10cSrcweir {
1197cdf0e10cSrcweir 	if (ValidColRow(nCol,nRow))
1198cdf0e10cSrcweir 		return aCol[nCol].HasDataAt( nRow );
1199cdf0e10cSrcweir 	else
1200cdf0e10cSrcweir 		return sal_False;
1201cdf0e10cSrcweir }
1202cdf0e10cSrcweir 
1203cdf0e10cSrcweir 
HasStringData(SCCOL nCol,SCROW nRow)1204cdf0e10cSrcweir sal_Bool ScTable::HasStringData( SCCOL nCol, SCROW nRow )
1205cdf0e10cSrcweir {
1206cdf0e10cSrcweir 	if (ValidColRow(nCol,nRow))
1207cdf0e10cSrcweir 		return aCol[nCol].HasStringData( nRow );
1208cdf0e10cSrcweir 	else
1209cdf0e10cSrcweir 		return sal_False;
1210cdf0e10cSrcweir }
1211cdf0e10cSrcweir 
1212cdf0e10cSrcweir 
HasValueData(SCCOL nCol,SCROW nRow)1213cdf0e10cSrcweir sal_Bool ScTable::HasValueData( SCCOL nCol, SCROW nRow )
1214cdf0e10cSrcweir {
1215cdf0e10cSrcweir 	if (ValidColRow(nCol,nRow))
1216cdf0e10cSrcweir 		return aCol[nCol].HasValueData( nRow );
1217cdf0e10cSrcweir 	else
1218cdf0e10cSrcweir 		return sal_False;
1219cdf0e10cSrcweir }
1220cdf0e10cSrcweir 
1221cdf0e10cSrcweir 
HasStringCells(SCCOL nStartCol,SCROW nStartRow,SCCOL nEndCol,SCROW nEndRow) const1222cdf0e10cSrcweir sal_Bool ScTable::HasStringCells( SCCOL nStartCol, SCROW nStartRow,
1223cdf0e10cSrcweir 								SCCOL nEndCol, SCROW nEndRow ) const
1224cdf0e10cSrcweir {
1225cdf0e10cSrcweir 	if ( ValidCol(nEndCol) )
1226cdf0e10cSrcweir 		for ( SCCOL nCol=nStartCol; nCol<=nEndCol; nCol++ )
1227cdf0e10cSrcweir 			if (aCol[nCol].HasStringCells(nStartRow, nEndRow))
1228cdf0e10cSrcweir 				return sal_True;
1229cdf0e10cSrcweir 
1230cdf0e10cSrcweir 	return sal_False;
1231cdf0e10cSrcweir }
1232cdf0e10cSrcweir 
1233cdf0e10cSrcweir 
1234cdf0e10cSrcweir //UNUSED2008-05  sal_uInt16 ScTable::GetErrCode( SCCOL nCol, SCROW nRow ) const
1235cdf0e10cSrcweir //UNUSED2008-05  {
1236cdf0e10cSrcweir //UNUSED2008-05      if (ValidColRow( nCol, nRow ))
1237cdf0e10cSrcweir //UNUSED2008-05          return aCol[nCol].GetErrCode( nRow );
1238cdf0e10cSrcweir //UNUSED2008-05      return 0;
1239cdf0e10cSrcweir //UNUSED2008-05  }
1240cdf0e10cSrcweir 
1241cdf0e10cSrcweir 
SetDirtyVar()1242cdf0e10cSrcweir void ScTable::SetDirtyVar()
1243cdf0e10cSrcweir {
1244cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL; i++)
1245cdf0e10cSrcweir 		aCol[i].SetDirtyVar();
1246cdf0e10cSrcweir }
1247cdf0e10cSrcweir 
1248cdf0e10cSrcweir 
SetDirty()1249cdf0e10cSrcweir void ScTable::SetDirty()
1250cdf0e10cSrcweir {
1251cdf0e10cSrcweir 	sal_Bool bOldAutoCalc = pDocument->GetAutoCalc();
1252cdf0e10cSrcweir 	pDocument->SetAutoCalc( sal_False );	// Mehrfachberechnungen vermeiden
1253cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL; i++)
1254cdf0e10cSrcweir 		aCol[i].SetDirty();
1255cdf0e10cSrcweir 	pDocument->SetAutoCalc( bOldAutoCalc );
1256cdf0e10cSrcweir }
1257cdf0e10cSrcweir 
1258cdf0e10cSrcweir 
SetDirty(const ScRange & rRange)1259cdf0e10cSrcweir void ScTable::SetDirty( const ScRange& rRange )
1260cdf0e10cSrcweir {
1261cdf0e10cSrcweir 	sal_Bool bOldAutoCalc = pDocument->GetAutoCalc();
1262cdf0e10cSrcweir 	pDocument->SetAutoCalc( sal_False );	// Mehrfachberechnungen vermeiden
1263cdf0e10cSrcweir 	SCCOL nCol2 = rRange.aEnd.Col();
1264cdf0e10cSrcweir 	for (SCCOL i=rRange.aStart.Col(); i<=nCol2; i++)
1265cdf0e10cSrcweir 		aCol[i].SetDirty( rRange );
1266cdf0e10cSrcweir 	pDocument->SetAutoCalc( bOldAutoCalc );
1267cdf0e10cSrcweir }
1268cdf0e10cSrcweir 
1269cdf0e10cSrcweir 
SetTableOpDirty(const ScRange & rRange)1270cdf0e10cSrcweir void ScTable::SetTableOpDirty( const ScRange& rRange )
1271cdf0e10cSrcweir {
1272cdf0e10cSrcweir 	sal_Bool bOldAutoCalc = pDocument->GetAutoCalc();
1273cdf0e10cSrcweir 	pDocument->SetAutoCalc( sal_False );	// no multiple recalculation
1274cdf0e10cSrcweir 	SCCOL nCol2 = rRange.aEnd.Col();
1275cdf0e10cSrcweir 	for (SCCOL i=rRange.aStart.Col(); i<=nCol2; i++)
1276cdf0e10cSrcweir 		aCol[i].SetTableOpDirty( rRange );
1277cdf0e10cSrcweir 	pDocument->SetAutoCalc( bOldAutoCalc );
1278cdf0e10cSrcweir }
1279cdf0e10cSrcweir 
1280cdf0e10cSrcweir 
SetDirtyAfterLoad()1281cdf0e10cSrcweir void ScTable::SetDirtyAfterLoad()
1282cdf0e10cSrcweir {
1283cdf0e10cSrcweir 	sal_Bool bOldAutoCalc = pDocument->GetAutoCalc();
1284cdf0e10cSrcweir 	pDocument->SetAutoCalc( sal_False );	// Mehrfachberechnungen vermeiden
1285cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL; i++)
1286cdf0e10cSrcweir 		aCol[i].SetDirtyAfterLoad();
1287cdf0e10cSrcweir 	pDocument->SetAutoCalc( bOldAutoCalc );
1288cdf0e10cSrcweir }
1289cdf0e10cSrcweir 
1290cdf0e10cSrcweir 
SetRelNameDirty()1291cdf0e10cSrcweir void ScTable::SetRelNameDirty()
1292cdf0e10cSrcweir {
1293cdf0e10cSrcweir 	sal_Bool bOldAutoCalc = pDocument->GetAutoCalc();
1294cdf0e10cSrcweir 	pDocument->SetAutoCalc( sal_False );	// Mehrfachberechnungen vermeiden
1295cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL; i++)
1296cdf0e10cSrcweir 		aCol[i].SetRelNameDirty();
1297cdf0e10cSrcweir 	pDocument->SetAutoCalc( bOldAutoCalc );
1298cdf0e10cSrcweir }
1299cdf0e10cSrcweir 
1300cdf0e10cSrcweir 
SetLoadingMedium(bool bLoading)1301cdf0e10cSrcweir void ScTable::SetLoadingMedium(bool bLoading)
1302cdf0e10cSrcweir {
1303cdf0e10cSrcweir     mpRowHeights->enableTreeSearch(!bLoading);
1304cdf0e10cSrcweir 
1305cdf0e10cSrcweir     // When loading a medium, prefer inserting row heights from the back
1306cdf0e10cSrcweir     // position since the row heights are stored and read in ascending order
1307cdf0e10cSrcweir     // during import.
1308cdf0e10cSrcweir     mpRowHeights->setInsertFromBack(bLoading);
1309cdf0e10cSrcweir }
1310cdf0e10cSrcweir 
1311cdf0e10cSrcweir 
CalcAll()1312cdf0e10cSrcweir void ScTable::CalcAll()
1313cdf0e10cSrcweir {
1314cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL; i++) aCol[i].CalcAll();
1315cdf0e10cSrcweir }
1316cdf0e10cSrcweir 
1317cdf0e10cSrcweir 
CompileAll()1318cdf0e10cSrcweir void ScTable::CompileAll()
1319cdf0e10cSrcweir {
1320cdf0e10cSrcweir 	for (SCCOL i=0; i <= MAXCOL; i++) aCol[i].CompileAll();
1321cdf0e10cSrcweir }
1322cdf0e10cSrcweir 
1323cdf0e10cSrcweir 
CompileXML(ScProgress & rProgress)1324cdf0e10cSrcweir void ScTable::CompileXML( ScProgress& rProgress )
1325cdf0e10cSrcweir {
1326cdf0e10cSrcweir 	for (SCCOL i=0; i <= MAXCOL; i++)
1327cdf0e10cSrcweir 	{
1328cdf0e10cSrcweir 		aCol[i].CompileXML( rProgress );
1329cdf0e10cSrcweir 	}
1330cdf0e10cSrcweir }
1331cdf0e10cSrcweir 
CalcAfterLoad()1332cdf0e10cSrcweir void ScTable::CalcAfterLoad()
1333cdf0e10cSrcweir {
1334cdf0e10cSrcweir 	for (SCCOL i=0; i <= MAXCOL; i++) aCol[i].CalcAfterLoad();
1335cdf0e10cSrcweir }
1336cdf0e10cSrcweir 
1337cdf0e10cSrcweir 
ResetChanged(const ScRange & rRange)1338cdf0e10cSrcweir void ScTable::ResetChanged( const ScRange& rRange )
1339cdf0e10cSrcweir {
1340cdf0e10cSrcweir 	SCCOL nStartCol = rRange.aStart.Col();
1341cdf0e10cSrcweir 	SCROW nStartRow = rRange.aStart.Row();
1342cdf0e10cSrcweir 	SCCOL nEndCol = rRange.aEnd.Col();
1343cdf0e10cSrcweir 	SCROW nEndRow = rRange.aEnd.Row();
1344cdf0e10cSrcweir 
1345cdf0e10cSrcweir 	for (SCCOL nCol=nStartCol; nCol<=nEndCol; nCol++)
1346cdf0e10cSrcweir 		aCol[nCol].ResetChanged(nStartRow, nEndRow);
1347cdf0e10cSrcweir }
1348cdf0e10cSrcweir 
1349cdf0e10cSrcweir //	Attribute
1350cdf0e10cSrcweir 
GetAttr(SCCOL nCol,SCROW nRow,sal_uInt16 nWhich) const1351cdf0e10cSrcweir const SfxPoolItem* ScTable::GetAttr( SCCOL nCol, SCROW nRow, sal_uInt16 nWhich ) const
1352cdf0e10cSrcweir {
1353cdf0e10cSrcweir 	if (ValidColRow(nCol,nRow))
1354cdf0e10cSrcweir 		return aCol[nCol].GetAttr( nRow, nWhich );
1355cdf0e10cSrcweir 	else
1356cdf0e10cSrcweir 		return NULL;
1357cdf0e10cSrcweir }
1358cdf0e10cSrcweir 
1359cdf0e10cSrcweir 
GetNumberFormat(SCCOL nCol,SCROW nRow) const1360cdf0e10cSrcweir sal_uLong ScTable::GetNumberFormat( SCCOL nCol, SCROW nRow ) const
1361cdf0e10cSrcweir {
1362cdf0e10cSrcweir 	if (ValidColRow(nCol,nRow))
1363cdf0e10cSrcweir 		return aCol[nCol].GetNumberFormat( nRow );
1364cdf0e10cSrcweir 	else
1365cdf0e10cSrcweir 		return 0;
1366cdf0e10cSrcweir }
1367cdf0e10cSrcweir 
1368cdf0e10cSrcweir 
GetPattern(SCCOL nCol,SCROW nRow) const1369cdf0e10cSrcweir const ScPatternAttr* ScTable::GetPattern( SCCOL nCol, SCROW nRow ) const
1370cdf0e10cSrcweir {
1371cdf0e10cSrcweir 	if (ValidColRow(nCol,nRow))
1372cdf0e10cSrcweir 		return aCol[nCol].GetPattern( nRow );
1373cdf0e10cSrcweir 	else
1374cdf0e10cSrcweir     {
1375cdf0e10cSrcweir         DBG_ERROR("wrong column or row");
1376cdf0e10cSrcweir         return pDocument->GetDefPattern();      // for safety
1377cdf0e10cSrcweir     }
1378cdf0e10cSrcweir }
1379cdf0e10cSrcweir 
1380cdf0e10cSrcweir 
GetMostUsedPattern(SCCOL nCol,SCROW nStartRow,SCROW nEndRow) const1381cdf0e10cSrcweir const ScPatternAttr* ScTable::GetMostUsedPattern( SCCOL nCol, SCROW nStartRow, SCROW nEndRow ) const
1382cdf0e10cSrcweir {
1383cdf0e10cSrcweir     if ( ValidColRow( nCol, nStartRow ) && ValidRow( nEndRow ) && (nStartRow <= nEndRow) )
1384cdf0e10cSrcweir         return aCol[nCol].GetMostUsedPattern( nStartRow, nEndRow );
1385cdf0e10cSrcweir     else
1386cdf0e10cSrcweir         return NULL;
1387cdf0e10cSrcweir }
1388cdf0e10cSrcweir 
1389cdf0e10cSrcweir 
HasAttrib(SCCOL nCol1,SCROW nRow1,SCCOL nCol2,SCROW nRow2,sal_uInt16 nMask) const1390cdf0e10cSrcweir bool ScTable::HasAttrib( SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2, sal_uInt16 nMask ) const
1391cdf0e10cSrcweir {
1392cdf0e10cSrcweir 	bool bFound = false;
1393cdf0e10cSrcweir 	for (SCCOL i=nCol1; i<=nCol2 && !bFound; i++)
1394cdf0e10cSrcweir 		bFound |= aCol[i].HasAttrib( nRow1, nRow2, nMask );
1395cdf0e10cSrcweir 	return bFound;
1396cdf0e10cSrcweir }
1397cdf0e10cSrcweir 
1398cdf0e10cSrcweir 
1399cdf0e10cSrcweir //UNUSED2009-05 sal_Bool ScTable::HasLines( const ScRange& rRange, Rectangle& rSizes ) const
1400cdf0e10cSrcweir //UNUSED2009-05 {
1401cdf0e10cSrcweir //UNUSED2009-05     SCCOL nCol1 = rRange.aStart.Col();
1402cdf0e10cSrcweir //UNUSED2009-05     SCROW nRow1 = rRange.aStart.Row();
1403cdf0e10cSrcweir //UNUSED2009-05     SCCOL nCol2 = rRange.aEnd.Col();
1404cdf0e10cSrcweir //UNUSED2009-05     SCROW nRow2 = rRange.aEnd.Row();
1405cdf0e10cSrcweir //UNUSED2009-05     PutInOrder( nCol1, nCol2 );
1406cdf0e10cSrcweir //UNUSED2009-05     PutInOrder( nRow1, nRow2 );
1407cdf0e10cSrcweir //UNUSED2009-05
1408cdf0e10cSrcweir //UNUSED2009-05     sal_Bool bFound = sal_False;
1409cdf0e10cSrcweir //UNUSED2009-05     for (SCCOL i=nCol1; i<=nCol2; i++)
1410cdf0e10cSrcweir //UNUSED2009-05         if (aCol[i].HasLines( nRow1, nRow2, rSizes, (i==nCol1), (i==nCol2) ))
1411cdf0e10cSrcweir //UNUSED2009-05             bFound = sal_True;
1412cdf0e10cSrcweir //UNUSED2009-05
1413cdf0e10cSrcweir //UNUSED2009-05     return bFound;
1414cdf0e10cSrcweir //UNUSED2009-05 }
1415cdf0e10cSrcweir 
1416cdf0e10cSrcweir 
HasAttribSelection(const ScMarkData & rMark,sal_uInt16 nMask) const1417cdf0e10cSrcweir sal_Bool ScTable::HasAttribSelection( const ScMarkData& rMark, sal_uInt16 nMask ) const
1418cdf0e10cSrcweir {
1419cdf0e10cSrcweir 	sal_Bool bFound=sal_False;
1420cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL && !bFound; i++)
1421cdf0e10cSrcweir 		bFound |= aCol[i].HasAttribSelection( rMark, nMask );
1422cdf0e10cSrcweir 	return bFound;
1423cdf0e10cSrcweir }
1424cdf0e10cSrcweir 
1425cdf0e10cSrcweir 
ExtendMerge(SCCOL nStartCol,SCROW nStartRow,SCCOL & rEndCol,SCROW & rEndRow,sal_Bool bRefresh,sal_Bool bAttrs)1426cdf0e10cSrcweir sal_Bool ScTable::ExtendMerge( SCCOL nStartCol, SCROW nStartRow,
1427cdf0e10cSrcweir 						   SCCOL& rEndCol, SCROW& rEndRow,
1428cdf0e10cSrcweir 						   sal_Bool bRefresh, sal_Bool bAttrs )
1429cdf0e10cSrcweir {
1430cdf0e10cSrcweir     if (!(ValidCol(nStartCol) && ValidCol(rEndCol)))
1431cdf0e10cSrcweir     {
1432cdf0e10cSrcweir         DBG_ERRORFILE("ScTable::ExtendMerge: invalid column number");
1433cdf0e10cSrcweir         return sal_False;
1434cdf0e10cSrcweir     }
1435cdf0e10cSrcweir 	sal_Bool bFound=sal_False;
1436cdf0e10cSrcweir 	SCCOL nOldEndX = rEndCol;
1437cdf0e10cSrcweir 	SCROW nOldEndY = rEndRow;
1438cdf0e10cSrcweir 	for (SCCOL i=nStartCol; i<=nOldEndX; i++)
1439cdf0e10cSrcweir 		bFound |= aCol[i].ExtendMerge( i, nStartRow, nOldEndY, rEndCol, rEndRow, bRefresh, bAttrs );
1440cdf0e10cSrcweir 	return bFound;
1441cdf0e10cSrcweir }
1442cdf0e10cSrcweir 
1443cdf0e10cSrcweir 
IsBlockEmpty(SCCOL nCol1,SCROW nRow1,SCCOL nCol2,SCROW nRow2,bool bIgnoreNotes) const1444cdf0e10cSrcweir sal_Bool ScTable::IsBlockEmpty( SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2, bool bIgnoreNotes ) const
1445cdf0e10cSrcweir {
1446cdf0e10cSrcweir     if (!(ValidCol(nCol1) && ValidCol(nCol2)))
1447cdf0e10cSrcweir     {
1448cdf0e10cSrcweir         DBG_ERRORFILE("ScTable::IsBlockEmpty: invalid column number");
1449cdf0e10cSrcweir         return sal_False;
1450cdf0e10cSrcweir     }
1451cdf0e10cSrcweir 	sal_Bool bEmpty = sal_True;
1452cdf0e10cSrcweir 	for (SCCOL i=nCol1; i<=nCol2 && bEmpty; i++)
1453cdf0e10cSrcweir 		bEmpty = aCol[i].IsEmptyBlock( nRow1, nRow2, bIgnoreNotes );
1454cdf0e10cSrcweir 	return bEmpty;
1455cdf0e10cSrcweir }
1456cdf0e10cSrcweir 
FillMaxRot(RowInfo * pRowInfo,SCSIZE nArrCount,SCCOL nX1,SCCOL nX2,SCCOL nCol,SCROW nAttrRow1,SCROW nAttrRow2,SCSIZE nArrY,const ScPatternAttr * pPattern,const SfxItemSet * pCondSet)1457cdf0e10cSrcweir SCSIZE ScTable::FillMaxRot( RowInfo* pRowInfo, SCSIZE nArrCount, SCCOL nX1, SCCOL nX2,
1458cdf0e10cSrcweir 							SCCOL nCol, SCROW nAttrRow1, SCROW nAttrRow2, SCSIZE nArrY,
1459cdf0e10cSrcweir 							const ScPatternAttr* pPattern, const SfxItemSet* pCondSet )
1460cdf0e10cSrcweir {
1461cdf0e10cSrcweir 	//	Rueckgabe = neues nArrY
1462cdf0e10cSrcweir 
1463cdf0e10cSrcweir 	sal_uInt8 nRotDir = pPattern->GetRotateDir( pCondSet );
1464cdf0e10cSrcweir 	if ( nRotDir != SC_ROTDIR_NONE )
1465cdf0e10cSrcweir 	{
1466cdf0e10cSrcweir 		sal_Bool bHit = sal_True;
1467cdf0e10cSrcweir 		if ( nCol+1 < nX1 )								// column to the left
1468cdf0e10cSrcweir 			bHit = ( nRotDir != SC_ROTDIR_LEFT );
1469cdf0e10cSrcweir 		else if ( nCol > nX2+1 )						// column to the right
1470cdf0e10cSrcweir 			bHit = ( nRotDir != SC_ROTDIR_RIGHT );		// SC_ROTDIR_STANDARD may now also be extended to the left
1471cdf0e10cSrcweir 
1472cdf0e10cSrcweir 		if ( bHit )
1473cdf0e10cSrcweir 		{
1474cdf0e10cSrcweir 			double nFactor = 0.0;
1475cdf0e10cSrcweir 			if ( nCol > nX2+1 )
1476cdf0e10cSrcweir 			{
1477cdf0e10cSrcweir 				long nRotVal = ((const SfxInt32Item&) pPattern->
1478cdf0e10cSrcweir 						GetItem( ATTR_ROTATE_VALUE, pCondSet )).GetValue();
1479cdf0e10cSrcweir 				double nRealOrient = nRotVal * F_PI18000;	// 1/100 Grad
1480cdf0e10cSrcweir 				double nCos = cos( nRealOrient );
1481cdf0e10cSrcweir 				double nSin = sin( nRealOrient );
1482cdf0e10cSrcweir 				//!	begrenzen !!!
1483cdf0e10cSrcweir 				//!	zusaetzlich Faktor fuer unterschiedliche PPT X/Y !!!
1484cdf0e10cSrcweir 
1485cdf0e10cSrcweir 				//	bei SC_ROTDIR_LEFT kommt immer ein negativer Wert heraus,
1486cdf0e10cSrcweir 				//	wenn der Modus beruecksichtigt wird
1487cdf0e10cSrcweir 				nFactor = -fabs( nCos / nSin );
1488cdf0e10cSrcweir 			}
1489cdf0e10cSrcweir 
1490cdf0e10cSrcweir 			for ( SCROW nRow = nAttrRow1; nRow <= nAttrRow2; nRow++ )
1491cdf0e10cSrcweir 			{
1492cdf0e10cSrcweir                 if (!RowHidden(nRow))
1493cdf0e10cSrcweir 				{
1494cdf0e10cSrcweir 					sal_Bool bHitOne = sal_True;
1495cdf0e10cSrcweir 					if ( nCol > nX2+1 )
1496cdf0e10cSrcweir 					{
1497cdf0e10cSrcweir 						// reicht die gedrehte Zelle bis in den sichtbaren Bereich?
1498cdf0e10cSrcweir 
1499cdf0e10cSrcweir 						SCCOL nTouchedCol = nCol;
1500cdf0e10cSrcweir                         long nWidth = static_cast<long>(mpRowHeights->getValue(nRow) * nFactor);
1501cdf0e10cSrcweir 						DBG_ASSERT(nWidth <= 0, "Richtung falsch");
1502cdf0e10cSrcweir 						while ( nWidth < 0 && nTouchedCol > 0 )
1503cdf0e10cSrcweir 						{
1504cdf0e10cSrcweir 							--nTouchedCol;
1505cdf0e10cSrcweir 							nWidth += GetColWidth( nTouchedCol );
1506cdf0e10cSrcweir 						}
1507cdf0e10cSrcweir 						if ( nTouchedCol > nX2 )
1508cdf0e10cSrcweir 							bHitOne = sal_False;
1509cdf0e10cSrcweir 					}
1510cdf0e10cSrcweir 
1511cdf0e10cSrcweir 					if (bHitOne)
1512cdf0e10cSrcweir 					{
1513cdf0e10cSrcweir 						while ( nArrY<nArrCount && pRowInfo[nArrY].nRowNo < nRow )
1514cdf0e10cSrcweir 							++nArrY;
1515cdf0e10cSrcweir 						if ( nArrY<nArrCount && pRowInfo[nArrY].nRowNo == nRow )
1516cdf0e10cSrcweir 							pRowInfo[nArrY].nRotMaxCol = nCol;
1517cdf0e10cSrcweir 					}
1518cdf0e10cSrcweir 				}
1519cdf0e10cSrcweir 			}
1520cdf0e10cSrcweir 		}
1521cdf0e10cSrcweir 	}
1522cdf0e10cSrcweir 
1523cdf0e10cSrcweir 	return nArrY;
1524cdf0e10cSrcweir }
1525cdf0e10cSrcweir 
FindMaxRotCol(RowInfo * pRowInfo,SCSIZE nArrCount,SCCOL nX1,SCCOL nX2)1526cdf0e10cSrcweir void ScTable::FindMaxRotCol( RowInfo* pRowInfo, SCSIZE nArrCount, SCCOL nX1, SCCOL nX2 )
1527cdf0e10cSrcweir {
1528cdf0e10cSrcweir     if ( !pColWidth || !mpRowHeights || !pColFlags || !pRowFlags )
1529cdf0e10cSrcweir 	{
1530cdf0e10cSrcweir 		DBG_ERROR( "Spalten-/Zeileninfo fehlt" );
1531cdf0e10cSrcweir 		return;
1532cdf0e10cSrcweir 	}
1533cdf0e10cSrcweir 
1534cdf0e10cSrcweir 	//	nRotMaxCol ist auf SC_ROTMAX_NONE initialisiert, nRowNo ist schon gesetzt
1535cdf0e10cSrcweir 
1536cdf0e10cSrcweir 	SCROW nY1 = pRowInfo[0].nRowNo;
1537cdf0e10cSrcweir 	SCROW nY2 = pRowInfo[nArrCount-1].nRowNo;
1538cdf0e10cSrcweir 
1539cdf0e10cSrcweir 	for (SCCOL nCol=0; nCol<=MAXCOL; nCol++)
1540cdf0e10cSrcweir 	{
1541cdf0e10cSrcweir         if (!ColHidden(nCol))
1542cdf0e10cSrcweir 		{
1543cdf0e10cSrcweir 			SCSIZE nArrY = 0;
1544cdf0e10cSrcweir 			ScDocAttrIterator aIter( pDocument, nTab, nCol, nY1, nCol, nY2 );
1545cdf0e10cSrcweir 			SCCOL nAttrCol;
1546cdf0e10cSrcweir             SCROW nAttrRow1, nAttrRow2;
1547cdf0e10cSrcweir 			const ScPatternAttr* pPattern = aIter.GetNext( nAttrCol, nAttrRow1, nAttrRow2 );
1548cdf0e10cSrcweir 			while ( pPattern )
1549cdf0e10cSrcweir 			{
1550cdf0e10cSrcweir 				const SfxPoolItem* pCondItem;
1551cdf0e10cSrcweir 				if ( pPattern->GetItemSet().GetItemState( ATTR_CONDITIONAL, sal_True, &pCondItem )
1552cdf0e10cSrcweir 						== SFX_ITEM_SET )
1553cdf0e10cSrcweir 				{
1554cdf0e10cSrcweir 					//	alle Formate durchgehen, damit die Zellen nicht einzeln
1555cdf0e10cSrcweir 					//	angeschaut werden muessen
1556cdf0e10cSrcweir 
1557cdf0e10cSrcweir 					sal_uLong nIndex = ((const SfxUInt32Item*)pCondItem)->GetValue();
1558cdf0e10cSrcweir 					ScConditionalFormatList* pList = pDocument->GetCondFormList();
1559cdf0e10cSrcweir 					ScStyleSheetPool* pStylePool = pDocument->GetStyleSheetPool();
1560cdf0e10cSrcweir 					if (pList && pStylePool && nIndex)
1561cdf0e10cSrcweir 					{
1562cdf0e10cSrcweir 						const ScConditionalFormat* pFormat = pList->GetFormat(nIndex);
1563cdf0e10cSrcweir 						if ( pFormat )
1564cdf0e10cSrcweir 						{
1565cdf0e10cSrcweir 							sal_uInt16 nEntryCount = pFormat->Count();
1566cdf0e10cSrcweir 							for (sal_uInt16 nEntry=0; nEntry<nEntryCount; nEntry++)
1567cdf0e10cSrcweir 							{
1568cdf0e10cSrcweir                                 String aStyleName = pFormat->GetEntry(nEntry)->GetStyle();
1569cdf0e10cSrcweir                                 if (aStyleName.Len())
1570cdf0e10cSrcweir 								{
1571cdf0e10cSrcweir 									SfxStyleSheetBase* pStyleSheet =
1572cdf0e10cSrcweir                                             pStylePool->Find( aStyleName, SFX_STYLE_FAMILY_PARA );
1573cdf0e10cSrcweir 									if ( pStyleSheet )
1574cdf0e10cSrcweir 									{
1575cdf0e10cSrcweir 										FillMaxRot( pRowInfo, nArrCount, nX1, nX2,
1576cdf0e10cSrcweir 													nCol, nAttrRow1, nAttrRow2,
1577cdf0e10cSrcweir 													nArrY, pPattern, &pStyleSheet->GetItemSet() );
1578cdf0e10cSrcweir 										//	nArrY nicht veraendern
1579cdf0e10cSrcweir 									}
1580cdf0e10cSrcweir 								}
1581cdf0e10cSrcweir 							}
1582cdf0e10cSrcweir 						}
1583cdf0e10cSrcweir 					}
1584cdf0e10cSrcweir 				}
1585cdf0e10cSrcweir 
1586cdf0e10cSrcweir 				nArrY = FillMaxRot( pRowInfo, nArrCount, nX1, nX2,
1587cdf0e10cSrcweir 									nCol, nAttrRow1, nAttrRow2,
1588cdf0e10cSrcweir 									nArrY, pPattern, NULL );
1589cdf0e10cSrcweir 
1590cdf0e10cSrcweir 				pPattern = aIter.GetNext( nAttrCol, nAttrRow1, nAttrRow2 );
1591cdf0e10cSrcweir 			}
1592cdf0e10cSrcweir 		}
1593cdf0e10cSrcweir 	}
1594cdf0e10cSrcweir }
1595cdf0e10cSrcweir 
HasBlockMatrixFragment(SCCOL nCol1,SCROW nRow1,SCCOL nCol2,SCROW nRow2) const1596cdf0e10cSrcweir sal_Bool ScTable::HasBlockMatrixFragment( SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2 ) const
1597cdf0e10cSrcweir {
1598cdf0e10cSrcweir 	// nix:0, mitte:1, unten:2, links:4, oben:8, rechts:16, offen:32
1599cdf0e10cSrcweir 	sal_uInt16 nEdges;
1600cdf0e10cSrcweir 
1601cdf0e10cSrcweir 	if ( nCol1 == nCol2 )
1602cdf0e10cSrcweir 	{	// linke und rechte Spalte
1603cdf0e10cSrcweir 		const sal_uInt16 n = 4 | 16;
1604cdf0e10cSrcweir 		nEdges = aCol[nCol1].GetBlockMatrixEdges( nRow1, nRow2, n );
1605cdf0e10cSrcweir 		// nicht (4 und 16) oder 1 oder 32
1606cdf0e10cSrcweir 		if ( nEdges && (((nEdges & n) != n) || (nEdges & 33)) )
1607cdf0e10cSrcweir 			return sal_True;		// linke oder rechte Kante fehlt oder offen
1608cdf0e10cSrcweir 	}
1609cdf0e10cSrcweir 	else
1610cdf0e10cSrcweir 	{	// linke Spalte
1611cdf0e10cSrcweir 		nEdges = aCol[nCol1].GetBlockMatrixEdges( nRow1, nRow2, 4 );
1612cdf0e10cSrcweir 		// nicht 4 oder 1 oder 32
1613cdf0e10cSrcweir 		if ( nEdges && (((nEdges & 4) != 4) || (nEdges & 33)) )
1614cdf0e10cSrcweir 			return sal_True;		// linke Kante fehlt oder offen
1615cdf0e10cSrcweir 		// rechte Spalte
1616cdf0e10cSrcweir 		nEdges = aCol[nCol2].GetBlockMatrixEdges( nRow1, nRow2, 16 );
1617cdf0e10cSrcweir 		// nicht 16 oder 1 oder 32
1618cdf0e10cSrcweir 		if ( nEdges && (((nEdges & 16) != 16) || (nEdges & 33)) )
1619cdf0e10cSrcweir 			return sal_True;		// rechte Kante fehlt oder offen
1620cdf0e10cSrcweir 	}
1621cdf0e10cSrcweir 
1622cdf0e10cSrcweir 	if ( nRow1 == nRow2 )
1623cdf0e10cSrcweir 	{	// obere und untere Zeile
1624cdf0e10cSrcweir 		sal_Bool bOpen = sal_False;
1625cdf0e10cSrcweir 		const sal_uInt16 n = 2 | 8;
1626cdf0e10cSrcweir 		for ( SCCOL i=nCol1; i<=nCol2; i++)
1627cdf0e10cSrcweir 		{
1628cdf0e10cSrcweir 			nEdges = aCol[i].GetBlockMatrixEdges( nRow1, nRow1, n );
1629cdf0e10cSrcweir 			if ( nEdges )
1630cdf0e10cSrcweir 			{
1631cdf0e10cSrcweir 				if ( (nEdges & n) != n )
1632cdf0e10cSrcweir 					return sal_True;		// obere oder untere Kante fehlt
1633cdf0e10cSrcweir 				if ( nEdges & 4 )
1634cdf0e10cSrcweir 					bOpen = sal_True;		// linke Kante oeffnet, weitersehen
1635cdf0e10cSrcweir 				else if ( !bOpen )
1636cdf0e10cSrcweir 					return sal_True;		// es gibt was, was nicht geoeffnet wurde
1637cdf0e10cSrcweir 				if ( nEdges & 16 )
1638cdf0e10cSrcweir 					bOpen = sal_False;		// rechte Kante schliesst
1639cdf0e10cSrcweir 			}
1640cdf0e10cSrcweir 		}
1641cdf0e10cSrcweir 		if ( bOpen )
1642cdf0e10cSrcweir 			return sal_True;				// es geht noch weiter
1643cdf0e10cSrcweir 	}
1644cdf0e10cSrcweir 	else
1645cdf0e10cSrcweir 	{
1646cdf0e10cSrcweir 		sal_uInt16 j, n;
1647cdf0e10cSrcweir         SCROW nR;
1648cdf0e10cSrcweir 		// erst obere Zeile, dann untere Zeile
1649cdf0e10cSrcweir 		for ( j=0, nR=nRow1, n=8; j<2; j++, nR=nRow2, n=2 )
1650cdf0e10cSrcweir 		{
1651cdf0e10cSrcweir 			sal_Bool bOpen = sal_False;
1652cdf0e10cSrcweir 			for ( SCCOL i=nCol1; i<=nCol2; i++)
1653cdf0e10cSrcweir 			{
1654cdf0e10cSrcweir 				nEdges = aCol[i].GetBlockMatrixEdges( nR, nR, n );
1655cdf0e10cSrcweir 				if ( nEdges )
1656cdf0e10cSrcweir 				{
1657cdf0e10cSrcweir 					// in oberere Zeile keine obere Kante bzw.
1658cdf0e10cSrcweir 					// in unterer Zeile keine untere Kante
1659cdf0e10cSrcweir 					if ( (nEdges & n) != n )
1660cdf0e10cSrcweir 						return sal_True;
1661cdf0e10cSrcweir 					if ( nEdges & 4 )
1662cdf0e10cSrcweir 						bOpen = sal_True;		// linke Kante oeffnet, weitersehen
1663cdf0e10cSrcweir 					else if ( !bOpen )
1664cdf0e10cSrcweir 						return sal_True;		// es gibt was, was nicht geoeffnet wurde
1665cdf0e10cSrcweir 					if ( nEdges & 16 )
1666cdf0e10cSrcweir 						bOpen = sal_False;		// rechte Kante schliesst
1667cdf0e10cSrcweir 				}
1668cdf0e10cSrcweir 			}
1669cdf0e10cSrcweir 			if ( bOpen )
1670cdf0e10cSrcweir 				return sal_True;				// es geht noch weiter
1671cdf0e10cSrcweir 		}
1672cdf0e10cSrcweir 	}
1673cdf0e10cSrcweir 	return sal_False;
1674cdf0e10cSrcweir }
1675cdf0e10cSrcweir 
1676cdf0e10cSrcweir 
HasSelectionMatrixFragment(const ScMarkData & rMark) const1677cdf0e10cSrcweir sal_Bool ScTable::HasSelectionMatrixFragment( const ScMarkData& rMark ) const
1678cdf0e10cSrcweir {
1679cdf0e10cSrcweir 	sal_Bool bFound=sal_False;
1680cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL && !bFound; i++)
1681cdf0e10cSrcweir 		bFound |= aCol[i].HasSelectionMatrixFragment(rMark);
1682cdf0e10cSrcweir 	return bFound;
1683cdf0e10cSrcweir }
1684cdf0e10cSrcweir 
1685cdf0e10cSrcweir 
IsBlockEditable(SCCOL nCol1,SCROW nRow1,SCCOL nCol2,SCROW nRow2,sal_Bool * pOnlyNotBecauseOfMatrix) const1686cdf0e10cSrcweir sal_Bool ScTable::IsBlockEditable( SCCOL nCol1, SCROW nRow1, SCCOL nCol2,
1687cdf0e10cSrcweir 			SCROW nRow2, sal_Bool* pOnlyNotBecauseOfMatrix /* = NULL */ ) const
1688cdf0e10cSrcweir {
1689cdf0e10cSrcweir     if ( !ValidColRow( nCol2, nRow2 ) )
1690cdf0e10cSrcweir     {
1691cdf0e10cSrcweir         DBG_ERRORFILE("IsBlockEditable: invalid column or row");
1692cdf0e10cSrcweir         if (pOnlyNotBecauseOfMatrix)
1693cdf0e10cSrcweir             *pOnlyNotBecauseOfMatrix = sal_False;
1694cdf0e10cSrcweir         return sal_False;
1695cdf0e10cSrcweir     }
1696cdf0e10cSrcweir 
1697cdf0e10cSrcweir 	sal_Bool bIsEditable = sal_True;
1698cdf0e10cSrcweir 	if ( nLockCount )
1699cdf0e10cSrcweir 		bIsEditable = sal_False;
1700cdf0e10cSrcweir     else if ( IsProtected() && !pDocument->IsScenario(nTab) )
1701cdf0e10cSrcweir     {
1702cdf0e10cSrcweir         if((bIsEditable = !HasAttrib( nCol1, nRow1, nCol2, nRow2, HASATTR_PROTECTED )) != sal_False)
1703cdf0e10cSrcweir         {
1704cdf0e10cSrcweir             // If Sheet is protected and cells are not protected then
1705cdf0e10cSrcweir             // check the active scenario protect flag if this range is
1706cdf0e10cSrcweir             // on the active scenario range. Note the 'copy back' must also
1707cdf0e10cSrcweir             // be set to apply protection.
1708cdf0e10cSrcweir             sal_uInt16 nScenTab = nTab+1;
1709cdf0e10cSrcweir             while(pDocument->IsScenario(nScenTab))
1710cdf0e10cSrcweir             {
1711cdf0e10cSrcweir                 ScRange aEditRange(nCol1, nRow1, nScenTab, nCol2, nRow2, nScenTab);
1712cdf0e10cSrcweir                 if(pDocument->IsActiveScenario(nScenTab) && pDocument->HasScenarioRange(nScenTab, aEditRange))
1713cdf0e10cSrcweir                 {
1714cdf0e10cSrcweir                     sal_uInt16 nFlags;
1715cdf0e10cSrcweir                     pDocument->GetScenarioFlags(nScenTab,nFlags);
1716cdf0e10cSrcweir                     bIsEditable = !((nFlags & SC_SCENARIO_PROTECT) && (nFlags & SC_SCENARIO_TWOWAY));
1717cdf0e10cSrcweir                     break;
1718cdf0e10cSrcweir                 }
1719cdf0e10cSrcweir                 nScenTab++;
1720cdf0e10cSrcweir             }
1721cdf0e10cSrcweir         }
1722cdf0e10cSrcweir     }
1723cdf0e10cSrcweir     else if (pDocument->IsScenario(nTab))
1724cdf0e10cSrcweir     {
1725cdf0e10cSrcweir         // Determine if the preceding sheet is protected
1726cdf0e10cSrcweir         SCTAB nActualTab = nTab;
1727cdf0e10cSrcweir         do
1728cdf0e10cSrcweir         {
1729cdf0e10cSrcweir             nActualTab--;
1730cdf0e10cSrcweir         }
1731cdf0e10cSrcweir         while(pDocument->IsScenario(nActualTab));
1732cdf0e10cSrcweir 
1733cdf0e10cSrcweir         if(pDocument->IsTabProtected(nActualTab))
1734cdf0e10cSrcweir         {
1735cdf0e10cSrcweir             ScRange aEditRange(nCol1, nRow1, nTab, nCol2, nRow2, nTab);
1736cdf0e10cSrcweir             if(pDocument->HasScenarioRange(nTab, aEditRange))
1737cdf0e10cSrcweir             {
1738cdf0e10cSrcweir                 sal_uInt16 nFlags;
1739cdf0e10cSrcweir                 pDocument->GetScenarioFlags(nTab,nFlags);
1740cdf0e10cSrcweir                 bIsEditable = !(nFlags & SC_SCENARIO_PROTECT);
1741cdf0e10cSrcweir             }
1742cdf0e10cSrcweir         }
1743cdf0e10cSrcweir     }
1744cdf0e10cSrcweir 	if ( bIsEditable )
1745cdf0e10cSrcweir 	{
1746cdf0e10cSrcweir 		if ( HasBlockMatrixFragment( nCol1, nRow1, nCol2, nRow2 ) )
1747cdf0e10cSrcweir 		{
1748cdf0e10cSrcweir 			bIsEditable = sal_False;
1749cdf0e10cSrcweir 			if ( pOnlyNotBecauseOfMatrix )
1750cdf0e10cSrcweir 				*pOnlyNotBecauseOfMatrix = sal_True;
1751cdf0e10cSrcweir 		}
1752cdf0e10cSrcweir 		else if ( pOnlyNotBecauseOfMatrix )
1753cdf0e10cSrcweir 			*pOnlyNotBecauseOfMatrix = sal_False;
1754cdf0e10cSrcweir 	}
1755cdf0e10cSrcweir 	else if ( pOnlyNotBecauseOfMatrix )
1756cdf0e10cSrcweir 		*pOnlyNotBecauseOfMatrix = sal_False;
1757cdf0e10cSrcweir 	return bIsEditable;
1758cdf0e10cSrcweir }
1759cdf0e10cSrcweir 
1760cdf0e10cSrcweir 
IsSelectionEditable(const ScMarkData & rMark,sal_Bool * pOnlyNotBecauseOfMatrix) const1761cdf0e10cSrcweir sal_Bool ScTable::IsSelectionEditable( const ScMarkData& rMark,
1762cdf0e10cSrcweir 			sal_Bool* pOnlyNotBecauseOfMatrix /* = NULL */ ) const
1763cdf0e10cSrcweir {
1764cdf0e10cSrcweir 	sal_Bool bIsEditable = sal_True;
1765cdf0e10cSrcweir 	if ( nLockCount )
1766cdf0e10cSrcweir 		bIsEditable = sal_False;
1767cdf0e10cSrcweir     else if ( IsProtected() && !pDocument->IsScenario(nTab) )
1768cdf0e10cSrcweir     {
1769cdf0e10cSrcweir         if((bIsEditable = !HasAttribSelection( rMark, HASATTR_PROTECTED )) != sal_False)
1770cdf0e10cSrcweir         {
1771cdf0e10cSrcweir             // If Sheet is protected and cells are not protected then
1772cdf0e10cSrcweir             // check the active scenario protect flag if this area is
1773cdf0e10cSrcweir             // in the active scenario range.
1774cdf0e10cSrcweir             ScRangeList aRanges;
1775cdf0e10cSrcweir             rMark.FillRangeListWithMarks( &aRanges, sal_False );
1776cdf0e10cSrcweir             sal_uLong nRangeCount = aRanges.Count();
1777cdf0e10cSrcweir             SCTAB nScenTab = nTab+1;
1778cdf0e10cSrcweir             while(pDocument->IsScenario(nScenTab) && bIsEditable)
1779cdf0e10cSrcweir             {
1780cdf0e10cSrcweir                 if(pDocument->IsActiveScenario(nScenTab))
1781cdf0e10cSrcweir                 {
1782cdf0e10cSrcweir                     for (sal_uLong i=0; i<nRangeCount && bIsEditable; i++)
1783cdf0e10cSrcweir                     {
1784cdf0e10cSrcweir                         ScRange aRange = *aRanges.GetObject(i);
1785cdf0e10cSrcweir                         if(pDocument->HasScenarioRange(nScenTab, aRange))
1786cdf0e10cSrcweir                         {
1787cdf0e10cSrcweir                             sal_uInt16 nFlags;
1788cdf0e10cSrcweir                             pDocument->GetScenarioFlags(nScenTab,nFlags);
1789cdf0e10cSrcweir                             bIsEditable = !((nFlags & SC_SCENARIO_PROTECT) && (nFlags & SC_SCENARIO_TWOWAY));
1790cdf0e10cSrcweir                         }
1791cdf0e10cSrcweir                     }
1792cdf0e10cSrcweir                 }
1793cdf0e10cSrcweir                 nScenTab++;
1794cdf0e10cSrcweir             }
1795cdf0e10cSrcweir         }
1796cdf0e10cSrcweir     }
1797cdf0e10cSrcweir     else if (pDocument->IsScenario(nTab))
1798cdf0e10cSrcweir     {
1799cdf0e10cSrcweir         // Determine if the preceding sheet is protected
1800cdf0e10cSrcweir         SCTAB nActualTab = nTab;
1801cdf0e10cSrcweir         do
1802cdf0e10cSrcweir         {
1803cdf0e10cSrcweir             nActualTab--;
1804cdf0e10cSrcweir         }
1805cdf0e10cSrcweir         while(pDocument->IsScenario(nActualTab));
1806cdf0e10cSrcweir 
1807cdf0e10cSrcweir         if(pDocument->IsTabProtected(nActualTab))
1808cdf0e10cSrcweir         {
1809cdf0e10cSrcweir             ScRangeList aRanges;
1810cdf0e10cSrcweir             rMark.FillRangeListWithMarks( &aRanges, sal_False );
1811cdf0e10cSrcweir             sal_uLong nRangeCount = aRanges.Count();
1812cdf0e10cSrcweir             for (sal_uLong i=0; i<nRangeCount && bIsEditable; i++)
1813cdf0e10cSrcweir             {
1814cdf0e10cSrcweir                 ScRange aRange = *aRanges.GetObject(i);
1815cdf0e10cSrcweir                 if(pDocument->HasScenarioRange(nTab, aRange))
1816cdf0e10cSrcweir                 {
1817cdf0e10cSrcweir                     sal_uInt16 nFlags;
1818cdf0e10cSrcweir                     pDocument->GetScenarioFlags(nTab,nFlags);
1819cdf0e10cSrcweir                     bIsEditable = !(nFlags & SC_SCENARIO_PROTECT);
1820cdf0e10cSrcweir                 }
1821cdf0e10cSrcweir             }
1822cdf0e10cSrcweir         }
1823cdf0e10cSrcweir     }
1824cdf0e10cSrcweir 	if ( bIsEditable )
1825cdf0e10cSrcweir 	{
1826cdf0e10cSrcweir 		if ( HasSelectionMatrixFragment( rMark ) )
1827cdf0e10cSrcweir 		{
1828cdf0e10cSrcweir 			bIsEditable = sal_False;
1829cdf0e10cSrcweir 			if ( pOnlyNotBecauseOfMatrix )
1830cdf0e10cSrcweir 				*pOnlyNotBecauseOfMatrix = sal_True;
1831cdf0e10cSrcweir 		}
1832cdf0e10cSrcweir 		else if ( pOnlyNotBecauseOfMatrix )
1833cdf0e10cSrcweir 			*pOnlyNotBecauseOfMatrix = sal_False;
1834cdf0e10cSrcweir 	}
1835cdf0e10cSrcweir 	else if ( pOnlyNotBecauseOfMatrix )
1836cdf0e10cSrcweir 		*pOnlyNotBecauseOfMatrix = sal_False;
1837cdf0e10cSrcweir 	return bIsEditable;
1838cdf0e10cSrcweir }
1839cdf0e10cSrcweir 
1840cdf0e10cSrcweir 
1841cdf0e10cSrcweir 
LockTable()1842cdf0e10cSrcweir void ScTable::LockTable()
1843cdf0e10cSrcweir {
1844cdf0e10cSrcweir 	++nLockCount;
1845cdf0e10cSrcweir }
1846cdf0e10cSrcweir 
1847cdf0e10cSrcweir 
UnlockTable()1848cdf0e10cSrcweir void ScTable::UnlockTable()
1849cdf0e10cSrcweir {
1850cdf0e10cSrcweir 	if (nLockCount)
1851cdf0e10cSrcweir 		--nLockCount;
1852cdf0e10cSrcweir 	else
1853cdf0e10cSrcweir 	{
1854cdf0e10cSrcweir 		DBG_ERROR("UnlockTable ohne LockTable");
1855cdf0e10cSrcweir 	}
1856cdf0e10cSrcweir }
1857cdf0e10cSrcweir 
1858cdf0e10cSrcweir 
MergeSelectionPattern(ScMergePatternState & rState,const ScMarkData & rMark,sal_Bool bDeep) const1859cdf0e10cSrcweir void ScTable::MergeSelectionPattern( ScMergePatternState& rState, const ScMarkData& rMark, sal_Bool bDeep ) const
1860cdf0e10cSrcweir {
1861cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL; i++)
1862cdf0e10cSrcweir 		aCol[i].MergeSelectionPattern( rState, rMark, bDeep );
1863cdf0e10cSrcweir }
1864cdf0e10cSrcweir 
1865cdf0e10cSrcweir 
MergePatternArea(ScMergePatternState & rState,SCCOL nCol1,SCROW nRow1,SCCOL nCol2,SCROW nRow2,sal_Bool bDeep) const1866cdf0e10cSrcweir void ScTable::MergePatternArea( ScMergePatternState& rState, SCCOL nCol1, SCROW nRow1,
1867cdf0e10cSrcweir 													SCCOL nCol2, SCROW nRow2, sal_Bool bDeep ) const
1868cdf0e10cSrcweir {
1869cdf0e10cSrcweir 	for (SCCOL i=nCol1; i<=nCol2; i++)
1870cdf0e10cSrcweir 		aCol[i].MergePatternArea( rState, nRow1, nRow2, bDeep );
1871cdf0e10cSrcweir }
1872cdf0e10cSrcweir 
1873cdf0e10cSrcweir 
MergeBlockFrame(SvxBoxItem * pLineOuter,SvxBoxInfoItem * pLineInner,ScLineFlags & rFlags,SCCOL nStartCol,SCROW nStartRow,SCCOL nEndCol,SCROW nEndRow) const1874cdf0e10cSrcweir void ScTable::MergeBlockFrame( SvxBoxItem* pLineOuter, SvxBoxInfoItem* pLineInner, ScLineFlags& rFlags,
1875cdf0e10cSrcweir 					SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol, SCROW nEndRow ) const
1876cdf0e10cSrcweir {
1877cdf0e10cSrcweir 	if (ValidColRow(nStartCol, nStartRow) && ValidColRow(nEndCol, nEndRow))
1878cdf0e10cSrcweir 	{
1879cdf0e10cSrcweir 		PutInOrder(nStartCol, nEndCol);
1880cdf0e10cSrcweir 		PutInOrder(nStartRow, nEndRow);
1881cdf0e10cSrcweir 		for (SCCOL i=nStartCol; i<=nEndCol; i++)
1882cdf0e10cSrcweir 			aCol[i].MergeBlockFrame( pLineOuter, pLineInner, rFlags,
1883cdf0e10cSrcweir 									nStartRow, nEndRow, (i==nStartCol), nEndCol-i );
1884cdf0e10cSrcweir 	}
1885cdf0e10cSrcweir }
1886cdf0e10cSrcweir 
1887cdf0e10cSrcweir 
ApplyBlockFrame(const SvxBoxItem * pLineOuter,const SvxBoxInfoItem * pLineInner,SCCOL nStartCol,SCROW nStartRow,SCCOL nEndCol,SCROW nEndRow)1888cdf0e10cSrcweir void ScTable::ApplyBlockFrame( const SvxBoxItem* pLineOuter, const SvxBoxInfoItem* pLineInner,
1889cdf0e10cSrcweir 					SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol, SCROW nEndRow )
1890cdf0e10cSrcweir {
1891cdf0e10cSrcweir 	if (ValidColRow(nStartCol, nStartRow) && ValidColRow(nEndCol, nEndRow))
1892cdf0e10cSrcweir 	{
1893cdf0e10cSrcweir 		PutInOrder(nStartCol, nEndCol);
1894cdf0e10cSrcweir 		PutInOrder(nStartRow, nEndRow);
1895cdf0e10cSrcweir 		for (SCCOL i=nStartCol; i<=nEndCol; i++)
1896cdf0e10cSrcweir 			aCol[i].ApplyBlockFrame( pLineOuter, pLineInner,
1897cdf0e10cSrcweir 									nStartRow, nEndRow, (i==nStartCol), nEndCol-i );
1898cdf0e10cSrcweir 	}
1899cdf0e10cSrcweir }
1900cdf0e10cSrcweir 
1901cdf0e10cSrcweir 
ApplyPattern(SCCOL nCol,SCROW nRow,const ScPatternAttr & rAttr)1902cdf0e10cSrcweir void ScTable::ApplyPattern( SCCOL nCol, SCROW nRow, const ScPatternAttr& rAttr )
1903cdf0e10cSrcweir {
1904cdf0e10cSrcweir 	if (ValidColRow(nCol,nRow))
1905cdf0e10cSrcweir 		aCol[nCol].ApplyPattern( nRow, rAttr );
1906cdf0e10cSrcweir }
1907cdf0e10cSrcweir 
1908cdf0e10cSrcweir 
ApplyPatternArea(SCCOL nStartCol,SCROW nStartRow,SCCOL nEndCol,SCROW nEndRow,const ScPatternAttr & rAttr)1909cdf0e10cSrcweir void ScTable::ApplyPatternArea( SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol, SCROW nEndRow,
1910cdf0e10cSrcweir 									 const ScPatternAttr& rAttr )
1911cdf0e10cSrcweir {
1912cdf0e10cSrcweir 	if (ValidColRow(nStartCol, nStartRow) && ValidColRow(nEndCol, nEndRow))
1913cdf0e10cSrcweir 	{
1914cdf0e10cSrcweir 		PutInOrder(nStartCol, nEndCol);
1915cdf0e10cSrcweir 		PutInOrder(nStartRow, nEndRow);
1916cdf0e10cSrcweir 		for (SCCOL i = nStartCol; i <= nEndCol; i++)
1917cdf0e10cSrcweir 			aCol[i].ApplyPatternArea(nStartRow, nEndRow, rAttr);
1918cdf0e10cSrcweir 	}
1919cdf0e10cSrcweir }
1920cdf0e10cSrcweir 
ApplyPooledPatternArea(SCCOL nStartCol,SCROW nStartRow,SCCOL nEndCol,SCROW nEndRow,const ScPatternAttr & rPooledAttr,const ScPatternAttr & rAttr)19213a02adb1SWang Lei void ScTable::ApplyPooledPatternArea( SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol, SCROW nEndRow,
19223a02adb1SWang Lei 									 const ScPatternAttr& rPooledAttr, const ScPatternAttr& rAttr )
19233a02adb1SWang Lei {
19243a02adb1SWang Lei 	if (ValidColRow(nStartCol, nStartRow) && ValidColRow(nEndCol, nEndRow))
19253a02adb1SWang Lei 	{
19263a02adb1SWang Lei 		PutInOrder(nStartCol, nEndCol);
19273a02adb1SWang Lei 		PutInOrder(nStartRow, nEndRow);
19283a02adb1SWang Lei 		for (SCCOL i = nStartCol; i <= nEndCol; i++)
19293a02adb1SWang Lei 		{
19303a02adb1SWang Lei 			sal_Bool bSet = sal_True;
19313a02adb1SWang Lei 			SCROW nStar, nEnd;
19323a02adb1SWang Lei 			const ScPatternAttr* pAttr = aCol[i].GetPatternRange(nStar, nEnd, nStartRow);
19333a02adb1SWang Lei 			if (nStar >nStartRow || nEnd < nEndRow || pAttr!=pDocument->GetDefPattern())
19343a02adb1SWang Lei 				bSet = sal_False;
19353a02adb1SWang Lei 
19363a02adb1SWang Lei 			if (bSet)
19373a02adb1SWang Lei 				aCol[i].SetPatternArea(nStartRow, nEndRow, rPooledAttr);
19383a02adb1SWang Lei 			else
19393a02adb1SWang Lei 				aCol[i].ApplyPatternArea(nStartRow, nEndRow, rAttr);
19403a02adb1SWang Lei 		}
19413a02adb1SWang Lei 	}
19423a02adb1SWang Lei }
19433a02adb1SWang Lei 
ApplyPatternIfNumberformatIncompatible(const ScRange & rRange,const ScPatternAttr & rPattern,short nNewType)1944cdf0e10cSrcweir void ScTable::ApplyPatternIfNumberformatIncompatible( const ScRange& rRange,
1945cdf0e10cSrcweir 		const ScPatternAttr& rPattern, short nNewType )
1946cdf0e10cSrcweir {
1947cdf0e10cSrcweir 	SCCOL nEndCol = rRange.aEnd.Col();
1948cdf0e10cSrcweir 	for ( SCCOL nCol = rRange.aStart.Col(); nCol <= nEndCol; nCol++ )
1949cdf0e10cSrcweir 	{
1950cdf0e10cSrcweir 		aCol[nCol].ApplyPatternIfNumberformatIncompatible( rRange, rPattern, nNewType );
1951cdf0e10cSrcweir 	}
1952cdf0e10cSrcweir }
1953cdf0e10cSrcweir 
1954cdf0e10cSrcweir 
1955cdf0e10cSrcweir 
ApplyStyle(SCCOL nCol,SCROW nRow,const ScStyleSheet & rStyle)1956cdf0e10cSrcweir void ScTable::ApplyStyle( SCCOL nCol, SCROW nRow, const ScStyleSheet& rStyle )
1957cdf0e10cSrcweir {
1958cdf0e10cSrcweir 	if (ValidColRow(nCol,nRow))
1959cdf0e10cSrcweir 		aCol[nCol].ApplyStyle( nRow, rStyle );
1960cdf0e10cSrcweir }
1961cdf0e10cSrcweir 
1962cdf0e10cSrcweir 
ApplyStyleArea(SCCOL nStartCol,SCROW nStartRow,SCCOL nEndCol,SCROW nEndRow,const ScStyleSheet & rStyle)1963cdf0e10cSrcweir void ScTable::ApplyStyleArea( SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol, SCROW nEndRow, const ScStyleSheet& rStyle )
1964cdf0e10cSrcweir {
1965cdf0e10cSrcweir 	if (ValidColRow(nStartCol, nStartRow) && ValidColRow(nEndCol, nEndRow))
1966cdf0e10cSrcweir 	{
1967cdf0e10cSrcweir 		PutInOrder(nStartCol, nEndCol);
1968cdf0e10cSrcweir 		PutInOrder(nStartRow, nEndRow);
1969cdf0e10cSrcweir 		for (SCCOL i = nStartCol; i <= nEndCol; i++)
1970cdf0e10cSrcweir 			aCol[i].ApplyStyleArea(nStartRow, nEndRow, rStyle);
1971cdf0e10cSrcweir 	}
1972cdf0e10cSrcweir }
1973cdf0e10cSrcweir 
1974cdf0e10cSrcweir 
ApplySelectionStyle(const ScStyleSheet & rStyle,const ScMarkData & rMark)1975cdf0e10cSrcweir void ScTable::ApplySelectionStyle(const ScStyleSheet& rStyle, const ScMarkData& rMark)
1976cdf0e10cSrcweir {
1977cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL; i++)
1978cdf0e10cSrcweir 		aCol[i].ApplySelectionStyle( rStyle, rMark );
1979cdf0e10cSrcweir }
1980cdf0e10cSrcweir 
1981cdf0e10cSrcweir 
ApplySelectionLineStyle(const ScMarkData & rMark,const SvxBorderLine * pLine,sal_Bool bColorOnly)1982cdf0e10cSrcweir void ScTable::ApplySelectionLineStyle( const ScMarkData& rMark,
1983cdf0e10cSrcweir 							const SvxBorderLine* pLine, sal_Bool bColorOnly )
1984cdf0e10cSrcweir {
1985cdf0e10cSrcweir 	if ( bColorOnly && !pLine )
1986cdf0e10cSrcweir 		return;
1987cdf0e10cSrcweir 
1988cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL; i++)
1989cdf0e10cSrcweir 		aCol[i].ApplySelectionLineStyle( rMark, pLine, bColorOnly );
1990cdf0e10cSrcweir }
1991cdf0e10cSrcweir 
1992cdf0e10cSrcweir 
GetStyle(SCCOL nCol,SCROW nRow) const1993cdf0e10cSrcweir const ScStyleSheet* ScTable::GetStyle( SCCOL nCol, SCROW nRow ) const
1994cdf0e10cSrcweir {
1995cdf0e10cSrcweir 	if (ValidColRow(nCol, nRow))
1996cdf0e10cSrcweir 		return aCol[nCol].GetStyle(nRow);
1997cdf0e10cSrcweir 	else
1998cdf0e10cSrcweir 		return NULL;
1999cdf0e10cSrcweir }
2000cdf0e10cSrcweir 
2001cdf0e10cSrcweir 
GetSelectionStyle(const ScMarkData & rMark,sal_Bool & rFound) const2002cdf0e10cSrcweir const ScStyleSheet* ScTable::GetSelectionStyle( const ScMarkData& rMark, sal_Bool& rFound ) const
2003cdf0e10cSrcweir {
2004cdf0e10cSrcweir 	rFound = sal_False;
2005cdf0e10cSrcweir 
2006cdf0e10cSrcweir 	sal_Bool	bEqual = sal_True;
2007cdf0e10cSrcweir 	sal_Bool	bColFound;
2008cdf0e10cSrcweir 
2009cdf0e10cSrcweir 	const ScStyleSheet* pStyle = NULL;
2010cdf0e10cSrcweir 	const ScStyleSheet* pNewStyle;
2011cdf0e10cSrcweir 
2012cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL && bEqual; i++)
2013cdf0e10cSrcweir 		if (rMark.HasMultiMarks(i))
2014cdf0e10cSrcweir 		{
2015cdf0e10cSrcweir 			pNewStyle = aCol[i].GetSelectionStyle( rMark, bColFound );
2016cdf0e10cSrcweir 			if (bColFound)
2017cdf0e10cSrcweir 			{
2018cdf0e10cSrcweir 				rFound = sal_True;
2019cdf0e10cSrcweir 				if ( !pNewStyle || ( pStyle && pNewStyle != pStyle ) )
2020cdf0e10cSrcweir 					bEqual = sal_False;												// unterschiedliche
2021cdf0e10cSrcweir 				pStyle = pNewStyle;
2022cdf0e10cSrcweir 			}
2023cdf0e10cSrcweir 		}
2024cdf0e10cSrcweir 
2025cdf0e10cSrcweir 	return bEqual ? pStyle : NULL;
2026cdf0e10cSrcweir }
2027cdf0e10cSrcweir 
2028cdf0e10cSrcweir 
GetAreaStyle(sal_Bool & rFound,SCCOL nCol1,SCROW nRow1,SCCOL nCol2,SCROW nRow2) const2029cdf0e10cSrcweir const ScStyleSheet*	ScTable::GetAreaStyle( sal_Bool& rFound, SCCOL nCol1, SCROW nRow1,
2030cdf0e10cSrcweir 													SCCOL nCol2, SCROW nRow2 ) const
2031cdf0e10cSrcweir {
2032cdf0e10cSrcweir 	rFound = sal_False;
2033cdf0e10cSrcweir 
2034cdf0e10cSrcweir 	sal_Bool	bEqual = sal_True;
2035cdf0e10cSrcweir 	sal_Bool	bColFound;
2036cdf0e10cSrcweir 
2037cdf0e10cSrcweir 	const ScStyleSheet* pStyle = NULL;
2038cdf0e10cSrcweir 	const ScStyleSheet* pNewStyle;
2039cdf0e10cSrcweir 
2040cdf0e10cSrcweir 	for (SCCOL i=nCol1; i<=nCol2 && bEqual; i++)
2041cdf0e10cSrcweir 	{
2042cdf0e10cSrcweir 		pNewStyle = aCol[i].GetAreaStyle(bColFound, nRow1, nRow2);
2043cdf0e10cSrcweir 		if (bColFound)
2044cdf0e10cSrcweir 		{
2045cdf0e10cSrcweir 			rFound = sal_True;
2046cdf0e10cSrcweir 			if ( !pNewStyle || ( pStyle && pNewStyle != pStyle ) )
2047cdf0e10cSrcweir 				bEqual = sal_False;												// unterschiedliche
2048cdf0e10cSrcweir 			pStyle = pNewStyle;
2049cdf0e10cSrcweir 		}
2050cdf0e10cSrcweir 	}
2051cdf0e10cSrcweir 
2052cdf0e10cSrcweir 	return bEqual ? pStyle : NULL;
2053cdf0e10cSrcweir }
2054cdf0e10cSrcweir 
2055cdf0e10cSrcweir 
IsStyleSheetUsed(const ScStyleSheet & rStyle,sal_Bool bGatherAllStyles) const2056cdf0e10cSrcweir sal_Bool ScTable::IsStyleSheetUsed( const ScStyleSheet& rStyle, sal_Bool bGatherAllStyles ) const
2057cdf0e10cSrcweir {
2058cdf0e10cSrcweir 	sal_Bool bIsUsed = sal_False;
2059cdf0e10cSrcweir 
2060cdf0e10cSrcweir 	for ( SCCOL i=0; i<=MAXCOL; i++ )
2061cdf0e10cSrcweir     {
2062cdf0e10cSrcweir 		if ( aCol[i].IsStyleSheetUsed( rStyle, bGatherAllStyles ) )
2063cdf0e10cSrcweir         {
2064cdf0e10cSrcweir             if ( !bGatherAllStyles )
2065cdf0e10cSrcweir                 return sal_True;
2066cdf0e10cSrcweir             bIsUsed = sal_True;
2067cdf0e10cSrcweir         }
2068cdf0e10cSrcweir     }
2069cdf0e10cSrcweir 
2070cdf0e10cSrcweir 	return bIsUsed;
2071cdf0e10cSrcweir }
2072cdf0e10cSrcweir 
2073cdf0e10cSrcweir 
StyleSheetChanged(const SfxStyleSheetBase * pStyleSheet,sal_Bool bRemoved,OutputDevice * pDev,double nPPTX,double nPPTY,const Fraction & rZoomX,const Fraction & rZoomY)2074cdf0e10cSrcweir void ScTable::StyleSheetChanged( const SfxStyleSheetBase* pStyleSheet, sal_Bool bRemoved,
2075cdf0e10cSrcweir 								OutputDevice* pDev,
2076cdf0e10cSrcweir 								double nPPTX, double nPPTY,
2077cdf0e10cSrcweir 								const Fraction& rZoomX, const Fraction& rZoomY )
2078cdf0e10cSrcweir {
2079cdf0e10cSrcweir     ScFlatBoolRowSegments aUsedRows;
2080cdf0e10cSrcweir     for (SCCOL i = 0; i <= MAXCOL; ++i)
2081cdf0e10cSrcweir         aCol[i].FindStyleSheet(pStyleSheet, aUsedRows, bRemoved);
2082cdf0e10cSrcweir 
2083cdf0e10cSrcweir     SCROW nRow = 0;
2084cdf0e10cSrcweir     while (nRow <= MAXROW)
2085cdf0e10cSrcweir     {
2086cdf0e10cSrcweir         ScFlatBoolRowSegments::RangeData aData;
2087cdf0e10cSrcweir         if (!aUsedRows.getRangeData(nRow, aData))
2088cdf0e10cSrcweir             // search failed!
2089cdf0e10cSrcweir             return;
2090cdf0e10cSrcweir 
2091cdf0e10cSrcweir         SCROW nEndRow = aData.mnRow2;
2092cdf0e10cSrcweir         if (aData.mbValue)
2093cdf0e10cSrcweir             SetOptimalHeight(nRow, nEndRow, 0, pDev, nPPTX, nPPTY, rZoomX, rZoomY, sal_False);
2094cdf0e10cSrcweir 
2095cdf0e10cSrcweir         nRow = nEndRow + 1;
2096cdf0e10cSrcweir     }
2097cdf0e10cSrcweir }
2098cdf0e10cSrcweir 
2099cdf0e10cSrcweir 
ApplyFlags(SCCOL nStartCol,SCROW nStartRow,SCCOL nEndCol,SCROW nEndRow,sal_Int16 nFlags)2100cdf0e10cSrcweir sal_Bool ScTable::ApplyFlags( SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol, SCROW nEndRow,
2101cdf0e10cSrcweir 									sal_Int16 nFlags )
2102cdf0e10cSrcweir {
2103cdf0e10cSrcweir 	sal_Bool bChanged = sal_False;
2104cdf0e10cSrcweir 	if (ValidColRow(nStartCol, nStartRow) && ValidColRow(nEndCol, nEndRow))
2105cdf0e10cSrcweir 		for (SCCOL i = nStartCol; i <= nEndCol; i++)
2106cdf0e10cSrcweir 			bChanged |= aCol[i].ApplyFlags(nStartRow, nEndRow, nFlags);
2107cdf0e10cSrcweir 	return bChanged;
2108cdf0e10cSrcweir }
2109cdf0e10cSrcweir 
2110cdf0e10cSrcweir 
RemoveFlags(SCCOL nStartCol,SCROW nStartRow,SCCOL nEndCol,SCROW nEndRow,sal_Int16 nFlags)2111cdf0e10cSrcweir sal_Bool ScTable::RemoveFlags( SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol, SCROW nEndRow,
2112cdf0e10cSrcweir 									sal_Int16 nFlags )
2113cdf0e10cSrcweir {
2114cdf0e10cSrcweir 	sal_Bool bChanged = sal_False;
2115cdf0e10cSrcweir 	if (ValidColRow(nStartCol, nStartRow) && ValidColRow(nEndCol, nEndRow))
2116cdf0e10cSrcweir 		for (SCCOL i = nStartCol; i <= nEndCol; i++)
2117cdf0e10cSrcweir 			bChanged |= aCol[i].RemoveFlags(nStartRow, nEndRow, nFlags);
2118cdf0e10cSrcweir 	return bChanged;
2119cdf0e10cSrcweir }
2120cdf0e10cSrcweir 
2121cdf0e10cSrcweir 
SetPattern(SCCOL nCol,SCROW nRow,const ScPatternAttr & rAttr,sal_Bool bPutToPool)2122cdf0e10cSrcweir void ScTable::SetPattern( SCCOL nCol, SCROW nRow, const ScPatternAttr& rAttr, sal_Bool bPutToPool )
2123cdf0e10cSrcweir {
2124cdf0e10cSrcweir 	if (ValidColRow(nCol,nRow))
2125cdf0e10cSrcweir 		aCol[nCol].SetPattern( nRow, rAttr, bPutToPool );
2126cdf0e10cSrcweir }
2127cdf0e10cSrcweir 
2128cdf0e10cSrcweir 
ApplyAttr(SCCOL nCol,SCROW nRow,const SfxPoolItem & rAttr)2129cdf0e10cSrcweir void ScTable::ApplyAttr( SCCOL nCol, SCROW nRow, const SfxPoolItem& rAttr )
2130cdf0e10cSrcweir {
2131cdf0e10cSrcweir 	if (ValidColRow(nCol,nRow))
2132cdf0e10cSrcweir 		aCol[nCol].ApplyAttr( nRow, rAttr );
2133cdf0e10cSrcweir }
2134cdf0e10cSrcweir 
2135cdf0e10cSrcweir 
ApplySelectionCache(SfxItemPoolCache * pCache,const ScMarkData & rMark)2136cdf0e10cSrcweir void ScTable::ApplySelectionCache( SfxItemPoolCache* pCache, const ScMarkData& rMark )
2137cdf0e10cSrcweir {
2138cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL; i++)
2139cdf0e10cSrcweir 		aCol[i].ApplySelectionCache( pCache, rMark );
2140cdf0e10cSrcweir }
2141cdf0e10cSrcweir 
2142cdf0e10cSrcweir 
ChangeSelectionIndent(sal_Bool bIncrement,const ScMarkData & rMark)2143cdf0e10cSrcweir void ScTable::ChangeSelectionIndent( sal_Bool bIncrement, const ScMarkData& rMark )
2144cdf0e10cSrcweir {
2145cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL; i++)
2146cdf0e10cSrcweir 		aCol[i].ChangeSelectionIndent( bIncrement, rMark );
2147cdf0e10cSrcweir }
2148cdf0e10cSrcweir 
2149cdf0e10cSrcweir 
ClearSelectionItems(const sal_uInt16 * pWhich,const ScMarkData & rMark)2150cdf0e10cSrcweir void ScTable::ClearSelectionItems( const sal_uInt16* pWhich, const ScMarkData& rMark )
2151cdf0e10cSrcweir {
2152cdf0e10cSrcweir 	for (SCCOL i=0; i<=MAXCOL; i++)
2153cdf0e10cSrcweir 		aCol[i].ClearSelectionItems( pWhich, rMark );
2154cdf0e10cSrcweir }
2155cdf0e10cSrcweir 
2156cdf0e10cSrcweir 
2157cdf0e10cSrcweir //	Spaltenbreiten / Zeilenhoehen
2158cdf0e10cSrcweir 
SetColWidth(SCCOL nCol,sal_uInt16 nNewWidth)2159cdf0e10cSrcweir void ScTable::SetColWidth( SCCOL nCol, sal_uInt16 nNewWidth )
2160cdf0e10cSrcweir {
2161cdf0e10cSrcweir 	if (VALIDCOL(nCol) && pColWidth)
2162cdf0e10cSrcweir 	{
2163cdf0e10cSrcweir 		if (!nNewWidth)
2164cdf0e10cSrcweir 		{
2165cdf0e10cSrcweir //			DBG_ERROR("Spaltenbreite 0 in SetColWidth");
2166cdf0e10cSrcweir 			nNewWidth = STD_COL_WIDTH;
2167cdf0e10cSrcweir 		}
2168cdf0e10cSrcweir 
2169cdf0e10cSrcweir 		if ( nNewWidth != pColWidth[nCol] )
2170cdf0e10cSrcweir 		{
2171cdf0e10cSrcweir 			IncRecalcLevel();
2172cdf0e10cSrcweir             InitializeNoteCaptions();
2173cdf0e10cSrcweir 			ScDrawLayer* pDrawLayer = pDocument->GetDrawLayer();
2174cdf0e10cSrcweir 			if (pDrawLayer)
2175cdf0e10cSrcweir 				pDrawLayer->WidthChanged( nTab, nCol, ((long) nNewWidth) - (long) pColWidth[nCol] );
2176cdf0e10cSrcweir 			pColWidth[nCol] = nNewWidth;
2177cdf0e10cSrcweir 			DecRecalcLevel();
2178cdf0e10cSrcweir 
2179cdf0e10cSrcweir             InvalidatePageBreaks();
2180cdf0e10cSrcweir 		}
2181cdf0e10cSrcweir 	}
2182cdf0e10cSrcweir 	else
2183cdf0e10cSrcweir 	{
2184cdf0e10cSrcweir 		DBG_ERROR("Falsche Spaltennummer oder keine Breiten");
2185cdf0e10cSrcweir 	}
2186cdf0e10cSrcweir }
2187cdf0e10cSrcweir 
2188cdf0e10cSrcweir 
SetRowHeight(SCROW nRow,sal_uInt16 nNewHeight)2189cdf0e10cSrcweir void ScTable::SetRowHeight( SCROW nRow, sal_uInt16 nNewHeight )
2190cdf0e10cSrcweir {
2191cdf0e10cSrcweir     if (VALIDROW(nRow) && mpRowHeights)
2192cdf0e10cSrcweir 	{
2193cdf0e10cSrcweir 		if (!nNewHeight)
2194cdf0e10cSrcweir 		{
2195cdf0e10cSrcweir 			DBG_ERROR("Zeilenhoehe 0 in SetRowHeight");
2196cdf0e10cSrcweir 			nNewHeight = ScGlobal::nStdRowHeight;
2197cdf0e10cSrcweir 		}
2198cdf0e10cSrcweir 
2199cdf0e10cSrcweir         sal_uInt16 nOldHeight = mpRowHeights->getValue(nRow);
2200cdf0e10cSrcweir 		if ( nNewHeight != nOldHeight )
2201cdf0e10cSrcweir 		{
2202cdf0e10cSrcweir 			IncRecalcLevel();
2203cdf0e10cSrcweir             InitializeNoteCaptions();
2204cdf0e10cSrcweir 			ScDrawLayer* pDrawLayer = pDocument->GetDrawLayer();
2205cdf0e10cSrcweir 			if (pDrawLayer)
2206cdf0e10cSrcweir 				pDrawLayer->HeightChanged( nTab, nRow, ((long) nNewHeight) - (long) nOldHeight );
2207cdf0e10cSrcweir             mpRowHeights->setValue(nRow, nRow, nNewHeight);
2208cdf0e10cSrcweir 			DecRecalcLevel();
2209cdf0e10cSrcweir 
2210cdf0e10cSrcweir             InvalidatePageBreaks();
2211cdf0e10cSrcweir 		}
2212cdf0e10cSrcweir 	}
2213cdf0e10cSrcweir 	else
2214cdf0e10cSrcweir 	{
2215cdf0e10cSrcweir 		DBG_ERROR("Falsche Zeilennummer oder keine Hoehen");
2216cdf0e10cSrcweir 	}
2217cdf0e10cSrcweir }
2218cdf0e10cSrcweir 
2219cdf0e10cSrcweir namespace {
2220cdf0e10cSrcweir 
2221cdf0e10cSrcweir /**
2222cdf0e10cSrcweir  * Check if the new pixel size is different from the old size between
2223cdf0e10cSrcweir  * specified ranges.
2224cdf0e10cSrcweir  */
lcl_pixelSizeChanged(ScFlatUInt16RowSegments & rRowHeights,SCROW nStartRow,SCROW nEndRow,sal_uInt16 nNewHeight,double nPPTY)2225cdf0e10cSrcweir bool lcl_pixelSizeChanged(
2226cdf0e10cSrcweir     ScFlatUInt16RowSegments& rRowHeights, SCROW nStartRow, SCROW nEndRow,
2227cdf0e10cSrcweir     sal_uInt16 nNewHeight, double nPPTY)
2228cdf0e10cSrcweir {
2229cdf0e10cSrcweir     long nNewPix = static_cast<long>(nNewHeight * nPPTY);
2230cdf0e10cSrcweir 
2231cdf0e10cSrcweir     ScFlatUInt16RowSegments::ForwardIterator aFwdIter(rRowHeights);
2232cdf0e10cSrcweir     for (SCROW nRow = nStartRow; nRow <= nEndRow; ++nRow)
2233cdf0e10cSrcweir     {
2234cdf0e10cSrcweir         sal_uInt16 nHeight;
2235cdf0e10cSrcweir         if (!aFwdIter.getValue(nRow, nHeight))
2236cdf0e10cSrcweir             break;
2237cdf0e10cSrcweir 
2238cdf0e10cSrcweir         if (nHeight != nNewHeight)
2239cdf0e10cSrcweir         {
2240cdf0e10cSrcweir             bool bChanged = (nNewPix != static_cast<long>(nHeight * nPPTY));
2241cdf0e10cSrcweir             if (bChanged)
2242cdf0e10cSrcweir                 return true;
2243cdf0e10cSrcweir         }
2244cdf0e10cSrcweir 
2245cdf0e10cSrcweir         // Skip ahead to the last position of the current range.
2246cdf0e10cSrcweir         nRow = aFwdIter.getLastPos();
2247cdf0e10cSrcweir     }
2248cdf0e10cSrcweir     return false;
2249cdf0e10cSrcweir }
2250cdf0e10cSrcweir 
2251cdf0e10cSrcweir }
2252cdf0e10cSrcweir 
SetRowHeightRange(SCROW nStartRow,SCROW nEndRow,sal_uInt16 nNewHeight,double,double nPPTY)2253cdf0e10cSrcweir sal_Bool ScTable::SetRowHeightRange( SCROW nStartRow, SCROW nEndRow, sal_uInt16 nNewHeight,
2254cdf0e10cSrcweir                                     double /* nPPTX */, double nPPTY )
2255cdf0e10cSrcweir {
2256cdf0e10cSrcweir 	sal_Bool bChanged = sal_False;
2257cdf0e10cSrcweir     if (VALIDROW(nStartRow) && VALIDROW(nEndRow) && mpRowHeights)
2258cdf0e10cSrcweir 	{
2259cdf0e10cSrcweir 		IncRecalcLevel();
2260cdf0e10cSrcweir         InitializeNoteCaptions();
2261cdf0e10cSrcweir 		if (!nNewHeight)
2262cdf0e10cSrcweir 		{
2263cdf0e10cSrcweir 			DBG_ERROR("Zeilenhoehe 0 in SetRowHeight");
2264cdf0e10cSrcweir 			nNewHeight = ScGlobal::nStdRowHeight;
2265cdf0e10cSrcweir 		}
2266cdf0e10cSrcweir 
2267cdf0e10cSrcweir         sal_Bool bSingle = sal_False;   // sal_True = process every row for its own
2268cdf0e10cSrcweir 		ScDrawLayer* pDrawLayer = pDocument->GetDrawLayer();
2269cdf0e10cSrcweir 		if (pDrawLayer)
2270cdf0e10cSrcweir 			if (pDrawLayer->HasObjectsInRows( nTab, nStartRow, nEndRow ))
2271cdf0e10cSrcweir 				bSingle = sal_True;
2272cdf0e10cSrcweir 
2273cdf0e10cSrcweir 		if (bSingle)
2274cdf0e10cSrcweir 		{
2275cdf0e10cSrcweir             ScFlatUInt16RowSegments::RangeData aData;
2276cdf0e10cSrcweir             mpRowHeights->getRangeData(nStartRow, aData);
2277cdf0e10cSrcweir             if (nNewHeight == aData.mnValue && nEndRow <= aData.mnRow2)
2278cdf0e10cSrcweir                 bSingle = sal_False;    // no difference in this range
2279cdf0e10cSrcweir 		}
2280cdf0e10cSrcweir 		if (bSingle)
2281cdf0e10cSrcweir 		{
2282cdf0e10cSrcweir 			if (nEndRow-nStartRow < 20)
2283cdf0e10cSrcweir             {
2284cdf0e10cSrcweir                 if (!bChanged)
2285cdf0e10cSrcweir                     bChanged = lcl_pixelSizeChanged(*mpRowHeights, nStartRow, nEndRow, nNewHeight, nPPTY);
2286cdf0e10cSrcweir 
2287cdf0e10cSrcweir                 /*  #i94028# #i94991# If drawing objects are involved, each row
2288cdf0e10cSrcweir                     has to be changed for its own, because each call to
2289cdf0e10cSrcweir                     ScDrawLayer::HeightChanged expects correct row heights
2290cdf0e10cSrcweir                     above passed row in the document. Cannot use array iterator
2291cdf0e10cSrcweir                     because array changes in every cycle. */
2292cdf0e10cSrcweir                 if( pDrawLayer )
2293cdf0e10cSrcweir                 {
2294cdf0e10cSrcweir                     for( SCROW nRow = nStartRow; nRow <= nEndRow ; ++nRow )
2295cdf0e10cSrcweir                     {
2296cdf0e10cSrcweir                         pDrawLayer->HeightChanged( nTab, nRow,
2297cdf0e10cSrcweir                              static_cast<long>(nNewHeight) - static_cast<long>(mpRowHeights->getValue(nRow)));
2298cdf0e10cSrcweir                         mpRowHeights->setValue(nRow, nRow, nNewHeight);
2299cdf0e10cSrcweir                     }
2300cdf0e10cSrcweir                 }
2301cdf0e10cSrcweir                 else
2302cdf0e10cSrcweir                     mpRowHeights->setValue(nStartRow, nEndRow, nNewHeight);
2303cdf0e10cSrcweir             }
2304cdf0e10cSrcweir 			else
2305cdf0e10cSrcweir 			{
2306cdf0e10cSrcweir 				SCROW nMid = (nStartRow+nEndRow) / 2;
2307cdf0e10cSrcweir 				if (SetRowHeightRange( nStartRow, nMid, nNewHeight, 1.0, 1.0 ))
2308cdf0e10cSrcweir 					bChanged = sal_True;
2309cdf0e10cSrcweir 				if (SetRowHeightRange( nMid+1, nEndRow, nNewHeight, 1.0, 1.0 ))
2310cdf0e10cSrcweir 					bChanged = sal_True;
2311cdf0e10cSrcweir 			}
2312cdf0e10cSrcweir 		}
2313cdf0e10cSrcweir 		else
2314cdf0e10cSrcweir 		{
2315cdf0e10cSrcweir 			if (pDrawLayer)
2316cdf0e10cSrcweir 			{
2317cdf0e10cSrcweir                 // #i115025# When comparing to nNewHeight for the whole range, the height
2318cdf0e10cSrcweir                 // including hidden rows has to be used (same behavior as 3.2).
2319cdf0e10cSrcweir                 unsigned long nOldHeights = mpRowHeights->getSumValue(nStartRow, nEndRow);
2320cdf0e10cSrcweir                 // FIXME: should we test for overflows?
2321cdf0e10cSrcweir 				long nHeightDif = (long) (unsigned long) nNewHeight *
2322cdf0e10cSrcweir                     (nEndRow - nStartRow + 1) - nOldHeights;
2323cdf0e10cSrcweir 				pDrawLayer->HeightChanged( nTab, nEndRow, nHeightDif );
2324cdf0e10cSrcweir 			}
2325cdf0e10cSrcweir 
2326cdf0e10cSrcweir             if (!bChanged)
2327cdf0e10cSrcweir                 bChanged = lcl_pixelSizeChanged(*mpRowHeights, nStartRow, nEndRow, nNewHeight, nPPTY);
2328cdf0e10cSrcweir 
2329cdf0e10cSrcweir             mpRowHeights->setValue(nStartRow, nEndRow, nNewHeight);
2330cdf0e10cSrcweir 		}
2331cdf0e10cSrcweir 		DecRecalcLevel();
2332cdf0e10cSrcweir 
2333cdf0e10cSrcweir         if (bChanged)
2334cdf0e10cSrcweir             InvalidatePageBreaks();
2335cdf0e10cSrcweir 	}
2336cdf0e10cSrcweir 	else
2337cdf0e10cSrcweir 	{
2338cdf0e10cSrcweir 		DBG_ERROR("Falsche Zeilennummer oder keine Hoehen");
2339cdf0e10cSrcweir 	}
2340cdf0e10cSrcweir 
2341cdf0e10cSrcweir 	return bChanged;
2342cdf0e10cSrcweir }
2343cdf0e10cSrcweir 
SetRowHeightOnly(SCROW nStartRow,SCROW nEndRow,sal_uInt16 nNewHeight)2344cdf0e10cSrcweir void ScTable::SetRowHeightOnly( SCROW nStartRow, SCROW nEndRow, sal_uInt16 nNewHeight )
2345cdf0e10cSrcweir {
2346cdf0e10cSrcweir     if (!ValidRow(nStartRow) || !ValidRow(nEndRow) || !mpRowHeights)
2347cdf0e10cSrcweir         return;
2348cdf0e10cSrcweir 
2349cdf0e10cSrcweir     if (!nNewHeight)
2350cdf0e10cSrcweir         nNewHeight = ScGlobal::nStdRowHeight;
2351cdf0e10cSrcweir 
2352cdf0e10cSrcweir     mpRowHeights->setValue(nStartRow, nEndRow, nNewHeight);
2353cdf0e10cSrcweir }
2354cdf0e10cSrcweir 
SetColWidthOnly(SCCOL nCol,sal_uInt16 nNewWidth)23553ce8cab8SWang Lei void ScTable::SetColWidthOnly( SCCOL nCol, sal_uInt16 nNewWidth )
23563ce8cab8SWang Lei {
23573ce8cab8SWang Lei 	if (!VALIDCOL(nCol) || !pColWidth)
23583ce8cab8SWang Lei         return;
23593ce8cab8SWang Lei 
23603ce8cab8SWang Lei     if (!nNewWidth)
23613ce8cab8SWang Lei         nNewWidth = STD_COL_WIDTH;
23623ce8cab8SWang Lei 
23633ce8cab8SWang Lei     pColWidth[nCol] = nNewWidth;
23643ce8cab8SWang Lei }
SetManualHeight(SCROW nStartRow,SCROW nEndRow,sal_Bool bManual)2365cdf0e10cSrcweir void ScTable::SetManualHeight( SCROW nStartRow, SCROW nEndRow, sal_Bool bManual )
2366cdf0e10cSrcweir {
2367cdf0e10cSrcweir 	if (VALIDROW(nStartRow) && VALIDROW(nEndRow) && pRowFlags)
2368cdf0e10cSrcweir 	{
2369cdf0e10cSrcweir 		if (bManual)
2370cdf0e10cSrcweir             pRowFlags->OrValue( nStartRow, nEndRow, CR_MANUALSIZE);
2371cdf0e10cSrcweir 		else
2372cdf0e10cSrcweir             pRowFlags->AndValue( nStartRow, nEndRow, sal::static_int_cast<sal_uInt8>(~CR_MANUALSIZE));
2373cdf0e10cSrcweir 	}
2374cdf0e10cSrcweir 	else
2375cdf0e10cSrcweir 	{
2376cdf0e10cSrcweir 		DBG_ERROR("Falsche Zeilennummer oder keine Zeilenflags");
2377cdf0e10cSrcweir 	}
2378cdf0e10cSrcweir }
2379cdf0e10cSrcweir 
2380cdf0e10cSrcweir 
GetColWidth(SCCOL nCol) const2381cdf0e10cSrcweir sal_uInt16 ScTable::GetColWidth( SCCOL nCol ) const
2382cdf0e10cSrcweir {
2383cdf0e10cSrcweir 	DBG_ASSERT(VALIDCOL(nCol),"Falsche Spaltennummer");
2384cdf0e10cSrcweir 
2385cdf0e10cSrcweir 	if (VALIDCOL(nCol) && pColFlags && pColWidth)
2386cdf0e10cSrcweir 	{
2387cdf0e10cSrcweir         if (ColHidden(nCol))
2388cdf0e10cSrcweir 			return 0;
2389cdf0e10cSrcweir 		else
2390cdf0e10cSrcweir 			return pColWidth[nCol];
2391cdf0e10cSrcweir 	}
2392cdf0e10cSrcweir 	else
2393cdf0e10cSrcweir 		return (sal_uInt16) STD_COL_WIDTH;
2394cdf0e10cSrcweir }
2395cdf0e10cSrcweir 
2396cdf0e10cSrcweir 
GetOriginalWidth(SCCOL nCol) const2397cdf0e10cSrcweir sal_uInt16 ScTable::GetOriginalWidth( SCCOL nCol ) const		// immer die eingestellte
2398cdf0e10cSrcweir {
2399cdf0e10cSrcweir 	DBG_ASSERT(VALIDCOL(nCol),"Falsche Spaltennummer");
2400cdf0e10cSrcweir 
2401cdf0e10cSrcweir 	if (VALIDCOL(nCol) && pColWidth)
2402cdf0e10cSrcweir 		return pColWidth[nCol];
2403cdf0e10cSrcweir 	else
2404cdf0e10cSrcweir 		return (sal_uInt16) STD_COL_WIDTH;
2405cdf0e10cSrcweir }
2406cdf0e10cSrcweir 
2407cdf0e10cSrcweir 
GetCommonWidth(SCCOL nEndCol)2408cdf0e10cSrcweir sal_uInt16 ScTable::GetCommonWidth( SCCOL nEndCol )
2409cdf0e10cSrcweir {
2410cdf0e10cSrcweir 	//	get the width that is used in the largest continuous column range (up to nEndCol)
2411cdf0e10cSrcweir 
2412cdf0e10cSrcweir 	if ( !ValidCol(nEndCol) )
2413cdf0e10cSrcweir 	{
2414cdf0e10cSrcweir 		DBG_ERROR("wrong column");
2415cdf0e10cSrcweir 		nEndCol = MAXCOL;
2416cdf0e10cSrcweir 	}
2417cdf0e10cSrcweir 
2418cdf0e10cSrcweir 	sal_uInt16 nMaxWidth = 0;
2419cdf0e10cSrcweir 	sal_uInt16 nMaxCount = 0;
2420cdf0e10cSrcweir 	SCCOL nRangeStart = 0;
2421cdf0e10cSrcweir 	while ( nRangeStart <= nEndCol )
2422cdf0e10cSrcweir 	{
2423cdf0e10cSrcweir 		//	skip hidden columns
2424cdf0e10cSrcweir 		while ( nRangeStart <= nEndCol && ColHidden(nRangeStart) )
2425cdf0e10cSrcweir 			++nRangeStart;
2426cdf0e10cSrcweir 		if ( nRangeStart <= nEndCol )
2427cdf0e10cSrcweir 		{
2428cdf0e10cSrcweir 			sal_uInt16 nThisCount = 0;
2429cdf0e10cSrcweir 			sal_uInt16 nThisWidth = pColWidth[nRangeStart];
2430cdf0e10cSrcweir 			SCCOL nRangeEnd = nRangeStart;
2431cdf0e10cSrcweir 			while ( nRangeEnd <= nEndCol && pColWidth[nRangeEnd] == nThisWidth )
2432cdf0e10cSrcweir 			{
2433cdf0e10cSrcweir 				++nThisCount;
2434cdf0e10cSrcweir 				++nRangeEnd;
2435cdf0e10cSrcweir 
2436cdf0e10cSrcweir 				//	skip hidden columns
2437cdf0e10cSrcweir 				while ( nRangeEnd <= nEndCol && ColHidden(nRangeEnd) )
2438cdf0e10cSrcweir 					++nRangeEnd;
2439cdf0e10cSrcweir 			}
2440cdf0e10cSrcweir 
2441cdf0e10cSrcweir 			if ( nThisCount > nMaxCount )
2442cdf0e10cSrcweir 			{
2443cdf0e10cSrcweir 				nMaxCount = nThisCount;
2444cdf0e10cSrcweir 				nMaxWidth = nThisWidth;
2445cdf0e10cSrcweir 			}
2446cdf0e10cSrcweir 
2447cdf0e10cSrcweir 			nRangeStart = nRangeEnd;		// next range
2448cdf0e10cSrcweir 		}
2449cdf0e10cSrcweir 	}
2450cdf0e10cSrcweir 
2451cdf0e10cSrcweir 	return nMaxWidth;
2452cdf0e10cSrcweir }
2453cdf0e10cSrcweir 
2454cdf0e10cSrcweir 
GetRowHeight(SCROW nRow,SCROW * pStartRow,SCROW * pEndRow,bool bHiddenAsZero) const2455cdf0e10cSrcweir sal_uInt16 ScTable::GetRowHeight( SCROW nRow, SCROW* pStartRow, SCROW* pEndRow, bool bHiddenAsZero ) const
2456cdf0e10cSrcweir {
2457cdf0e10cSrcweir     DBG_ASSERT(VALIDROW(nRow),"Invalid row number");
2458cdf0e10cSrcweir 
2459cdf0e10cSrcweir     if (VALIDROW(nRow) && mpRowHeights)
2460cdf0e10cSrcweir     {
2461cdf0e10cSrcweir         if (bHiddenAsZero && RowHidden( nRow, pStartRow, pEndRow))
2462cdf0e10cSrcweir             return 0;
2463cdf0e10cSrcweir         else
2464cdf0e10cSrcweir         {
2465cdf0e10cSrcweir             ScFlatUInt16RowSegments::RangeData aData;
2466cdf0e10cSrcweir             if (!mpRowHeights->getRangeData(nRow, aData))
2467cdf0e10cSrcweir             {
2468cdf0e10cSrcweir                 if (pStartRow)
2469cdf0e10cSrcweir                     *pStartRow = nRow;
2470cdf0e10cSrcweir                 if (pEndRow)
2471cdf0e10cSrcweir                     *pEndRow = nRow;
2472cdf0e10cSrcweir                 // TODO: What should we return in case the search fails?
2473cdf0e10cSrcweir                 return 0;
2474cdf0e10cSrcweir             }
2475cdf0e10cSrcweir 
2476cdf0e10cSrcweir             // If bHiddenAsZero, pStartRow and pEndRow were initialized to
2477cdf0e10cSrcweir             // boundaries of a non-hidden segment. Assume that the previous and
2478cdf0e10cSrcweir             // next segment are hidden then and limit the current height
2479cdf0e10cSrcweir             // segment.
2480cdf0e10cSrcweir             if (pStartRow)
2481cdf0e10cSrcweir                 *pStartRow = (bHiddenAsZero ? std::max( *pStartRow, aData.mnRow1) : aData.mnRow1);
2482cdf0e10cSrcweir             if (pEndRow)
2483cdf0e10cSrcweir                 *pEndRow = (bHiddenAsZero ? std::min( *pEndRow, aData.mnRow2) : aData.mnRow2);
2484cdf0e10cSrcweir             return aData.mnValue;
2485cdf0e10cSrcweir         }
2486cdf0e10cSrcweir     }
2487cdf0e10cSrcweir     else
2488cdf0e10cSrcweir     {
2489cdf0e10cSrcweir         if (pStartRow)
2490cdf0e10cSrcweir             *pStartRow = nRow;
2491cdf0e10cSrcweir         if (pEndRow)
2492cdf0e10cSrcweir             *pEndRow = nRow;
2493cdf0e10cSrcweir         return (sal_uInt16) ScGlobal::nStdRowHeight;
2494cdf0e10cSrcweir     }
2495cdf0e10cSrcweir }
2496cdf0e10cSrcweir 
2497cdf0e10cSrcweir 
GetRowHeight(SCROW nStartRow,SCROW nEndRow) const2498cdf0e10cSrcweir sal_uLong ScTable::GetRowHeight( SCROW nStartRow, SCROW nEndRow ) const
2499cdf0e10cSrcweir {
2500cdf0e10cSrcweir 	DBG_ASSERT(VALIDROW(nStartRow) && VALIDROW(nEndRow),"Falsche Zeilennummer");
2501cdf0e10cSrcweir 
2502cdf0e10cSrcweir 	if (VALIDROW(nStartRow) && VALIDROW(nEndRow) && mpRowHeights)
2503cdf0e10cSrcweir 	{
2504cdf0e10cSrcweir         sal_uLong nHeight = 0;
2505cdf0e10cSrcweir         SCROW nRow = nStartRow;
2506cdf0e10cSrcweir         while (nRow <= nEndRow)
2507cdf0e10cSrcweir         {
2508cdf0e10cSrcweir             SCROW nLastRow = -1;
2509cdf0e10cSrcweir             if (!RowHidden(nRow, nLastRow))
2510cdf0e10cSrcweir             {
2511cdf0e10cSrcweir                 if (nLastRow > nEndRow)
2512cdf0e10cSrcweir                     nLastRow = nEndRow;
2513cdf0e10cSrcweir                 nHeight += mpRowHeights->getSumValue(nRow, nLastRow);
2514cdf0e10cSrcweir             }
2515cdf0e10cSrcweir             nRow = nLastRow + 1;
2516cdf0e10cSrcweir         }
2517cdf0e10cSrcweir         return nHeight;
2518cdf0e10cSrcweir 	}
2519cdf0e10cSrcweir 	else
2520cdf0e10cSrcweir 		return (sal_uLong) ((nEndRow - nStartRow + 1) * ScGlobal::nStdRowHeight);
2521cdf0e10cSrcweir }
2522cdf0e10cSrcweir 
2523cdf0e10cSrcweir 
GetScaledRowHeight(SCROW nStartRow,SCROW nEndRow,double fScale) const2524cdf0e10cSrcweir sal_uLong ScTable::GetScaledRowHeight( SCROW nStartRow, SCROW nEndRow, double fScale ) const
2525cdf0e10cSrcweir {
2526cdf0e10cSrcweir 	DBG_ASSERT(VALIDROW(nStartRow) && VALIDROW(nEndRow),"Falsche Zeilennummer");
2527cdf0e10cSrcweir 
2528cdf0e10cSrcweir 	if (VALIDROW(nStartRow) && VALIDROW(nEndRow) && mpRowHeights)
2529cdf0e10cSrcweir 	{
2530cdf0e10cSrcweir         sal_uLong nHeight = 0;
2531cdf0e10cSrcweir         SCROW nRow = nStartRow;
2532cdf0e10cSrcweir         while (nRow <= nEndRow)
2533cdf0e10cSrcweir         {
2534cdf0e10cSrcweir             SCROW nLastRow = -1;
2535cdf0e10cSrcweir             if (!RowHidden(nRow, nLastRow))
2536cdf0e10cSrcweir             {
2537cdf0e10cSrcweir                 if (nLastRow > nEndRow)
2538cdf0e10cSrcweir                     nLastRow = nEndRow;
2539cdf0e10cSrcweir 
2540cdf0e10cSrcweir                 // #i117315# can't use getSumValue, because individual values must be rounded
2541cdf0e10cSrcweir                 while (nRow <= nLastRow)
2542cdf0e10cSrcweir                 {
2543cdf0e10cSrcweir                     ScFlatUInt16RowSegments::RangeData aData;
2544cdf0e10cSrcweir                     if (!mpRowHeights->getRangeData(nRow, aData))
2545cdf0e10cSrcweir                         return nHeight;   // shouldn't happen
2546cdf0e10cSrcweir 
2547cdf0e10cSrcweir                     SCROW nSegmentEnd = std::min( nLastRow, aData.mnRow2 );
2548cdf0e10cSrcweir 
2549cdf0e10cSrcweir                     // round-down a single height value, multiply resulting (pixel) values
2550cdf0e10cSrcweir                     sal_uLong nOneHeight = static_cast<sal_uLong>( aData.mnValue * fScale );
2551cdf0e10cSrcweir                     nHeight += nOneHeight * ( nSegmentEnd + 1 - nRow );
2552cdf0e10cSrcweir 
2553cdf0e10cSrcweir                     nRow = nSegmentEnd + 1;
2554cdf0e10cSrcweir                 }
2555cdf0e10cSrcweir             }
2556cdf0e10cSrcweir             nRow = nLastRow + 1;
2557cdf0e10cSrcweir         }
2558cdf0e10cSrcweir         return nHeight;
2559cdf0e10cSrcweir 	}
2560cdf0e10cSrcweir 	else
2561cdf0e10cSrcweir 		return (sal_uLong) ((nEndRow - nStartRow + 1) * ScGlobal::nStdRowHeight * fScale);
2562cdf0e10cSrcweir }
2563cdf0e10cSrcweir 
2564cdf0e10cSrcweir 
GetOriginalHeight(SCROW nRow) const2565cdf0e10cSrcweir sal_uInt16 ScTable::GetOriginalHeight( SCROW nRow ) const		// non-0 even if hidden
2566cdf0e10cSrcweir {
2567cdf0e10cSrcweir 	DBG_ASSERT(VALIDROW(nRow),"wrong row number");
2568cdf0e10cSrcweir 
2569cdf0e10cSrcweir     if (VALIDROW(nRow) && mpRowHeights)
2570cdf0e10cSrcweir         return mpRowHeights->getValue(nRow);
2571cdf0e10cSrcweir 	else
2572cdf0e10cSrcweir 		return (sal_uInt16) ScGlobal::nStdRowHeight;
2573cdf0e10cSrcweir }
2574cdf0e10cSrcweir 
2575cdf0e10cSrcweir 
2576cdf0e10cSrcweir //	Spalten-/Zeilen-Flags
2577cdf0e10cSrcweir 
2578cdf0e10cSrcweir 
GetHiddenRowCount(SCROW nRow)2579cdf0e10cSrcweir SCROW ScTable::GetHiddenRowCount( SCROW nRow )
2580cdf0e10cSrcweir {
2581cdf0e10cSrcweir     if (!ValidRow(nRow))
2582cdf0e10cSrcweir         return 0;
2583cdf0e10cSrcweir 
2584cdf0e10cSrcweir     SCROW nLastRow = -1;
2585cdf0e10cSrcweir     if (!RowHidden(nRow, nLastRow) || !ValidRow(nLastRow))
2586cdf0e10cSrcweir         return 0;
2587cdf0e10cSrcweir 
2588cdf0e10cSrcweir     return nLastRow - nRow + 1;
2589cdf0e10cSrcweir }
2590cdf0e10cSrcweir 
2591cdf0e10cSrcweir 
2592cdf0e10cSrcweir //!		ShowRows / DBShowRows zusammenfassen
2593cdf0e10cSrcweir 
ShowCol(SCCOL nCol,bool bShow)2594cdf0e10cSrcweir void ScTable::ShowCol(SCCOL nCol, bool bShow)
2595cdf0e10cSrcweir {
2596cdf0e10cSrcweir 	if (VALIDCOL(nCol))
2597cdf0e10cSrcweir 	{
2598cdf0e10cSrcweir         bool bWasVis = !ColHidden(nCol);
2599cdf0e10cSrcweir 		if (bWasVis != bShow)
2600cdf0e10cSrcweir 		{
2601cdf0e10cSrcweir 			IncRecalcLevel();
2602cdf0e10cSrcweir             InitializeNoteCaptions();
2603cdf0e10cSrcweir 			ScDrawLayer* pDrawLayer = pDocument->GetDrawLayer();
2604cdf0e10cSrcweir 			if (pDrawLayer)
2605cdf0e10cSrcweir 			{
2606cdf0e10cSrcweir 				if (bShow)
2607cdf0e10cSrcweir 					pDrawLayer->WidthChanged( nTab, nCol, (long) pColWidth[nCol] );
2608cdf0e10cSrcweir 				else
2609cdf0e10cSrcweir 					pDrawLayer->WidthChanged( nTab, nCol, -(long) pColWidth[nCol] );
2610cdf0e10cSrcweir 			}
2611cdf0e10cSrcweir 
2612cdf0e10cSrcweir             SetColHidden(nCol, nCol, !bShow);
2613cdf0e10cSrcweir 	    DecRecalcLevel();
2614cdf0e10cSrcweir 
2615cdf0e10cSrcweir 			ScChartListenerCollection* pCharts = pDocument->GetChartListenerCollection();
2616cdf0e10cSrcweir 			if ( pCharts )
2617cdf0e10cSrcweir 				pCharts->SetRangeDirty(ScRange( nCol, 0, nTab, nCol, MAXROW, nTab ));
2618cdf0e10cSrcweir 		}
2619cdf0e10cSrcweir 	}
2620cdf0e10cSrcweir 	else
2621cdf0e10cSrcweir 	{
2622cdf0e10cSrcweir 		DBG_ERROR("Falsche Spaltennummer oder keine Flags");
2623cdf0e10cSrcweir 	}
2624cdf0e10cSrcweir }
2625cdf0e10cSrcweir 
2626cdf0e10cSrcweir 
ShowRow(SCROW nRow,bool bShow)2627cdf0e10cSrcweir void ScTable::ShowRow(SCROW nRow, bool bShow)
2628cdf0e10cSrcweir {
2629cdf0e10cSrcweir 	if (VALIDROW(nRow) && pRowFlags)
2630cdf0e10cSrcweir 	{
2631cdf0e10cSrcweir         bool bWasVis = !RowHidden(nRow);
2632cdf0e10cSrcweir 		if (bWasVis != bShow)
2633cdf0e10cSrcweir 		{
2634cdf0e10cSrcweir 			IncRecalcLevel();
2635cdf0e10cSrcweir             InitializeNoteCaptions();
2636cdf0e10cSrcweir 			ScDrawLayer* pDrawLayer = pDocument->GetDrawLayer();
2637cdf0e10cSrcweir 			if (pDrawLayer)
2638cdf0e10cSrcweir 			{
2639cdf0e10cSrcweir 				if (bShow)
2640cdf0e10cSrcweir                     pDrawLayer->HeightChanged(
2641cdf0e10cSrcweir                         nTab, nRow, static_cast<long>(mpRowHeights->getValue(nRow)));
2642cdf0e10cSrcweir 				else
2643cdf0e10cSrcweir                     pDrawLayer->HeightChanged(
2644cdf0e10cSrcweir                         nTab, nRow, -static_cast<long>(mpRowHeights->getValue(nRow)));
2645cdf0e10cSrcweir 			}
2646cdf0e10cSrcweir 
2647cdf0e10cSrcweir             SetRowHidden(nRow, nRow, !bShow);
2648cdf0e10cSrcweir 			if (bShow)
2649cdf0e10cSrcweir                 SetRowFiltered(nRow, nRow, false);
2650cdf0e10cSrcweir 		DecRecalcLevel();
2651cdf0e10cSrcweir 
2652cdf0e10cSrcweir 			ScChartListenerCollection* pCharts = pDocument->GetChartListenerCollection();
2653cdf0e10cSrcweir 			if ( pCharts )
2654cdf0e10cSrcweir 				pCharts->SetRangeDirty(ScRange( 0, nRow, nTab, MAXCOL, nRow, nTab ));
2655cdf0e10cSrcweir 
2656cdf0e10cSrcweir             InvalidatePageBreaks();
2657cdf0e10cSrcweir 		}
2658cdf0e10cSrcweir 	}
2659cdf0e10cSrcweir 	else
2660cdf0e10cSrcweir 	{
2661cdf0e10cSrcweir 		DBG_ERROR("Falsche Zeilennummer oder keine Flags");
2662cdf0e10cSrcweir 	}
2663cdf0e10cSrcweir }
2664cdf0e10cSrcweir 
2665cdf0e10cSrcweir 
DBShowRow(SCROW nRow,bool bShow)2666cdf0e10cSrcweir void ScTable::DBShowRow(SCROW nRow, bool bShow)
2667cdf0e10cSrcweir {
2668cdf0e10cSrcweir 	if (VALIDROW(nRow) && pRowFlags)
2669cdf0e10cSrcweir 	{
2670cdf0e10cSrcweir         bool bWasVis = !RowHidden(nRow);
2671cdf0e10cSrcweir 		IncRecalcLevel();
2672cdf0e10cSrcweir         InitializeNoteCaptions();
2673cdf0e10cSrcweir 		if (bWasVis != bShow)
2674cdf0e10cSrcweir 		{
2675cdf0e10cSrcweir 			ScDrawLayer* pDrawLayer = pDocument->GetDrawLayer();
2676cdf0e10cSrcweir 			if (pDrawLayer)
2677cdf0e10cSrcweir 			{
2678cdf0e10cSrcweir 				if (bShow)
2679cdf0e10cSrcweir                     pDrawLayer->HeightChanged(
2680cdf0e10cSrcweir                         nTab, nRow, static_cast<long>(mpRowHeights->getValue(nRow)));
2681cdf0e10cSrcweir 				else
2682cdf0e10cSrcweir                     pDrawLayer->HeightChanged(
2683cdf0e10cSrcweir                         nTab, nRow, -static_cast<long>(mpRowHeights->getValue(nRow)));
2684cdf0e10cSrcweir 			}
2685cdf0e10cSrcweir 		}
2686cdf0e10cSrcweir 
2687cdf0e10cSrcweir 		//	Filter-Flag immer setzen, auch wenn Hidden unveraendert
2688cdf0e10cSrcweir         SetRowHidden(nRow, nRow, !bShow);
2689cdf0e10cSrcweir         SetRowFiltered(nRow, nRow, !bShow);
2690cdf0e10cSrcweir 	DecRecalcLevel();
2691cdf0e10cSrcweir 
2692cdf0e10cSrcweir 		if (bWasVis != bShow)
2693cdf0e10cSrcweir 		{
2694cdf0e10cSrcweir 			ScChartListenerCollection* pCharts = pDocument->GetChartListenerCollection();
2695cdf0e10cSrcweir 			if ( pCharts )
2696cdf0e10cSrcweir 				pCharts->SetRangeDirty(ScRange( 0, nRow, nTab, MAXCOL, nRow, nTab ));
2697cdf0e10cSrcweir 
2698cdf0e10cSrcweir 			if (pOutlineTable)
2699cdf0e10cSrcweir 				UpdateOutlineRow( nRow, nRow, bShow );
2700cdf0e10cSrcweir 
2701cdf0e10cSrcweir             InvalidatePageBreaks();
2702cdf0e10cSrcweir 		}
2703cdf0e10cSrcweir 	}
2704cdf0e10cSrcweir 	else
2705cdf0e10cSrcweir 	{
2706cdf0e10cSrcweir 		DBG_ERROR("Falsche Zeilennummer oder keine Flags");
2707cdf0e10cSrcweir 	}
2708cdf0e10cSrcweir }
2709cdf0e10cSrcweir 
2710cdf0e10cSrcweir 
DBShowRows(SCROW nRow1,SCROW nRow2,bool bShow,bool bSetFlags)2711cdf0e10cSrcweir void ScTable::DBShowRows(SCROW nRow1, SCROW nRow2, bool bShow, bool bSetFlags)
2712cdf0e10cSrcweir {
2713cdf0e10cSrcweir     // #i116164# IncRecalcLevel/DecRecalcLevel is in ScTable::Query
2714cdf0e10cSrcweir 	SCROW nStartRow = nRow1;
2715cdf0e10cSrcweir     InitializeNoteCaptions();
2716cdf0e10cSrcweir 	while (nStartRow <= nRow2)
2717cdf0e10cSrcweir 	{
2718cdf0e10cSrcweir         SCROW nEndRow = -1;
2719cdf0e10cSrcweir         bool bWasVis = !RowHidden(nStartRow, nEndRow);
2720cdf0e10cSrcweir         if (nEndRow > nRow2)
2721cdf0e10cSrcweir             nEndRow = nRow2;
2722cdf0e10cSrcweir 
2723cdf0e10cSrcweir 		sal_Bool bChanged = ( bWasVis != bShow );
2724cdf0e10cSrcweir 		if ( bChanged && bSetFlags )
2725cdf0e10cSrcweir 		{
2726cdf0e10cSrcweir 			ScDrawLayer* pDrawLayer = pDocument->GetDrawLayer();
2727cdf0e10cSrcweir 			if (pDrawLayer)
2728cdf0e10cSrcweir 			{
2729cdf0e10cSrcweir                 long nHeight = static_cast<long>(mpRowHeights->getSumValue(nStartRow, nEndRow));
2730cdf0e10cSrcweir 				if (bShow)
2731cdf0e10cSrcweir 					pDrawLayer->HeightChanged( nTab, nStartRow, nHeight );
2732cdf0e10cSrcweir 				else
2733cdf0e10cSrcweir 					pDrawLayer->HeightChanged( nTab, nStartRow, -nHeight );
2734cdf0e10cSrcweir 			}
2735cdf0e10cSrcweir 		}
2736cdf0e10cSrcweir 
2737cdf0e10cSrcweir         // #i116164# Directly modify the flags only if there are drawing objects within the area.
2738cdf0e10cSrcweir         // Otherwise, all modifications are made together in ScTable::Query, so the tree isn't constantly rebuilt.
2739cdf0e10cSrcweir         if ( bSetFlags )
2740cdf0e10cSrcweir         {
2741cdf0e10cSrcweir             SetRowHidden(nStartRow, nEndRow, !bShow);
2742cdf0e10cSrcweir             SetRowFiltered(nStartRow, nEndRow, !bShow);
2743cdf0e10cSrcweir         }
2744cdf0e10cSrcweir 
2745cdf0e10cSrcweir 		if ( bChanged )
2746cdf0e10cSrcweir 		{
2747cdf0e10cSrcweir 			ScChartListenerCollection* pCharts = pDocument->GetChartListenerCollection();
2748cdf0e10cSrcweir 			if ( pCharts )
2749cdf0e10cSrcweir 				pCharts->SetRangeDirty(ScRange( 0, nStartRow, nTab, MAXCOL, nEndRow, nTab ));
2750cdf0e10cSrcweir 		}
2751cdf0e10cSrcweir 
2752cdf0e10cSrcweir 		nStartRow = nEndRow + 1;
2753cdf0e10cSrcweir 	}
2754cdf0e10cSrcweir 
2755cdf0e10cSrcweir 	//	#i12341# For Show/Hide rows, the outlines are updated separately from the outside.
2756cdf0e10cSrcweir 	//	For filtering, the changes aren't visible to the caller, so UpdateOutlineRow has
2757cdf0e10cSrcweir 	//	to be done here.
2758cdf0e10cSrcweir 	if (pOutlineTable)
2759cdf0e10cSrcweir 		UpdateOutlineRow( nRow1, nRow2, bShow );
2760cdf0e10cSrcweir }
2761cdf0e10cSrcweir 
2762cdf0e10cSrcweir 
ShowRows(SCROW nRow1,SCROW nRow2,bool bShow)2763cdf0e10cSrcweir void ScTable::ShowRows(SCROW nRow1, SCROW nRow2, bool bShow)
2764cdf0e10cSrcweir {
2765cdf0e10cSrcweir 	SCROW nStartRow = nRow1;
2766cdf0e10cSrcweir 	IncRecalcLevel();
2767cdf0e10cSrcweir     InitializeNoteCaptions();
2768cdf0e10cSrcweir 
2769cdf0e10cSrcweir     // #i116164# if there are no drawing objects within the row range, a single HeightChanged call is enough
2770cdf0e10cSrcweir     ScDrawLayer* pDrawLayer = pDocument->GetDrawLayer();
2771cdf0e10cSrcweir     bool bHasObjects = pDrawLayer && pDrawLayer->HasObjectsInRows( nTab, nRow1, nRow2, false );
2772cdf0e10cSrcweir     long nOldHeight = 0;
2773cdf0e10cSrcweir     if ( pDrawLayer && !bHasObjects )
2774cdf0e10cSrcweir         nOldHeight = static_cast<long>(GetRowHeight(nRow1, nRow2));
2775cdf0e10cSrcweir 
2776cdf0e10cSrcweir 	while (nStartRow <= nRow2)
2777cdf0e10cSrcweir 	{
2778cdf0e10cSrcweir         SCROW nEndRow = -1;
2779cdf0e10cSrcweir         bool bWasVis = !RowHidden(nStartRow, nEndRow);
2780cdf0e10cSrcweir         if (nEndRow > nRow2)
2781cdf0e10cSrcweir             nEndRow = nRow2;
2782cdf0e10cSrcweir 
2783cdf0e10cSrcweir 		sal_Bool bChanged = ( bWasVis != bShow );
2784cdf0e10cSrcweir         if ( bChanged && bHasObjects )
2785cdf0e10cSrcweir 		{
2786cdf0e10cSrcweir 			if (pDrawLayer)
2787cdf0e10cSrcweir 			{
2788cdf0e10cSrcweir                 long nHeight = static_cast<long>(mpRowHeights->getSumValue(nStartRow, nEndRow));
2789cdf0e10cSrcweir 				if (bShow)
2790cdf0e10cSrcweir 					pDrawLayer->HeightChanged( nTab, nStartRow, nHeight );
2791cdf0e10cSrcweir 				else
2792cdf0e10cSrcweir 					pDrawLayer->HeightChanged( nTab, nStartRow, -nHeight );
2793cdf0e10cSrcweir 			}
2794cdf0e10cSrcweir 		}
2795cdf0e10cSrcweir 
2796cdf0e10cSrcweir         // #i116164# Directly modify the flags only if there are drawing objects within the area.
2797cdf0e10cSrcweir         // Otherwise, all rows are modified together after the loop, so the tree isn't constantly rebuilt.
2798cdf0e10cSrcweir         if ( bHasObjects )
2799cdf0e10cSrcweir         {
2800cdf0e10cSrcweir             SetRowHidden(nStartRow, nEndRow, !bShow);
2801cdf0e10cSrcweir             if (bShow)
2802cdf0e10cSrcweir                 SetRowFiltered(nStartRow, nEndRow, false);
2803cdf0e10cSrcweir         }
2804cdf0e10cSrcweir 
2805cdf0e10cSrcweir 		if ( bChanged )
2806cdf0e10cSrcweir 		{
2807cdf0e10cSrcweir 			ScChartListenerCollection* pCharts = pDocument->GetChartListenerCollection();
2808cdf0e10cSrcweir 			if ( pCharts )
2809cdf0e10cSrcweir 				pCharts->SetRangeDirty(ScRange( 0, nStartRow, nTab, MAXCOL, nEndRow, nTab ));
2810cdf0e10cSrcweir 
2811cdf0e10cSrcweir             InvalidatePageBreaks();
2812cdf0e10cSrcweir 		}
2813cdf0e10cSrcweir 
2814cdf0e10cSrcweir 		nStartRow = nEndRow + 1;
2815cdf0e10cSrcweir 	}
2816cdf0e10cSrcweir 
2817cdf0e10cSrcweir     if ( !bHasObjects )
2818cdf0e10cSrcweir     {
2819cdf0e10cSrcweir         // #i116164# set the flags for the whole range at once
2820cdf0e10cSrcweir         SetRowHidden(nRow1, nRow2, !bShow);
2821cdf0e10cSrcweir         if (bShow)
2822cdf0e10cSrcweir             SetRowFiltered(nRow1, nRow2, false);
2823cdf0e10cSrcweir 
2824cdf0e10cSrcweir         if ( pDrawLayer )
2825cdf0e10cSrcweir         {
2826cdf0e10cSrcweir             // if there are no objects in the range, a single HeightChanged call is enough
2827cdf0e10cSrcweir             long nNewHeight = 0;
2828cdf0e10cSrcweir             if ( bShow )
2829cdf0e10cSrcweir                 nNewHeight = static_cast<long>(GetRowHeight(nRow1, nRow2));
2830cdf0e10cSrcweir             if ( nNewHeight != nOldHeight )
2831cdf0e10cSrcweir                 pDrawLayer->HeightChanged( nTab, nRow1, nNewHeight - nOldHeight );
2832cdf0e10cSrcweir         }
2833cdf0e10cSrcweir     }
2834cdf0e10cSrcweir 
2835cdf0e10cSrcweir 	DecRecalcLevel();
2836cdf0e10cSrcweir }
2837cdf0e10cSrcweir 
IsDataFiltered() const2838cdf0e10cSrcweir sal_Bool ScTable::IsDataFiltered() const
2839cdf0e10cSrcweir {
2840cdf0e10cSrcweir 	sal_Bool bAnyQuery = sal_False;
2841cdf0e10cSrcweir 	ScDBData* pDBData = pDocument->GetFilterDBAtTable(nTab);
2842cdf0e10cSrcweir 	if ( pDBData )
2843cdf0e10cSrcweir 	{
2844cdf0e10cSrcweir 		ScQueryParam aParam;
2845cdf0e10cSrcweir 		pDBData->GetQueryParam( aParam );
2846cdf0e10cSrcweir 		if ( aParam.GetEntry(0).bDoQuery )
2847cdf0e10cSrcweir 			bAnyQuery = sal_True;
2848cdf0e10cSrcweir 	}
2849cdf0e10cSrcweir 	return bAnyQuery;
2850cdf0e10cSrcweir }
2851cdf0e10cSrcweir 
SetColFlags(SCCOL nCol,sal_uInt8 nNewFlags)2852cdf0e10cSrcweir void ScTable::SetColFlags( SCCOL nCol, sal_uInt8 nNewFlags )
2853cdf0e10cSrcweir {
2854cdf0e10cSrcweir 	if (VALIDCOL(nCol) && pColFlags)
2855cdf0e10cSrcweir 		pColFlags[nCol] = nNewFlags;
2856cdf0e10cSrcweir 	else
2857cdf0e10cSrcweir 	{
2858cdf0e10cSrcweir 		DBG_ERROR("Falsche Spaltennummer oder keine Flags");
2859cdf0e10cSrcweir 	}
2860cdf0e10cSrcweir }
2861cdf0e10cSrcweir 
2862cdf0e10cSrcweir 
SetRowFlags(SCROW nRow,sal_uInt8 nNewFlags)2863cdf0e10cSrcweir void ScTable::SetRowFlags( SCROW nRow, sal_uInt8 nNewFlags )
2864cdf0e10cSrcweir {
2865cdf0e10cSrcweir 	if (VALIDROW(nRow) && pRowFlags)
2866cdf0e10cSrcweir 		pRowFlags->SetValue( nRow, nNewFlags);
2867cdf0e10cSrcweir 	else
2868cdf0e10cSrcweir 	{
2869cdf0e10cSrcweir 		DBG_ERROR("Falsche Zeilennummer oder keine Flags");
2870cdf0e10cSrcweir 	}
2871cdf0e10cSrcweir }
2872cdf0e10cSrcweir 
2873cdf0e10cSrcweir 
SetRowFlags(SCROW nStartRow,SCROW nEndRow,sal_uInt8 nNewFlags)2874cdf0e10cSrcweir void ScTable::SetRowFlags( SCROW nStartRow, SCROW nEndRow, sal_uInt8 nNewFlags )
2875cdf0e10cSrcweir {
2876cdf0e10cSrcweir 	if (VALIDROW(nStartRow) && VALIDROW(nEndRow) && pRowFlags)
2877cdf0e10cSrcweir 		pRowFlags->SetValue( nStartRow, nEndRow, nNewFlags);
2878cdf0e10cSrcweir 	else
2879cdf0e10cSrcweir 	{
2880cdf0e10cSrcweir 		DBG_ERROR("Falsche Zeilennummer(n) oder keine Flags");
2881cdf0e10cSrcweir 	}
2882cdf0e10cSrcweir }
2883cdf0e10cSrcweir 
2884cdf0e10cSrcweir 
GetColFlags(SCCOL nCol) const2885cdf0e10cSrcweir sal_uInt8 ScTable::GetColFlags( SCCOL nCol ) const
2886cdf0e10cSrcweir {
2887cdf0e10cSrcweir 	if (VALIDCOL(nCol) && pColFlags)
2888cdf0e10cSrcweir 		return pColFlags[nCol];
2889cdf0e10cSrcweir 	else
2890cdf0e10cSrcweir 		return 0;
2891cdf0e10cSrcweir }
2892cdf0e10cSrcweir 
2893cdf0e10cSrcweir 
GetRowFlags(SCROW nRow) const2894cdf0e10cSrcweir sal_uInt8 ScTable::GetRowFlags( SCROW nRow ) const
2895cdf0e10cSrcweir {
2896cdf0e10cSrcweir 	if (VALIDROW(nRow) && pRowFlags)
2897cdf0e10cSrcweir 		return pRowFlags->GetValue(nRow);
2898cdf0e10cSrcweir 	else
2899cdf0e10cSrcweir 		return 0;
2900cdf0e10cSrcweir }
2901cdf0e10cSrcweir 
2902cdf0e10cSrcweir 
GetLastFlaggedRow() const2903cdf0e10cSrcweir SCROW ScTable::GetLastFlaggedRow() const
2904cdf0e10cSrcweir {
2905cdf0e10cSrcweir     SCROW nLastFound = 0;
2906cdf0e10cSrcweir     if (pRowFlags)
2907cdf0e10cSrcweir     {
2908cdf0e10cSrcweir         SCROW nRow = pRowFlags->GetLastAnyBitAccess( 0, sal::static_int_cast<sal_uInt8>(CR_ALL) );
2909cdf0e10cSrcweir         if (ValidRow(nRow))
2910cdf0e10cSrcweir             nLastFound = nRow;
2911cdf0e10cSrcweir     }
2912cdf0e10cSrcweir 
2913cdf0e10cSrcweir     if (!maRowManualBreaks.empty())
2914cdf0e10cSrcweir         nLastFound = ::std::max(nLastFound, *maRowManualBreaks.rbegin());
2915cdf0e10cSrcweir 
2916cdf0e10cSrcweir     if (mpHiddenRows)
2917cdf0e10cSrcweir     {
2918cdf0e10cSrcweir         SCROW nRow = mpHiddenRows->findLastNotOf(false);
2919cdf0e10cSrcweir         if (ValidRow(nRow))
2920cdf0e10cSrcweir             nLastFound = ::std::max(nLastFound, nRow);
2921cdf0e10cSrcweir     }
2922cdf0e10cSrcweir 
2923cdf0e10cSrcweir     if (mpFilteredRows)
2924cdf0e10cSrcweir     {
2925cdf0e10cSrcweir         SCROW nRow = mpFilteredRows->findLastNotOf(false);
2926cdf0e10cSrcweir         if (ValidRow(nRow))
2927cdf0e10cSrcweir             nLastFound = ::std::max(nLastFound, nRow);
2928cdf0e10cSrcweir     }
2929cdf0e10cSrcweir 
2930cdf0e10cSrcweir     return nLastFound;
2931cdf0e10cSrcweir }
2932cdf0e10cSrcweir 
2933cdf0e10cSrcweir 
GetLastChangedCol() const2934cdf0e10cSrcweir SCCOL ScTable::GetLastChangedCol() const
2935cdf0e10cSrcweir {
2936cdf0e10cSrcweir 	if ( !pColFlags )
2937cdf0e10cSrcweir 		return 0;
2938cdf0e10cSrcweir 
2939cdf0e10cSrcweir 	SCCOL nLastFound = 0;
2940cdf0e10cSrcweir 	for (SCCOL nCol = 1; nCol <= MAXCOL; nCol++)
2941cdf0e10cSrcweir         if ((pColFlags[nCol] & CR_ALL) || (pColWidth[nCol] != STD_COL_WIDTH))
2942cdf0e10cSrcweir 			nLastFound = nCol;
2943cdf0e10cSrcweir 
2944cdf0e10cSrcweir 	return nLastFound;
2945cdf0e10cSrcweir }
2946cdf0e10cSrcweir 
2947cdf0e10cSrcweir 
GetLastChangedRow() const2948cdf0e10cSrcweir SCROW ScTable::GetLastChangedRow() const
2949cdf0e10cSrcweir {
2950cdf0e10cSrcweir 	if ( !pRowFlags )
2951cdf0e10cSrcweir 		return 0;
2952cdf0e10cSrcweir 
2953cdf0e10cSrcweir     SCROW nLastFlags = GetLastFlaggedRow();
2954cdf0e10cSrcweir 
2955cdf0e10cSrcweir     // Find the last row position where the height is NOT the standard row
2956cdf0e10cSrcweir     // height.
2957cdf0e10cSrcweir     // KOHEI: Test this to make sure it does what it's supposed to.
2958cdf0e10cSrcweir     SCROW nLastHeight = mpRowHeights->findLastNotOf(ScGlobal::nStdRowHeight);
2959cdf0e10cSrcweir     if (!ValidRow(nLastHeight))
2960cdf0e10cSrcweir         nLastHeight = 0;
2961cdf0e10cSrcweir 
2962cdf0e10cSrcweir 	return std::max( nLastFlags, nLastHeight);
2963cdf0e10cSrcweir }
2964cdf0e10cSrcweir 
2965cdf0e10cSrcweir 
UpdateOutlineCol(SCCOL nStartCol,SCCOL nEndCol,sal_Bool bShow)2966cdf0e10cSrcweir sal_Bool ScTable::UpdateOutlineCol( SCCOL nStartCol, SCCOL nEndCol, sal_Bool bShow )
2967cdf0e10cSrcweir {
2968cdf0e10cSrcweir 	if (pOutlineTable && pColFlags)
2969cdf0e10cSrcweir     {
2970cdf0e10cSrcweir         ScBitMaskCompressedArray< SCCOLROW, sal_uInt8> aArray( MAXCOL, pColFlags, MAXCOLCOUNT);
2971cdf0e10cSrcweir 		return pOutlineTable->GetColArray()->ManualAction( nStartCol, nEndCol, bShow, *this, true );
2972cdf0e10cSrcweir     }
2973cdf0e10cSrcweir 	else
2974cdf0e10cSrcweir 		return sal_False;
2975cdf0e10cSrcweir }
2976cdf0e10cSrcweir 
2977cdf0e10cSrcweir 
UpdateOutlineRow(SCROW nStartRow,SCROW nEndRow,sal_Bool bShow)2978cdf0e10cSrcweir sal_Bool ScTable::UpdateOutlineRow( SCROW nStartRow, SCROW nEndRow, sal_Bool bShow )
2979cdf0e10cSrcweir {
2980cdf0e10cSrcweir 	if (pOutlineTable && pRowFlags)
2981cdf0e10cSrcweir 		return pOutlineTable->GetRowArray()->ManualAction( nStartRow, nEndRow, bShow, *this, false );
2982cdf0e10cSrcweir 	else
2983cdf0e10cSrcweir 		return sal_False;
2984cdf0e10cSrcweir }
2985cdf0e10cSrcweir 
2986cdf0e10cSrcweir 
ExtendHidden(SCCOL & rX1,SCROW & rY1,SCCOL & rX2,SCROW & rY2)2987cdf0e10cSrcweir void ScTable::ExtendHidden( SCCOL& rX1, SCROW& rY1, SCCOL& rX2, SCROW& rY2 )
2988cdf0e10cSrcweir {
2989cdf0e10cSrcweir     // Column-wise expansion
2990cdf0e10cSrcweir 
2991cdf0e10cSrcweir     while (rX1 > 0 && ColHidden(rX1-1))
2992cdf0e10cSrcweir         --rX1;
2993cdf0e10cSrcweir 
2994cdf0e10cSrcweir     while (rX2 < MAXCOL && ColHidden(rX2+1))
2995cdf0e10cSrcweir         ++rX2;
2996cdf0e10cSrcweir 
2997cdf0e10cSrcweir     // Row-wise expansion
2998cdf0e10cSrcweir 
2999cdf0e10cSrcweir     if (rY1 > 0)
3000cdf0e10cSrcweir 	{
3001cdf0e10cSrcweir         ScFlatBoolRowSegments::RangeData aData;
3002cdf0e10cSrcweir         if (mpHiddenRows->getRangeData(rY1-1, aData) && aData.mbValue)
3003cdf0e10cSrcweir         {
3004cdf0e10cSrcweir             SCROW nStartRow = aData.mnRow1;
3005cdf0e10cSrcweir             if (ValidRow(nStartRow))
3006cdf0e10cSrcweir                 rY1 = nStartRow;
3007cdf0e10cSrcweir         }
3008cdf0e10cSrcweir     }
3009cdf0e10cSrcweir     if (rY2 < MAXROW)
3010cdf0e10cSrcweir     {
3011cdf0e10cSrcweir         SCROW nEndRow = -1;
3012cdf0e10cSrcweir         if (RowHidden(rY2+1, nEndRow) && ValidRow(nEndRow))
3013cdf0e10cSrcweir             rY2 = nEndRow;
3014cdf0e10cSrcweir 	}
3015cdf0e10cSrcweir }
3016cdf0e10cSrcweir 
3017cdf0e10cSrcweir 
StripHidden(SCCOL & rX1,SCROW & rY1,SCCOL & rX2,SCROW & rY2)3018cdf0e10cSrcweir void ScTable::StripHidden( SCCOL& rX1, SCROW& rY1, SCCOL& rX2, SCROW& rY2 )
3019cdf0e10cSrcweir {
3020cdf0e10cSrcweir     while ( rX2>rX1 && ColHidden(rX2) )
3021cdf0e10cSrcweir         --rX2;
3022cdf0e10cSrcweir     while ( rX2>rX1 && ColHidden(rX1) )
3023cdf0e10cSrcweir         ++rX1;
3024cdf0e10cSrcweir 
3025cdf0e10cSrcweir     if (rY1 < rY2)
3026cdf0e10cSrcweir 	{
3027cdf0e10cSrcweir         ScFlatBoolRowSegments::RangeData aData;
3028cdf0e10cSrcweir         if (mpHiddenRows->getRangeData(rY2, aData) && aData.mbValue)
3029cdf0e10cSrcweir         {
3030cdf0e10cSrcweir             SCROW nStartRow = aData.mnRow1;
3031cdf0e10cSrcweir             if (ValidRow(nStartRow) && nStartRow >= rY1)
3032cdf0e10cSrcweir                 rY2 = nStartRow;
3033cdf0e10cSrcweir         }
3034cdf0e10cSrcweir     }
3035cdf0e10cSrcweir 
3036cdf0e10cSrcweir     if (rY1 < rY2)
3037cdf0e10cSrcweir     {
3038cdf0e10cSrcweir         SCROW nEndRow = -1;
3039cdf0e10cSrcweir         if (RowHidden(rY1, nEndRow) && ValidRow(nEndRow) && nEndRow <= rY2)
3040cdf0e10cSrcweir             rY1 = nEndRow;
3041cdf0e10cSrcweir 	}
3042cdf0e10cSrcweir }
3043cdf0e10cSrcweir 
3044cdf0e10cSrcweir 
3045cdf0e10cSrcweir //	Auto-Outline
3046cdf0e10cSrcweir 
3047cdf0e10cSrcweir template< typename T >
DiffSign(T a,T b)3048cdf0e10cSrcweir short DiffSign( T a, T b )
3049cdf0e10cSrcweir {
3050cdf0e10cSrcweir 	return (a<b) ? -1 :
3051cdf0e10cSrcweir 			(a>b) ? 1 : 0;
3052cdf0e10cSrcweir }
3053cdf0e10cSrcweir 
3054cdf0e10cSrcweir 
DoAutoOutline(SCCOL nStartCol,SCROW nStartRow,SCCOL nEndCol,SCROW nEndRow)3055cdf0e10cSrcweir void ScTable::DoAutoOutline( SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol, SCROW nEndRow )
3056cdf0e10cSrcweir {
3057cdf0e10cSrcweir 	sal_Bool bSizeChanged = sal_False;
3058cdf0e10cSrcweir 	sal_Bool bMissed	  = sal_False;
3059cdf0e10cSrcweir 
3060cdf0e10cSrcweir 	SCCOL nCol;
3061cdf0e10cSrcweir 	SCROW nRow;
3062cdf0e10cSrcweir 	SCROW i;
3063cdf0e10cSrcweir 	sal_Bool bFound;
3064cdf0e10cSrcweir 	ScOutlineArray* pArray;
3065cdf0e10cSrcweir 	ScBaseCell* pCell;
3066cdf0e10cSrcweir 	ScRange aRef;
3067cdf0e10cSrcweir /*	ScPatternAttr aBoldPattern( pDocument->GetPool() );				//!	spezielle Format-Vorlage
3068cdf0e10cSrcweir 	aBoldPattern.GetItemSet().Put( SvxWeightItem( WEIGHT_BOLD ) );
3069cdf0e10cSrcweir */
3070cdf0e10cSrcweir 
3071cdf0e10cSrcweir 	StartOutlineTable();
3072cdf0e10cSrcweir 
3073cdf0e10cSrcweir 							// Zeilen
3074cdf0e10cSrcweir 
3075cdf0e10cSrcweir 	SCROW	nCount = nEndRow-nStartRow+1;
3076cdf0e10cSrcweir 	sal_Bool*	pUsed = new sal_Bool[nCount];
3077cdf0e10cSrcweir 	for (i=0; i<nCount; i++)
3078cdf0e10cSrcweir 		pUsed[i] = sal_False;
3079cdf0e10cSrcweir 	for (nCol=nStartCol; nCol<=nEndCol; nCol++)
3080cdf0e10cSrcweir 		if (!aCol[nCol].IsEmptyData())
3081cdf0e10cSrcweir 			aCol[nCol].FindUsed( nStartRow, nEndRow, pUsed );
3082cdf0e10cSrcweir 
3083cdf0e10cSrcweir 	pArray = pOutlineTable->GetRowArray();
3084cdf0e10cSrcweir 	for (nRow=nStartRow; nRow<=nEndRow; nRow++)
3085cdf0e10cSrcweir 		if (pUsed[nRow-nStartRow])
3086cdf0e10cSrcweir 		{
3087cdf0e10cSrcweir 			bFound = sal_False;
3088cdf0e10cSrcweir 			for (nCol=nStartCol; nCol<=nEndCol && !bFound; nCol++)
3089cdf0e10cSrcweir 				if (!aCol[nCol].IsEmptyData())
3090cdf0e10cSrcweir 				{
3091cdf0e10cSrcweir 					pCell = aCol[nCol].GetCell( nRow );
3092cdf0e10cSrcweir 					if (pCell)
3093cdf0e10cSrcweir 						if ( pCell->GetCellType() == CELLTYPE_FORMULA )
3094cdf0e10cSrcweir 							if (((ScFormulaCell*)pCell)->HasRefListExpressibleAsOneReference( aRef ))
3095cdf0e10cSrcweir 								if ( aRef.aStart.Col() == nCol && aRef.aEnd.Col() == nCol &&
3096cdf0e10cSrcweir 									 aRef.aStart.Tab() == nTab && aRef.aEnd.Tab() == nTab &&
3097cdf0e10cSrcweir 									 DiffSign( aRef.aStart.Row(), nRow ) ==
3098cdf0e10cSrcweir 										DiffSign( aRef.aEnd.Row(), nRow ) )
3099cdf0e10cSrcweir 								{
3100cdf0e10cSrcweir 									if (pArray->Insert( aRef.aStart.Row(), aRef.aEnd.Row(), bSizeChanged ))
3101cdf0e10cSrcweir 									{
3102cdf0e10cSrcweir //										ApplyPatternArea( nStartCol, nRow, nEndCol, nRow, aBoldPattern );
3103cdf0e10cSrcweir 										bFound = sal_True;
3104cdf0e10cSrcweir 									}
3105cdf0e10cSrcweir 									else
3106cdf0e10cSrcweir 										bMissed = sal_True;
3107cdf0e10cSrcweir 								}
3108cdf0e10cSrcweir 				}
3109cdf0e10cSrcweir 		}
3110cdf0e10cSrcweir 
3111cdf0e10cSrcweir 	delete[] pUsed;
3112cdf0e10cSrcweir 
3113cdf0e10cSrcweir 							// Spalten
3114cdf0e10cSrcweir 
3115cdf0e10cSrcweir 	pArray = pOutlineTable->GetColArray();
3116cdf0e10cSrcweir 	for (nCol=nStartCol; nCol<=nEndCol; nCol++)
3117cdf0e10cSrcweir 	{
3118cdf0e10cSrcweir 		if (!aCol[nCol].IsEmptyData())
3119cdf0e10cSrcweir 		{
3120cdf0e10cSrcweir 			bFound = sal_False;
3121cdf0e10cSrcweir 			ScColumnIterator aIter( &aCol[nCol], nStartRow, nEndRow );
3122cdf0e10cSrcweir 			while ( aIter.Next( nRow, pCell ) && !bFound )
3123cdf0e10cSrcweir 			{
3124cdf0e10cSrcweir 				if ( pCell->GetCellType() == CELLTYPE_FORMULA )
3125cdf0e10cSrcweir 					if (((ScFormulaCell*)pCell)->HasRefListExpressibleAsOneReference( aRef ))
3126cdf0e10cSrcweir 						if ( aRef.aStart.Row() == nRow && aRef.aEnd.Row() == nRow &&
3127cdf0e10cSrcweir 							 aRef.aStart.Tab() == nTab && aRef.aEnd.Tab() == nTab &&
3128cdf0e10cSrcweir 							 DiffSign( aRef.aStart.Col(), nCol ) ==
3129cdf0e10cSrcweir 								DiffSign( aRef.aEnd.Col(), nCol ) )
3130cdf0e10cSrcweir 						{
3131cdf0e10cSrcweir 							if (pArray->Insert( aRef.aStart.Col(), aRef.aEnd.Col(), bSizeChanged ))
3132cdf0e10cSrcweir 							{
3133cdf0e10cSrcweir //								ApplyPatternArea( nCol, nStartRow, nCol, nEndRow, aBoldPattern );
3134cdf0e10cSrcweir 								bFound = sal_True;
3135cdf0e10cSrcweir 							}
3136cdf0e10cSrcweir 							else
3137cdf0e10cSrcweir 								bMissed = sal_True;
3138cdf0e10cSrcweir 						}
3139cdf0e10cSrcweir 			}
3140cdf0e10cSrcweir 		}
3141cdf0e10cSrcweir 	}
3142cdf0e10cSrcweir }
3143cdf0e10cSrcweir 
3144cdf0e10cSrcweir 									//	CopyData - fuer Query in anderen Bereich
3145cdf0e10cSrcweir 
CopyData(SCCOL nStartCol,SCROW nStartRow,SCCOL nEndCol,SCROW nEndRow,SCCOL nDestCol,SCROW nDestRow,SCTAB nDestTab)3146cdf0e10cSrcweir void ScTable::CopyData( SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol, SCROW nEndRow,
3147cdf0e10cSrcweir 							SCCOL nDestCol, SCROW nDestRow, SCTAB nDestTab )
3148cdf0e10cSrcweir {
3149cdf0e10cSrcweir 	//!		wenn fuer mehrere Zeilen benutzt, nach Spalten optimieren!
3150cdf0e10cSrcweir 
3151cdf0e10cSrcweir 	ScAddress aSrc( nStartCol, nStartRow, nTab );
3152cdf0e10cSrcweir 	ScAddress aDest( nDestCol, nDestRow, nDestTab );
3153cdf0e10cSrcweir 	ScRange aRange( aSrc, aDest );
3154cdf0e10cSrcweir 	sal_Bool bThisTab = ( nDestTab == nTab );
3155cdf0e10cSrcweir 	SCROW nDestY = nDestRow;
3156cdf0e10cSrcweir 	for (SCROW nRow=nStartRow; nRow<=nEndRow; nRow++)
3157cdf0e10cSrcweir 	{
3158cdf0e10cSrcweir 		aSrc.SetRow( nRow );
3159cdf0e10cSrcweir 		aDest.SetRow( nDestY );
3160cdf0e10cSrcweir 		SCCOL nDestX = nDestCol;
3161cdf0e10cSrcweir 		for (SCCOL nCol=nStartCol; nCol<=nEndCol; nCol++)
3162cdf0e10cSrcweir 		{
3163cdf0e10cSrcweir 			aSrc.SetCol( nCol );
3164cdf0e10cSrcweir 			aDest.SetCol( nDestX );
3165cdf0e10cSrcweir 			ScBaseCell* pCell = GetCell( nCol, nRow );
3166cdf0e10cSrcweir 			if (pCell)
3167cdf0e10cSrcweir 			{
3168cdf0e10cSrcweir                 pCell = pCell->CloneWithoutNote( *pDocument );
3169cdf0e10cSrcweir 				if (pCell->GetCellType() == CELLTYPE_FORMULA)
3170cdf0e10cSrcweir 				{
3171cdf0e10cSrcweir 					((ScFormulaCell*)pCell)->UpdateReference( URM_COPY, aRange,
3172cdf0e10cSrcweir 									((SCsCOL) nDestCol) - ((SCsCOL) nStartCol),
3173cdf0e10cSrcweir 									((SCsROW) nDestRow) - ((SCsROW) nStartRow),
3174cdf0e10cSrcweir 									((SCsTAB) nDestTab) - ((SCsTAB) nTab) );
3175cdf0e10cSrcweir 					((ScFormulaCell*)pCell)->aPos = aDest;
3176cdf0e10cSrcweir 				}
3177cdf0e10cSrcweir 			}
3178cdf0e10cSrcweir 			if (bThisTab)
3179cdf0e10cSrcweir 			{
3180cdf0e10cSrcweir 				PutCell( nDestX, nDestY, pCell );
3181cdf0e10cSrcweir 				SetPattern( nDestX, nDestY, *GetPattern( nCol, nRow ), sal_True );
3182cdf0e10cSrcweir 			}
3183cdf0e10cSrcweir 			else
3184cdf0e10cSrcweir 			{
3185cdf0e10cSrcweir 				pDocument->PutCell( aDest, pCell );
3186cdf0e10cSrcweir 				pDocument->SetPattern( aDest, *GetPattern( nCol, nRow ), sal_True );
3187cdf0e10cSrcweir 			}
3188cdf0e10cSrcweir 
3189cdf0e10cSrcweir 			++nDestX;
3190cdf0e10cSrcweir 		}
3191cdf0e10cSrcweir 		++nDestY;
3192cdf0e10cSrcweir 	}
3193cdf0e10cSrcweir }
3194cdf0e10cSrcweir 
3195cdf0e10cSrcweir 
RefVisible(ScFormulaCell * pCell)3196cdf0e10cSrcweir sal_Bool ScTable::RefVisible(ScFormulaCell* pCell)
3197cdf0e10cSrcweir {
3198cdf0e10cSrcweir 	ScRange aRef;
3199cdf0e10cSrcweir 
3200cdf0e10cSrcweir 	if (pCell->HasOneReference(aRef))
3201cdf0e10cSrcweir 	{
3202cdf0e10cSrcweir 		if (aRef.aStart.Col()==aRef.aEnd.Col() && aRef.aStart.Tab()==aRef.aEnd.Tab())
3203cdf0e10cSrcweir 		{
3204cdf0e10cSrcweir             SCROW nEndRow;
3205cdf0e10cSrcweir             if (!RowFiltered(aRef.aStart.Row(), NULL, &nEndRow))
3206cdf0e10cSrcweir                 // row not filtered.
3207cdf0e10cSrcweir                 nEndRow = ::std::numeric_limits<SCROW>::max();
3208cdf0e10cSrcweir 
3209cdf0e10cSrcweir             if (!ValidRow(nEndRow) || nEndRow < aRef.aEnd.Row())
3210cdf0e10cSrcweir                 return sal_True;    // at least partly visible
3211cdf0e10cSrcweir             return sal_False;       // completely invisible
3212cdf0e10cSrcweir 		}
3213cdf0e10cSrcweir 	}
3214cdf0e10cSrcweir 
3215cdf0e10cSrcweir 	return sal_True;						// irgendwie anders
3216cdf0e10cSrcweir }
3217cdf0e10cSrcweir 
3218cdf0e10cSrcweir 
GetUpperCellString(SCCOL nCol,SCROW nRow,String & rStr)3219cdf0e10cSrcweir void ScTable::GetUpperCellString(SCCOL nCol, SCROW nRow, String& rStr)
3220cdf0e10cSrcweir {
3221cdf0e10cSrcweir 	GetInputString(nCol, nRow, rStr);
3222cdf0e10cSrcweir 	rStr.EraseTrailingChars();
3223cdf0e10cSrcweir 	rStr.EraseLeadingChars();
3224cdf0e10cSrcweir 	ScGlobal::pCharClass->toUpper(rStr);
3225cdf0e10cSrcweir }
3226cdf0e10cSrcweir 
3227cdf0e10cSrcweir 
3228cdf0e10cSrcweir // Berechnen der Groesse der Tabelle und setzen der Groesse an der DrawPage
3229cdf0e10cSrcweir 
SetDrawPageSize(bool bResetStreamValid,bool bUpdateNoteCaptionPos)3230cdf0e10cSrcweir void ScTable::SetDrawPageSize(bool bResetStreamValid, bool bUpdateNoteCaptionPos)
3231cdf0e10cSrcweir {
3232cdf0e10cSrcweir 	ScDrawLayer* pDrawLayer = pDocument->GetDrawLayer();
3233cdf0e10cSrcweir 	if( pDrawLayer )
3234cdf0e10cSrcweir 	{
3235cdf0e10cSrcweir         double fValX = GetColOffset( MAXCOL + 1 ) * HMM_PER_TWIPS;
3236cdf0e10cSrcweir         double fValY = GetRowOffset( MAXROW + 1 ) * HMM_PER_TWIPS;
3237cdf0e10cSrcweir         const long nMax = ::std::numeric_limits<long>::max();
3238cdf0e10cSrcweir         // #i113884# Avoid int32 overflow with possible negative results than can cause bad effects.
3239cdf0e10cSrcweir         // If the draw page size is smaller than all rows, only the bottom of the sheet is affected.
3240cdf0e10cSrcweir         long x = ( fValX > (double)nMax ) ? nMax : (long) fValX;
3241cdf0e10cSrcweir         long y = ( fValY > (double)nMax ) ? nMax : (long) fValY;
3242cdf0e10cSrcweir 
3243cdf0e10cSrcweir 		if ( IsLayoutRTL() )		// IsNegativePage
3244cdf0e10cSrcweir 			x = -x;
3245cdf0e10cSrcweir 
3246cdf0e10cSrcweir 		pDrawLayer->SetPageSize( static_cast<sal_uInt16>(nTab), Size( x, y ), bUpdateNoteCaptionPos );
3247cdf0e10cSrcweir 	}
3248cdf0e10cSrcweir 
3249cdf0e10cSrcweir     // #i102616# actions that modify the draw page size count as sheet modification
3250cdf0e10cSrcweir     // (exception: InitDrawLayer)
3251cdf0e10cSrcweir     if (bResetStreamValid && IsStreamValid())
3252cdf0e10cSrcweir         SetStreamValid(sal_False);
3253cdf0e10cSrcweir }
3254cdf0e10cSrcweir 
3255cdf0e10cSrcweir 
GetRowOffset(SCROW nRow) const3256cdf0e10cSrcweir sal_uLong ScTable::GetRowOffset( SCROW nRow ) const
3257cdf0e10cSrcweir {
3258cdf0e10cSrcweir 	sal_uLong n = 0;
3259cdf0e10cSrcweir     if ( mpHiddenRows && mpRowHeights )
3260cdf0e10cSrcweir 	{
3261cdf0e10cSrcweir         if (nRow == 0)
3262cdf0e10cSrcweir             return 0;
3263cdf0e10cSrcweir         else if (nRow == 1)
3264cdf0e10cSrcweir             return GetRowHeight(0);
3265cdf0e10cSrcweir 
3266cdf0e10cSrcweir         n = GetTotalRowHeight(0, nRow-1);
3267cdf0e10cSrcweir #ifdef DBG_UTIL
3268cdf0e10cSrcweir         if (n == ::std::numeric_limits<unsigned long>::max())
3269cdf0e10cSrcweir             DBG_ERRORFILE("ScTable::GetRowOffset: row heights overflow");
3270cdf0e10cSrcweir #endif
3271cdf0e10cSrcweir 	}
3272cdf0e10cSrcweir 	else
3273cdf0e10cSrcweir 	{
3274cdf0e10cSrcweir 		DBG_ERROR("GetRowOffset: Daten fehlen");
3275cdf0e10cSrcweir 	}
3276cdf0e10cSrcweir 	return n;
3277cdf0e10cSrcweir }
3278cdf0e10cSrcweir 
GetRowForHeight(sal_uLong nHeight) const3279cdf0e10cSrcweir SCROW ScTable::GetRowForHeight(sal_uLong nHeight) const
3280cdf0e10cSrcweir {
3281cdf0e10cSrcweir     sal_uInt32 nSum = 0;
3282cdf0e10cSrcweir 
3283cdf0e10cSrcweir     ScFlatBoolRowSegments::RangeData aData;
3284cdf0e10cSrcweir     for (SCROW nRow = 0; nRow <= MAXROW; ++nRow)
3285cdf0e10cSrcweir     {
3286cdf0e10cSrcweir         if (!mpHiddenRows->getRangeData(nRow, aData))
3287cdf0e10cSrcweir             break;
3288cdf0e10cSrcweir 
3289cdf0e10cSrcweir         if (aData.mbValue)
3290cdf0e10cSrcweir         {
3291cdf0e10cSrcweir             nRow = aData.mnRow2;
3292cdf0e10cSrcweir             continue;
3293cdf0e10cSrcweir         }
3294cdf0e10cSrcweir 
3295cdf0e10cSrcweir         sal_uInt32 nNew = mpRowHeights->getValue(nRow);
3296cdf0e10cSrcweir         nSum += nNew;
3297cdf0e10cSrcweir         if (nSum > nHeight)
3298cdf0e10cSrcweir         {
3299cdf0e10cSrcweir             return nRow < MAXROW ? nRow + 1 : MAXROW;
3300cdf0e10cSrcweir         }
3301cdf0e10cSrcweir     }
3302cdf0e10cSrcweir     return -1;
3303cdf0e10cSrcweir }
3304cdf0e10cSrcweir 
3305cdf0e10cSrcweir 
GetColOffset(SCCOL nCol) const3306cdf0e10cSrcweir sal_uLong ScTable::GetColOffset( SCCOL nCol ) const
3307cdf0e10cSrcweir {
3308cdf0e10cSrcweir 	sal_uLong n = 0;
3309cdf0e10cSrcweir 	if ( pColWidth )
3310cdf0e10cSrcweir 	{
3311cdf0e10cSrcweir 		SCCOL i;
3312cdf0e10cSrcweir 		for( i = 0; i < nCol; i++ )
3313cdf0e10cSrcweir             if (!ColHidden(i))
3314cdf0e10cSrcweir 				n += pColWidth[i];
3315cdf0e10cSrcweir 	}
3316cdf0e10cSrcweir 	else
3317cdf0e10cSrcweir 	{
3318cdf0e10cSrcweir 		DBG_ERROR("GetColumnOffset: Daten fehlen");
3319cdf0e10cSrcweir 	}
3320cdf0e10cSrcweir 	return n;
3321cdf0e10cSrcweir }
3322cdf0e10cSrcweir 
GetColumnByIndex(sal_Int32 index)33230deba7fbSSteve Yin ScColumn* ScTable::GetColumnByIndex(sal_Int32 index)
33240deba7fbSSteve Yin {
33250deba7fbSSteve Yin 	if( index <= MAXCOL && index >= 0 )
33260deba7fbSSteve Yin 	{
33270deba7fbSSteve Yin 		return &(aCol[index]);
33280deba7fbSSteve Yin 	}
33290deba7fbSSteve Yin 	return NULL;
33300deba7fbSSteve Yin }
33310deba7fbSSteve Yin 
3332