Version 5.2.6.1, tag libreoffice-5.2.6.1
[LibreOffice.git] / sc / inc / olinetab.hxx
blob02f4d701d86271bebde6c8bc260b6e03ed26489b
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
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_OLINETAB_HXX
21 #define INCLUDED_SC_INC_OLINETAB_HXX
23 #include "scdllapi.h"
24 #include "address.hxx"
26 #include <map>
28 #define SC_OL_MAXDEPTH 7
30 class ScTable;
32 class ScOutlineEntry
34 SCCOLROW nStart;
35 SCSIZE nSize;
36 bool bHidden;
37 bool bVisible;
39 public:
40 ScOutlineEntry( SCCOLROW nNewStart, SCCOLROW nNewSize, bool bNewHidden = false );
41 ScOutlineEntry( const ScOutlineEntry& rEntry );
43 SC_DLLPUBLIC SCCOLROW GetStart() const { return nStart;}
44 SCSIZE GetSize() const { return nSize;}
45 SC_DLLPUBLIC SCCOLROW GetEnd() const;
47 /**
48 * @return true is the group is hidden, false otherwise.
50 SC_DLLPUBLIC bool IsHidden() const { return bHidden;}
52 /**
53 * @return true if the control is visible, false otherwise.
55 SC_DLLPUBLIC bool IsVisible() const { return bVisible;}
57 void Move( SCsCOLROW nDelta );
58 void SetSize( SCSIZE nNewSize );
59 void SetPosSize( SCCOLROW nNewPos, SCSIZE nNewSize );
60 void SetHidden( bool bNewHidden );
61 void SetVisible( bool bNewVisible );
64 class ScOutlineCollection
66 typedef std::map<SCCOLROW, ScOutlineEntry> MapType;
67 MapType m_Entries;
69 public:
70 typedef MapType::iterator iterator;
71 typedef MapType::const_iterator const_iterator;
73 ScOutlineCollection();
75 size_t size() const;
76 void clear();
77 void insert(ScOutlineEntry const& rEntry);
78 iterator begin();
79 iterator end();
80 const_iterator begin() const;
81 const_iterator end() const;
82 void erase(const iterator& pos);
83 bool empty() const;
85 iterator FindStart(SCCOLROW nMinStart);
88 class SC_DLLPUBLIC ScOutlineArray
90 friend class ScSubOutlineIterator;
92 private:
93 size_t nDepth;
94 ScOutlineCollection aCollections[SC_OL_MAXDEPTH];
96 bool DecDepth();
97 void FindEntry(
98 SCCOLROW nSearchPos, size_t& rFindLevel, size_t& rFindIndex,
99 size_t nMaxLevel = SC_OL_MAXDEPTH);
101 void RemoveSub(SCCOLROW nStartPos, SCCOLROW nEndPos, size_t nLevel);
102 void PromoteSub(SCCOLROW nStartPos, SCCOLROW nEndPos, size_t nStartLevel);
104 public:
105 ScOutlineArray();
106 ScOutlineArray( const ScOutlineArray& rArray );
108 size_t GetDepth() const { return nDepth;}
110 bool FindTouchedLevel(
111 SCCOLROW nBlockStart, SCCOLROW nBlockEnd, size_t& rFindLevel) const;
113 bool Insert( SCCOLROW nStartPos, SCCOLROW nEndPos, bool& rSizeChanged,
114 bool bHidden = false );
115 bool Remove( SCCOLROW nBlockStart, SCCOLROW nBlockEnd, bool& rSizeChanged );
117 ScOutlineEntry* GetEntry(size_t nLevel, size_t nIndex);
118 const ScOutlineEntry* GetEntry(size_t nLevel, size_t nIndex) const;
119 size_t GetCount(size_t nLevel) const;
120 const ScOutlineEntry* GetEntryByPos(size_t nLevel, SCCOLROW nPos) const;
122 bool GetEntryIndex(size_t nLevel, SCCOLROW nPos, size_t& rnIndex) const;
123 bool GetEntryIndexInRange(
124 size_t nLevel, SCCOLROW nBlockStart, SCCOLROW nBlockEnd, size_t& rnIndex) const;
126 void SetVisibleBelow(
127 size_t nLevel, size_t nEntry, bool bValue, bool bSkipHidden = false);
129 void GetRange(SCCOLROW& rStart, SCCOLROW& rEnd) const;
130 void ExtendBlock(size_t nLevel, SCCOLROW& rBlkStart, SCCOLROW& rBlkEnd);
132 bool TestInsertSpace(SCSIZE nSize, SCCOLROW nMaxVal) const;
133 void InsertSpace(SCCOLROW nStartPos, SCSIZE nSize);
134 bool DeleteSpace(SCCOLROW nStartPos, SCSIZE nSize);
136 bool ManualAction(
137 SCCOLROW nStartPos, SCCOLROW nEndPos, bool bShow, const ScTable& rTable, bool bCol);
139 void finalizeImport(ScTable& rTable);
141 void RemoveAll();
144 class ScOutlineTable
146 private:
147 ScOutlineArray aColOutline;
148 ScOutlineArray aRowOutline;
150 public:
151 ScOutlineTable();
152 ScOutlineTable( const ScOutlineTable& rOutline );
154 const ScOutlineArray& GetColArray() const { return aColOutline; }
155 ScOutlineArray& GetColArray() { return aColOutline; }
156 const ScOutlineArray& GetRowArray() const { return aRowOutline; }
157 ScOutlineArray& GetRowArray() { return aRowOutline; }
159 bool TestInsertCol( SCSIZE nSize );
160 void InsertCol( SCCOL nStartCol, SCSIZE nSize );
161 bool DeleteCol( SCCOL nStartCol, SCSIZE nSize ); // TRUE: Undo only using original
162 bool TestInsertRow( SCSIZE nSize );
163 void InsertRow( SCROW nStartRow, SCSIZE nSize );
164 bool DeleteRow( SCROW nStartRow, SCSIZE nSize );
167 class ScSubOutlineIterator
169 private:
170 ScOutlineArray* pArray;
171 SCCOLROW nStart;
172 SCCOLROW nEnd;
173 size_t nSubLevel;
174 size_t nSubEntry;
175 size_t nDepth;
177 public:
178 ScSubOutlineIterator( ScOutlineArray* pOutlineArray );
179 ScSubOutlineIterator( ScOutlineArray* pOutlineArray, size_t nLevel, size_t nEntry );
181 ScOutlineEntry* GetNext();
182 size_t LastLevel() const { return nSubLevel;}
183 size_t LastEntry() const;
184 void DeleteLast();
187 #endif
189 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */