37e6631cc5
Change-Id: Ib15413e73409cc33de01fa92a47b9d1237cfc4b2
187 lines
6.1 KiB
C++
187 lines
6.1 KiB
C++
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
/*
|
|
* This file is part of the LibreOffice project.
|
|
*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
*
|
|
* This file incorporates work covered by the following license notice:
|
|
*
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
* contributor license agreements. See the NOTICE file distributed
|
|
* with this work for additional information regarding copyright
|
|
* ownership. The ASF licenses this file to you under the Apache
|
|
* License, Version 2.0 (the "License"); you may not use this file
|
|
* except in compliance with the License. You may obtain a copy of
|
|
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
|
|
*/
|
|
|
|
#ifndef INCLUDED_SC_INC_OLINETAB_HXX
|
|
#define INCLUDED_SC_INC_OLINETAB_HXX
|
|
|
|
#include "scdllapi.h"
|
|
#include "address.hxx"
|
|
|
|
#include <boost/ptr_container/ptr_map.hpp>
|
|
|
|
#define SC_OL_MAXDEPTH 7
|
|
|
|
class ScTable;
|
|
|
|
class ScOutlineEntry
|
|
{
|
|
SCCOLROW nStart;
|
|
SCSIZE nSize;
|
|
bool bHidden;
|
|
bool bVisible;
|
|
|
|
public:
|
|
ScOutlineEntry( SCCOLROW nNewStart, SCCOLROW nNewSize, bool bNewHidden = false );
|
|
ScOutlineEntry( const ScOutlineEntry& rEntry );
|
|
|
|
SC_DLLPUBLIC SCCOLROW GetStart() const { return nStart;}
|
|
SCSIZE GetSize() const { return nSize;}
|
|
SC_DLLPUBLIC SCCOLROW GetEnd() const;
|
|
|
|
/**
|
|
* @return true is the group is hidden, false otherwise.
|
|
*/
|
|
SC_DLLPUBLIC bool IsHidden() const { return bHidden;}
|
|
|
|
/**
|
|
* @return true if the control is visible, false otherwise.
|
|
*/
|
|
SC_DLLPUBLIC bool IsVisible() const { return bVisible;}
|
|
|
|
void Move( SCsCOLROW nDelta );
|
|
void SetSize( SCSIZE nNewSize );
|
|
void SetPosSize( SCCOLROW nNewPos, SCSIZE nNewSize );
|
|
void SetHidden( bool bNewHidden );
|
|
void SetVisible( bool bNewVisible );
|
|
};
|
|
|
|
class ScOutlineCollection
|
|
{
|
|
typedef boost::ptr_map<SCCOLROW, ScOutlineEntry> MapType;
|
|
MapType maEntries;
|
|
|
|
public:
|
|
typedef MapType::iterator iterator;
|
|
typedef MapType::const_iterator const_iterator;
|
|
|
|
ScOutlineCollection();
|
|
|
|
size_t size() const;
|
|
void clear();
|
|
void insert(ScOutlineEntry* pEntry);
|
|
iterator begin();
|
|
iterator end();
|
|
const_iterator begin() const;
|
|
const_iterator end() const;
|
|
void erase(iterator pos);
|
|
bool empty() const;
|
|
|
|
iterator FindStart(SCCOLROW nMinStart);
|
|
};
|
|
|
|
class SC_DLLPUBLIC ScOutlineArray
|
|
{
|
|
friend class ScSubOutlineIterator;
|
|
|
|
private:
|
|
size_t nDepth;
|
|
ScOutlineCollection aCollections[SC_OL_MAXDEPTH];
|
|
|
|
bool DecDepth();
|
|
void FindEntry(
|
|
SCCOLROW nSearchPos, size_t& rFindLevel, size_t& rFindIndex,
|
|
size_t nMaxLevel = SC_OL_MAXDEPTH);
|
|
|
|
void RemoveSub(SCCOLROW nStartPos, SCCOLROW nEndPos, size_t nLevel);
|
|
void PromoteSub(SCCOLROW nStartPos, SCCOLROW nEndPos, size_t nStartLevel);
|
|
|
|
public:
|
|
ScOutlineArray();
|
|
ScOutlineArray( const ScOutlineArray& rArray );
|
|
|
|
size_t GetDepth() const { return nDepth;}
|
|
|
|
bool FindTouchedLevel(
|
|
SCCOLROW nBlockStart, SCCOLROW nBlockEnd, size_t& rFindLevel) const;
|
|
|
|
bool Insert( SCCOLROW nStartPos, SCCOLROW nEndPos, bool& rSizeChanged,
|
|
bool bHidden = false, bool bVisible = true );
|
|
bool Remove( SCCOLROW nBlockStart, SCCOLROW nBlockEnd, bool& rSizeChanged );
|
|
|
|
ScOutlineEntry* GetEntry(size_t nLevel, size_t nIndex);
|
|
const ScOutlineEntry* GetEntry(size_t nLevel, size_t nIndex) const;
|
|
size_t GetCount(size_t nLevel) const;
|
|
const ScOutlineEntry* GetEntryByPos(size_t nLevel, SCCOLROW nPos) const;
|
|
|
|
bool GetEntryIndex(size_t nLevel, SCCOLROW nPos, size_t& rnIndex) const;
|
|
bool GetEntryIndexInRange(
|
|
size_t nLevel, SCCOLROW nBlockStart, SCCOLROW nBlockEnd, size_t& rnIndex) const;
|
|
|
|
void SetVisibleBelow(
|
|
size_t nLevel, size_t nEntry, bool bValue, bool bSkipHidden = false);
|
|
|
|
void GetRange(SCCOLROW& rStart, SCCOLROW& rEnd) const;
|
|
void ExtendBlock(size_t nLevel, SCCOLROW& rBlkStart, SCCOLROW& rBlkEnd);
|
|
|
|
bool TestInsertSpace(SCSIZE nSize, SCCOLROW nMaxVal) const;
|
|
void InsertSpace(SCCOLROW nStartPos, SCSIZE nSize);
|
|
bool DeleteSpace(SCCOLROW nStartPos, SCSIZE nSize);
|
|
|
|
bool ManualAction(
|
|
SCCOLROW nStartPos, SCCOLROW nEndPos, bool bShow, const ScTable& rTable, bool bCol);
|
|
|
|
void RemoveAll();
|
|
};
|
|
|
|
class ScOutlineTable
|
|
{
|
|
private:
|
|
ScOutlineArray aColOutline;
|
|
ScOutlineArray aRowOutline;
|
|
|
|
public:
|
|
ScOutlineTable();
|
|
ScOutlineTable( const ScOutlineTable& rOutline );
|
|
|
|
const ScOutlineArray& GetColArray() const { return aColOutline; }
|
|
ScOutlineArray& GetColArray() { return aColOutline; }
|
|
const ScOutlineArray& GetRowArray() const { return aRowOutline; }
|
|
ScOutlineArray& GetRowArray() { return aRowOutline; }
|
|
|
|
bool TestInsertCol( SCSIZE nSize );
|
|
void InsertCol( SCCOL nStartCol, SCSIZE nSize );
|
|
bool DeleteCol( SCCOL nStartCol, SCSIZE nSize ); // TRUE: Undo only using original
|
|
bool TestInsertRow( SCSIZE nSize );
|
|
void InsertRow( SCROW nStartRow, SCSIZE nSize );
|
|
bool DeleteRow( SCROW nStartRow, SCSIZE nSize );
|
|
};
|
|
|
|
class ScSubOutlineIterator
|
|
{
|
|
private:
|
|
ScOutlineArray* pArray;
|
|
SCCOLROW nStart;
|
|
SCCOLROW nEnd;
|
|
size_t nSubLevel;
|
|
size_t nSubEntry;
|
|
size_t nDepth;
|
|
|
|
public:
|
|
ScSubOutlineIterator( ScOutlineArray* pOutlineArray );
|
|
ScSubOutlineIterator( ScOutlineArray* pOutlineArray, size_t nLevel, size_t nEntry );
|
|
|
|
ScOutlineEntry* GetNext();
|
|
size_t LastLevel() const { return nSubLevel;}
|
|
size_t LastEntry() const;
|
|
void DeleteLast();
|
|
};
|
|
|
|
#endif
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|