Files
libreoffice/sw/inc/docary.hxx

190 lines
6.2 KiB
C++
Raw Normal View History

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2000-09-18 16:15:01 +00:00
/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
2000-09-18 16:15:01 +00:00
*
* Copyright 2000, 2010 Oracle and/or its affiliates.
2000-09-18 16:15:01 +00:00
*
* OpenOffice.org - a multi-platform office productivity suite
2000-09-18 16:15:01 +00:00
*
* This file is part of OpenOffice.org.
2000-09-18 16:15:01 +00:00
*
* OpenOffice.org is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License version 3
* only, as published by the Free Software Foundation.
2000-09-18 16:15:01 +00:00
*
* OpenOffice.org is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License version 3 for more details
* (a copy is included in the LICENSE file that accompanied this code).
2000-09-18 16:15:01 +00:00
*
* You should have received a copy of the GNU Lesser General Public License
* version 3 along with OpenOffice.org. If not, see
* <http://www.openoffice.org/license.html>
* for a copy of the LGPLv3 License.
2000-09-18 16:15:01 +00:00
*
************************************************************************/
#ifndef _DOCARY_HXX
#define _DOCARY_HXX
#include <com/sun/star/i18n/ForbiddenCharacters.hpp>
#include <vector>
#include <set>
#include <algorithm>
#include <svl/svarray.hxx>
2000-09-18 16:15:01 +00:00
class SwFieldType;
class SwFmt;
2000-09-18 16:15:01 +00:00
class SwFrmFmt;
class SwCharFmt;
class SwTOXType;
class SwUndo;
class SwSectionFmt;
class SwNumRule;
class SwRedline;
class SwUnoCrsr;
class SwOLENode;
class SwTxtFmtColl;
class SwGrfFmtColl;
2000-09-18 16:15:01 +00:00
namespace com { namespace sun { namespace star { namespace i18n {
struct ForbiddenCharacters; // comes from the I18N UNO interface
}}}}
2000-09-18 16:15:01 +00:00
#include <swtypes.hxx>
// provides some methods for generic operations on lists that contain
// SwFmt* subclasses.
class SwFmtsBase
{
public:
virtual size_t GetFmtCount() const = 0;
virtual SwFmt* GetFmt(size_t idx) const = 0;
virtual ~SwFmtsBase() = 0;
};
2000-09-18 16:15:01 +00:00
class SwGrfFmtColls : public std::vector<SwGrfFmtColl*>, public SwFmtsBase
{
public:
virtual size_t GetFmtCount() const { return size(); }
virtual SwFmt* GetFmt(size_t idx) const { return (SwFmt*)operator[](idx); }
sal_uInt16 GetPos(const SwGrfFmtColl* pFmt) const;
// free's any remaining child objects
virtual ~SwGrfFmtColls() {}
};
2000-09-18 16:15:01 +00:00
// Specific frame formats (frames, DrawObjects).
class SW_DLLPUBLIC SwFrmFmts : public std::vector<SwFrmFmt*>, public SwFmtsBase
{
public:
virtual size_t GetFmtCount() const { return size(); }
virtual SwFmt* GetFmt(size_t idx) const { return (SwFmt*)operator[](idx); }
sal_uInt16 GetPos(const SwFrmFmt* pFmt) const;
bool Contains(const SwFrmFmt* pFmt) const;
// free's any remaining child objects
virtual ~SwFrmFmts();
};
2000-09-18 16:15:01 +00:00
class SwCharFmts : public std::vector<SwCharFmt*>, public SwFmtsBase
{
public:
virtual size_t GetFmtCount() const { return size(); }
virtual SwFmt* GetFmt(size_t idx) const { return (SwFmt*)operator[](idx); }
sal_uInt16 GetPos(const SwCharFmt* pFmt) const;
bool Contains(const SwCharFmt* pFmt) const;
// free's any remaining child objects
virtual ~SwCharFmts();
};
class SwTxtFmtColls : public std::vector<SwTxtFmtColl*>, public SwFmtsBase
{
public:
virtual size_t GetFmtCount() const { return size(); }
virtual SwFmt* GetFmt(size_t idx) const { return (SwFmt*)operator[](idx); }
sal_uInt16 GetPos(const SwTxtFmtColl* pFmt) const;
virtual ~SwTxtFmtColls() {}
};
// Array of Undo-history.
class SW_DLLPUBLIC SwSectionFmts : public std::vector<SwSectionFmt*>, public SwFmtsBase
{
public:
virtual size_t GetFmtCount() const { return size(); }
virtual SwFmt* GetFmt(size_t idx) const { return (SwFmt*)operator[](idx); }
sal_uInt16 GetPos(const SwSectionFmt* pFmt) const;
bool Contains(const SwSectionFmt* pFmt) const;
// free's any remaining child objects
virtual ~SwSectionFmts();
};
2000-09-18 16:15:01 +00:00
class SwFldTypes : public std::vector<SwFieldType*> {
public:
// the destructor will free all objects still in the vector
~SwFldTypes();
sal_uInt16 GetPos(const SwFieldType* pFieldType) const;
};
2000-09-18 16:15:01 +00:00
class SwTOXTypes : public std::vector<SwTOXType*> {
public:
// the destructor will free all objects still in the vector
~SwTOXTypes();
sal_uInt16 GetPos(const SwTOXType* pTOXType) const;
};
2000-09-18 16:15:01 +00:00
class SW_DLLPUBLIC SwNumRuleTbl : public std::vector<SwNumRule*> {
public:
// the destructor will free all objects still in the vector
~SwNumRuleTbl();
sal_uInt16 GetPos(const SwNumRule* pRule) const;
};
2000-09-18 16:15:01 +00:00
typedef SwRedline* SwRedlinePtr;
SV_DECL_PTRARR_SORT_DEL( _SwRedlineTbl, SwRedlinePtr, 0 )
2000-09-18 16:15:01 +00:00
class SwRedlineTbl : private _SwRedlineTbl
{
public:
SwRedlineTbl( sal_uInt8 nSize = 0 )
: _SwRedlineTbl( nSize ) {}
2000-09-18 16:15:01 +00:00
~SwRedlineTbl() {}
sal_Bool SavePtrInArr( SwRedlinePtr p ) { return _SwRedlineTbl::Insert( p ); }
2000-09-18 16:15:01 +00:00
sal_Bool Insert( SwRedlinePtr& p, sal_Bool bIns = sal_True );
sal_Bool Insert( SwRedlinePtr& p, sal_uInt16& rInsPos, sal_Bool bIns = sal_True );
sal_Bool InsertWithValidRanges( SwRedlinePtr& p, sal_uInt16* pInsPos = 0 );
2000-09-18 16:15:01 +00:00
void Remove( sal_uInt16 nP, sal_uInt16 nL = 1 );
void DeleteAndDestroy( sal_uInt16 nP, sal_uInt16 nL=1 );
2000-09-18 16:15:01 +00:00
// Search next or previous Redline with the same Seq. No.
// Search can be restricted via Lookahaed.
// Using 0 or USHRT_MAX makes search the whole array.
sal_uInt16 FindNextOfSeqNo( sal_uInt16 nSttPos, sal_uInt16 nLookahead = 20 ) const;
sal_uInt16 FindPrevOfSeqNo( sal_uInt16 nSttPos, sal_uInt16 nLookahead = 20 ) const;
sal_uInt16 FindNextSeqNo( sal_uInt16 nSeqNo, sal_uInt16 nSttPos,
sal_uInt16 nLookahead = 20 ) const;
sal_uInt16 FindPrevSeqNo( sal_uInt16 nSeqNo, sal_uInt16 nSttPos,
sal_uInt16 nLookahead = 20 ) const;
2000-09-18 16:15:01 +00:00
using _SwRedlineTbl::Count;
using _SwRedlineTbl::operator[];
using _SwRedlineTbl::GetObject;
using _SwRedlineTbl::Seek_Entry;
using _SwRedlineTbl::GetPos;
2000-09-18 16:15:01 +00:00
};
class SwUnoCrsrTbl : public std::set<SwUnoCrsr*> {
public:
// the destructor will free all objects still in the set
~SwUnoCrsrTbl();
};
2000-09-18 16:15:01 +00:00
class SwOLENodes : public std::vector<SwOLENode*> {};
2000-09-18 16:15:01 +00:00
#endif //_DOCARY_HXX
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */