1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #ifndef INCLUDED_SC_INC_ATTARRAY_HXX
21 #define INCLUDED_SC_INC_ATTARRAY_HXX
28 class ScEditDataArray
;
32 class ScFlatBoolRowSegments
;
34 class SfxItemPoolCache
;
35 class SfxStyleSheetBase
;
39 namespace editeng
{ class SvxBorderLine
; }
41 #define SC_LINE_EMPTY 0
43 #define SC_LINE_DONTCARE 2
45 #define SC_ATTRARRAY_DELTA 4
56 ScLineFlags() : nLeft(SC_LINE_EMPTY
),nRight(SC_LINE_EMPTY
),nTop(SC_LINE_EMPTY
),
57 nBottom(SC_LINE_EMPTY
),nHori(SC_LINE_EMPTY
),nVert(SC_LINE_EMPTY
) {}
60 struct ScMergePatternState
62 SfxItemSet
* pItemSet
; ///< allocated in MergePatternArea, used for resulting ScPatternAttr
63 const ScPatternAttr
* pOld1
; ///< existing objects, temporary
64 const ScPatternAttr
* pOld2
;
66 ScMergePatternState() : pItemSet(NULL
), pOld1(NULL
), pOld2(NULL
) {}
72 const ScPatternAttr
* pPattern
;
80 ScDocument
* pDocument
;
86 friend class ScDocument
; // for FillInfo
87 friend class ScDocumentIterator
;
88 friend class ScAttrIterator
;
89 friend class ScHorizontalAttrIterator
;
91 bool ApplyFrame( const SvxBoxItem
* pLineOuter
, const SvxBoxInfoItem
* pLineInner
,
92 SCROW nStartRow
, SCROW nEndRow
,
93 bool bLeft
, SCCOL nDistRight
, bool bTop
, SCROW nDistBottom
);
95 void RemoveCellCharAttribs( SCROW nStartRow
, SCROW nEndRow
,
96 const ScPatternAttr
* pPattern
, ScEditDataArray
* pDataArray
);
98 ScAttrArray(const ScAttrArray
&) SAL_DELETED_FUNCTION
;
99 ScAttrArray
& operator=(const ScAttrArray
&) SAL_DELETED_FUNCTION
;
102 ScAttrArray( SCCOL nNewCol
, SCTAB nNewTab
, ScDocument
* pDoc
);
105 void SetTab(SCTAB nNewTab
) { nTab
= nNewTab
; }
106 void SetCol(SCCOL nNewCol
) { nCol
= nNewCol
; }
107 #if OSL_DEBUG_LEVEL > 1
108 void TestData() const;
110 void Reset( const ScPatternAttr
* pPattern
);
111 bool Concat(SCSIZE nPos
);
113 const ScPatternAttr
* GetPattern( SCROW nRow
) const;
114 const ScPatternAttr
* GetPatternRange( SCROW
& rStartRow
, SCROW
& rEndRow
, SCROW nRow
) const;
115 void MergePatternArea( SCROW nStartRow
, SCROW nEndRow
, ScMergePatternState
& rState
, bool bDeep
) const;
117 void MergeBlockFrame( SvxBoxItem
* pLineOuter
, SvxBoxInfoItem
* pLineInner
, ScLineFlags
& rFlags
,
118 SCROW nStartRow
, SCROW nEndRow
, bool bLeft
, SCCOL nDistRight
) const;
119 void ApplyBlockFrame( const SvxBoxItem
* pLineOuter
, const SvxBoxInfoItem
* pLineInner
,
120 SCROW nStartRow
, SCROW nEndRow
, bool bLeft
, SCCOL nDistRight
);
122 void SetPattern( SCROW nRow
, const ScPatternAttr
* pPattern
, bool bPutToPool
= false );
123 void SetPatternArea( SCROW nStartRow
, SCROW nEndRow
, const ScPatternAttr
* pPattern
,
124 bool bPutToPool
= false, ScEditDataArray
* pDataArray
= NULL
);
125 void ApplyStyleArea( SCROW nStartRow
, SCROW nEndRow
, ScStyleSheet
* pStyle
);
126 void ApplyCacheArea( SCROW nStartRow
, SCROW nEndRow
, SfxItemPoolCache
* pCache
,
127 ScEditDataArray
* pDataArray
= NULL
);
128 bool SetAttrEntries(ScAttrEntry
* pNewData
, SCSIZE nSize
);
129 void ApplyLineStyleArea( SCROW nStartRow
, SCROW nEndRow
,
130 const ::editeng::SvxBorderLine
* pLine
, bool bColorOnly
);
132 void AddCondFormat( SCROW nStartRow
, SCROW nEndRow
, sal_uInt32 nIndex
);
133 /// if nIndex == 0, remove all conditional format data
134 void RemoveCondFormat( SCROW nStartRow
, SCROW nEndRow
, sal_uInt32 nIndex
);
136 void ClearItems( SCROW nStartRow
, SCROW nEndRow
, const sal_uInt16
* pWhich
);
137 void ChangeIndent( SCROW nStartRow
, SCROW nEndRow
, bool bIncrement
);
139 /// Including current, may return -1
140 SCsROW
GetNextUnprotected( SCsROW nRow
, bool bUp
) const;
142 /// May return -1 if not found
144 SCsROW nRow
, const ScStyleSheet
* pSearchStyle
, bool bUp
,
145 const ScMarkArray
* pMarkArray
= NULL
) const;
147 bool SearchStyleRange(
148 SCsROW
& rRow
, SCsROW
& rEndRow
, const ScStyleSheet
* pSearchStyle
, bool bUp
,
149 const ScMarkArray
* pMarkArray
= NULL
) const;
151 bool ApplyFlags( SCROW nStartRow
, SCROW nEndRow
, sal_Int16 nFlags
);
152 bool RemoveFlags( SCROW nStartRow
, SCROW nEndRow
, sal_Int16 nFlags
);
154 bool Search( SCROW nRow
, SCSIZE
& nIndex
) const;
156 bool HasAttrib( SCROW nRow1
, SCROW nRow2
, sal_uInt16 nMask
) const;
157 bool IsMerged( SCROW nRow
) const;
158 bool ExtendMerge( SCCOL nThisCol
, SCROW nStartRow
, SCROW nEndRow
,
159 SCCOL
& rPaintCol
, SCROW
& rPaintRow
,
161 bool RemoveAreaMerge( SCROW nStartRow
, SCROW nEndRow
);
163 void FindStyleSheet( const SfxStyleSheetBase
* pStyleSheet
, ScFlatBoolRowSegments
& rUsedRows
, bool bReset
);
164 bool IsStyleSheetUsed( const ScStyleSheet
& rStyle
, bool bGatherAllStyles
) const;
166 void DeleteAreaSafe(SCROW nStartRow
, SCROW nEndRow
);
167 void SetPatternAreaSafe( SCROW nStartRow
, SCROW nEndRow
,
168 const ScPatternAttr
* pWantedPattern
, bool bDefault
);
169 void CopyAreaSafe( SCROW nStartRow
, SCROW nEndRow
, long nDy
, ScAttrArray
& rAttrArray
);
171 bool IsEmpty() const;
173 bool GetFirstVisibleAttr( SCROW
& rFirstRow
) const;
174 bool GetLastVisibleAttr( SCROW
& rLastRow
, SCROW nLastData
, bool bFullFormattedArea
= false ) const;
175 bool HasVisibleAttrIn( SCROW nStartRow
, SCROW nEndRow
) const;
176 bool IsVisibleEqual( const ScAttrArray
& rOther
,
177 SCROW nStartRow
, SCROW nEndRow
) const;
178 bool IsAllEqual( const ScAttrArray
& rOther
, SCROW nStartRow
, SCROW nEndRow
) const;
180 bool TestInsertCol( SCROW nStartRow
, SCROW nEndRow
) const;
181 bool TestInsertRow( SCSIZE nSize
) const;
182 void InsertRow( SCROW nStartRow
, SCSIZE nSize
);
183 void DeleteRow( SCROW nStartRow
, SCSIZE nSize
);
184 void DeleteRange( SCSIZE nStartIndex
, SCSIZE nEndIndex
);
185 void DeleteArea( SCROW nStartRow
, SCROW nEndRow
);
186 void MoveTo( SCROW nStartRow
, SCROW nEndRow
, ScAttrArray
& rAttrArray
);
188 SCROW nStartRow
, SCROW nEndRow
, long nDy
, ScAttrArray
& rAttrArray
, sal_Int16 nStripFlags
= 0) const;
190 void DeleteHardAttr( SCROW nStartRow
, SCROW nEndRow
);
192 /* i123909: Pre-calculate needed memory, and pre-reserve enough memory */
193 bool Reserve( SCSIZE nReserve
);
194 SCSIZE
Count() const { return nCount
; }
195 SCSIZE
Count( SCROW nRow1
, SCROW nRow2
) const;
198 // Iterator for attributes
202 const ScAttrArray
* pArray
;
207 inline ScAttrIterator( const ScAttrArray
* pNewArray
, SCROW nStart
, SCROW nEnd
);
208 inline const ScPatternAttr
* Next( SCROW
& rTop
, SCROW
& rBottom
);
209 inline const ScPatternAttr
* Resync( SCROW nRow
, SCROW
& rTop
, SCROW
& rBottom
);
210 SCROW
GetNextRow() const { return nRow
; }
213 inline ScAttrIterator::ScAttrIterator( const ScAttrArray
* pNewArray
, SCROW nStart
, SCROW nEnd
) :
219 pArray
->Search( nStart
, nPos
);
224 inline const ScPatternAttr
* ScAttrIterator::Next( SCROW
& rTop
, SCROW
& rBottom
)
226 const ScPatternAttr
* pRet
;
227 if ( nPos
< pArray
->nCount
&& nRow
<= nEndRow
)
230 rBottom
= std::min( pArray
->pData
[nPos
].nRow
, nEndRow
);
231 pRet
= pArray
->pData
[nPos
].pPattern
;
240 inline const ScPatternAttr
* ScAttrIterator::Resync( SCROW nRowP
, SCROW
& rTop
, SCROW
& rBottom
)
243 // Chances are high that the pattern changed on nRowP introduced a span
244 // starting right there. Assume that Next() was called so nPos already
245 // advanced. Another high chance is that the change extended a previous or
246 // next pattern. In all these cases we don't need to search.
247 if (3 <= nPos
&& nPos
<= pArray
->nCount
&& pArray
->pData
[nPos
-3].nRow
< nRowP
&&
248 nRowP
<= pArray
->pData
[nPos
-2].nRow
)
250 else if (2 <= nPos
&& nPos
<= pArray
->nCount
&& pArray
->pData
[nPos
-2].nRow
< nRowP
&&
251 nRowP
<= pArray
->pData
[nPos
-1].nRow
)
253 else if (pArray
->nCount
> 0 && nRowP
<= pArray
->pData
[0].nRow
)
256 pArray
->Search( nRowP
, nPos
);
257 return Next( rTop
, rBottom
);
262 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */