Files
libreoffice/sw/source/core/inc/txmsrt.hxx

288 lines
8.8 KiB
C++

/*************************************************************************
*
* $RCSfile: txmsrt.hxx,v $
*
* $Revision: 1.2 $
*
* last change: $Author: jp $ $Date: 2000-10-20 10:53:11 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
*
* - GNU Lesser General Public License Version 2.1
* - Sun Industry Standards Source License Version 1.1
*
* Sun Microsystems Inc., October, 2000
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2000 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* This library 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 for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
*
* Sun Industry Standards Source License Version 1.1
* =================================================
* The contents of this file are subject to the Sun Industry Standards
* Source License Version 1.1 (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.openoffice.org/license.html.
*
* Software provided under this License is provided on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
* See the License for the specific provisions governing your rights and
* obligations concerning the Software.
*
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
*
* Copyright: 2000 by Sun Microsystems, Inc.
*
* All Rights Reserved.
*
* Contributor(s): _______________________________________
*
*
************************************************************************/
#ifndef _TXMSRT_HXX
#define _TXMSRT_HXX
#ifndef _LANG_HXX
#include <tools/lang.hxx>
#endif
#ifndef _INTN_HXX
#include <tools/intn.hxx>
#endif
#ifndef _TOX_HXX
#include <tox.hxx>
#endif
class International;
class CharClass;
class SwCntntNode;
class SwTxtNode;
class SwTxtTOXMark;
class SwIndex;
class SwFmtFld;
enum TOXSortType
{
TOX_SORT_INDEX,
TOX_SORT_CUSTOM,
TOX_SORT_CONTENT,
TOX_SORT_PARA,
TOX_SORT_TABLE,
TOX_SORT_AUTHORITY
};
struct SwTOXSource
{
const SwCntntNode* pNd;
xub_StrLen nPos;
BOOL bMainEntry;
SwTOXSource() : pNd(0), nPos(0), bMainEntry(FALSE) {}
SwTOXSource( const SwCntntNode* pNode, xub_StrLen n, BOOL bMain )
: pNd(pNode), nPos(n), bMainEntry(bMain)
{}
};
SV_DECL_VARARR( SwTOXSources, SwTOXSource, 0, 10 )
class SwTOXInternational
{
International* pIntl;
CharClass* pCharClass;
LanguageType eLang;
public:
SwTOXInternational( LanguageType nLang );
SwTOXInternational( const SwTOXInternational& );
~SwTOXInternational();
inline BOOL IsEqual( const String& rTxt1, const String& rTxt2,
USHORT nFlags ) const
{
return COMPARE_EQUAL == pIntl->Compare( rTxt1, rTxt2, nFlags );
}
inline BOOL IsLess( const String& rTxt1, const String& rTxt2,
USHORT nFlags ) const
{
return COMPARE_LESS == pIntl->Compare( rTxt1, rTxt2, nFlags );
}
inline StringCompare Compare( const String& rTxt1, const String& rTxt2,
USHORT nFlags ) const
{
return pIntl->Compare( rTxt1, rTxt2, nFlags );
}
inline sal_Unicode GetIndexChar( const String& rTxt ) const
{ return pIntl->GetIndexChar( rTxt ); }
inline String GetFollowingText( USHORT nType ) const
{ return pIntl->GetFollowingText( (FollowingText)nType ); }
String ToUpper( const String& rStr, xub_StrLen nPos ) const;
inline BOOL IsNumeric( const String& rStr ) const;
};
/*--------------------------------------------------------------------
Beschreibung: Klassen fuer die Sortierung der Verzeichnisse
--------------------------------------------------------------------*/
struct SwTOXSortTabBase
{
SwTOXSources aTOXSources;
const SwTxtNode* pTOXNd;
const SwTxtTOXMark* pTxtMark;
const SwTOXInternational* pTOXIntl;
ULONG nPos;
xub_StrLen nCntPos;
USHORT nType, nLanguage;
static USHORT nOpt;
SwTOXSortTabBase( TOXSortType nType,
const SwCntntNode* pTOXSrc,
const SwTxtTOXMark* pTxtMark,
const SwTOXInternational* pIntl );
USHORT GetType() const { return nType; }
USHORT GetOptions() const { return nOpt; }
virtual void FillText( SwTxtNode& rNd, const SwIndex& rInsPos, USHORT nAuthField = 0) const;
virtual USHORT GetLevel() const = 0;
virtual BOOL operator==( const SwTOXSortTabBase& );
virtual BOOL operator<( const SwTOXSortTabBase& );
virtual String GetURL() const;
inline const String& GetTxt() const;
private:
BOOL bValidTxt;
String sSortTxt;
virtual void _GetText( String& ) = 0;
};
inline const String& SwTOXSortTabBase::GetTxt() const
{
if( !bValidTxt )
{
SwTOXSortTabBase* pThis = (SwTOXSortTabBase*)this;
pThis->_GetText( pThis->sSortTxt );
pThis->bValidTxt = TRUE;
}
return sSortTxt;
}
/*--------------------------------------------------------------------
Beschreibung: fuer Sortierung nach Text
--------------------------------------------------------------------*/
struct SwTOXIndex : public SwTOXSortTabBase
{
SwTOXIndex( const SwTxtNode&, const SwTxtTOXMark*, USHORT nOptions, BYTE nKeyLevel,
const SwTOXInternational& rIntl );
virtual void FillText( SwTxtNode& rNd, const SwIndex& rInsPos, USHORT nAuthField = 0 ) const;
virtual USHORT GetLevel() const;
virtual BOOL operator==( const SwTOXSortTabBase& );
virtual BOOL operator<( const SwTOXSortTabBase& );
private:
virtual void _GetText( String& );
BYTE nKeyLevel;
};
struct SwTOXCustom : public SwTOXSortTabBase
{
SwTOXCustom(const String& rKey, USHORT nLevel, const SwTOXInternational& rIntl );
virtual USHORT GetLevel() const;
virtual BOOL operator==( const SwTOXSortTabBase& );
virtual BOOL operator<( const SwTOXSortTabBase& );
private:
virtual void _GetText( String& );
String aKey;
USHORT nLev;
};
/*--------------------------------------------------------------------
Beschreibung: fuer Sortierung nach Position
--------------------------------------------------------------------*/
struct SwTOXContent : public SwTOXSortTabBase
{
SwTOXContent( const SwTxtNode&, const SwTxtTOXMark*,
const SwTOXInternational& rIntl );
virtual void FillText( SwTxtNode& rNd, const SwIndex& rInsPos, USHORT nAuthField = 0 ) const;
virtual USHORT GetLevel() const;
private:
virtual void _GetText( String& );
};
struct SwTOXPara : public SwTOXSortTabBase
{
SwTOXPara( const SwCntntNode&, SwTOXElement, USHORT nLevel = FORM_ALPHA_DELIMITTER );
void SetStartIndex( xub_StrLen nSet) { nStartIndex = nSet;}
void SetEndIndex( xub_StrLen nSet ) { nEndIndex = nSet;}
virtual void FillText( SwTxtNode& rNd, const SwIndex& rInsPos, USHORT nAuthField = 0 ) const;
virtual USHORT GetLevel() const;
virtual String GetURL() const;
private:
virtual void _GetText( String& );
SwTOXElement eType;
USHORT m_nLevel;
xub_StrLen nStartIndex;
xub_StrLen nEndIndex;
};
struct SwTOXTable : public SwTOXSortTabBase
{
SwTOXTable( const SwCntntNode& rNd );
void SetLevel(USHORT nSet){nLevel = nSet;}
virtual USHORT GetLevel() const;
virtual String GetURL() const;
private:
virtual void _GetText( String& );
USHORT nLevel;
};
struct SwTOXAuthority : public SwTOXSortTabBase
{
private:
SwFmtFld& m_rField;
virtual void FillText( SwTxtNode& rNd, const SwIndex& rInsPos, USHORT nAuthField = 0 ) const;
virtual void _GetText( String& );
public:
SwTOXAuthority( const SwCntntNode& rNd, SwFmtFld& rField, const SwTOXInternational& rIntl );
SwFmtFld& GetFldFmt() {return m_rField;}
virtual BOOL operator==( const SwTOXSortTabBase& );
virtual BOOL operator<( const SwTOXSortTabBase& );
virtual USHORT GetLevel() const;
};
#endif // _TXMSRT_HXX