2000-09-18 23:08:29 +00:00
|
|
|
|
/*************************************************************************
|
|
|
|
|
*
|
|
|
|
|
* $RCSfile: docnum.cxx,v $
|
|
|
|
|
*
|
2005-03-29 13:37:07 +00:00
|
|
|
|
* $Revision: 1.48 $
|
2000-09-18 23:08:29 +00:00
|
|
|
|
*
|
2005-03-29 13:37:07 +00:00
|
|
|
|
* last change: $Author: rt $ $Date: 2005-03-29 14:37:07 $
|
2000-09-18 23:08:29 +00:00
|
|
|
|
*
|
|
|
|
|
* 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): _______________________________________
|
|
|
|
|
*
|
|
|
|
|
*
|
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
|
|
#pragma hdrstop
|
|
|
|
|
|
|
|
|
|
#ifndef _HINTIDS_HXX
|
|
|
|
|
#include <hintids.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifndef _DATE_HXX //autogen
|
|
|
|
|
#include <tools/date.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _TIME_HXX //autogen
|
|
|
|
|
#include <tools/time.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _TOOLS_RESID_HXX //autogen
|
|
|
|
|
#include <tools/resid.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _SVX_LRSPITEM_HXX //autogen
|
|
|
|
|
#include <svx/lrspitem.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifndef _FTNINFO_HXX //autogen
|
|
|
|
|
#include <ftninfo.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _FTNIDX_HXX //autogen
|
|
|
|
|
#include <ftnidx.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _DOC_HXX
|
|
|
|
|
#include <doc.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _PAM_HXX
|
|
|
|
|
#include <pam.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _NDTXT_HXX
|
|
|
|
|
#include <ndtxt.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _NUMRULE_HXX
|
|
|
|
|
#include <numrule.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _DOCTXM_HXX
|
|
|
|
|
#include <doctxm.hxx> // pTOXBaseRing
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _POOLFMT_HXX
|
|
|
|
|
#include <poolfmt.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _UNDOBJ_HXX
|
|
|
|
|
#include <undobj.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _SWUNDO_HXX
|
|
|
|
|
#include <swundo.hxx>
|
|
|
|
|
#endif
|
2004-10-22 07:11:47 +00:00
|
|
|
|
#ifndef _SW_UNDO_TXT_FMT_COLL_HXX
|
|
|
|
|
#include <SwUndoFmt.hxx>
|
|
|
|
|
#endif
|
2000-09-18 23:08:29 +00:00
|
|
|
|
#ifndef _ROLBCK_HXX
|
|
|
|
|
#include <rolbck.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _PARATR_HXX
|
|
|
|
|
#include <paratr.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _DOCARY_HXX
|
|
|
|
|
#include <docary.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _MVSAVE_HXX
|
|
|
|
|
#include <mvsave.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _HINTS_HXX
|
|
|
|
|
#include <hints.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _TXTFRM_HXX
|
|
|
|
|
#include <txtfrm.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _HINTS_HXX
|
|
|
|
|
#include <hints.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _PAMTYP_HXX
|
|
|
|
|
#include <pamtyp.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _REDLINE_HXX
|
|
|
|
|
#include <redline.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _COMCORE_HRC
|
|
|
|
|
#include <comcore.hrc>
|
|
|
|
|
#endif
|
2003-06-10 12:17:20 +00:00
|
|
|
|
#ifndef _SVX_ADJITEM_HXX
|
|
|
|
|
#include <svx/adjitem.hxx>
|
|
|
|
|
#endif
|
2003-09-04 10:46:01 +00:00
|
|
|
|
#ifndef _SVX_FRMDIRITEM_HXX
|
|
|
|
|
#include <svx/frmdiritem.hxx>
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef _FRMATR_HXX
|
|
|
|
|
#include <frmatr.hxx>
|
|
|
|
|
#endif
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
2005-01-25 12:59:21 +00:00
|
|
|
|
#include <map>
|
|
|
|
|
|
|
|
|
|
using std::map;
|
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
inline BYTE GetUpperLvlChg( BYTE nCurLvl, BYTE nLevel, USHORT nMask )
|
|
|
|
|
{
|
|
|
|
|
if( 1 < nLevel )
|
|
|
|
|
{
|
|
|
|
|
if( nCurLvl + 1 >= nLevel )
|
|
|
|
|
nCurLvl -= nLevel - 1;
|
|
|
|
|
else
|
|
|
|
|
nCurLvl = 0;
|
|
|
|
|
}
|
|
|
|
|
return (nMask - 1) & ~(( 1 << nCurLvl ) - 1);
|
|
|
|
|
}
|
|
|
|
|
|
2004-11-26 12:24:12 +00:00
|
|
|
|
SwNumRule * SwDoc::GetOutlineNumRule() const
|
|
|
|
|
{
|
|
|
|
|
SwNumRule * pResult = NULL;
|
|
|
|
|
if (pNumRuleTbl)
|
|
|
|
|
{
|
|
|
|
|
for (ULONG nI = 0; nI < pNumRuleTbl->Count(); nI++)
|
|
|
|
|
if ((*pNumRuleTbl)[nI]->GetName() ==
|
|
|
|
|
String(SwNumRule::GetOutlineRuleName(),
|
|
|
|
|
RTL_TEXTENCODING_ASCII_US))
|
|
|
|
|
{
|
|
|
|
|
pResult = (*pNumRuleTbl)[nI];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return pResult;
|
|
|
|
|
}
|
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
void SwDoc::SetOutlineNumRule( const SwNumRule& rRule )
|
|
|
|
|
{
|
|
|
|
|
USHORT nChkLevel = 0, nChgFmtLevel = 0;
|
2005-02-21 15:15:34 +00:00
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
if( pOutlineRule )
|
|
|
|
|
(*pOutlineRule) = rRule;
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
pOutlineRule = new SwNumRule( rRule );
|
2004-03-30 15:05:30 +00:00
|
|
|
|
|
2004-11-27 10:40:56 +00:00
|
|
|
|
AddNumRule(pOutlineRule); // #i36749#
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
2004-03-30 15:05:30 +00:00
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
pOutlineRule->SetRuleType( OUTLINE_RULE );
|
|
|
|
|
pOutlineRule->SetName( String::CreateFromAscii(
|
|
|
|
|
SwNumRule::GetOutlineRuleName() ));
|
|
|
|
|
|
|
|
|
|
// teste ob die evt. gesetzen CharFormate in diesem Document
|
|
|
|
|
// definiert sind
|
|
|
|
|
pOutlineRule->CheckCharFmts( this );
|
|
|
|
|
|
2005-02-21 15:15:34 +00:00
|
|
|
|
PropagateOutlineRule();
|
|
|
|
|
UpdateNumRule();
|
2000-09-18 23:08:29 +00:00
|
|
|
|
UpdateExpFlds();
|
|
|
|
|
|
|
|
|
|
SetModified();
|
|
|
|
|
}
|
|
|
|
|
|
2004-12-08 16:41:03 +00:00
|
|
|
|
void SwDoc::PropagateOutlineRule()
|
|
|
|
|
{
|
|
|
|
|
for (USHORT n = 0; n < pTxtFmtCollTbl->Count(); n++)
|
|
|
|
|
{
|
|
|
|
|
SwTxtFmtColl *pColl = (*pTxtFmtCollTbl)[n];
|
|
|
|
|
|
|
|
|
|
if (NO_NUMBERING != pColl->GetOutlineLevel())
|
|
|
|
|
{
|
|
|
|
|
SwClientIter aIter(*pColl);
|
|
|
|
|
|
|
|
|
|
const SwClient * pClient = aIter.First(TYPE(SwTxtNode));
|
|
|
|
|
while (pClient)
|
|
|
|
|
{
|
|
|
|
|
SwTxtNode * pTxtNode = ((SwTxtNode *) pClient);
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
2005-03-29 13:37:07 +00:00
|
|
|
|
SwNumRule * pCurNumRule = pTxtNode->GetNumRule();
|
|
|
|
|
|
|
|
|
|
if (pCurNumRule == NULL)
|
|
|
|
|
{
|
|
|
|
|
const SwPaM aPam(*pTxtNode);
|
|
|
|
|
SetNumRule(aPam, *GetOutlineNumRule());
|
2004-12-08 16:41:03 +00:00
|
|
|
|
|
2005-03-29 13:37:07 +00:00
|
|
|
|
pTxtNode->SetLevel(pColl->GetOutlineLevel());
|
|
|
|
|
}
|
2004-12-08 16:41:03 +00:00
|
|
|
|
|
|
|
|
|
pClient = aIter.Next();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
|
|
// Hoch-/Runterstufen
|
|
|
|
|
BOOL SwDoc::OutlineUpDown( const SwPaM& rPam, short nOffset )
|
|
|
|
|
{
|
|
|
|
|
if( !GetNodes().GetOutLineNds().Count() || !nOffset )
|
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
|
|
// den Bereich feststellen
|
|
|
|
|
const SwOutlineNodes& rOutlNds = GetNodes().GetOutLineNds();
|
|
|
|
|
const SwNodePtr pSttNd = (SwNodePtr)&rPam.Start()->nNode.GetNode();
|
|
|
|
|
const SwNodePtr pEndNd = (SwNodePtr)&rPam.End()->nNode.GetNode();
|
|
|
|
|
USHORT nSttPos, nEndPos;
|
|
|
|
|
|
|
|
|
|
if( !rOutlNds.Seek_Entry( pSttNd, &nSttPos ) &&
|
|
|
|
|
!nSttPos-- )
|
|
|
|
|
// wir stehen in keiner "Outline-Section"
|
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
|
|
if( rOutlNds.Seek_Entry( pEndNd, &nEndPos ) )
|
|
|
|
|
++nEndPos;
|
|
|
|
|
|
|
|
|
|
// jetzt haben wir unseren Bereich im OutlineNodes-Array
|
|
|
|
|
// dann prufe ersmal, ob nicht unterebenen aufgehoben werden
|
|
|
|
|
// (Stufung ueber die Grenzen)
|
|
|
|
|
register USHORT n;
|
|
|
|
|
|
|
|
|
|
// so, dann koennen wir:
|
|
|
|
|
// 1. Vorlagen-Array anlegen
|
|
|
|
|
SwTxtFmtColl* aCollArr[ MAXLEVEL ];
|
|
|
|
|
memset( aCollArr, 0, sizeof( SwTxtFmtColl* ) * MAXLEVEL );
|
|
|
|
|
|
|
|
|
|
for( n = 0; n < pTxtFmtCollTbl->Count(); ++n )
|
|
|
|
|
{
|
|
|
|
|
BYTE nLevel = (*pTxtFmtCollTbl)[ n ]->GetOutlineLevel();
|
|
|
|
|
if( nLevel < MAXLEVEL )
|
|
|
|
|
aCollArr[ nLevel ] = (*pTxtFmtCollTbl)[ n ];
|
|
|
|
|
}
|
|
|
|
|
|
2003-09-04 10:46:01 +00:00
|
|
|
|
/* --> #111107# */
|
|
|
|
|
/* Find the last occupied level (backward). */
|
|
|
|
|
for (n = MAXLEVEL - 1; n > 0; n--)
|
|
|
|
|
{
|
|
|
|
|
if (aCollArr[n] != 0)
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* If an occupied level is found, choose next level (which IS
|
|
|
|
|
unoccupied) until a valid level is found. If no occupied level
|
|
|
|
|
was found n is 0 and aCollArr[0] is 0. In this case no demoting
|
|
|
|
|
is possible. */
|
|
|
|
|
if (aCollArr[n] != 0)
|
|
|
|
|
{
|
|
|
|
|
while (n < MAXLEVEL - 1)
|
|
|
|
|
{
|
|
|
|
|
n++;
|
|
|
|
|
|
|
|
|
|
SwTxtFmtColl *aTmpColl =
|
|
|
|
|
GetTxtCollFromPool(RES_POOLCOLL_HEADLINE1 + n);
|
|
|
|
|
|
|
|
|
|
if (aTmpColl->GetOutlineLevel() == n)
|
|
|
|
|
{
|
|
|
|
|
aCollArr[n] = aTmpColl;
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Find the first occupied level (forward). */
|
|
|
|
|
for (n = 0; n < MAXLEVEL - 1; n++)
|
|
|
|
|
{
|
|
|
|
|
if (aCollArr[n] != 0)
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* If an occupied level is found, choose previous level (which IS
|
|
|
|
|
unoccupied) until a valid level is found. If no occupied level
|
|
|
|
|
was found n is MAXLEVEL - 1 and aCollArr[MAXLEVEL - 1] is 0. In
|
|
|
|
|
this case no demoting is possible. */
|
|
|
|
|
if (aCollArr[n] != 0)
|
|
|
|
|
{
|
|
|
|
|
while (n > 0)
|
|
|
|
|
{
|
|
|
|
|
n--;
|
|
|
|
|
|
|
|
|
|
SwTxtFmtColl *aTmpColl =
|
|
|
|
|
GetTxtCollFromPool(RES_POOLCOLL_HEADLINE1 + n);
|
|
|
|
|
|
|
|
|
|
if (aTmpColl->GetOutlineLevel() == n)
|
|
|
|
|
{
|
|
|
|
|
aCollArr[n] = aTmpColl;
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
/* <-- #111107# */
|
|
|
|
|
|
2003-05-16 12:51:26 +00:00
|
|
|
|
/* --> #i13747#
|
|
|
|
|
|
|
|
|
|
Build a move table that states from which level an outline will
|
2003-09-04 10:46:01 +00:00
|
|
|
|
|
|
|
|
|
be moved to which other level. */
|
2003-05-16 12:51:26 +00:00
|
|
|
|
|
|
|
|
|
/* the move table
|
|
|
|
|
|
|
|
|
|
aMoveArr[n] = m: replace aCollArr[n] with aCollArr[m]
|
|
|
|
|
*/
|
|
|
|
|
int aMoveArr[MAXLEVEL];
|
|
|
|
|
int nStep; // step size for searching in aCollArr: -1 or 1
|
|
|
|
|
int nNum; // amount of steps for stepping in aCollArr
|
|
|
|
|
|
|
|
|
|
if (nOffset < 0)
|
|
|
|
|
{
|
|
|
|
|
nStep = -1;
|
|
|
|
|
nNum = -nOffset;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
nStep = 1;
|
|
|
|
|
nNum = nOffset;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* traverse aCollArr */
|
|
|
|
|
for (n = 0; n < MAXLEVEL; n++)
|
|
|
|
|
{
|
|
|
|
|
/* If outline level n has an assigned paragraph style step
|
|
|
|
|
nNum steps forwards (nStep == 1) or backwards (nStep ==
|
|
|
|
|
-1). One step is to go to the next non-null entry in
|
|
|
|
|
aCollArr in the selected direction. If nNum steps were
|
|
|
|
|
possible write the index of the entry found to aCollArr[n],
|
|
|
|
|
i.e. outline level n will be replaced by outline level
|
|
|
|
|
aCollArr[n].
|
|
|
|
|
|
|
|
|
|
If outline level n has no assigned paragraph style
|
|
|
|
|
aMoveArr[n] is set to -1.
|
|
|
|
|
*/
|
|
|
|
|
if (aCollArr[n] != NULL)
|
|
|
|
|
{
|
|
|
|
|
USHORT m = n;
|
|
|
|
|
int nCount = nNum;
|
|
|
|
|
|
|
|
|
|
while (nCount > 0 && m + nStep >= 0 && m + nStep < MAXLEVEL)
|
|
|
|
|
{
|
|
|
|
|
m += nStep;
|
|
|
|
|
|
|
|
|
|
if (aCollArr[m] != NULL)
|
|
|
|
|
nCount--;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (nCount == 0)
|
|
|
|
|
aMoveArr[n] = m;
|
|
|
|
|
else
|
|
|
|
|
aMoveArr[n] = -1;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
aMoveArr[n] = -1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* If moving of the outline levels is applicable, i.e. for all
|
|
|
|
|
outline levels occuring in the document there has to be a valid
|
|
|
|
|
target outline level implied by aMoveArr. */
|
|
|
|
|
bool bMoveApplicable = true;
|
|
|
|
|
for (n = nSttPos; n < nEndPos; n++)
|
|
|
|
|
{
|
|
|
|
|
SwTxtNode* pTxtNd = rOutlNds[ n ]->GetTxtNode();
|
|
|
|
|
SwTxtFmtColl* pColl = pTxtNd->GetTxtColl();
|
|
|
|
|
int nLevel = pColl->GetOutlineLevel();
|
|
|
|
|
|
|
|
|
|
if (aMoveArr[nLevel] == -1)
|
|
|
|
|
bMoveApplicable = false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (! bMoveApplicable )
|
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
|
|
/* <-- #i13747 # */
|
2000-09-18 23:08:29 +00:00
|
|
|
|
if( DoesUndo() )
|
|
|
|
|
{
|
|
|
|
|
ClearRedo();
|
2004-09-08 14:17:53 +00:00
|
|
|
|
StartUndo(UNDO_OUTLINE_LR);
|
2000-09-18 23:08:29 +00:00
|
|
|
|
AppendUndo( new SwUndoOutlineLeftRight( rPam, nOffset ) );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 2. allen Nodes die neue Vorlage zuweisen
|
2003-05-16 12:51:26 +00:00
|
|
|
|
|
|
|
|
|
n = nSttPos;
|
|
|
|
|
while( n < nEndPos)
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
|
|
|
|
SwTxtNode* pTxtNd = rOutlNds[ n ]->GetTxtNode();
|
|
|
|
|
SwTxtFmtColl* pColl = pTxtNd->GetTxtColl();
|
2003-05-16 12:51:26 +00:00
|
|
|
|
|
|
|
|
|
ASSERT(pColl->GetOutlineLevel() < MAXLEVEL,
|
|
|
|
|
"non outline node in outline nodes?");
|
|
|
|
|
|
|
|
|
|
int nLevel = pColl->GetOutlineLevel();
|
|
|
|
|
|
|
|
|
|
ASSERT(aMoveArr[nLevel] >= 0,
|
|
|
|
|
"move table: current TxtColl not found when building table!");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (nLevel < MAXLEVEL && aMoveArr[nLevel] >= 0)
|
|
|
|
|
{
|
|
|
|
|
pColl = aCollArr[ aMoveArr[nLevel] ];
|
|
|
|
|
|
|
|
|
|
if (pColl != NULL)
|
|
|
|
|
pColl = (SwTxtFmtColl*)pTxtNd->ChgFmtColl( pColl );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
n++;
|
2000-09-18 23:08:29 +00:00
|
|
|
|
// Undo ???
|
|
|
|
|
}
|
2004-09-08 14:17:53 +00:00
|
|
|
|
if (DoesUndo())
|
|
|
|
|
EndUndo(UNDO_OUTLINE_LR);
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
|
|
SetModified();
|
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Hoch-/Runter - Verschieben !
|
|
|
|
|
BOOL SwDoc::MoveOutlinePara( const SwPaM& rPam, short nOffset )
|
|
|
|
|
{
|
|
|
|
|
// kein Verschiebung in den Sonderbereichen
|
|
|
|
|
const SwPosition& rStt = *rPam.Start(),
|
|
|
|
|
& rEnd = &rStt == rPam.GetPoint() ? *rPam.GetMark()
|
|
|
|
|
: *rPam.GetPoint();
|
|
|
|
|
if( !GetNodes().GetOutLineNds().Count() || !nOffset ||
|
|
|
|
|
rStt.nNode.GetIndex() < aNodes.GetEndOfExtras().GetIndex() ||
|
|
|
|
|
rEnd.nNode.GetIndex() < aNodes.GetEndOfExtras().GetIndex() )
|
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
|
|
USHORT nAktPos = 0;
|
|
|
|
|
SwNodeIndex aSttRg( rStt.nNode ), aEndRg( rEnd.nNode );
|
|
|
|
|
|
|
|
|
|
// nach vorne -> vom Start erfragen
|
|
|
|
|
// nach hinten -> vom End erfragen
|
|
|
|
|
if( 0 > nOffset ) // nach vorne
|
|
|
|
|
{
|
|
|
|
|
SwNode* pSrch = &aSttRg.GetNode();
|
|
|
|
|
if( !GetNodes().GetOutLineNds().Seek_Entry( pSrch, &nAktPos ) )
|
|
|
|
|
{
|
|
|
|
|
if( !nAktPos-- )
|
|
|
|
|
// wir stehen in keiner "Outline-Section"
|
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
|
|
// dann sollten wir den Start korrigieren !!!
|
|
|
|
|
aSttRg = *GetNodes().GetOutLineNds()[ nAktPos ];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
pSrch = &aEndRg.GetNode();
|
|
|
|
|
USHORT nTmp;
|
|
|
|
|
if( GetNodes().GetOutLineNds().Seek_Entry( pSrch, &nTmp ))
|
|
|
|
|
// wenn die Selection in einem OutlineNode endet, diesen noch
|
|
|
|
|
// mitnehmen
|
|
|
|
|
aEndRg++;
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
aEndRg = nTmp < GetNodes().GetOutLineNds().Count()
|
|
|
|
|
? *GetNodes().GetOutLineNds()[ nTmp ]
|
|
|
|
|
: GetNodes().GetEndOfContent();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if( aEndRg == aSttRg )
|
|
|
|
|
// kein Bereich, dann machen wir uns einen
|
|
|
|
|
aEndRg++;
|
|
|
|
|
}
|
|
|
|
|
// nach hinten
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
SwNode* pSrch = &aEndRg.GetNode();
|
|
|
|
|
if( GetNodes().GetOutLineNds().Seek_Entry( pSrch, &nAktPos ) )
|
|
|
|
|
++nAktPos;
|
|
|
|
|
|
|
|
|
|
aEndRg = nAktPos < GetNodes().GetOutLineNds().Count()
|
|
|
|
|
? *GetNodes().GetOutLineNds()[ nAktPos ]
|
|
|
|
|
: GetNodes().GetEndOfContent();
|
|
|
|
|
|
|
|
|
|
pSrch = &aSttRg.GetNode();
|
|
|
|
|
USHORT nTmp;
|
|
|
|
|
if( !GetNodes().GetOutLineNds().Seek_Entry( pSrch, &nTmp ) )
|
|
|
|
|
{
|
|
|
|
|
if( --nTmp )
|
|
|
|
|
aSttRg = *GetNodes().GetOutLineNds()[ nTmp ];
|
|
|
|
|
else
|
|
|
|
|
aSttRg = *GetNodes().GetEndOfContent().StartOfSectionNode();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
// neue Position errechnen:
|
|
|
|
|
const SwNode* pNd;
|
|
|
|
|
if( nOffset < 0 && nAktPos < USHORT(-nOffset) )
|
|
|
|
|
pNd = GetNodes().GetEndOfContent().StartOfSectionNode();
|
|
|
|
|
else if( nAktPos + nOffset >= GetNodes().GetOutLineNds().Count() )
|
|
|
|
|
pNd = &GetNodes().GetEndOfContent();
|
|
|
|
|
else
|
|
|
|
|
pNd = GetNodes().GetOutLineNds()[ nAktPos + nOffset ];
|
|
|
|
|
|
|
|
|
|
ULONG nNewPos = pNd->GetIndex();
|
|
|
|
|
|
|
|
|
|
ASSERT( aSttRg.GetIndex() > nNewPos || nNewPos >= aEndRg.GetIndex(),
|
|
|
|
|
"Position liegt im MoveBereich" );
|
|
|
|
|
|
|
|
|
|
// wurde ein Position in den Sonderbereichen errechnet, dann
|
|
|
|
|
// setze die Position auf den Dokumentanfang.
|
|
|
|
|
// Sollten da Bereiche oder Tabellen stehen, so werden sie nach
|
|
|
|
|
// hinten verschoben.
|
|
|
|
|
nNewPos = Max( nNewPos, aNodes.GetEndOfExtras().GetIndex() + 2 );
|
|
|
|
|
|
|
|
|
|
long nOffs = nNewPos - ( 0 < nOffset ? aEndRg.GetIndex() : aSttRg.GetIndex());
|
|
|
|
|
SwPaM aPam( aSttRg, aEndRg, 0, -1 );
|
|
|
|
|
return MoveParagraph( aPam, nOffs, TRUE );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
USHORT lcl_FindOutlineName( const SwNodes& rNds, const String& rName,
|
|
|
|
|
BOOL bExact )
|
|
|
|
|
{
|
|
|
|
|
USHORT nSavePos = USHRT_MAX;
|
|
|
|
|
const SwOutlineNodes& rOutlNds = rNds.GetOutLineNds();
|
|
|
|
|
for( USHORT n = 0; n < rOutlNds.Count(); ++n )
|
|
|
|
|
{
|
|
|
|
|
SwTxtNode* pTxtNd = rOutlNds[ n ]->GetTxtNode();
|
2001-11-27 12:24:29 +00:00
|
|
|
|
String sTxt( pTxtNd->GetExpandTxt() );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
if( sTxt.Equals( rName ) )
|
|
|
|
|
{
|
|
|
|
|
// "exact" gefunden, setze Pos auf den Node
|
|
|
|
|
nSavePos = n;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
else if( !bExact && USHRT_MAX == nSavePos &&
|
|
|
|
|
COMPARE_EQUAL == sTxt.CompareTo( rName, rName.Len()) )
|
|
|
|
|
{
|
|
|
|
|
// dann vielleicht nur den den 1.Teil vom Text gefunden
|
|
|
|
|
nSavePos = n;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return nSavePos;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
USHORT lcl_FindOutlineNum( const SwNodes& rNds, String& rName )
|
|
|
|
|
{
|
|
|
|
|
// Gueltig Nummern sind (immer nur Offsets!!!):
|
|
|
|
|
// ([Nummer]+\.)+ (als regulaerer Ausdruck!)
|
|
|
|
|
// (Nummer gefolgt von Punkt, zum 5 Wiederholungen)
|
|
|
|
|
// also: "1.1.", "1.", "1.1.1."
|
|
|
|
|
xub_StrLen nPos = 0;
|
|
|
|
|
String sNum = rName.GetToken( 0, '.', nPos );
|
|
|
|
|
if( STRING_NOTFOUND == nPos )
|
|
|
|
|
return USHRT_MAX; // ungueltige Nummer!!!
|
|
|
|
|
|
|
|
|
|
USHORT nLevelVal[ MAXLEVEL ]; // Nummern aller Levels
|
|
|
|
|
memset( nLevelVal, 0, MAXLEVEL * sizeof( nLevelVal[0] ));
|
|
|
|
|
BYTE nLevel = 0;
|
|
|
|
|
String sName( rName );
|
|
|
|
|
|
|
|
|
|
while( STRING_NOTFOUND != nPos )
|
|
|
|
|
{
|
|
|
|
|
USHORT nVal = 0;
|
|
|
|
|
sal_Unicode c;
|
|
|
|
|
for( USHORT n = 0; n < sNum.Len(); ++n )
|
|
|
|
|
if( '0' <= ( c = sNum.GetChar( n )) && c <= '9' )
|
|
|
|
|
{
|
|
|
|
|
nVal *= 10; nVal += c - '0';
|
|
|
|
|
}
|
|
|
|
|
else if( nLevel )
|
|
|
|
|
break; // "fast" gueltige Nummer
|
|
|
|
|
else
|
|
|
|
|
return USHRT_MAX; // ungueltige Nummer!!!
|
|
|
|
|
|
|
|
|
|
if( MAXLEVEL > nLevel )
|
|
|
|
|
nLevelVal[ nLevel++ ] = nVal;
|
|
|
|
|
|
|
|
|
|
sName.Erase( 0, nPos );
|
|
|
|
|
nPos = 0;
|
|
|
|
|
sNum = sName.GetToken( 0, '.', nPos );
|
2003-03-27 14:45:43 +00:00
|
|
|
|
// #i4533# without this check all parts delimited by a dot are treated as outline numbers
|
|
|
|
|
if(!ByteString(sNum, gsl_getSystemTextEncoding()).IsNumericAscii())
|
|
|
|
|
nPos = STRING_NOTFOUND;
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
|
|
|
|
rName = sName; // das ist der nachfolgende Text.
|
|
|
|
|
|
|
|
|
|
// alle Levels gelesen, dann suche mal im Document nach dieser
|
|
|
|
|
// Gliederung:
|
|
|
|
|
const SwOutlineNodes& rOutlNds = rNds.GetOutLineNds();
|
|
|
|
|
// OS: ohne OutlineNodes lohnt die Suche nicht
|
|
|
|
|
// und man spart sich einen Absturz #42958#
|
|
|
|
|
if(!rOutlNds.Count())
|
|
|
|
|
return USHRT_MAX;
|
|
|
|
|
SwTxtNode* pNd;
|
|
|
|
|
nPos = 0;
|
2004-06-28 11:58:35 +00:00
|
|
|
|
//search in the existing outline nodes for the required outline num array
|
|
|
|
|
for( ; nPos < rOutlNds.Count(); ++nPos )
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-06-28 11:58:35 +00:00
|
|
|
|
pNd = rOutlNds[ nPos ]->GetTxtNode();
|
|
|
|
|
BYTE nLvl = pNd->GetTxtColl()->GetOutlineLevel();
|
|
|
|
|
if( nLvl == nLevel - 1 && 0 != pNd->GetNum())
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-06-28 11:58:35 +00:00
|
|
|
|
// check for the outline num
|
|
|
|
|
const SwNodeNum* pNdNum = pNd->GetNum() ;
|
|
|
|
|
const USHORT* pLevelVal = pNdNum->GetLevelVal();
|
|
|
|
|
//now compare with the one searched for
|
|
|
|
|
bool bEqual = true;
|
|
|
|
|
for( BYTE n = 0; (n < nLevel) && bEqual; ++n )
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-06-28 11:58:35 +00:00
|
|
|
|
bEqual = pLevelVal[n] == nLevelVal[n];
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
2004-06-28 11:58:35 +00:00
|
|
|
|
if(bEqual)
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-06-28 11:58:35 +00:00
|
|
|
|
break;
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2004-06-28 11:58:35 +00:00
|
|
|
|
if( nPos >= rOutlNds.Count() )
|
|
|
|
|
nPos = USHRT_MAX;
|
2000-09-18 23:08:29 +00:00
|
|
|
|
return nPos;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// zu diesem Gliederungspunkt
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// JP 13.06.96:
|
|
|
|
|
// im Namen kann eine Nummer oder/und der Text stehen.
|
|
|
|
|
// zuerst wird ueber die Nummer versucht den richtigen Eintrag zu finden.
|
|
|
|
|
// Gibt es diesen, dann wird ueber den Text verglichen, od es der
|
|
|
|
|
// gewuenschte ist. Ist das nicht der Fall, wird noch mal nur ueber den
|
|
|
|
|
// Text gesucht. Wird dieser gefunden ist es der Eintrag. Ansonsten der,
|
|
|
|
|
// der ueber die Nummer gefunden wurde.
|
|
|
|
|
// Ist keine Nummer angegeben, dann nur den Text suchen.
|
|
|
|
|
|
|
|
|
|
BOOL SwDoc::GotoOutline( SwPosition& rPos, const String& rName ) const
|
|
|
|
|
{
|
|
|
|
|
if( rName.Len() )
|
|
|
|
|
{
|
|
|
|
|
const SwOutlineNodes& rOutlNds = GetNodes().GetOutLineNds();
|
|
|
|
|
|
|
|
|
|
// 1. Schritt: ueber die Nummer:
|
|
|
|
|
String sName( rName );
|
|
|
|
|
USHORT nFndPos = ::lcl_FindOutlineNum( GetNodes(), sName );
|
|
|
|
|
if( USHRT_MAX != nFndPos )
|
|
|
|
|
{
|
|
|
|
|
SwTxtNode* pNd = rOutlNds[ nFndPos ]->GetTxtNode();
|
2003-03-27 14:45:43 +00:00
|
|
|
|
String sExpandedText = pNd->GetExpandTxt();
|
|
|
|
|
//#i4533# leading numbers followed by a dot have been remove while
|
|
|
|
|
//searching for the outline position
|
|
|
|
|
//to compensate this they must be removed from the paragraphs text content, too
|
|
|
|
|
USHORT nPos = 0;
|
|
|
|
|
String sTempNum;
|
|
|
|
|
while(sExpandedText.Len() && (sTempNum = sExpandedText.GetToken(0, '.', nPos)).Len() &&
|
|
|
|
|
STRING_NOTFOUND != nPos &&
|
|
|
|
|
ByteString(sTempNum, gsl_getSystemTextEncoding()).IsNumericAscii())
|
|
|
|
|
{
|
|
|
|
|
sExpandedText.Erase(0, nPos);
|
|
|
|
|
nPos = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if( !sExpandedText.Equals( sName ) )
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
|
|
|
|
USHORT nTmp = ::lcl_FindOutlineName( GetNodes(), sName, TRUE );
|
|
|
|
|
if( USHRT_MAX != nTmp ) // ueber den Namen gefunden
|
|
|
|
|
{
|
|
|
|
|
nFndPos = nTmp;
|
|
|
|
|
pNd = rOutlNds[ nFndPos ]->GetTxtNode();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
rPos.nNode = *pNd;
|
|
|
|
|
rPos.nContent.Assign( pNd, 0 );
|
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
nFndPos = ::lcl_FindOutlineName( GetNodes(), rName, FALSE );
|
|
|
|
|
if( USHRT_MAX != nFndPos )
|
|
|
|
|
{
|
|
|
|
|
SwTxtNode* pNd = rOutlNds[ nFndPos ]->GetTxtNode();
|
|
|
|
|
rPos.nNode = *pNd;
|
|
|
|
|
rPos.nContent.Assign( pNd, 0 );
|
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void SwDoc::SetOutlineLSpace( BYTE nLevel, short nFirstLnOfst, USHORT nLSpace )
|
|
|
|
|
{
|
|
|
|
|
if( MAXLEVEL >= nLevel )
|
|
|
|
|
{
|
|
|
|
|
const SwNumFmt& rNFmt = pOutlineRule->Get( nLevel );
|
|
|
|
|
if( nLSpace != rNFmt.GetAbsLSpace() ||
|
|
|
|
|
nFirstLnOfst != rNFmt.GetFirstLineOffset() )
|
|
|
|
|
{
|
|
|
|
|
SwNumFmt aFmt( rNFmt );
|
|
|
|
|
aFmt.SetAbsLSpace( nLSpace );
|
|
|
|
|
aFmt.SetFirstLineOffset( nFirstLnOfst );
|
|
|
|
|
pOutlineRule->Set( nLevel, aFmt );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* */
|
|
|
|
|
|
|
|
|
|
// --- Nummerierung -----------------------------------------
|
|
|
|
|
|
2004-03-08 11:24:21 +00:00
|
|
|
|
void SwNumRuleInfo::MakeList( SwDoc& rDoc, BOOL bOutline )
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-11-16 14:39:29 +00:00
|
|
|
|
SwNumRule* pRule = rDoc.FindNumRulePtr(rName);
|
2004-10-22 07:11:47 +00:00
|
|
|
|
|
2004-11-16 14:39:29 +00:00
|
|
|
|
// no rule, no fun.
|
|
|
|
|
if ( !pRule )
|
|
|
|
|
return;
|
2004-10-22 07:11:47 +00:00
|
|
|
|
|
2004-11-16 14:39:29 +00:00
|
|
|
|
//
|
|
|
|
|
// 1. Case: Information already available at pRule:
|
|
|
|
|
//
|
|
|
|
|
if (pRule->GetList())
|
2004-10-22 07:11:47 +00:00
|
|
|
|
{
|
2004-11-16 14:39:29 +00:00
|
|
|
|
// copy list to own pList pointer:
|
|
|
|
|
aList = *pRule->GetList();
|
2004-10-22 07:11:47 +00:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2004-11-16 14:39:29 +00:00
|
|
|
|
//
|
|
|
|
|
// 2. Case: Information has to be generated from scratch:
|
|
|
|
|
//
|
2004-10-22 07:11:47 +00:00
|
|
|
|
|
2004-03-08 11:24:21 +00:00
|
|
|
|
// -> #111955#
|
|
|
|
|
if (bOutline)
|
|
|
|
|
{
|
|
|
|
|
const SwOutlineNodes & rOutlineNodes = rDoc.GetNodes().GetOutLineNds();
|
|
|
|
|
|
|
|
|
|
for (int i = 0; i < rOutlineNodes.Count(); i++)
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-03-08 11:24:21 +00:00
|
|
|
|
SwTxtNode & aNode = *((SwTxtNode *) rOutlineNodes[i]);
|
|
|
|
|
|
2004-03-30 15:05:30 +00:00
|
|
|
|
AddNode(aNode);
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
2004-03-08 11:24:21 +00:00
|
|
|
|
}
|
|
|
|
|
// <- #111955#
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
SwModify* pMod;
|
|
|
|
|
const SfxPoolItem* pItem;
|
|
|
|
|
USHORT i, nMaxItems = rDoc.GetAttrPool().GetItemCount
|
|
|
|
|
( RES_PARATR_NUMRULE);
|
|
|
|
|
for( i = 0; i < nMaxItems; ++i )
|
|
|
|
|
{
|
|
|
|
|
pItem = rDoc.GetAttrPool().GetItem( RES_PARATR_NUMRULE, i );
|
|
|
|
|
if( 0 != pItem)
|
|
|
|
|
{
|
|
|
|
|
pMod = (SwModify*)((SwNumRuleItem*)pItem)->GetDefinedIn();
|
|
|
|
|
if (0 != pMod &&
|
|
|
|
|
((SwNumRuleItem*)pItem)->GetValue().Len() &&
|
|
|
|
|
((SwNumRuleItem*)pItem)->GetValue() == rName )
|
|
|
|
|
{
|
|
|
|
|
if( pMod->IsA( TYPE( SwFmt )) )
|
|
|
|
|
pMod->GetInfo( *this );
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
SwTxtNode* pModTxtNode = (SwTxtNode*)pMod;
|
2004-03-30 15:05:30 +00:00
|
|
|
|
|
|
|
|
|
// #115901#
|
|
|
|
|
if( pModTxtNode->GetNodes().IsDocNodes())
|
|
|
|
|
{
|
2004-03-08 11:24:21 +00:00
|
|
|
|
AddNode( *pModTxtNode );
|
2004-03-30 15:05:30 +00:00
|
|
|
|
}
|
2004-03-08 11:24:21 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2004-10-22 07:11:47 +00:00
|
|
|
|
|
2004-11-16 14:39:29 +00:00
|
|
|
|
// --> FME 2004-11-03 #i36571# The numrule and this info structure should
|
|
|
|
|
// have different instances of the list:
|
|
|
|
|
SwTxtNodeTable* pNewList = new SwTxtNodeTable( aList );
|
|
|
|
|
pRule->SetList(pNewList);
|
|
|
|
|
// <--
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void lcl_ChgNumRule( SwDoc& rDoc, const SwNumRule& rRule, SwHistory* pHist,
|
|
|
|
|
SwNumRuleInfo* pRuleInfo = 0 )
|
|
|
|
|
{
|
|
|
|
|
SwNumRule* pOld = rDoc.FindNumRulePtr( rRule.GetName() );
|
|
|
|
|
ASSERT( pOld, "ohne die alte NumRule geht gar nichts" );
|
|
|
|
|
|
|
|
|
|
USHORT nChkLevel = 0, nChgFmtLevel = 0, nMask = 1;
|
2003-12-01 15:34:51 +00:00
|
|
|
|
BYTE n;
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
2003-12-01 15:34:51 +00:00
|
|
|
|
for( n = 0; n < MAXLEVEL; ++n, nMask <<= 1 )
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
|
|
|
|
const SwNumFmt& rOldFmt = pOld->Get( n ),
|
|
|
|
|
& rNewFmt = rRule.Get( n );
|
|
|
|
|
|
|
|
|
|
if( rOldFmt != rNewFmt )
|
|
|
|
|
{
|
|
|
|
|
nChgFmtLevel |= nMask;
|
|
|
|
|
if( rOldFmt.GetAbsLSpace() != rNewFmt.GetAbsLSpace() ||
|
|
|
|
|
rOldFmt.GetFirstLineOffset() != rNewFmt.GetFirstLineOffset() )
|
|
|
|
|
nChkLevel |= nMask;
|
|
|
|
|
}
|
2001-02-23 11:45:30 +00:00
|
|
|
|
else if( SVX_NUM_NUMBER_NONE > rNewFmt.GetNumberingType() && 1 < rNewFmt.GetIncludeUpperLevels() &&
|
|
|
|
|
0 != (nChgFmtLevel & GetUpperLvlChg( n, rNewFmt.GetIncludeUpperLevels(),nMask )) )
|
2000-09-18 23:08:29 +00:00
|
|
|
|
nChgFmtLevel |= nMask;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if( !nChgFmtLevel ) // es wurde nichts veraendert?
|
|
|
|
|
{
|
|
|
|
|
pOld->CheckCharFmts( &rDoc );
|
|
|
|
|
pOld->SetContinusNum( rRule.IsContinusNum() );
|
2005-02-22 09:02:43 +00:00
|
|
|
|
pOld->SetRuleType( rRule.GetRuleType() );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
return ;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SwNumRuleInfo* pUpd;
|
|
|
|
|
if( !pRuleInfo )
|
|
|
|
|
{
|
|
|
|
|
pUpd = new SwNumRuleInfo( rRule.GetName() );
|
|
|
|
|
pUpd->MakeList( rDoc );
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
pUpd = pRuleInfo;
|
|
|
|
|
|
|
|
|
|
BYTE nLvl;
|
|
|
|
|
for( ULONG nFirst = 0, nLast = pUpd->GetList().Count();
|
|
|
|
|
nFirst < nLast; ++nFirst )
|
|
|
|
|
{
|
|
|
|
|
SwTxtNode* pTxtNd = pUpd->GetList().GetObject( nFirst );
|
2004-03-08 11:24:21 +00:00
|
|
|
|
if( pTxtNd->GetNum() &&
|
|
|
|
|
( nLvl = (pTxtNd->GetNum()->GetRealLevel()) ) < MAXLEVEL )
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
|
|
|
|
if( nChgFmtLevel & ( 1 << nLvl ))
|
|
|
|
|
{
|
|
|
|
|
pTxtNd->NumRuleChgd();
|
|
|
|
|
|
|
|
|
|
#ifndef NUM_RELSPACE
|
|
|
|
|
if( nChkLevel && (nChkLevel & ( 1 << nLvl )) &&
|
|
|
|
|
pOld->IsRuleLSpace( *pTxtNd ) )
|
|
|
|
|
pTxtNd->SetNumLSpace( TRUE );
|
|
|
|
|
|
|
|
|
|
if( pHist )
|
|
|
|
|
{
|
|
|
|
|
const SfxPoolItem& rItem =
|
|
|
|
|
pTxtNd->SwCntntNode::GetAttr( RES_LR_SPACE );
|
|
|
|
|
pHist->Add( &rItem, &rItem, pTxtNd->GetIndex() );
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for( n = 0; n < MAXLEVEL; ++n )
|
|
|
|
|
if( nChgFmtLevel & ( 1 << n ))
|
|
|
|
|
pOld->Set( n, rRule.GetNumFmt( n ));
|
|
|
|
|
|
|
|
|
|
pOld->CheckCharFmts( &rDoc );
|
|
|
|
|
pOld->SetInvalidRule( TRUE );
|
|
|
|
|
pOld->SetContinusNum( rRule.IsContinusNum() );
|
2005-02-22 09:02:43 +00:00
|
|
|
|
pOld->SetRuleType( rRule.GetRuleType() );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
|
|
if( !pRuleInfo )
|
|
|
|
|
delete pUpd;
|
|
|
|
|
}
|
|
|
|
|
|
2005-03-08 10:21:10 +00:00
|
|
|
|
// --> OD 2005-02-18 #i42921# - re-use unused 3rd parameter - it replaces local
|
|
|
|
|
// variable <bSetItem>
|
2000-09-18 23:08:29 +00:00
|
|
|
|
void SwDoc::SetNumRule( const SwPaM& rPam, const SwNumRule& rRule,
|
2005-03-08 10:21:10 +00:00
|
|
|
|
sal_Bool bSetItem )
|
|
|
|
|
// <--
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
|
|
|
|
SwUndoInsNum* pUndo;
|
|
|
|
|
if( DoesUndo() )
|
|
|
|
|
{
|
|
|
|
|
ClearRedo();
|
2004-09-08 14:17:53 +00:00
|
|
|
|
StartUndo( UNDO_INSNUM ); // Klammerung fuer die Attribute!
|
2000-09-18 23:08:29 +00:00
|
|
|
|
AppendUndo( pUndo = new SwUndoInsNum( rPam, rRule ) );
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
pUndo = 0;
|
|
|
|
|
|
|
|
|
|
ULONG nPamPos = rPam.Start()->nNode.GetIndex();
|
|
|
|
|
SwNumRule* pNew = FindNumRulePtr( rRule.GetName() );
|
2003-06-10 12:17:20 +00:00
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
if( !pNew )
|
2003-06-10 12:17:20 +00:00
|
|
|
|
{
|
2000-09-18 23:08:29 +00:00
|
|
|
|
pNew = (*pNumRuleTbl)[ MakeNumRule( rRule.GetName(), &rRule ) ];
|
2003-06-10 12:17:20 +00:00
|
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
|
else if( rRule.IsAutoRule() && !(*pNew == rRule) )
|
|
|
|
|
{
|
|
|
|
|
// die Rule existiert schon, wurde aber veraendert. Dann muss hier
|
|
|
|
|
// entschieden werden, in wie weit eine neue erzeugt wird oder
|
|
|
|
|
// die aktuelle geupdatet wird.
|
|
|
|
|
|
|
|
|
|
// neue erzeugen wenn:
|
|
|
|
|
// - der Pam einen Bereich hat
|
|
|
|
|
// - Nodes existieren, die mit der Rule neu Starten
|
|
|
|
|
|
|
|
|
|
if( rPam.HasMark() )
|
|
|
|
|
pNew = (*pNumRuleTbl)[ MakeNumRule( rRule.GetName(), &rRule ) ];
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
SwNumRuleInfo aUpd( rRule.GetName() );
|
|
|
|
|
aUpd.MakeList( *this );
|
|
|
|
|
|
|
|
|
|
// Position suchen und bestimme ob ein Node davor oder dahinter
|
|
|
|
|
// einen Start erzwingt
|
|
|
|
|
SwTxtNode* pTxtNd;
|
|
|
|
|
ULONG nFndPos, nFirst, nLast;
|
|
|
|
|
|
|
|
|
|
if( TABLE_ENTRY_NOTFOUND != aUpd.GetList().SearchKey( nPamPos, &nFndPos ))
|
|
|
|
|
++nFndPos;
|
|
|
|
|
|
|
|
|
|
for( nLast = nFndPos; nLast < aUpd.GetList().Count(); ++nLast )
|
|
|
|
|
if( ( pTxtNd = aUpd.GetList().GetObject( nLast ))->GetNum() &&
|
|
|
|
|
pTxtNd->GetNum()->IsStart() )
|
|
|
|
|
break;
|
|
|
|
|
for( nFirst = nFndPos; nFirst; )
|
|
|
|
|
if( ( pTxtNd = aUpd.GetList().GetObject( --nFirst ))->GetNum() &&
|
|
|
|
|
pTxtNd->GetNum()->IsStart() )
|
|
|
|
|
break;
|
|
|
|
|
|
2005-03-08 10:21:10 +00:00
|
|
|
|
bSetItem = sal_False;
|
2000-09-18 23:08:29 +00:00
|
|
|
|
nPamPos = ULONG_MAX;
|
|
|
|
|
if( !pNew->IsAutoRule() || nFirst || nLast != aUpd.GetList().Count() )
|
|
|
|
|
{
|
|
|
|
|
// dann neue Numerierung ueber diesen Bereich
|
|
|
|
|
// definieren und den Start am Anfang/Ende zurueck setzen
|
|
|
|
|
pTxtNd = aUpd.GetList().GetObject( nFirst );
|
|
|
|
|
if( pTxtNd->GetNum()->IsStart() )
|
|
|
|
|
{
|
|
|
|
|
((SwNodeNum*)pTxtNd->GetNum())->SetStart( FALSE );
|
|
|
|
|
if( pUndo )
|
|
|
|
|
pUndo->SetSttNum( pTxtNd->GetIndex() );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SwHistory* pHist = pUndo ? pUndo->GetHistory() : 0;
|
|
|
|
|
#ifndef NUM_RELSPACE
|
|
|
|
|
if( pHist )
|
|
|
|
|
{
|
|
|
|
|
// die LRSpaces muessen zuerst gesichert werden
|
|
|
|
|
for( ULONG n = nFirst; n < nLast; ++n )
|
|
|
|
|
{
|
|
|
|
|
pTxtNd = aUpd.GetList().GetObject( n );
|
|
|
|
|
SfxPoolItem* pItem = (SfxPoolItem*)
|
|
|
|
|
&pTxtNd->SwCntntNode::GetAttr( RES_LR_SPACE );
|
|
|
|
|
pHist->Add( pItem, pItem, pTxtNd->GetIndex() );
|
|
|
|
|
}
|
|
|
|
|
pUndo->SetLRSpaceEndPos();
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
SwRegHistory aRegH( pHist );
|
|
|
|
|
SwNumRule* pOld = pNew;
|
|
|
|
|
pNew = (*pNumRuleTbl)[ MakeNumRule( rRule.GetName(), &rRule ) ];
|
|
|
|
|
|
|
|
|
|
USHORT nChgFmtLevel = 0;
|
|
|
|
|
for( BYTE n = 0; n < MAXLEVEL; ++n )
|
|
|
|
|
{
|
|
|
|
|
const SwNumFmt& rOldFmt = pOld->Get( n ),
|
|
|
|
|
& rNewFmt = rRule.Get( n );
|
|
|
|
|
|
|
|
|
|
if( rOldFmt.GetAbsLSpace() != rNewFmt.GetAbsLSpace() ||
|
|
|
|
|
rOldFmt.GetFirstLineOffset() != rNewFmt.GetFirstLineOffset() )
|
|
|
|
|
nChgFmtLevel |= ( 1 << n );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SwNumRuleItem aRule( pNew->GetName() );
|
|
|
|
|
for( ; nFirst < nLast; ++nFirst )
|
|
|
|
|
{
|
|
|
|
|
pTxtNd = aUpd.GetList().GetObject( nFirst );
|
|
|
|
|
|
|
|
|
|
aRegH.RegisterInModify( pTxtNd, *pTxtNd );
|
|
|
|
|
|
|
|
|
|
#ifndef NUM_RELSPACE
|
|
|
|
|
BYTE nLvl = !pTxtNd->GetNum() ? NO_NUMBERING
|
2004-03-08 11:24:21 +00:00
|
|
|
|
: pTxtNd->GetNum()->GetRealLevel();
|
2000-09-18 23:08:29 +00:00
|
|
|
|
if( nLvl < MAXLEVEL && (nChgFmtLevel & ( 1 << nLvl )) &&
|
|
|
|
|
pOld->IsRuleLSpace( *pTxtNd ) )
|
|
|
|
|
pTxtNd->SetNumLSpace( TRUE );
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
pTxtNd->SwCntntNode::SetAttr( aRule );
|
|
|
|
|
pTxtNd->NumRuleChgd();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// dann nur die Rule Updaten
|
|
|
|
|
SwHistory* pHist = 0;
|
|
|
|
|
if( pUndo )
|
|
|
|
|
{
|
|
|
|
|
pUndo->SaveOldNumRule( *pNew );
|
|
|
|
|
pHist = pUndo->GetHistory();
|
|
|
|
|
}
|
|
|
|
|
::lcl_ChgNumRule( *this, rRule, pHist, &aUpd );
|
|
|
|
|
if( pUndo )
|
|
|
|
|
pUndo->SetLRSpaceEndPos();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2004-11-26 12:24:12 +00:00
|
|
|
|
else if( rRule != *pNew )
|
|
|
|
|
{
|
|
|
|
|
if( pUndo )
|
|
|
|
|
{
|
|
|
|
|
pUndo->SaveOldNumRule( *pNew );
|
|
|
|
|
::lcl_ChgNumRule( *this, rRule, pUndo->GetHistory() );
|
|
|
|
|
pUndo->SetLRSpaceEndPos();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
::lcl_ChgNumRule( *this, rRule, NULL );
|
|
|
|
|
}
|
|
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
|
|
if( bSetItem )
|
|
|
|
|
{
|
|
|
|
|
#ifndef NUM_RELSPACE
|
|
|
|
|
if( pUndo )
|
|
|
|
|
{
|
|
|
|
|
SwHistory* pHist = pUndo->GetHistory();
|
|
|
|
|
SwCntntNode* pCNd;
|
|
|
|
|
for( ULONG n = nPamPos, nEndPos = rPam.End()->nNode.GetIndex();
|
|
|
|
|
n <= nEndPos; ++n )
|
|
|
|
|
if( 0 != ( pCNd = GetNodes()[ n ]->GetCntntNode() ))
|
|
|
|
|
{
|
|
|
|
|
const SfxPoolItem& rItem = pCNd->GetAttr( RES_LR_SPACE );
|
|
|
|
|
pHist->Add( &rItem, &rItem, n );
|
|
|
|
|
}
|
|
|
|
|
pUndo->SetLRSpaceEndPos();
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
Insert( rPam, SwNumRuleItem( pNew->GetName() ) );
|
|
|
|
|
}
|
|
|
|
|
UpdateNumRule( pNew->GetName(), nPamPos );
|
|
|
|
|
|
2004-09-08 14:17:53 +00:00
|
|
|
|
EndUndo( UNDO_INSNUM );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
|
|
SetModified();
|
|
|
|
|
}
|
|
|
|
|
|
2004-05-11 11:03:53 +00:00
|
|
|
|
void SwDoc::ReplaceNumRule(const SwPaM & rPaM, const SwNumRule & rNumRule)
|
|
|
|
|
{
|
|
|
|
|
if (DoesUndo())
|
|
|
|
|
StartUndo(UNDO_START);
|
|
|
|
|
|
|
|
|
|
ULONG nStt = rPaM.Start()->nNode.GetIndex();
|
|
|
|
|
ULONG nEnd = rPaM.End()->nNode.GetIndex();
|
|
|
|
|
|
|
|
|
|
for (ULONG n = nStt; n <= nEnd; n++)
|
|
|
|
|
{
|
|
|
|
|
SwTxtNode * pCNd = GetNodes()[n]->GetTxtNode();
|
|
|
|
|
|
|
|
|
|
if (pCNd && NULL != pCNd->GetNumRule())
|
|
|
|
|
{
|
|
|
|
|
SwPaM aPam(*pCNd);
|
|
|
|
|
|
|
|
|
|
Insert(aPam, SwNumRuleItem(rNumRule.GetName()));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (DoesUndo())
|
|
|
|
|
EndUndo(UNDO_START);
|
|
|
|
|
}
|
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
void SwDoc::SetNumRuleStart( const SwPosition& rPos, BOOL bFlag )
|
|
|
|
|
{
|
|
|
|
|
SwTxtNode* pTxtNd = rPos.nNode.GetNode().GetTxtNode();
|
|
|
|
|
const SwNumRule* pRule;
|
|
|
|
|
if( pTxtNd && pTxtNd->GetNum() && 0 != ( pRule = pTxtNd->GetNumRule() )
|
|
|
|
|
&& bFlag != pTxtNd->GetNum()->IsStart())
|
|
|
|
|
{
|
|
|
|
|
if( DoesUndo() )
|
|
|
|
|
{
|
|
|
|
|
ClearRedo();
|
|
|
|
|
AppendUndo( new SwUndoNumRuleStart( rPos, bFlag ));
|
|
|
|
|
}
|
|
|
|
|
SwNodeNum aNum( *pTxtNd->GetNum() );
|
|
|
|
|
aNum.SetStart( bFlag );
|
|
|
|
|
pTxtNd->UpdateNum( aNum );
|
|
|
|
|
UpdateNumRule( pRule->GetName(),
|
|
|
|
|
bFlag ? rPos.nNode.GetIndex() : ULONG_MAX );
|
|
|
|
|
SetModified();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void SwDoc::SetNodeNumStart( const SwPosition& rPos, USHORT nStt )
|
|
|
|
|
{
|
|
|
|
|
SwTxtNode* pTxtNd = rPos.nNode.GetNode().GetTxtNode();
|
|
|
|
|
const SwNumRule* pRule;
|
|
|
|
|
if( pTxtNd && pTxtNd->GetNum() && 0 != ( pRule = pTxtNd->GetNumRule() )
|
|
|
|
|
&& nStt != pTxtNd->GetNum()->GetSetValue() )
|
|
|
|
|
{
|
|
|
|
|
if( DoesUndo() )
|
|
|
|
|
{
|
|
|
|
|
ClearRedo();
|
|
|
|
|
AppendUndo( new SwUndoNumRuleStart( rPos, nStt ));
|
|
|
|
|
}
|
|
|
|
|
SwNodeNum aNum( *pTxtNd->GetNum() );
|
|
|
|
|
aNum.SetSetValue( nStt );
|
|
|
|
|
pTxtNd->UpdateNum( aNum );
|
|
|
|
|
UpdateNumRule( pRule->GetName(), USHRT_MAX != nStt
|
|
|
|
|
? rPos.nNode.GetIndex() : ULONG_MAX );
|
|
|
|
|
SetModified();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// loeschen geht nur, wenn die Rule niemand benutzt!
|
2004-09-08 14:17:53 +00:00
|
|
|
|
BOOL SwDoc::DelNumRule( const String& rName, BOOL bBroadcast )
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
|
|
|
|
USHORT nPos = FindNumRule( rName );
|
|
|
|
|
if( USHRT_MAX != nPos && !IsUsed( *(*pNumRuleTbl)[ nPos ] ))
|
|
|
|
|
{
|
2004-09-08 14:17:53 +00:00
|
|
|
|
if (DoesUndo())
|
|
|
|
|
{
|
|
|
|
|
SwUndo * pUndo =
|
|
|
|
|
new SwUndoNumruleDelete(*(*pNumRuleTbl)[nPos], this);
|
|
|
|
|
|
|
|
|
|
AppendUndo(pUndo);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (bBroadcast)
|
|
|
|
|
BroadcastStyleOperation(rName, SFX_STYLE_FAMILY_PSEUDO,
|
|
|
|
|
SFX_STYLESHEET_ERASED);
|
|
|
|
|
|
2004-11-16 14:39:29 +00:00
|
|
|
|
// --> FME 2004-11-02 #i34097# DeleteAndDestroy deletes rName if
|
|
|
|
|
// rName is directly taken from the numrule.
|
|
|
|
|
const String aTmpName( rName );
|
|
|
|
|
// <--
|
2000-09-18 23:08:29 +00:00
|
|
|
|
pNumRuleTbl->DeleteAndDestroy( nPos );
|
2004-11-16 14:39:29 +00:00
|
|
|
|
aNumRuleMap.erase(aTmpName);
|
2004-10-22 07:11:47 +00:00
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
SetModified();
|
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
|
|
|
|
|
2004-06-11 14:46:59 +00:00
|
|
|
|
// #106897#
|
|
|
|
|
void SwDoc::ChgNumRuleFmts( const SwNumRule& rRule, const String * pName )
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-06-11 14:46:59 +00:00
|
|
|
|
// #106897#
|
|
|
|
|
SwNumRule* pRule = FindNumRulePtr( pName ? *pName : rRule.GetName() );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
if( pRule )
|
|
|
|
|
{
|
|
|
|
|
SwUndoInsNum* pUndo = 0;
|
|
|
|
|
SwHistory* pHistory = 0;
|
|
|
|
|
if( DoesUndo() && pRule->IsAutoRule() )
|
|
|
|
|
{
|
|
|
|
|
ClearRedo();
|
|
|
|
|
pUndo = new SwUndoInsNum( *pRule, rRule );
|
|
|
|
|
pHistory = pUndo->GetHistory();
|
|
|
|
|
AppendUndo( pUndo );
|
|
|
|
|
}
|
|
|
|
|
::lcl_ChgNumRule( *this, rRule, pHistory );
|
|
|
|
|
|
|
|
|
|
if( pUndo )
|
|
|
|
|
pUndo->SetLRSpaceEndPos();
|
|
|
|
|
|
|
|
|
|
SetModified();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2004-09-08 14:17:53 +00:00
|
|
|
|
sal_Bool SwDoc::RenameNumRule(const String & rOldName, const String & rNewName,
|
|
|
|
|
BOOL bBroadcast)
|
|
|
|
|
{
|
|
|
|
|
sal_Bool bResult = sal_False;
|
|
|
|
|
SwNumRule * pNumRule = FindNumRulePtr(rOldName);
|
|
|
|
|
|
|
|
|
|
if (pNumRule)
|
|
|
|
|
{
|
|
|
|
|
if (DoesUndo())
|
|
|
|
|
{
|
|
|
|
|
SwUndo * pUndo = new SwUndoNumruleRename(rOldName, rNewName, this);
|
|
|
|
|
|
|
|
|
|
AppendUndo(pUndo);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SwNumRuleInfo aInfo(rOldName);
|
|
|
|
|
aInfo.MakeList(*this);
|
|
|
|
|
|
|
|
|
|
pNumRule->SetName(rNewName);
|
|
|
|
|
|
|
|
|
|
SwNumRuleItem aItem(rNewName);
|
|
|
|
|
for (int nI = 0; nI < aInfo.GetList().Count(); nI++)
|
|
|
|
|
{
|
|
|
|
|
SwTxtNode * pTxtNd = aInfo.GetList().GetObject(nI);
|
|
|
|
|
|
|
|
|
|
pTxtNd->SwCntntNode::SetAttr(aItem);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bResult = sal_True;
|
|
|
|
|
|
|
|
|
|
if (bBroadcast)
|
|
|
|
|
BroadcastStyleOperation(rOldName, SFX_STYLE_FAMILY_PSEUDO,
|
|
|
|
|
SFX_STYLESHEET_MODIFIED);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return bResult;
|
|
|
|
|
}
|
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
void SwDoc::StopNumRuleAnimations( OutputDevice* pOut )
|
|
|
|
|
{
|
|
|
|
|
for( USHORT n = GetNumRuleTbl().Count(); n; )
|
|
|
|
|
{
|
|
|
|
|
SwNumRuleInfo aUpd( GetNumRuleTbl()[ --n ]->GetName() );
|
|
|
|
|
aUpd.MakeList( *this );
|
|
|
|
|
|
|
|
|
|
for( ULONG nFirst = 0, nLast = aUpd.GetList().Count();
|
|
|
|
|
nFirst < nLast; ++nFirst )
|
|
|
|
|
{
|
|
|
|
|
SwTxtNode* pTNd = aUpd.GetList().GetObject( nFirst );
|
|
|
|
|
|
|
|
|
|
SwClientIter aIter( *pTNd );
|
|
|
|
|
for( SwFrm* pFrm = (SwFrm*)aIter.First( TYPE(SwFrm) );
|
|
|
|
|
pFrm; pFrm = (SwFrm*)aIter.Next() )
|
|
|
|
|
if( ((SwTxtFrm*)pFrm)->HasAnimation() )
|
|
|
|
|
((SwTxtFrm*)pFrm)->StopAnimation( pOut );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOL SwDoc::ReplaceNumRule( const SwPosition& rPos,
|
|
|
|
|
const String& rOldRule, const String& rNewRule )
|
|
|
|
|
{
|
|
|
|
|
BOOL bRet = FALSE;
|
|
|
|
|
SwNumRule *pOldRule = FindNumRulePtr( rOldRule ),
|
|
|
|
|
*pNewRule = FindNumRulePtr( rNewRule );
|
|
|
|
|
if( pOldRule && pNewRule && pOldRule != pNewRule )
|
|
|
|
|
{
|
|
|
|
|
SwUndoInsNum* pUndo = 0;
|
|
|
|
|
if( DoesUndo() )
|
|
|
|
|
{
|
|
|
|
|
ClearRedo();
|
|
|
|
|
StartUndo( UNDO_START ); // Klammerung fuer die Attribute!
|
|
|
|
|
AppendUndo( pUndo = new SwUndoInsNum( rPos, *pNewRule, rOldRule ) );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SwNumRuleInfo aUpd( rOldRule );
|
|
|
|
|
aUpd.MakeList( *this );
|
|
|
|
|
|
2004-06-11 14:46:59 +00:00
|
|
|
|
if (aUpd.GetList().Count() > 0) // #106897#
|
|
|
|
|
{
|
|
|
|
|
// Position suchen und bestimme ob ein Node davor oder dahinter
|
|
|
|
|
// einen Start erzwingt
|
|
|
|
|
SwTxtNode* pTxtNd;
|
|
|
|
|
ULONG nFndPos, nFirst, nLast;
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
2004-06-11 14:46:59 +00:00
|
|
|
|
if( TABLE_ENTRY_NOTFOUND != aUpd.GetList().SearchKey(
|
|
|
|
|
rPos.nNode.GetIndex(), &nFndPos ))
|
|
|
|
|
++nFndPos;
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
2004-06-11 14:46:59 +00:00
|
|
|
|
for( nLast = nFndPos; nLast < aUpd.GetList().Count(); ++nLast )
|
|
|
|
|
if( ( pTxtNd = aUpd.GetList().GetObject( nLast ))->GetNum() &&
|
|
|
|
|
pTxtNd->GetNum()->IsStart() )
|
|
|
|
|
break;
|
|
|
|
|
for( nFirst = nFndPos; nFirst; )
|
|
|
|
|
if( ( pTxtNd = aUpd.GetList().GetObject( --nFirst ))->GetNum() &&
|
|
|
|
|
pTxtNd->GetNum()->IsStart() )
|
|
|
|
|
break;
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
2004-06-11 14:46:59 +00:00
|
|
|
|
// dann neue Numerierung ueber diesen Bereich
|
|
|
|
|
// definieren und den Start am Anfang/Ende zurueck setzen
|
|
|
|
|
pTxtNd = aUpd.GetList().GetObject( nFirst );
|
|
|
|
|
if( pTxtNd->GetNum()->IsStart() )
|
|
|
|
|
{
|
|
|
|
|
((SwNodeNum*)pTxtNd->GetNum())->SetStart( FALSE );
|
|
|
|
|
if( pUndo )
|
|
|
|
|
pUndo->SetSttNum( pTxtNd->GetIndex() );
|
|
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
2004-06-11 14:46:59 +00:00
|
|
|
|
SwRegHistory aRegH( pUndo ? pUndo->GetHistory() : 0 );
|
|
|
|
|
USHORT nChgFmtLevel = 0;
|
|
|
|
|
for( BYTE n = 0; n < MAXLEVEL; ++n )
|
|
|
|
|
{
|
|
|
|
|
const SwNumFmt& rOldFmt = pOldRule->Get( n ),
|
|
|
|
|
& rNewFmt = pNewRule->Get( n );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
2004-06-11 14:46:59 +00:00
|
|
|
|
if( rOldFmt.GetAbsLSpace() != rNewFmt.GetAbsLSpace() ||
|
|
|
|
|
rOldFmt.GetFirstLineOffset() != rNewFmt.GetFirstLineOffset() )
|
|
|
|
|
nChgFmtLevel |= ( 1 << n );
|
|
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
2004-06-11 14:46:59 +00:00
|
|
|
|
SwNumRuleItem aRule( rNewRule );
|
|
|
|
|
for( ; nFirst < nLast; ++nFirst )
|
|
|
|
|
{
|
|
|
|
|
pTxtNd = aUpd.GetList().GetObject( nFirst );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
2004-06-11 14:46:59 +00:00
|
|
|
|
aRegH.RegisterInModify( pTxtNd, *pTxtNd );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
|
|
#ifndef NUM_RELSPACE
|
|
|
|
|
BYTE nLvl = !pTxtNd->GetNum() ? NO_NUMBERING
|
2004-03-08 11:24:21 +00:00
|
|
|
|
: pTxtNd->GetNum()->GetRealLevel();
|
2000-09-18 23:08:29 +00:00
|
|
|
|
if( nLvl < MAXLEVEL && (nChgFmtLevel & ( 1 << nLvl )) &&
|
|
|
|
|
pOldRule->IsRuleLSpace( *pTxtNd ) )
|
|
|
|
|
pTxtNd->SetNumLSpace( TRUE );
|
|
|
|
|
#endif
|
|
|
|
|
|
2004-06-11 14:46:59 +00:00
|
|
|
|
pTxtNd->SwCntntNode::SetAttr( aRule );
|
|
|
|
|
pTxtNd->NumRuleChgd();
|
|
|
|
|
}
|
|
|
|
|
EndUndo( UNDO_END );
|
|
|
|
|
SetModified();
|
|
|
|
|
|
|
|
|
|
bRet = TRUE; // #106897#
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2004-06-11 14:46:59 +00:00
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
return bRet;
|
|
|
|
|
}
|
|
|
|
|
|
2005-01-25 12:59:21 +00:00
|
|
|
|
void SwDoc::MakeUniqueNumRules(const SwPaM & rPaM)
|
|
|
|
|
{
|
2005-03-08 10:21:10 +00:00
|
|
|
|
ASSERT( rPaM.GetDoc() == this, "need same doc" );
|
|
|
|
|
|
2005-01-25 12:59:21 +00:00
|
|
|
|
map<SwNumRule *, SwNumRule *> aNumRuleMap;
|
|
|
|
|
|
|
|
|
|
ULONG nStt = rPaM.Start()->nNode.GetIndex();
|
|
|
|
|
ULONG nEnd = rPaM.End()->nNode.GetIndex();
|
|
|
|
|
|
2005-02-21 15:15:34 +00:00
|
|
|
|
bool bFirst = true;
|
|
|
|
|
|
2005-01-25 12:59:21 +00:00
|
|
|
|
for (ULONG n = nStt; n <= nEnd; n++)
|
|
|
|
|
{
|
|
|
|
|
SwTxtNode * pCNd = GetNodes()[n]->GetTxtNode();
|
|
|
|
|
|
|
|
|
|
if (pCNd)
|
|
|
|
|
{
|
|
|
|
|
SwNumRule * pRule = pCNd->GetNumRule();
|
|
|
|
|
|
|
|
|
|
if (pRule && pRule->IsAutoRule())
|
|
|
|
|
{
|
|
|
|
|
SwNumRule * pReplaceNumRule = aNumRuleMap[pRule];
|
|
|
|
|
|
|
|
|
|
if (! pReplaceNumRule)
|
|
|
|
|
{
|
2005-02-21 15:15:34 +00:00
|
|
|
|
if (bFirst)
|
|
|
|
|
{
|
|
|
|
|
SwPosition aPos(*pCNd);
|
|
|
|
|
pReplaceNumRule =
|
|
|
|
|
const_cast<SwNumRule *>
|
|
|
|
|
(SearchNumRule(aPos, FALSE, pCNd->HasNumber(),
|
|
|
|
|
FALSE, 0));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (! pReplaceNumRule)
|
|
|
|
|
{
|
|
|
|
|
pReplaceNumRule = new SwNumRule(*pRule);
|
|
|
|
|
pReplaceNumRule->SetName(GetUniqueNumRuleName());
|
|
|
|
|
|
|
|
|
|
}
|
2005-01-25 12:59:21 +00:00
|
|
|
|
|
|
|
|
|
aNumRuleMap[pRule] = pReplaceNumRule;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SwPaM aPam(*pCNd);
|
|
|
|
|
|
|
|
|
|
SetNumRule(aPam, *pReplaceNumRule);
|
2005-02-21 15:15:34 +00:00
|
|
|
|
|
|
|
|
|
bFirst = false;
|
2005-01-25 12:59:21 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
BOOL SwDoc::NoNum( const SwPaM& rPam )
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
BOOL bRet = SplitNode( *rPam.GetPoint() );
|
|
|
|
|
// ist ueberhaupt Nummerierung im Spiel ?
|
|
|
|
|
if( bRet )
|
|
|
|
|
{
|
|
|
|
|
// NoNum setzen und Upaten
|
|
|
|
|
const SwNodeIndex& rIdx = rPam.GetPoint()->nNode;
|
|
|
|
|
SwTxtNode* pNd = rIdx.GetNode().GetTxtNode();
|
|
|
|
|
const SwNodeNum* pNum = pNd->GetNum();
|
|
|
|
|
const SwNumRule* pRule = pNd->GetNumRule();
|
|
|
|
|
if( pNum && pRule )
|
|
|
|
|
{
|
|
|
|
|
SwNodeNum aNum( *pNum );
|
2004-03-08 11:24:21 +00:00
|
|
|
|
aNum.SetNoNum( TRUE );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
pNd->UpdateNum( aNum );
|
|
|
|
|
#ifndef NUM_RELSPACE
|
|
|
|
|
pNd->SetNumLSpace( TRUE );
|
|
|
|
|
#endif
|
|
|
|
|
UpdateNumRule( pRule->GetName(), rIdx.GetIndex() );
|
|
|
|
|
SetModified();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
bRet = FALSE; // keine Nummerierung , ?? oder immer TRUE ??
|
|
|
|
|
}
|
|
|
|
|
return bRet;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOL SwDoc::DelNumRules( const SwPaM& rPam )
|
|
|
|
|
{
|
|
|
|
|
ULONG nStt = rPam.GetPoint()->nNode.GetIndex(),
|
|
|
|
|
nEnd = rPam.GetMark()->nNode.GetIndex();
|
|
|
|
|
if( nStt > nEnd )
|
|
|
|
|
{
|
|
|
|
|
ULONG nTmp = nStt; nStt = nEnd; nEnd = nTmp;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SwUndoDelNum* pUndo;
|
|
|
|
|
if( DoesUndo() )
|
|
|
|
|
{
|
|
|
|
|
ClearRedo();
|
|
|
|
|
AppendUndo( pUndo = new SwUndoDelNum( rPam ) );
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
pUndo = 0;
|
|
|
|
|
|
|
|
|
|
SwRegHistory aRegH( pUndo ? pUndo->GetHistory() : 0 );
|
|
|
|
|
|
|
|
|
|
SwNumRuleItem aEmptyRule( aEmptyStr );
|
|
|
|
|
SvxLRSpaceItem aLRSpace;
|
|
|
|
|
String sNumRule;
|
|
|
|
|
const SfxPoolItem* pItem;
|
|
|
|
|
const String* pName;
|
|
|
|
|
SwNumRule* pRule;
|
|
|
|
|
const SwNode* pOutlNd = 0;
|
|
|
|
|
for( ; nStt <= nEnd; ++nStt )
|
|
|
|
|
{
|
|
|
|
|
SwTxtNode* pTNd = GetNodes()[ nStt ]->GetTxtNode();
|
|
|
|
|
if( pTNd && 0 != ( pItem = pTNd->GetNoCondAttr(
|
|
|
|
|
RES_PARATR_NUMRULE, TRUE ) ) &&
|
|
|
|
|
( pName = &((SwNumRuleItem*)pItem)->GetValue())->Len() )
|
|
|
|
|
{
|
|
|
|
|
if( *pName != sNumRule )
|
|
|
|
|
{
|
|
|
|
|
sNumRule = *pName;
|
|
|
|
|
pRule = FindNumRulePtr( *pName );
|
|
|
|
|
pRule->SetInvalidRule( TRUE );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// fuers Undo - Attribut Aenderungen merken
|
|
|
|
|
aRegH.RegisterInModify( pTNd, *pTNd );
|
|
|
|
|
|
|
|
|
|
BOOL bResetNumRule = FALSE;
|
|
|
|
|
const SwAttrSet* pAttrSet = pTNd->GetpSwAttrSet();
|
|
|
|
|
#ifndef NUM_RELSPACE
|
|
|
|
|
BYTE nLvl;
|
|
|
|
|
const SvxLRSpaceItem* pLRSpace;
|
|
|
|
|
if( pAttrSet && SFX_ITEM_SET == pAttrSet->GetItemState(
|
|
|
|
|
RES_LR_SPACE, FALSE, (const SfxPoolItem**)&pLRSpace ) &&
|
|
|
|
|
( !pTNd->GetNum() ||
|
2004-03-08 11:24:21 +00:00
|
|
|
|
(( nLvl = pTNd->GetNum()->GetRealLevel() ) <
|
2000-09-18 23:08:29 +00:00
|
|
|
|
MAXLEVEL && ( pRule->Get( nLvl ).GetAbsLSpace()
|
|
|
|
|
== pLRSpace->GetTxtLeft() )) ))
|
|
|
|
|
{
|
|
|
|
|
if( pLRSpace->GetRight() )
|
|
|
|
|
{
|
|
|
|
|
aLRSpace.SetRight( pLRSpace->GetRight() );
|
|
|
|
|
pTNd->SwCntntNode::SetAttr( aLRSpace );
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
pTNd->SwCntntNode::ResetAttr( RES_LR_SPACE );
|
|
|
|
|
pAttrSet = pTNd->GetpSwAttrSet();
|
|
|
|
|
}
|
|
|
|
|
bResetNumRule = TRUE;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
if( pUndo )
|
|
|
|
|
pUndo->AddNode( *pTNd, bResetNumRule );
|
|
|
|
|
|
|
|
|
|
// kommt die Rule vom Node, dann Reseten, sonst auf leer setzen
|
|
|
|
|
if( pAttrSet && SFX_ITEM_SET == pAttrSet->GetItemState(
|
|
|
|
|
RES_PARATR_NUMRULE, FALSE ))
|
|
|
|
|
pTNd->SwCntntNode::ResetAttr( RES_PARATR_NUMRULE );
|
|
|
|
|
else
|
|
|
|
|
pTNd->SwCntntNode::SetAttr( aEmptyRule );
|
|
|
|
|
|
2004-03-08 11:24:21 +00:00
|
|
|
|
if (0 != pTNd->GetNumRule())
|
|
|
|
|
pTNd->UpdateNum( SwNodeNum( 0 ));
|
|
|
|
|
else
|
|
|
|
|
pTNd->UpdateNum( SwNodeNum( NO_NUMBERING ));
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
|
|
if( RES_CONDTXTFMTCOLL == pTNd->GetFmtColl()->Which() )
|
|
|
|
|
pTNd->ChkCondColl();
|
|
|
|
|
else if( !pOutlNd && NO_NUMBERING !=
|
|
|
|
|
((SwTxtFmtColl*)pTNd->GetFmtColl())->GetOutlineLevel() )
|
|
|
|
|
pOutlNd = pTNd;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// dann noch alle Updaten
|
|
|
|
|
UpdateNumRule();
|
|
|
|
|
|
|
|
|
|
if( pOutlNd )
|
|
|
|
|
GetNodes().UpdtOutlineIdx( *pOutlNd );
|
|
|
|
|
|
|
|
|
|
// irgendetwas wurde geupdatet
|
|
|
|
|
return 0 != sNumRule.Len();
|
|
|
|
|
}
|
|
|
|
|
|
2004-10-22 07:11:47 +00:00
|
|
|
|
void SwDoc::InvalidateNumRules()
|
|
|
|
|
{
|
|
|
|
|
for (int n = 0; n < pNumRuleTbl->Count(); n++)
|
|
|
|
|
(*pNumRuleTbl)[n]->SetInvalidRule(TRUE);
|
|
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
|
|
// zum naechsten/vorhergehenden Punkt auf gleicher Ebene
|
|
|
|
|
|
|
|
|
|
BOOL lcl_IsNumOk( BYTE nSrchNum, BYTE& rLower, BYTE& rUpper,
|
|
|
|
|
BOOL bOverUpper, BYTE nNumber )
|
|
|
|
|
{
|
|
|
|
|
register BOOL bRet = FALSE;
|
|
|
|
|
if( nNumber < MAXLEVEL ) // keine Nummerierung ueberspringen
|
|
|
|
|
{
|
|
|
|
|
if( bOverUpper ? nSrchNum == nNumber : nSrchNum >= nNumber )
|
|
|
|
|
bRet = TRUE;
|
|
|
|
|
else if( nNumber > rLower )
|
|
|
|
|
rLower = nNumber;
|
|
|
|
|
else if( nNumber < rUpper )
|
|
|
|
|
rUpper = nNumber;
|
|
|
|
|
}
|
2004-03-08 11:24:21 +00:00
|
|
|
|
else if( !IsNum(nNumber))
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-03-08 11:24:21 +00:00
|
|
|
|
SetNoNum(&nNumber, FALSE);
|
2000-09-18 23:08:29 +00:00
|
|
|
|
if( bOverUpper ? FALSE : nSrchNum > nNumber )
|
|
|
|
|
bRet = TRUE;
|
|
|
|
|
else if( nNumber > rLower )
|
|
|
|
|
rLower = nNumber;
|
|
|
|
|
else if( nNumber < rUpper )
|
|
|
|
|
rUpper = nNumber;
|
|
|
|
|
}
|
|
|
|
|
return bRet;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOL lcl_IsValidPrevNextNumNode( const SwNodeIndex& rIdx )
|
|
|
|
|
{
|
|
|
|
|
BOOL bRet = FALSE;
|
|
|
|
|
const SwNode& rNd = rIdx.GetNode();
|
|
|
|
|
switch( rNd.GetNodeType() )
|
|
|
|
|
{
|
|
|
|
|
case ND_ENDNODE:
|
|
|
|
|
bRet = SwTableBoxStartNode == rNd.FindStartNode()->GetStartNodeType() ||
|
|
|
|
|
rNd.FindStartNode()->IsSectionNode();
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case ND_STARTNODE:
|
|
|
|
|
bRet = SwTableBoxStartNode == ((SwStartNode&)rNd).GetStartNodeType();
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case ND_SECTIONNODE: // der ist erlaubt, also weiter
|
|
|
|
|
bRet = TRUE;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
return bRet;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOL lcl_GotoNextPrevNum( SwPosition& rPos, BOOL bNext,
|
|
|
|
|
BOOL bOverUpper, BYTE* pUpper, BYTE* pLower )
|
|
|
|
|
{
|
|
|
|
|
const SwTxtNode* pNd = rPos.nNode.GetNode().GetTxtNode();
|
|
|
|
|
const SwNumRule* pRule;
|
|
|
|
|
if( !pNd || 0 == ( pRule = pNd->GetNumRule() ) || !pNd->GetNum() )
|
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
|
|
register BYTE nTmpNum = pNd->GetNum()->GetLevel(),
|
2004-03-08 11:24:21 +00:00
|
|
|
|
nSrchNum = GetRealLevel(nTmpNum);
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
|
|
SwNodeIndex aIdx( rPos.nNode );
|
2004-03-08 11:24:21 +00:00
|
|
|
|
if( !IsNum(nTmpNum) )
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
|
|
|
|
// falls gerade mal NO_NUMLEVEL an ist, so such den vorherigen Node
|
|
|
|
|
// mit Nummerierung
|
|
|
|
|
BOOL bError = FALSE;
|
|
|
|
|
do {
|
|
|
|
|
aIdx--;
|
|
|
|
|
if( aIdx.GetNode().IsTxtNode() )
|
|
|
|
|
{
|
|
|
|
|
pNd = aIdx.GetNode().GetTxtNode();
|
|
|
|
|
if( pNd->GetNum() && pRule == pNd->GetNumRule() )
|
|
|
|
|
{
|
|
|
|
|
nTmpNum = pNd->GetNum()->GetLevel();
|
2004-03-08 11:24:21 +00:00
|
|
|
|
if( !( ! IsNum(nTmpNum) &&
|
|
|
|
|
(GetRealLevel(nTmpNum) >= nSrchNum )) )
|
2000-09-18 23:08:29 +00:00
|
|
|
|
break; // gefunden
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
bError = TRUE;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
bError = !lcl_IsValidPrevNextNumNode( aIdx );
|
|
|
|
|
|
|
|
|
|
} while( !bError );
|
|
|
|
|
if( bError )
|
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BYTE nLower = nSrchNum, nUpper = nSrchNum;
|
|
|
|
|
BOOL bRet = FALSE;
|
|
|
|
|
|
|
|
|
|
const SwTxtNode* pLast;
|
|
|
|
|
if( bNext )
|
|
|
|
|
aIdx++, pLast = pNd;
|
|
|
|
|
else
|
|
|
|
|
aIdx--, pLast = 0;
|
|
|
|
|
|
|
|
|
|
while( bNext ? ( aIdx.GetIndex() < aIdx.GetNodes().Count() - 1 )
|
|
|
|
|
: aIdx.GetIndex() )
|
|
|
|
|
{
|
|
|
|
|
if( aIdx.GetNode().IsTxtNode() )
|
|
|
|
|
{
|
|
|
|
|
pNd = aIdx.GetNode().GetTxtNode();
|
|
|
|
|
if( pNd->GetNum() && pRule == pNd->GetNumRule() )
|
|
|
|
|
{
|
|
|
|
|
if( ::lcl_IsNumOk( nSrchNum, nLower, nUpper, bOverUpper,
|
|
|
|
|
pNd->GetNum()->GetLevel() ))
|
|
|
|
|
{
|
|
|
|
|
rPos.nNode = aIdx;
|
|
|
|
|
rPos.nContent.Assign( (SwTxtNode*)pNd, 0 );
|
|
|
|
|
bRet = TRUE;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
pLast = pNd;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
else if( !lcl_IsValidPrevNextNumNode( aIdx ))
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
if( bNext )
|
|
|
|
|
aIdx++;
|
|
|
|
|
else
|
|
|
|
|
aIdx--;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if( !bRet && !bOverUpper && pLast ) // nicht ueber hoehere Nummmern, aber bis Ende
|
|
|
|
|
{
|
|
|
|
|
if( bNext )
|
|
|
|
|
{
|
|
|
|
|
rPos.nNode = aIdx;
|
|
|
|
|
if( aIdx.GetNode().IsCntntNode() )
|
|
|
|
|
rPos.nContent.Assign( aIdx.GetNode().GetCntntNode(), 0 );
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
rPos.nNode.Assign( *pLast );
|
|
|
|
|
rPos.nContent.Assign( (SwTxtNode*)pLast, 0 );
|
|
|
|
|
}
|
|
|
|
|
bRet = TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if( bRet )
|
|
|
|
|
{
|
|
|
|
|
if( pUpper )
|
|
|
|
|
*pUpper = nUpper;
|
|
|
|
|
if( pLower )
|
|
|
|
|
*pLower = nLower;
|
|
|
|
|
}
|
|
|
|
|
return bRet;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOL SwDoc::GotoNextNum( SwPosition& rPos, BOOL bOverUpper,
|
|
|
|
|
BYTE* pUpper, BYTE* pLower )
|
|
|
|
|
{
|
|
|
|
|
return ::lcl_GotoNextPrevNum( rPos, TRUE, bOverUpper, pUpper, pLower );
|
|
|
|
|
}
|
|
|
|
|
|
2004-03-30 15:05:30 +00:00
|
|
|
|
// -> #i23731#
|
|
|
|
|
const SwNumRule * SwDoc::SearchNumRule(SwPosition & rPos,
|
|
|
|
|
BOOL bForward,
|
|
|
|
|
BOOL bNum,
|
2004-06-16 07:16:02 +00:00
|
|
|
|
BOOL bOutline,
|
2004-03-30 15:05:30 +00:00
|
|
|
|
int nNonEmptyAllowed)
|
|
|
|
|
{
|
|
|
|
|
const SwNumRule * pResult = NULL;
|
|
|
|
|
SwTxtNode * pTxtNd = rPos.nNode.GetNode().GetTxtNode();
|
|
|
|
|
SwNode * pStartFromNode = pTxtNd;
|
|
|
|
|
|
|
|
|
|
if (pTxtNd)
|
|
|
|
|
{
|
|
|
|
|
SwNodeIndex aIdx(rPos.nNode);
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
2004-03-30 15:05:30 +00:00
|
|
|
|
const SwNode * pNode = NULL;
|
|
|
|
|
do
|
|
|
|
|
{
|
|
|
|
|
if (bForward)
|
|
|
|
|
aIdx++;
|
|
|
|
|
else
|
|
|
|
|
aIdx--;
|
|
|
|
|
|
|
|
|
|
if (aIdx.GetNode().IsTxtNode())
|
|
|
|
|
{
|
|
|
|
|
pTxtNd = aIdx.GetNode().GetTxtNode();
|
|
|
|
|
|
|
|
|
|
const SwNumRule * pNumRule = pTxtNd->GetNumRule();
|
|
|
|
|
if (pNumRule)
|
|
|
|
|
{
|
2004-06-11 14:46:59 +00:00
|
|
|
|
if (pNumRule->IsOutlineRule() == bOutline && // #115901#
|
|
|
|
|
(bNum && pNumRule->Get(0).IsEnumeration() ||
|
|
|
|
|
!bNum && pNumRule->Get(0).IsItemize())) // #i22362#, #i29560#
|
2004-03-30 15:05:30 +00:00
|
|
|
|
pResult = pTxtNd->GetNumRule();
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
else if (pTxtNd->Len() > 0 || NULL != pTxtNd->GetNumRule())
|
|
|
|
|
{
|
|
|
|
|
if (nNonEmptyAllowed == 0)
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
nNonEmptyAllowed--;
|
|
|
|
|
|
|
|
|
|
if (nNonEmptyAllowed < 0)
|
|
|
|
|
nNonEmptyAllowed = -1;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
pNode = &aIdx.GetNode();
|
|
|
|
|
}
|
|
|
|
|
while (! (pNode == aNodes.DocumentSectionStartNode(pStartFromNode) ||
|
|
|
|
|
pNode == aNodes.DocumentSectionEndNode(pStartFromNode)));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return pResult;
|
|
|
|
|
}
|
|
|
|
|
// <- #i23731#
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
|
|
BOOL SwDoc::GotoPrevNum( SwPosition& rPos, BOOL bOverUpper,
|
|
|
|
|
BYTE* pUpper, BYTE* pLower )
|
|
|
|
|
{
|
|
|
|
|
return ::lcl_GotoNextPrevNum( rPos, FALSE, bOverUpper, pUpper, pLower );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOL SwDoc::NumUpDown( const SwPaM& rPam, BOOL bDown )
|
|
|
|
|
{
|
|
|
|
|
ULONG nStt = rPam.GetPoint()->nNode.GetIndex(),
|
|
|
|
|
nEnd = rPam.GetMark()->nNode.GetIndex();
|
|
|
|
|
if( nStt > nEnd )
|
|
|
|
|
{
|
|
|
|
|
ULONG nTmp = nStt; nStt = nEnd; nEnd = nTmp;
|
|
|
|
|
}
|
|
|
|
|
|
2004-03-30 15:05:30 +00:00
|
|
|
|
// -> #115901# outline nodes are promoted or demoted differently
|
|
|
|
|
bool bOnlyOutline = true;
|
|
|
|
|
bool bOnlyNonOutline = true;
|
|
|
|
|
for (ULONG n = nStt; n <= nEnd; n++)
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-03-30 15:05:30 +00:00
|
|
|
|
SwTxtNode * pTxtNd = GetNodes()[n]->GetTxtNode();
|
|
|
|
|
|
|
|
|
|
if (pTxtNd)
|
|
|
|
|
{
|
|
|
|
|
SwNumRule * pRule = pTxtNd->GetNumRule();
|
|
|
|
|
|
|
|
|
|
if (pRule)
|
|
|
|
|
{
|
|
|
|
|
if (pRule->IsOutlineRule())
|
|
|
|
|
bOnlyNonOutline = false;
|
|
|
|
|
else
|
|
|
|
|
bOnlyOutline = false;
|
|
|
|
|
}
|
|
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
2004-03-30 15:05:30 +00:00
|
|
|
|
// <- #115901#
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
2004-05-17 15:13:16 +00:00
|
|
|
|
BOOL bRet = TRUE;
|
2004-04-07 13:25:47 +00:00
|
|
|
|
char nDiff = bDown ? 1 : -1;
|
2004-03-30 15:05:30 +00:00
|
|
|
|
|
|
|
|
|
// ->#115901#
|
|
|
|
|
if (bOnlyOutline)
|
|
|
|
|
bRet = OutlineUpDown(rPam, nDiff);
|
|
|
|
|
else if (bOnlyNonOutline)
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-03-30 15:05:30 +00:00
|
|
|
|
|
|
|
|
|
const SfxPoolItem* pItem;
|
|
|
|
|
const String* pName;
|
2004-04-07 13:25:47 +00:00
|
|
|
|
|
|
|
|
|
/* --> #i24560#
|
|
|
|
|
|
|
|
|
|
Only promote or demote if all selected paragraphs are
|
|
|
|
|
promotable resp. demotable.
|
|
|
|
|
|
|
|
|
|
*/
|
2004-06-16 08:38:19 +00:00
|
|
|
|
for (ULONG nTmp = nStt; nTmp <= nEnd; ++nTmp)
|
2004-03-30 15:05:30 +00:00
|
|
|
|
{
|
2004-04-07 13:25:47 +00:00
|
|
|
|
SwTxtNode* pTNd = GetNodes()[ nTmp ]->GetTxtNode();
|
|
|
|
|
if( pTNd)
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-04-07 13:25:47 +00:00
|
|
|
|
pItem = pTNd->GetNoCondAttr(RES_PARATR_NUMRULE, TRUE );
|
|
|
|
|
|
|
|
|
|
if (0 != pItem)
|
2004-03-30 15:05:30 +00:00
|
|
|
|
{
|
2004-04-07 13:25:47 +00:00
|
|
|
|
pName = &((SwNumRuleItem*)pItem)->GetValue();
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
2004-04-07 13:25:47 +00:00
|
|
|
|
if (pName->Len())
|
2004-03-30 15:05:30 +00:00
|
|
|
|
{
|
2004-04-07 13:25:47 +00:00
|
|
|
|
BYTE nLevel = pTNd->GetNum()->GetRealLevel();
|
|
|
|
|
if( (-1 == nDiff && 0 >= nLevel) ||
|
|
|
|
|
(1 == nDiff && MAXLEVEL - 1 <= nLevel))
|
|
|
|
|
bRet = FALSE;
|
2004-03-30 15:05:30 +00:00
|
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2004-03-30 15:05:30 +00:00
|
|
|
|
if( bRet )
|
|
|
|
|
{
|
2004-04-07 13:25:47 +00:00
|
|
|
|
/* <-- #i24560# */
|
|
|
|
|
if( DoesUndo() )
|
|
|
|
|
{
|
|
|
|
|
ClearRedo();
|
|
|
|
|
AppendUndo( new SwUndoNumUpDown( rPam, nDiff ) );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
String sNumRule;
|
|
|
|
|
|
2004-06-16 08:38:19 +00:00
|
|
|
|
for(ULONG nTmp = nStt; nTmp <= nEnd; ++nTmp )
|
2004-04-07 13:25:47 +00:00
|
|
|
|
{
|
|
|
|
|
SwTxtNode* pTNd = GetNodes()[ nTmp ]->GetTxtNode();
|
|
|
|
|
if( pTNd)
|
|
|
|
|
{
|
|
|
|
|
pItem = pTNd->GetNoCondAttr(RES_PARATR_NUMRULE, TRUE );
|
|
|
|
|
|
|
|
|
|
if (0 != pItem)
|
|
|
|
|
{
|
|
|
|
|
pName = &((SwNumRuleItem*)pItem)->GetValue();
|
|
|
|
|
|
|
|
|
|
if (pName->Len())
|
|
|
|
|
{
|
|
|
|
|
BYTE nLevel = pTNd->GetNum()->GetLevel();
|
|
|
|
|
nLevel += nDiff;
|
|
|
|
|
SwNodeNum aNum( *pTNd->GetNum() );
|
|
|
|
|
aNum.SetLevel( nLevel );
|
|
|
|
|
|
|
|
|
|
pTNd->UpdateNum( aNum );
|
|
|
|
|
#ifndef NUM_RELSPACE
|
|
|
|
|
pTNd->SetNumLSpace( TRUE );
|
|
|
|
|
#endif
|
|
|
|
|
if( *pName != sNumRule )
|
|
|
|
|
{
|
|
|
|
|
sNumRule = *pName;
|
|
|
|
|
SwNumRule* pRule = FindNumRulePtr( *pName );
|
|
|
|
|
pRule->SetInvalidRule( TRUE );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2004-03-30 15:05:30 +00:00
|
|
|
|
UpdateNumRule();
|
|
|
|
|
SetModified();
|
|
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
2004-03-30 15:05:30 +00:00
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
return bRet;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOL SwDoc::MoveParagraph( const SwPaM& rPam, long nOffset, BOOL bIsOutlMv )
|
|
|
|
|
{
|
|
|
|
|
const SwPosition *pStt = rPam.Start(), *pEnd = rPam.End();
|
|
|
|
|
|
|
|
|
|
ULONG nStIdx = pStt->nNode.GetIndex();
|
|
|
|
|
ULONG nEndIdx = pEnd->nNode.GetIndex();
|
|
|
|
|
ULONG nInStIdx, nInEndIdx;
|
|
|
|
|
long nOffs = nOffset;
|
|
|
|
|
if( nOffset > 0 )
|
|
|
|
|
{
|
|
|
|
|
nInEndIdx = nEndIdx;
|
|
|
|
|
nEndIdx += nOffset;
|
|
|
|
|
++nOffs;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
nInEndIdx = nStIdx - 1;
|
|
|
|
|
nStIdx += nOffset;
|
|
|
|
|
}
|
|
|
|
|
nInStIdx = nInEndIdx + 1;
|
|
|
|
|
// Folgende Absatzbloecke sollen vertauscht werden:
|
|
|
|
|
// [ nStIdx, nInEndIdx ] mit [ nInStIdx, nEndIdx ]
|
|
|
|
|
|
|
|
|
|
SwNode *pStartNd = GetNodes()[ nStIdx ];
|
|
|
|
|
SwNode *pEndNd = GetNodes()[ nEndIdx ];
|
|
|
|
|
if( !pStartNd->IsCntntNode() || !pEndNd->IsCntntNode() )
|
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
|
|
pStartNd = pStartNd->FindStartNode();
|
|
|
|
|
pEndNd = pEndNd->FindStartNode();
|
|
|
|
|
// Es muss sich alles in einem Bereich abspielen
|
|
|
|
|
if( pStartNd != pEndNd )
|
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
|
|
// auf Redlining testen - darf die Selektion ueberhaupt verschoben
|
|
|
|
|
// werden?
|
|
|
|
|
if( !IsIgnoreRedline() )
|
|
|
|
|
{
|
|
|
|
|
USHORT nRedlPos = GetRedlinePos( pStt->nNode.GetNode(), REDLINE_DELETE );
|
|
|
|
|
if( USHRT_MAX != nRedlPos )
|
|
|
|
|
{
|
|
|
|
|
SwPosition aStPos( *pStt ), aEndPos( *pEnd );
|
|
|
|
|
aStPos.nContent = 0;
|
|
|
|
|
SwCntntNode* pCNd = pEnd->nNode.GetNode().GetCntntNode();
|
|
|
|
|
aEndPos.nContent = pCNd ? pCNd->Len() : 1;
|
|
|
|
|
BOOL bCheckDel = TRUE;
|
|
|
|
|
|
|
|
|
|
// es existiert fuer den Bereich irgendein Redline-Delete-Object
|
|
|
|
|
for( ; nRedlPos < GetRedlineTbl().Count(); ++nRedlPos )
|
|
|
|
|
{
|
|
|
|
|
const SwRedline* pTmp = GetRedlineTbl()[ nRedlPos ];
|
|
|
|
|
if( !bCheckDel || REDLINE_DELETE == pTmp->GetType() )
|
|
|
|
|
{
|
|
|
|
|
const SwPosition *pRStt = pTmp->Start(), *pREnd = pTmp->End();
|
|
|
|
|
switch( ComparePosition( *pRStt, *pREnd, aStPos, aEndPos ))
|
|
|
|
|
{
|
2001-01-26 17:09:51 +00:00
|
|
|
|
case POS_COLLIDE_START:
|
2000-09-18 23:08:29 +00:00
|
|
|
|
case POS_BEHIND: // Pos1 liegt hinter Pos2
|
|
|
|
|
nRedlPos = GetRedlineTbl().Count();
|
|
|
|
|
break;
|
|
|
|
|
|
2001-01-26 17:09:51 +00:00
|
|
|
|
case POS_COLLIDE_END:
|
2000-09-18 23:08:29 +00:00
|
|
|
|
case POS_BEFORE: // Pos1 liegt vor Pos2
|
|
|
|
|
break;
|
|
|
|
|
case POS_INSIDE: // Pos1 liegt vollstaendig in Pos2
|
|
|
|
|
// ist erlaubt, aber checke dann alle nachfolgenden
|
|
|
|
|
// auf Ueberlappungen
|
|
|
|
|
bCheckDel = FALSE;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case POS_OUTSIDE: // Pos2 liegt vollstaendig in Pos1
|
|
|
|
|
case POS_EQUAL: // Pos1 ist genauso gross wie Pos2
|
|
|
|
|
case POS_OVERLAP_BEFORE: // Pos1 ueberlappt Pos2 am Anfang
|
|
|
|
|
case POS_OVERLAP_BEHIND: // Pos1 ueberlappt Pos2 am Ende
|
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
{
|
|
|
|
|
// DataChanged vorm verschieben verschicken, dann bekommt
|
|
|
|
|
// man noch mit, welche Objecte sich im Bereich befinden.
|
|
|
|
|
// Danach koennen sie vor/hinter der Position befinden.
|
|
|
|
|
SwDataChanged aTmp( rPam, 0 );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SwNodeIndex aIdx( nOffset > 0 ? pEnd->nNode : pStt->nNode, nOffs );
|
|
|
|
|
SwNodeRange aMvRg( pStt->nNode, 0, pEnd->nNode, +1 );
|
|
|
|
|
|
|
|
|
|
SwRedline* pOwnRedl = 0;
|
|
|
|
|
if( IsRedlineOn() )
|
|
|
|
|
{
|
|
|
|
|
// wenn der Bereich komplett im eigenen Redline liegt, kann es
|
|
|
|
|
// verschoben werden!
|
|
|
|
|
USHORT nRedlPos = GetRedlinePos( pStt->nNode.GetNode(), REDLINE_INSERT );
|
|
|
|
|
if( USHRT_MAX != nRedlPos )
|
|
|
|
|
{
|
|
|
|
|
SwRedline* pTmp = GetRedlineTbl()[ nRedlPos ];
|
|
|
|
|
const SwPosition *pRStt = pTmp->Start(), *pREnd = pTmp->End();
|
|
|
|
|
SwRedline aTmpRedl( REDLINE_INSERT, rPam );
|
|
|
|
|
const SwCntntNode* pCEndNd = pEnd->nNode.GetNode().GetCntntNode();
|
|
|
|
|
// liegt komplett im Bereich, und ist auch der eigene Redline?
|
|
|
|
|
if( aTmpRedl.IsOwnRedline( *pTmp ) &&
|
|
|
|
|
(pRStt->nNode < pStt->nNode ||
|
|
|
|
|
(pRStt->nNode == pStt->nNode && !pRStt->nContent.GetIndex()) ) &&
|
|
|
|
|
(pEnd->nNode < pREnd->nNode ||
|
|
|
|
|
(pEnd->nNode == pREnd->nNode &&
|
|
|
|
|
pCEndNd ? pREnd->nContent.GetIndex() == pCEndNd->Len()
|
|
|
|
|
: !pREnd->nContent.GetIndex() )) )
|
|
|
|
|
{
|
|
|
|
|
pOwnRedl = pTmp;
|
|
|
|
|
if( nRedlPos + 1 < GetRedlineTbl().Count() )
|
|
|
|
|
{
|
|
|
|
|
pTmp = GetRedlineTbl()[ nRedlPos+1 ];
|
|
|
|
|
if( *pTmp->Start() == *pREnd )
|
|
|
|
|
// dann doch nicht!
|
|
|
|
|
pOwnRedl = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if( pOwnRedl &&
|
|
|
|
|
!( pRStt->nNode <= aIdx && aIdx <= pREnd->nNode ))
|
|
|
|
|
{
|
|
|
|
|
// nicht in sich selbst, dann auch nicht moven
|
|
|
|
|
pOwnRedl = 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if( !pOwnRedl )
|
|
|
|
|
{
|
|
|
|
|
StartUndo( UNDO_START );
|
|
|
|
|
|
|
|
|
|
// zuerst das Insert, dann das Loeschen
|
|
|
|
|
SwPosition aInsPos( aIdx );
|
|
|
|
|
aInsPos.nContent.Assign( aIdx.GetNode().GetCntntNode(), 0 );
|
|
|
|
|
|
|
|
|
|
SwPaM aPam( pStt->nNode, aMvRg.aEnd );
|
|
|
|
|
|
|
|
|
|
SwPaM& rOrigPam = (SwPaM&)rPam;
|
|
|
|
|
rOrigPam.DeleteMark();
|
|
|
|
|
rOrigPam.GetPoint()->nNode = aIdx.GetIndex() - 1;
|
|
|
|
|
|
|
|
|
|
BOOL bDelLastPara = !aInsPos.nNode.GetNode().IsCntntNode();
|
|
|
|
|
|
2002-11-14 17:29:22 +00:00
|
|
|
|
/* #101076# When copying to a non-content node Copy will
|
|
|
|
|
insert a paragraph before that node and insert before
|
|
|
|
|
that inserted node. Copy creates an SwUndoInserts that
|
|
|
|
|
does not cover the extra paragraph. Thus we insert the
|
|
|
|
|
extra paragraph ourselves, _with_ correct undo
|
|
|
|
|
information. */
|
2002-11-14 16:35:11 +00:00
|
|
|
|
if (bDelLastPara)
|
|
|
|
|
{
|
2002-11-14 17:29:22 +00:00
|
|
|
|
/* aInsPos points to the non-content node. Move it to
|
|
|
|
|
the previous content node. */
|
2002-11-14 16:35:11 +00:00
|
|
|
|
SwPaM aInsPam(aInsPos);
|
|
|
|
|
BOOL bMoved = aInsPam.Move(fnMoveBackward);
|
|
|
|
|
ASSERT(bMoved, "No content node found!");
|
|
|
|
|
|
|
|
|
|
if (bMoved)
|
|
|
|
|
{
|
2002-11-14 17:29:22 +00:00
|
|
|
|
/* Append the new node after the content node
|
|
|
|
|
found. The new position to insert the moved
|
|
|
|
|
paragraph at is before the inserted
|
|
|
|
|
paragraph. */
|
2002-11-14 16:35:11 +00:00
|
|
|
|
AppendTxtNode(*aInsPam.GetPoint());
|
|
|
|
|
aInsPos = *aInsPam.GetPoint();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
Copy( aPam, aInsPos );
|
|
|
|
|
if( bDelLastPara )
|
|
|
|
|
{
|
|
|
|
|
// dann muss der letzte leere Node wieder entfernt werden
|
|
|
|
|
aIdx = aInsPos.nNode;
|
|
|
|
|
SwCntntNode* pCNd = GetNodes().GoPrevious( &aInsPos.nNode );
|
|
|
|
|
xub_StrLen nCLen = 0; if( pCNd ) nCLen = pCNd->Len();
|
|
|
|
|
aInsPos.nContent.Assign( pCNd, nCLen );
|
|
|
|
|
|
|
|
|
|
// alle die im zu loeschenden Node stehen, mussen auf den
|
|
|
|
|
// naechsten umgestezt werden
|
|
|
|
|
SwPosition* pPos;
|
|
|
|
|
for( USHORT n = 0; n < GetRedlineTbl().Count(); ++n )
|
|
|
|
|
{
|
|
|
|
|
SwRedline* pTmp = GetRedlineTbl()[ n ];
|
|
|
|
|
if( ( pPos = &pTmp->GetBound(TRUE))->nNode == aIdx )
|
|
|
|
|
{
|
|
|
|
|
pPos->nNode++;
|
|
|
|
|
pPos->nContent.Assign( pPos->nNode.GetNode().GetCntntNode(),0);
|
|
|
|
|
}
|
|
|
|
|
if( ( pPos = &pTmp->GetBound(FALSE))->nNode == aIdx )
|
|
|
|
|
{
|
|
|
|
|
pPos->nNode++;
|
|
|
|
|
pPos->nContent.Assign( pPos->nNode.GetNode().GetCntntNode(),0);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
CorrRel( aIdx, aInsPos, 0, FALSE );
|
|
|
|
|
|
|
|
|
|
pCNd->JoinNext();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
rOrigPam.GetPoint()->nNode++;
|
|
|
|
|
rOrigPam.GetPoint()->nContent.Assign( rOrigPam.GetCntntNode(), 0 );
|
|
|
|
|
|
|
|
|
|
SwRedlineMode eOld = GetRedlineMode();
|
2003-04-01 14:30:16 +00:00
|
|
|
|
checkRedlining(eOld);
|
2000-09-18 23:08:29 +00:00
|
|
|
|
if( DoesUndo() )
|
|
|
|
|
{
|
|
|
|
|
//JP 06.01.98: MUSS noch optimiert werden!!!
|
|
|
|
|
SetRedlineMode( REDLINE_ON | REDLINE_SHOW_INSERT | REDLINE_SHOW_DELETE );
|
|
|
|
|
AppendUndo( new SwUndoRedlineDelete( aPam, UNDO_DELETE ));
|
|
|
|
|
}
|
2002-10-10 15:29:46 +00:00
|
|
|
|
|
|
|
|
|
SwRedline* pNewRedline = new SwRedline( REDLINE_DELETE, aPam );
|
|
|
|
|
|
|
|
|
|
// #101654# prevent assertion from aPam's target being deleted
|
|
|
|
|
// (Alternatively, one could just let aPam go out of scope, but
|
|
|
|
|
// that requires touching a lot of code.)
|
|
|
|
|
aPam.GetBound(TRUE).nContent.Assign( NULL, 0 );
|
|
|
|
|
aPam.GetBound(FALSE).nContent.Assign( NULL, 0 );
|
|
|
|
|
|
|
|
|
|
AppendRedline( pNewRedline );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
|
|
//JP 06.01.98: MUSS noch optimiert werden!!!
|
|
|
|
|
SetRedlineMode( eOld );
|
|
|
|
|
EndUndo( UNDO_END );
|
|
|
|
|
SetModified();
|
2002-11-14 16:35:11 +00:00
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if( !pOwnRedl && !IsIgnoreRedline() && GetRedlineTbl().Count() )
|
|
|
|
|
{
|
2004-07-30 13:55:41 +00:00
|
|
|
|
SwPaM aTemp(aIdx);
|
|
|
|
|
SplitRedline(aTemp);
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
|
|
|
|
|
2004-06-16 08:38:19 +00:00
|
|
|
|
ULONG nRedlSttNd(0), nRedlEndNd(0);
|
2000-09-18 23:08:29 +00:00
|
|
|
|
if( pOwnRedl )
|
|
|
|
|
{
|
|
|
|
|
const SwPosition *pRStt = pOwnRedl->Start(), *pREnd = pOwnRedl->End();
|
|
|
|
|
nRedlSttNd = pRStt->nNode.GetIndex();
|
|
|
|
|
nRedlEndNd = pREnd->nNode.GetIndex();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SwUndoMoveNum* pUndo = 0;
|
|
|
|
|
if( DoesUndo() )
|
|
|
|
|
pUndo = new SwUndoMoveNum( rPam, nOffset, bIsOutlMv );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Move( aMvRg, aIdx, DOC_MOVEREDLINES );
|
|
|
|
|
|
|
|
|
|
if( pUndo )
|
|
|
|
|
{
|
|
|
|
|
ClearRedo();
|
|
|
|
|
pUndo->SetStartNode( rPam.Start()->nNode.GetIndex() );
|
|
|
|
|
AppendUndo( pUndo );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if( pOwnRedl )
|
|
|
|
|
{
|
|
|
|
|
SwPosition *pRStt = pOwnRedl->Start(), *pREnd = pOwnRedl->End();
|
|
|
|
|
if( pRStt->nNode.GetIndex() != nRedlSttNd )
|
|
|
|
|
{
|
|
|
|
|
pRStt->nNode = nRedlSttNd;
|
|
|
|
|
pRStt->nContent.Assign( pRStt->nNode.GetNode().GetCntntNode(),0);
|
|
|
|
|
}
|
|
|
|
|
if( pREnd->nNode.GetIndex() != nRedlEndNd )
|
|
|
|
|
{
|
|
|
|
|
pREnd->nNode = nRedlEndNd;
|
|
|
|
|
SwCntntNode* pCNd = pREnd->nNode.GetNode().GetCntntNode();
|
|
|
|
|
xub_StrLen nL = 0; if( pCNd ) nL = pCNd->Len();
|
|
|
|
|
pREnd->nContent.Assign( pCNd, nL );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SetModified();
|
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
2004-03-30 15:05:30 +00:00
|
|
|
|
// #115901#: bOutline removed
|
|
|
|
|
BOOL SwDoc::NumOrNoNum( const SwNodeIndex& rIdx, BOOL bDel )
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
|
|
|
|
BOOL bRet = FALSE;
|
2004-03-30 15:05:30 +00:00
|
|
|
|
const SwNodeNum* pNum = NULL;
|
|
|
|
|
const SfxPoolItem* pItem = NULL;
|
|
|
|
|
const SwNumRule* pRule = NULL;
|
2000-09-18 23:08:29 +00:00
|
|
|
|
SwTxtNode* pTNd = rIdx.GetNode().GetTxtNode();
|
|
|
|
|
|
2004-05-11 11:03:53 +00:00
|
|
|
|
BOOL bTmp = FALSE;
|
2004-03-30 15:05:30 +00:00
|
|
|
|
if (pTNd)
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-03-30 15:05:30 +00:00
|
|
|
|
BOOL bTmp = FALSE;
|
|
|
|
|
USHORT nOldLevel = 0;
|
|
|
|
|
|
2004-05-13 09:42:18 +00:00
|
|
|
|
pItem = pTNd->GetNoCondAttr(RES_PARATR_NUMRULE,TRUE);
|
2004-03-30 15:05:30 +00:00
|
|
|
|
|
2004-05-13 09:42:18 +00:00
|
|
|
|
if (pItem && ((SwNumRuleItem*)pItem)->GetValue().Len() )
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-05-13 09:42:18 +00:00
|
|
|
|
pNum = pTNd->GetNum();
|
2004-03-30 15:05:30 +00:00
|
|
|
|
|
2004-05-13 09:42:18 +00:00
|
|
|
|
if (pNum)
|
2004-03-30 15:05:30 +00:00
|
|
|
|
{
|
2004-05-13 09:42:18 +00:00
|
|
|
|
pRule = FindNumRulePtr(((SwNumRuleItem*)pItem)->
|
|
|
|
|
GetValue());
|
2004-03-30 15:05:30 +00:00
|
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
2004-03-30 15:05:30 +00:00
|
|
|
|
if (pRule)
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-03-30 15:05:30 +00:00
|
|
|
|
if (bDel)
|
2004-06-11 14:46:59 +00:00
|
|
|
|
bTmp = pNum->IsNum(); // #i29560#
|
2004-03-30 15:05:30 +00:00
|
|
|
|
else
|
2004-06-11 14:46:59 +00:00
|
|
|
|
bTmp = !pNum->IsNum(); // #i29560#
|
2004-03-30 15:05:30 +00:00
|
|
|
|
|
|
|
|
|
nOldLevel = pNum->GetLevel();
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
2004-03-30 15:05:30 +00:00
|
|
|
|
|
|
|
|
|
if (bTmp &&
|
|
|
|
|
SVX_NUM_NUMBER_NONE != pRule->Get(GetRealLevel(pNum->GetLevel())).
|
|
|
|
|
GetNumberingType())
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-06-11 14:46:59 +00:00
|
|
|
|
SwNodeNum aNum( *pNum );
|
2004-05-13 09:42:18 +00:00
|
|
|
|
|
2004-06-11 14:46:59 +00:00
|
|
|
|
if( bDel )
|
|
|
|
|
aNum.SetNoNum(TRUE); // #i29560#
|
2004-05-13 09:42:18 +00:00
|
|
|
|
else
|
2004-06-11 14:46:59 +00:00
|
|
|
|
aNum.SetNoNum(FALSE); // #i29560#
|
2004-05-13 09:42:18 +00:00
|
|
|
|
|
2004-03-30 15:05:30 +00:00
|
|
|
|
if( DoesUndo() )
|
|
|
|
|
{
|
|
|
|
|
ClearRedo();
|
2004-05-13 09:42:18 +00:00
|
|
|
|
AppendUndo( new SwUndoNumOrNoNum( rIdx, *pNum, aNum ) );
|
2004-03-30 15:05:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
pTNd->UpdateNum( aNum );
|
|
|
|
|
#ifndef NUM_RELSPACE
|
|
|
|
|
pTNd->SetNumLSpace( TRUE );
|
|
|
|
|
#endif
|
2004-03-30 15:05:30 +00:00
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
((SwNumRule*)pRule)->SetInvalidRule( TRUE );
|
|
|
|
|
UpdateNumRule( pRule->GetName(), rIdx.GetIndex() );
|
2004-03-30 15:05:30 +00:00
|
|
|
|
|
|
|
|
|
bRet = TRUE;
|
|
|
|
|
SetModified();
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
2004-03-30 15:05:30 +00:00
|
|
|
|
|
|
|
|
|
// -> #115901#
|
2004-06-11 14:46:59 +00:00
|
|
|
|
if (! bRet && bDel && pNum && !IsNum(nOldLevel)) // #i29560#
|
2004-03-30 15:05:30 +00:00
|
|
|
|
{
|
|
|
|
|
SwPaM aPam(*pTNd);
|
|
|
|
|
|
|
|
|
|
DelNumRules(aPam);
|
|
|
|
|
|
|
|
|
|
bRet = TRUE;
|
|
|
|
|
}
|
|
|
|
|
// <- #115901#
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
2004-03-30 15:05:30 +00:00
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
return bRet;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SwNumRule* SwDoc::GetCurrNumRule( const SwPosition& rPos ) const
|
|
|
|
|
{
|
|
|
|
|
SwNumRule* pRet = 0;
|
2004-11-26 12:24:12 +00:00
|
|
|
|
SwTxtNode* pTNd = rPos.nNode.GetNode().GetTxtNode();
|
|
|
|
|
|
|
|
|
|
if( pTNd )
|
2004-03-08 11:24:21 +00:00
|
|
|
|
pRet = pTNd->GetNumRule();
|
2000-09-18 23:08:29 +00:00
|
|
|
|
return pRet;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
USHORT SwDoc::FindNumRule( const String& rName ) const
|
|
|
|
|
{
|
|
|
|
|
for( USHORT n = pNumRuleTbl->Count(); n; )
|
|
|
|
|
if( (*pNumRuleTbl)[ --n ]->GetName() == rName )
|
|
|
|
|
return n;
|
|
|
|
|
/*
|
|
|
|
|
//JP 20.11.97: sollte man im Find neue Rule anlegen??
|
|
|
|
|
erstmal nicht
|
|
|
|
|
USHORT nPoolId = GetPoolId( rName, GET_POOLID_NUMRULE );
|
|
|
|
|
if( USHRT_MAX != nPoolId )
|
|
|
|
|
{
|
|
|
|
|
SwDoc* pThis = (SwDoc*)this;
|
|
|
|
|
SwNumRule* pR = pThis->GetNumRuleFromPool( nPoolId );
|
|
|
|
|
for( n = pNumRuleTbl->Count(); n; )
|
|
|
|
|
if( (*pNumRuleTbl)[ --n ] == pR )
|
|
|
|
|
return n;
|
|
|
|
|
}
|
|
|
|
|
*/
|
|
|
|
|
return USHRT_MAX;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SwNumRule* SwDoc::FindNumRulePtr( const String& rName ) const
|
|
|
|
|
{
|
2004-10-22 07:11:47 +00:00
|
|
|
|
SwNumRule * pResult = 0;
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
2004-10-22 07:11:47 +00:00
|
|
|
|
pResult = aNumRuleMap[rName];
|
|
|
|
|
|
2004-11-27 10:40:56 +00:00
|
|
|
|
if ( !pResult )
|
|
|
|
|
{
|
|
|
|
|
for (int n = 0; n < pNumRuleTbl->Count(); n++)
|
|
|
|
|
{
|
|
|
|
|
if ((*pNumRuleTbl)[n]->GetName() == rName)
|
|
|
|
|
{
|
|
|
|
|
pResult = (*pNumRuleTbl)[n];
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2004-10-22 07:11:47 +00:00
|
|
|
|
return pResult;
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
|
|
|
|
|
2004-11-27 10:40:56 +00:00
|
|
|
|
// #i36749#
|
|
|
|
|
void SwDoc::AddNumRule(SwNumRule * pRule)
|
|
|
|
|
{
|
|
|
|
|
pNumRuleTbl->Insert(pRule, pNumRuleTbl->Count());
|
|
|
|
|
aNumRuleMap[pRule->GetName()] = pRule;
|
|
|
|
|
pRule->SetNumRuleMap(&aNumRuleMap);
|
|
|
|
|
}
|
|
|
|
|
|
2004-09-08 14:17:53 +00:00
|
|
|
|
USHORT SwDoc::MakeNumRule( const String &rName, const SwNumRule* pCpy,
|
|
|
|
|
BOOL bBroadcast)
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
|
|
|
|
SwNumRule* pNew;
|
|
|
|
|
if( pCpy )
|
|
|
|
|
{
|
|
|
|
|
pNew = new SwNumRule( *pCpy );
|
|
|
|
|
pNew->SetName( GetUniqueNumRuleName( &rName ));
|
|
|
|
|
if( pNew->GetName() != rName )
|
|
|
|
|
{
|
|
|
|
|
pNew->SetPoolFmtId( USHRT_MAX );
|
|
|
|
|
pNew->SetPoolHelpId( USHRT_MAX );
|
|
|
|
|
pNew->SetPoolHlpFileId( UCHAR_MAX );
|
|
|
|
|
}
|
|
|
|
|
pNew->CheckCharFmts( this );
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
pNew = new SwNumRule( GetUniqueNumRuleName( &rName ) );
|
|
|
|
|
USHORT nRet = pNumRuleTbl->Count();
|
2004-09-08 14:17:53 +00:00
|
|
|
|
|
2004-11-27 10:40:56 +00:00
|
|
|
|
AddNumRule(pNew); // #i36749#
|
2004-10-22 07:11:47 +00:00
|
|
|
|
|
2004-09-08 14:17:53 +00:00
|
|
|
|
if (DoesUndo())
|
|
|
|
|
{
|
|
|
|
|
SwUndo * pUndo = new SwUndoNumruleCreate(pNew, this);
|
|
|
|
|
|
|
|
|
|
AppendUndo(pUndo);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (bBroadcast)
|
|
|
|
|
BroadcastStyleOperation(pNew->GetName(), SFX_STYLE_FAMILY_PSEUDO,
|
|
|
|
|
SFX_STYLESHEET_CREATED);
|
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
return nRet;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
String SwDoc::GetUniqueNumRuleName( const String* pChkStr, BOOL bAutoNum ) const
|
|
|
|
|
{
|
|
|
|
|
String aName;
|
|
|
|
|
if( bAutoNum )
|
|
|
|
|
{
|
|
|
|
|
long n = Time().GetTime();
|
|
|
|
|
n += Date().GetDate();
|
|
|
|
|
aName = String::CreateFromInt32( n );
|
|
|
|
|
if( pChkStr && !pChkStr->Len() )
|
|
|
|
|
pChkStr = 0;
|
|
|
|
|
}
|
|
|
|
|
else if( pChkStr && pChkStr->Len() )
|
|
|
|
|
aName = *pChkStr;
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
pChkStr = 0;
|
|
|
|
|
aName = SW_RESSTR( STR_NUMRULE_DEFNAME );
|
|
|
|
|
}
|
|
|
|
|
|
2004-06-16 08:38:19 +00:00
|
|
|
|
USHORT nNum(0), nTmp, nFlagSize = ( pNumRuleTbl->Count() / 8 ) +2;
|
2000-09-18 23:08:29 +00:00
|
|
|
|
BYTE* pSetFlags = new BYTE[ nFlagSize ];
|
|
|
|
|
memset( pSetFlags, 0, nFlagSize );
|
|
|
|
|
|
|
|
|
|
xub_StrLen nNmLen = aName.Len();
|
|
|
|
|
if( !bAutoNum && pChkStr )
|
|
|
|
|
{
|
|
|
|
|
while( nNmLen-- && '0' <= aName.GetChar( nNmLen ) &&
|
|
|
|
|
'9' >= aName.GetChar( nNmLen ) )
|
|
|
|
|
; //nop
|
|
|
|
|
|
|
|
|
|
if( ++nNmLen < aName.Len() )
|
|
|
|
|
{
|
|
|
|
|
aName.Erase( nNmLen );
|
|
|
|
|
pChkStr = 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const SwNumRule* pNumRule;
|
2003-12-01 15:34:51 +00:00
|
|
|
|
USHORT n;
|
|
|
|
|
|
|
|
|
|
for( n = 0; n < pNumRuleTbl->Count(); ++n )
|
2000-09-18 23:08:29 +00:00
|
|
|
|
if( 0 != ( pNumRule = (*pNumRuleTbl)[ n ] ) )
|
|
|
|
|
{
|
|
|
|
|
const String& rNm = pNumRule->GetName();
|
|
|
|
|
if( rNm.Match( aName ) == nNmLen )
|
|
|
|
|
{
|
|
|
|
|
// Nummer bestimmen und das Flag setzen
|
|
|
|
|
nNum = rNm.Copy( nNmLen ).ToInt32();
|
|
|
|
|
if( nNum-- && nNum < pNumRuleTbl->Count() )
|
|
|
|
|
pSetFlags[ nNum / 8 ] |= (0x01 << ( nNum & 0x07 ));
|
|
|
|
|
}
|
|
|
|
|
if( pChkStr && pChkStr->Equals( rNm ) )
|
|
|
|
|
pChkStr = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if( !pChkStr )
|
|
|
|
|
{
|
|
|
|
|
// alle Nummern entsprechend geflag, also bestimme die richtige Nummer
|
|
|
|
|
nNum = pNumRuleTbl->Count();
|
|
|
|
|
for( n = 0; n < nFlagSize; ++n )
|
|
|
|
|
if( 0xff != ( nTmp = pSetFlags[ n ] ))
|
|
|
|
|
{
|
|
|
|
|
// also die Nummer bestimmen
|
|
|
|
|
nNum = n * 8;
|
|
|
|
|
while( nTmp & 1 )
|
|
|
|
|
++nNum, nTmp >>= 1;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
2004-02-04 13:06:52 +00:00
|
|
|
|
delete [] pSetFlags;
|
2000-09-18 23:08:29 +00:00
|
|
|
|
if( pChkStr && pChkStr->Len() )
|
|
|
|
|
return *pChkStr;
|
|
|
|
|
return aName += String::CreateFromInt32( ++nNum );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const SwNode* lcl_FindBaseNode( const SwNode& rNd )
|
|
|
|
|
{
|
|
|
|
|
const SwNodes& rNds = rNd.GetNodes();
|
|
|
|
|
ULONG nNdIdx = rNd.GetIndex();
|
|
|
|
|
if( nNdIdx > rNds.GetEndOfExtras().GetIndex() )
|
|
|
|
|
return rNds.GetEndOfContent().FindStartNode();
|
|
|
|
|
|
|
|
|
|
const SwNode* pSttNd = rNds[ ULONG(0) ]->FindStartNode();
|
|
|
|
|
const SwNode* pNd = rNd.FindStartNode();
|
|
|
|
|
while( pSttNd != pNd->FindStartNode()->FindStartNode() )
|
|
|
|
|
pNd = pNd->FindStartNode();
|
|
|
|
|
return pNd;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void SwDoc::UpdateNumRule()
|
|
|
|
|
{
|
2004-11-27 10:40:56 +00:00
|
|
|
|
const SwNumRuleTbl& rNmTbl = GetNumRuleTbl();
|
2000-09-18 23:08:29 +00:00
|
|
|
|
for( USHORT n = 0; n < rNmTbl.Count(); ++n )
|
|
|
|
|
if( rNmTbl[ n ]->IsInvalidRule() )
|
|
|
|
|
UpdateNumRule( rNmTbl[ n ]->GetName(), ULONG_MAX );
|
2004-03-08 11:24:21 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// -> #111955#
|
|
|
|
|
/**
|
|
|
|
|
Reset numbering to start values.
|
|
|
|
|
|
|
|
|
|
@param rNum the numbering to reset
|
|
|
|
|
@param rNumRule the numbering rule to take the start values
|
|
|
|
|
from
|
|
|
|
|
@param nStartLevel the level to start
|
|
|
|
|
@param bInitializedLevels array to mark reset levels in
|
|
|
|
|
|
|
|
|
|
All values in rNum that have a level >= nStartLevel are set to
|
|
|
|
|
their start level. The start level is looked up in rNumRule. For
|
|
|
|
|
all levels >= nStartLevel the accroding entry in bInitializedLevels
|
|
|
|
|
is set to true.
|
|
|
|
|
*/
|
|
|
|
|
void lcl_NodeNumReset(SwNodeNum & rNum, const SwNumRule & rNumRule,
|
|
|
|
|
int nStartLevel, bool * bInitializedLevels)
|
|
|
|
|
{
|
|
|
|
|
for (int i = nStartLevel; i < MAXLEVEL; i++)
|
|
|
|
|
{
|
|
|
|
|
rNum.GetLevelVal()[i] = rNumRule.Get(i).GetStart();
|
|
|
|
|
bInitializedLevels[i] = true;
|
|
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
|
|
|
|
|
2004-03-08 11:24:21 +00:00
|
|
|
|
/**
|
|
|
|
|
Update numbering for all nodes that have a certain numbering rule.
|
|
|
|
|
|
|
|
|
|
@param rName name of the numbering rule to search for
|
|
|
|
|
@param nUpdatePos document position to start at
|
|
|
|
|
*/
|
|
|
|
|
void SwDoc::UpdateNumRule( const String& rName, ULONG nUpdatePos )
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-03-08 11:24:21 +00:00
|
|
|
|
SwNumRule * pRule = FindNumRulePtr(rName);
|
|
|
|
|
ASSERT(pRule, "numrule not found");
|
|
|
|
|
if (pRule == NULL)
|
2004-11-27 10:40:56 +00:00
|
|
|
|
{
|
2004-03-08 11:24:21 +00:00
|
|
|
|
return;
|
2004-11-27 10:40:56 +00:00
|
|
|
|
}
|
2004-03-08 11:24:21 +00:00
|
|
|
|
|
|
|
|
|
UpdateNumRule(*pRule, nUpdatePos);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2004-11-09 12:44:19 +00:00
|
|
|
|
Helper function for SwDoc::UpdateNumRule. Update the num rule
|
|
|
|
|
rRule, using the nodes from rNumRuleInfo.GetList() with indices
|
|
|
|
|
[nUpdatePos..nLast].
|
|
|
|
|
|
|
|
|
|
@param rRule the num rule to update
|
|
|
|
|
@param rNumRuleInfo a suitable SwNumRuleInfo with an up-to-date node list
|
|
|
|
|
@param nUpdatePos start index into rNumRuleInfo.GetList()
|
|
|
|
|
@param nLast end index into rNumRuleInfo.GetList()
|
|
|
|
|
@param bInit TRUE: restart numbering, FALSE: continue numbering
|
|
|
|
|
*/
|
|
|
|
|
void lcl_UpdateNumRuleRange( SwNumRule & rRule,
|
|
|
|
|
SwNumRuleInfo& rNumRuleInfo,
|
|
|
|
|
ULONG nUpdatePos,
|
|
|
|
|
ULONG nLast,
|
|
|
|
|
BOOL bInit )
|
2004-03-08 11:24:21 +00:00
|
|
|
|
{
|
2004-11-09 12:44:19 +00:00
|
|
|
|
// early out, if there is nothing to do.
|
|
|
|
|
if( nUpdatePos >= nLast )
|
2004-03-08 11:24:21 +00:00
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
/* Temporal numbering holding the values to be changed in the
|
|
|
|
|
current node*/
|
2004-11-16 14:39:29 +00:00
|
|
|
|
SwNodeNum aNum(0), aOldNum(0);
|
2004-03-08 11:24:21 +00:00
|
|
|
|
/* Array for initialized levels.
|
|
|
|
|
bInitializedLevels[i] == true -> level i is initialized.
|
|
|
|
|
*/
|
|
|
|
|
bool bInitializedLevels[MAXLEVEL];
|
|
|
|
|
/* flag for initialized continuous numbering. */
|
|
|
|
|
bool bInitialized = false;
|
|
|
|
|
/* counter for continuous numbering */
|
|
|
|
|
int nCount = 0;
|
|
|
|
|
|
2005-03-08 10:21:10 +00:00
|
|
|
|
while (nUpdatePos < nLast)
|
|
|
|
|
{
|
|
|
|
|
SwTxtNode * pTxtNode = rNumRuleInfo.GetList().GetObject(nUpdatePos);
|
|
|
|
|
|
|
|
|
|
if (pTxtNode->MayBeNumbered())
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
nUpdatePos++;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (nUpdatePos >= nLast)
|
|
|
|
|
return;
|
|
|
|
|
|
2004-03-08 11:24:21 +00:00
|
|
|
|
/* If all paragraphs found are to be processed initialize all
|
|
|
|
|
levels with their start values.*/
|
2004-11-09 12:44:19 +00:00
|
|
|
|
if ( bInit )
|
2004-03-08 11:24:21 +00:00
|
|
|
|
{
|
|
|
|
|
for (int i = 0; i < MAXLEVEL; i++)
|
|
|
|
|
bInitializedLevels[i] = false;
|
|
|
|
|
|
|
|
|
|
lcl_NodeNumReset(aNum, rRule, 0, bInitializedLevels);
|
|
|
|
|
|
|
|
|
|
nCount = rRule.Get(0).GetStart();
|
|
|
|
|
bInitialized = true;
|
|
|
|
|
}
|
|
|
|
|
else /* If we start at a certain paragraph fill aNum/nCount with
|
|
|
|
|
values from that paragraph. Mark all levels as initalized,
|
|
|
|
|
including continuous numbering. */
|
|
|
|
|
{
|
|
|
|
|
for (int i = 0; i < MAXLEVEL; i++)
|
|
|
|
|
bInitializedLevels[i] = true;
|
|
|
|
|
|
2004-11-09 12:44:19 +00:00
|
|
|
|
aNum = *rNumRuleInfo.GetList().GetObject(nUpdatePos)->
|
2004-03-30 15:05:30 +00:00
|
|
|
|
GetNum(); // #115901#
|
2004-03-08 11:24:21 +00:00
|
|
|
|
|
|
|
|
|
nCount = aNum.GetLevelVal()[aNum.GetRealLevel()];
|
|
|
|
|
bInitialized = true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* The old level is the level of the first node to process. */
|
2004-11-09 12:44:19 +00:00
|
|
|
|
ASSERT( nUpdatePos < rNumRuleInfo.GetList().Count(), "wrong index" );
|
|
|
|
|
const SwNodeNum * pNum = rNumRuleInfo.GetList().GetObject(nUpdatePos)->
|
2004-03-08 11:24:21 +00:00
|
|
|
|
GetNum();
|
|
|
|
|
BYTE nOldLevel = pNum ? pNum->GetLevel() : 0;
|
|
|
|
|
|
|
|
|
|
/* Iterate over all nodes to process. */
|
2004-11-09 12:44:19 +00:00
|
|
|
|
while(nUpdatePos < nLast)
|
2004-03-08 11:24:21 +00:00
|
|
|
|
{
|
|
|
|
|
/* Get the current node. */
|
2004-11-09 12:44:19 +00:00
|
|
|
|
SwTxtNode * pTxtNode = rNumRuleInfo.GetList().GetObject(nUpdatePos);
|
2004-03-08 11:24:21 +00:00
|
|
|
|
|
2005-03-29 13:37:07 +00:00
|
|
|
|
/* Get old numbering of the current node. */
|
|
|
|
|
const SwNodeNum * pOldNum = pTxtNode->GetNum(); // #115901#
|
|
|
|
|
|
2004-03-30 15:05:30 +00:00
|
|
|
|
if (pTxtNode->MayBeNumbered())
|
2004-03-08 11:24:21 +00:00
|
|
|
|
{
|
2004-03-30 15:05:30 +00:00
|
|
|
|
/* If the current node has a conditional paragraph style,
|
|
|
|
|
ensure the current node gets the resulting style. */
|
|
|
|
|
if( RES_CONDTXTFMTCOLL == pTxtNode->GetFmtColl()->Which() )
|
|
|
|
|
pTxtNode->ChkCondColl();
|
2004-03-08 11:24:21 +00:00
|
|
|
|
|
2004-03-30 15:05:30 +00:00
|
|
|
|
// #111955# fixed loop due to not increasing nUpdatePos when
|
|
|
|
|
// pOldNum == 0
|
2004-06-11 14:46:59 +00:00
|
|
|
|
if (pOldNum && pOldNum->IsNum()) // #i29560#
|
2004-03-08 11:24:21 +00:00
|
|
|
|
{
|
2004-03-30 15:05:30 +00:00
|
|
|
|
BYTE nLevel = pOldNum->GetRealLevel();
|
2004-03-08 11:24:21 +00:00
|
|
|
|
|
2004-03-30 15:05:30 +00:00
|
|
|
|
/* If numbering restarts at the current node ...*/
|
|
|
|
|
if (pOldNum->IsStart())
|
|
|
|
|
{
|
|
|
|
|
/* Fill aNum with start values of current level and
|
|
|
|
|
subsequent levels. */
|
|
|
|
|
lcl_NodeNumReset(aNum, rRule, nLevel, bInitializedLevels);
|
|
|
|
|
|
|
|
|
|
/* Fill nCount with start values for continuous
|
|
|
|
|
numbering. */
|
|
|
|
|
nCount = rRule.Get(0).GetStart();
|
|
|
|
|
bInitialized = true;
|
|
|
|
|
}
|
|
|
|
|
/* If numbering restarts with a specific value ...*/
|
|
|
|
|
else if (pOldNum->HasSetValue())
|
|
|
|
|
{
|
|
|
|
|
/* Fill aNum with start values of current level and
|
|
|
|
|
subsequent levels. This also marks the current level as
|
|
|
|
|
initialized. Set specific value for current level. */
|
|
|
|
|
lcl_NodeNumReset(aNum, rRule, nLevel, bInitializedLevels);
|
|
|
|
|
aNum.GetLevelVal()[nLevel] = pOldNum->GetSetValue();
|
|
|
|
|
|
|
|
|
|
/* Fill nCount with the specific start value. */
|
|
|
|
|
nCount = pOldNum->GetSetValue();
|
|
|
|
|
bInitialized = true;
|
|
|
|
|
}
|
|
|
|
|
/* If the current node is the first in a row of nodes of its
|
|
|
|
|
level initialize the subsequent levels. */
|
|
|
|
|
else if (nOldLevel != nLevel)
|
|
|
|
|
{
|
|
|
|
|
lcl_NodeNumReset(aNum, rRule, nLevel + 1,
|
|
|
|
|
bInitializedLevels);
|
|
|
|
|
}
|
|
|
|
|
nOldLevel = nLevel;
|
|
|
|
|
|
|
|
|
|
int i;
|
|
|
|
|
|
|
|
|
|
/* All previous levels are initialized. */
|
|
|
|
|
for (i = nLevel - 1; i >= 0; i--)
|
|
|
|
|
bInitializedLevels[i] = false;
|
|
|
|
|
|
|
|
|
|
/* If the level of the current node is initialized do not
|
|
|
|
|
increase the value for this level. Mark this level as
|
|
|
|
|
uninitialized. */
|
|
|
|
|
if (bInitializedLevels[nLevel])
|
|
|
|
|
bInitializedLevels[nLevel] = false;
|
|
|
|
|
else /* If the level of the current node was not initialized
|
|
|
|
|
increase the value for this level. */
|
|
|
|
|
aNum.GetLevelVal()[nLevel]++;
|
|
|
|
|
|
|
|
|
|
/* If the continuous numbering was initialized. mark it as
|
|
|
|
|
uninitialized and do not increase the value for the
|
|
|
|
|
continuous numbering. */
|
|
|
|
|
if (bInitialized)
|
|
|
|
|
bInitialized = false;
|
|
|
|
|
else /* If the continuous numbering was not initialized,
|
|
|
|
|
increase its value. */
|
|
|
|
|
nCount++;
|
|
|
|
|
|
|
|
|
|
/* If the current numbering is continuous set the value for
|
|
|
|
|
the current level to the value of the continous
|
|
|
|
|
numbering. Mark the current numbering as
|
|
|
|
|
continous. Otherwise mark the current numbering as
|
|
|
|
|
non-continuous. */
|
|
|
|
|
if (rRule.IsContinusNum())
|
|
|
|
|
{
|
|
|
|
|
aNum.GetLevelVal()[nLevel] = nCount;
|
|
|
|
|
aNum.SetContinuousNum();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
aNum.SetContinuousNum(FALSE);
|
|
|
|
|
}
|
2004-03-08 11:24:21 +00:00
|
|
|
|
|
2004-03-30 15:05:30 +00:00
|
|
|
|
/* bChanged = true -> the current node's numbering has
|
|
|
|
|
to be altered. */
|
|
|
|
|
bool bChanged = false;
|
2004-03-08 11:24:21 +00:00
|
|
|
|
|
2004-03-30 15:05:30 +00:00
|
|
|
|
/* the numbering to replace the current numbering */
|
|
|
|
|
SwNodeNum aTmpNum = *pOldNum;
|
2004-03-08 11:24:21 +00:00
|
|
|
|
|
2004-03-30 15:05:30 +00:00
|
|
|
|
if (aNum.IsContinuousNum() != aTmpNum.IsContinuousNum())
|
2004-03-08 11:24:21 +00:00
|
|
|
|
{
|
2004-03-30 15:05:30 +00:00
|
|
|
|
/* Continuous numbering has been activated or deactivated
|
|
|
|
|
-> change the numbering of the current node. */
|
|
|
|
|
aTmpNum.SetContinuousNum(aNum.IsContinuousNum());
|
|
|
|
|
aTmpNum.GetLevelVal()[nLevel] = nCount;
|
2004-03-08 11:24:21 +00:00
|
|
|
|
bChanged = true;
|
|
|
|
|
}
|
|
|
|
|
|
2004-03-30 15:05:30 +00:00
|
|
|
|
/* For each level synchronize the local numbering (aNum)
|
|
|
|
|
with the numbering to be set in the current node
|
|
|
|
|
(aTmpNum). If there are differences propagate the value
|
|
|
|
|
fom aNum to aTmpNum. In this case the numbering of the
|
|
|
|
|
current node. */
|
|
|
|
|
for (i = 0; i < MAXLEVEL; i++)
|
|
|
|
|
{
|
|
|
|
|
if (aTmpNum.GetLevelVal()[i] != aNum.GetLevelVal()[i])
|
|
|
|
|
{
|
|
|
|
|
aTmpNum.GetLevelVal()[i] = aNum.GetLevelVal()[i];
|
|
|
|
|
bChanged = true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* If the current node's numbering is to be changed change the
|
|
|
|
|
according normal or outline numbering. */
|
|
|
|
|
if (bChanged)
|
|
|
|
|
{
|
|
|
|
|
// #115901#
|
2004-03-08 11:24:21 +00:00
|
|
|
|
pTxtNode->UpdateNum(aTmpNum);
|
2004-03-30 15:05:30 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2004-11-16 14:39:29 +00:00
|
|
|
|
else if (! pOldNum)
|
2004-03-30 15:05:30 +00:00
|
|
|
|
{
|
2004-06-11 14:46:59 +00:00
|
|
|
|
ASSERT(0, "No number!");
|
2004-03-08 11:24:21 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2005-03-29 13:37:07 +00:00
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (pOldNum)
|
|
|
|
|
{
|
|
|
|
|
BYTE nLevel = pOldNum->GetRealLevel();
|
|
|
|
|
|
|
|
|
|
lcl_NodeNumReset(aNum, rRule, nLevel + 1, bInitializedLevels);
|
|
|
|
|
}
|
|
|
|
|
}
|
2004-03-08 11:24:21 +00:00
|
|
|
|
|
|
|
|
|
nUpdatePos++;
|
|
|
|
|
}
|
2004-11-16 14:39:29 +00:00
|
|
|
|
|
|
|
|
|
rRule.SetInvalidRule(FALSE);
|
2004-03-08 11:24:21 +00:00
|
|
|
|
}
|
|
|
|
|
|
2004-11-09 12:44:19 +00:00
|
|
|
|
/** helper function for SwDoc::UpdateNumRule: update rule rRule within
|
|
|
|
|
the node section given by rNode using the nodes in
|
|
|
|
|
rNumRuleInfo.GetList(), starting from nUpdatePos.
|
|
|
|
|
|
|
|
|
|
@param rRule the SwNumRule we wish to update
|
|
|
|
|
@param rNumRuleInfo contains the list of nodes using rRule to be updated
|
|
|
|
|
@param rNode SwNode whose section will be updated
|
|
|
|
|
Note: the entire section from rNode.FindStartNode()
|
|
|
|
|
will be updated (see also nUpdatePos)
|
|
|
|
|
@param nUpdatePos update nodes >= rNumRuleInfo.GetList()[nUpdatePos]
|
|
|
|
|
*/
|
|
|
|
|
void lcl_UpdateNumRuleSection( SwNumRule& rRule,
|
|
|
|
|
SwNumRuleInfo& rNumRuleInfo,
|
|
|
|
|
SwNode& rNode,
|
|
|
|
|
ULONG& nUpdatePos )
|
|
|
|
|
{
|
|
|
|
|
// determine start/end positions
|
|
|
|
|
SwEndNode* pEndNode = rNode.EndOfSectionNode();
|
|
|
|
|
SwStartNode* pStartNode = pEndNode->StartOfSectionNode();
|
|
|
|
|
|
|
|
|
|
// determine start/end positions in node list
|
|
|
|
|
ULONG nStartPos = 0;
|
|
|
|
|
rNumRuleInfo.GetList().SearchKey( pStartNode->GetIndex(), &nStartPos );
|
|
|
|
|
ULONG nEndPos = 0;
|
|
|
|
|
rNumRuleInfo.GetList().SearchKey( pEndNode->GetIndex(), &nEndPos );
|
|
|
|
|
|
|
|
|
|
// update nodes (unless our section is before nUpdatePos)
|
|
|
|
|
if( nUpdatePos <= nEndPos )
|
|
|
|
|
{
|
|
|
|
|
// restart numbering unless nUpdatePos forces an update into the
|
|
|
|
|
// middle of a section
|
|
|
|
|
BOOL bInit = ( nUpdatePos <= nStartPos );
|
|
|
|
|
lcl_UpdateNumRuleRange( rRule, rNumRuleInfo,
|
|
|
|
|
nStartPos, nEndPos, bInit );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** helper function for SwDoc::UpdateNumRule: update num rule
|
|
|
|
|
seperately for each node section contained within the section
|
|
|
|
|
given by rNode. (Typically used to e.g. seperately update each
|
|
|
|
|
footnote or text box.)
|
|
|
|
|
|
|
|
|
|
Except for rNode, parameters are passed through to lcl_UpdateNumRuleSection
|
|
|
|
|
@see lcl_UpdateNumRuleSection for parameters
|
|
|
|
|
*/
|
|
|
|
|
void lcl_UpdateNumRuleSectionOfSections( SwNumRule & rRule,
|
|
|
|
|
SwNumRuleInfo& rNumRuleInfo,
|
|
|
|
|
SwNode& rNode,
|
|
|
|
|
ULONG& nUpdatePos )
|
|
|
|
|
{
|
|
|
|
|
ULONG nEndIndex = rNode.StartOfSectionNode()->EndOfSectionNode()->GetIndex();
|
|
|
|
|
SwNodeIndex aNodeIndex( *rNode.StartOfSectionNode() );
|
|
|
|
|
aNodeIndex++;
|
|
|
|
|
while( aNodeIndex < nEndIndex )
|
|
|
|
|
{
|
|
|
|
|
lcl_UpdateNumRuleSection( rRule, rNumRuleInfo, aNodeIndex.GetNode(),
|
|
|
|
|
nUpdatePos );
|
|
|
|
|
aNodeIndex = *aNodeIndex.GetNode().EndOfSectionNode();
|
|
|
|
|
aNodeIndex++;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// #115901#: bOutline removed
|
|
|
|
|
/**
|
|
|
|
|
Update numbering for all nodes that have a certain numbering rule.
|
|
|
|
|
|
|
|
|
|
@param rRule numbering rule to search for
|
|
|
|
|
@param nUpdatePos document position to start at
|
|
|
|
|
*/
|
|
|
|
|
void SwDoc::UpdateNumRule( SwNumRule & rRule, ULONG nUpdatePos)
|
|
|
|
|
{
|
|
|
|
|
if (IsInReading())
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
/* If old numbering is activated use the old algorithm. */
|
|
|
|
|
if (IsOldNumbering())
|
|
|
|
|
{
|
|
|
|
|
UpdateNumRuleOld(rRule, nUpdatePos);
|
|
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Get all paragraphs with the given numbering rule from the
|
|
|
|
|
document. */
|
|
|
|
|
SwNumRuleInfo aNumRuleInfo(rRule.GetName());
|
|
|
|
|
aNumRuleInfo.MakeList(*this); // #115901#
|
|
|
|
|
|
|
|
|
|
/* If there are no matching paragraphs we are done. */
|
|
|
|
|
if (aNumRuleInfo.GetList().Count() == 0)
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
/* ULONG_MAX -> process all paragraphs found */
|
|
|
|
|
if (nUpdatePos == ULONG_MAX)
|
|
|
|
|
nUpdatePos = 0;
|
|
|
|
|
else /* nUpdatePos is still the position in the document. Convert
|
|
|
|
|
to position in the list of found paragraphs. */
|
2004-11-16 14:39:29 +00:00
|
|
|
|
{
|
2004-11-09 12:44:19 +00:00
|
|
|
|
aNumRuleInfo.GetList().SearchKey(nUpdatePos, &nUpdatePos);
|
|
|
|
|
|
2004-11-16 14:39:29 +00:00
|
|
|
|
if (nUpdatePos >= 0)
|
|
|
|
|
nUpdatePos--;
|
|
|
|
|
}
|
|
|
|
|
|
2004-11-09 12:44:19 +00:00
|
|
|
|
// #115901#
|
|
|
|
|
if (nUpdatePos >= aNumRuleInfo.GetList().Count())
|
|
|
|
|
{
|
|
|
|
|
nUpdatePos = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* number each range (frames, redlines, footnotes, etc.) seperately */
|
|
|
|
|
lcl_UpdateNumRuleSectionOfSections(
|
|
|
|
|
rRule, aNumRuleInfo, aNodes.GetEndOfPostIts(), nUpdatePos );
|
|
|
|
|
lcl_UpdateNumRuleSectionOfSections(
|
|
|
|
|
rRule, aNumRuleInfo, aNodes.GetEndOfInserts(), nUpdatePos );
|
|
|
|
|
lcl_UpdateNumRuleSectionOfSections(
|
|
|
|
|
rRule, aNumRuleInfo, aNodes.GetEndOfAutotext(), nUpdatePos );
|
|
|
|
|
lcl_UpdateNumRuleSectionOfSections(
|
|
|
|
|
rRule, aNumRuleInfo, aNodes.GetEndOfRedlines(), nUpdatePos );
|
|
|
|
|
lcl_UpdateNumRuleSectionOfSections(
|
|
|
|
|
rRule, aNumRuleInfo, aNodes.GetEndOfExtras(), nUpdatePos );
|
|
|
|
|
lcl_UpdateNumRuleSection(
|
|
|
|
|
rRule, aNumRuleInfo, aNodes.GetEndOfContent(), nUpdatePos );
|
|
|
|
|
}
|
|
|
|
|
|
2004-03-08 11:24:21 +00:00
|
|
|
|
// pre-SRC680-numbering
|
2004-03-11 13:04:03 +00:00
|
|
|
|
void SwDoc::UpdateNumRuleOld( SwNumRule & rRule, ULONG nUpdPos )
|
2004-03-08 11:24:21 +00:00
|
|
|
|
{
|
|
|
|
|
SwNumRuleInfo aUpd( rRule.GetName() );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
aUpd.MakeList( *this );
|
|
|
|
|
|
|
|
|
|
if( ULONG_MAX == nUpdPos )
|
|
|
|
|
nUpdPos = 0;
|
|
|
|
|
else
|
|
|
|
|
aUpd.GetList().SearchKey( nUpdPos, &nUpdPos );
|
|
|
|
|
|
2004-03-11 13:04:03 +00:00
|
|
|
|
SwNumRule* pRule = &rRule;
|
2004-03-08 11:24:21 +00:00
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
if( nUpdPos < aUpd.GetList().Count() )
|
|
|
|
|
{
|
|
|
|
|
USHORT nInitLevels = USHRT_MAX; // Bitfeld fuer die Levels!
|
|
|
|
|
// TRUE: starte mit NumFmt Start
|
|
|
|
|
USHORT nNumVal = 0;
|
|
|
|
|
SwNodeNum aNum( 0 );
|
|
|
|
|
|
|
|
|
|
if( pRule->IsContinusNum() )
|
2001-02-23 11:45:30 +00:00
|
|
|
|
nNumVal = pRule->Get( 0 ).GetStart();
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
|
|
SwTxtNode* pStt = aUpd.GetList().GetObject( nUpdPos );
|
|
|
|
|
SwTxtNode* pPrev = nUpdPos ? aUpd.GetList().GetObject( nUpdPos-1 ) : 0;
|
|
|
|
|
const SwNode* pBaseNd = lcl_FindBaseNode( *pStt );
|
|
|
|
|
if( pPrev && lcl_FindBaseNode( *pPrev ) == pBaseNd )
|
|
|
|
|
{
|
|
|
|
|
if( pPrev->GetNum() )
|
|
|
|
|
{
|
|
|
|
|
const SwNodeNum* pPrevNdNum = pPrev->GetNum();
|
2004-03-08 11:24:21 +00:00
|
|
|
|
if( ! pPrevNdNum->IsNum() )
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2002-12-10 15:03:17 +00:00
|
|
|
|
// OD 10.12.2002 #106111# - use correct search level
|
|
|
|
|
BYTE nSrchLvl = GetRealLevel( pStt->GetNum()->GetLevel() );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
pPrevNdNum = 0;
|
|
|
|
|
ULONG nArrPos = nUpdPos-1;
|
|
|
|
|
while( nArrPos-- )
|
|
|
|
|
{
|
|
|
|
|
pPrev = aUpd.GetList().GetObject( nArrPos );
|
|
|
|
|
if( lcl_FindBaseNode( *pPrev ) != pBaseNd )
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
if( 0 != ( pPrevNdNum = pPrev->GetNum() ))
|
|
|
|
|
{
|
|
|
|
|
// uebergeordnete Ebene
|
2004-03-08 11:24:21 +00:00
|
|
|
|
if( nSrchLvl > pPrevNdNum->GetRealLevel())
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
|
|
|
|
pPrevNdNum = 0;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
// gleiche Ebene und kein NO_NUMLEVEL
|
2004-03-08 11:24:21 +00:00
|
|
|
|
if( nSrchLvl == pPrevNdNum->GetRealLevel()
|
|
|
|
|
&& pPrevNdNum->IsNum())
|
2000-09-18 23:08:29 +00:00
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
pPrevNdNum = 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if( pPrevNdNum )
|
|
|
|
|
{
|
|
|
|
|
aNum = *pPrevNdNum;
|
|
|
|
|
aNum.SetStart( FALSE );
|
|
|
|
|
aNum.SetSetValue( USHRT_MAX );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
nInitLevels = 0;
|
2002-12-10 15:03:17 +00:00
|
|
|
|
// OD 10.12.2002 #106111# - sublevels have to be restarted.
|
|
|
|
|
for ( int nSubLvl = GetRealLevel( aNum.GetLevel() ) + 1; nSubLvl < MAXLEVEL; ++nSubLvl)
|
|
|
|
|
nInitLevels |= ( 1 << nSubLvl );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
nNumVal = aNum.GetLevelVal()[ GetRealLevel( aNum.GetLevel() ) ];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const SwNode* pOutlNd = 0;
|
|
|
|
|
for( ; nUpdPos < aUpd.GetList().Count(); ++nUpdPos )
|
|
|
|
|
{
|
|
|
|
|
pStt = aUpd.GetList().GetObject( nUpdPos );
|
|
|
|
|
|
|
|
|
|
const SwNode* pTmpBaseNd = lcl_FindBaseNode( *pStt );
|
|
|
|
|
if( pTmpBaseNd != pBaseNd )
|
|
|
|
|
{
|
|
|
|
|
aNum.SetLevel( 0 );
|
|
|
|
|
memset( aNum.GetLevelVal(), 0,
|
|
|
|
|
(MAXLEVEL) * sizeof( aNum.GetLevelVal()[0]) );
|
|
|
|
|
pBaseNd = pTmpBaseNd;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BYTE nLevel = aNum.GetLevel();
|
2005-02-04 10:14:52 +00:00
|
|
|
|
|
|
|
|
|
SetNoNum(&nLevel, ! pStt->IsNumbered());
|
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
BYTE nNdOldLvl = MAXLEVEL;
|
|
|
|
|
if( pStt->GetNum() )
|
|
|
|
|
{
|
2004-11-26 12:24:12 +00:00
|
|
|
|
if( pStt->GetNum()->IsNum())
|
2000-09-18 23:08:29 +00:00
|
|
|
|
nNdOldLvl = nLevel = pStt->GetNum()->GetLevel();
|
|
|
|
|
if( pStt->GetNum()->IsStart() )
|
|
|
|
|
{
|
|
|
|
|
aNum.SetStart( TRUE );
|
2002-12-10 15:03:17 +00:00
|
|
|
|
// OD 10.12.2002 #106111# - correct reset of level numbers
|
2004-11-26 12:24:12 +00:00
|
|
|
|
for ( int nSubLvl = GetRealLevel(nLevel);
|
|
|
|
|
nSubLvl < MAXLEVEL; ++nSubLvl)
|
2002-12-10 15:03:17 +00:00
|
|
|
|
aNum.GetLevelVal()[ nSubLvl ] = 0;
|
2000-09-18 23:08:29 +00:00
|
|
|
|
if( pRule->IsContinusNum() )
|
|
|
|
|
{
|
2001-02-23 11:45:30 +00:00
|
|
|
|
nNumVal = pRule->Get( 0 ).GetStart();
|
2000-09-18 23:08:29 +00:00
|
|
|
|
nInitLevels |= 1;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
nInitLevels |= ( 1 << GetRealLevel( nLevel ));
|
|
|
|
|
}
|
|
|
|
|
else if( USHRT_MAX != pStt->GetNum()->GetSetValue() )
|
2002-12-10 15:03:17 +00:00
|
|
|
|
{
|
2000-09-18 23:08:29 +00:00
|
|
|
|
aNum.SetSetValue( nNumVal = pStt->GetNum()->GetSetValue() );
|
2002-12-10 15:03:17 +00:00
|
|
|
|
// OD 10.12.2002 #106111# - init <nInitLevels> for continues
|
|
|
|
|
// numbering.
|
|
|
|
|
if( pRule->IsContinusNum() )
|
|
|
|
|
nInitLevels |= 1;
|
|
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
|
|
|
|
|
2004-03-08 11:24:21 +00:00
|
|
|
|
if( ! IsNum(nLevel )) // NoNum mit Ebene
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
|
|
|
|
BYTE nPrevLvl = GetRealLevel( aNum.GetLevel() ),
|
|
|
|
|
nCurrLvl = GetRealLevel( nLevel );
|
|
|
|
|
|
|
|
|
|
if( nPrevLvl < nCurrLvl )
|
|
|
|
|
{
|
|
|
|
|
if( !(nInitLevels & ( 1 << nPrevLvl )) )
|
|
|
|
|
++nPrevLvl;
|
|
|
|
|
for( ; nPrevLvl < nCurrLvl; ++nPrevLvl )
|
|
|
|
|
nInitLevels |= ( 1 << nPrevLvl );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
aNum.SetLevel( nLevel );
|
2005-02-04 10:14:52 +00:00
|
|
|
|
aNum.SetNoNum(! IsNum(nLevel));
|
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
pStt->UpdateNum( aNum );
|
|
|
|
|
}
|
2004-03-08 11:24:21 +00:00
|
|
|
|
else //if( NO_NUM != nLevel )
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-11-26 12:24:12 +00:00
|
|
|
|
ASSERT(IsNum(nLevel), "NO_NUM?");
|
2004-03-08 11:24:21 +00:00
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
// beim Format mit Bitmap die Graphicen schon mal anfordern
|
|
|
|
|
const SwNumFmt* pNumFmt = pRule->GetNumFmt( GetRealLevel( nLevel ));
|
2004-03-30 15:05:30 +00:00
|
|
|
|
if (! (pNumFmt && SVX_NUM_NUMBER_NONE == pNumFmt->GetNumberingType()))
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-03-30 15:05:30 +00:00
|
|
|
|
if( pNumFmt && SVX_NUM_BITMAP == pNumFmt->GetNumberingType() )
|
|
|
|
|
pNumFmt->GetGraphic();
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
2004-03-30 15:05:30 +00:00
|
|
|
|
if( pRule->IsContinusNum() )
|
|
|
|
|
{
|
|
|
|
|
if( !(nInitLevels & 1) &&
|
|
|
|
|
!( pNumFmt && (SVX_NUM_CHAR_SPECIAL == pNumFmt->GetNumberingType() ||
|
|
|
|
|
SVX_NUM_BITMAP == pNumFmt->GetNumberingType() ||
|
|
|
|
|
SVX_NUM_NUMBER_NONE == pNumFmt->GetNumberingType() )))
|
|
|
|
|
++nNumVal;
|
2004-11-26 12:24:12 +00:00
|
|
|
|
aNum.GetLevelVal()[ GetRealLevel(nLevel) ] = nNumVal;
|
2004-03-30 15:05:30 +00:00
|
|
|
|
// OD 10.12.2002 #106111# - reset <nInitLevels>
|
|
|
|
|
nInitLevels &= ~1;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
BYTE nPrevLvl = GetRealLevel( aNum.GetLevel() );
|
2004-11-26 12:24:12 +00:00
|
|
|
|
if( nPrevLvl < GetRealLevel(nLevel) )
|
2000-09-18 23:08:29 +00:00
|
|
|
|
{
|
2004-03-30 15:05:30 +00:00
|
|
|
|
// Erfrage wie geloescht werden soll:
|
|
|
|
|
// z.B von Stufe 0 -> 1: 1 -> 0.1 ; wenn nStart = 1
|
|
|
|
|
// aber Stufe 1 -> 2: 1.1 -> 1.1.1 !!, nur 0.1 -> 0.0.1
|
|
|
|
|
if( !(nInitLevels & ( 1 << nPrevLvl )) )
|
|
|
|
|
++nPrevLvl;
|
|
|
|
|
|
2004-11-26 12:24:12 +00:00
|
|
|
|
for( int ii = nPrevLvl; ii < GetRealLevel(nLevel);
|
|
|
|
|
++ii )
|
2004-03-30 15:05:30 +00:00
|
|
|
|
{
|
|
|
|
|
nInitLevels &= ~( 1 << ii );
|
|
|
|
|
aNum.GetLevelVal()[ ii ] =
|
|
|
|
|
pRule->Get( ii ).GetStart();
|
|
|
|
|
}
|
2004-11-26 12:24:12 +00:00
|
|
|
|
aNum.GetLevelVal()[ GetRealLevel(nLevel) ] =
|
2004-03-30 15:05:30 +00:00
|
|
|
|
USHRT_MAX == aNum.GetSetValue()
|
2004-11-26 12:24:12 +00:00
|
|
|
|
? pRule->Get( GetRealLevel(nLevel) ).GetStart()
|
2000-09-18 23:08:29 +00:00
|
|
|
|
: aNum.GetSetValue();
|
2004-03-30 15:05:30 +00:00
|
|
|
|
}
|
|
|
|
|
else if( USHRT_MAX != aNum.GetSetValue() )
|
2004-11-26 12:24:12 +00:00
|
|
|
|
aNum.GetLevelVal()[ GetRealLevel(nLevel) ] =
|
|
|
|
|
aNum.GetSetValue();
|
|
|
|
|
else if( nInitLevels & ( 1 << GetRealLevel(nLevel) ))
|
|
|
|
|
aNum.GetLevelVal()[ GetRealLevel(nLevel) ] =
|
|
|
|
|
pRule->Get( GetRealLevel(nLevel) ).GetStart();
|
2004-03-30 15:05:30 +00:00
|
|
|
|
else
|
|
|
|
|
{
|
2005-03-08 10:21:10 +00:00
|
|
|
|
const SwNumFmt & rTmpNumFmt =
|
|
|
|
|
pRule->Get(GetRealLevel(nLevel));
|
2004-03-30 15:05:30 +00:00
|
|
|
|
|
2005-03-08 10:21:10 +00:00
|
|
|
|
if (SVX_NUM_NUMBER_NONE !=
|
|
|
|
|
rTmpNumFmt.GetNumberingType())
|
2004-11-26 12:24:12 +00:00
|
|
|
|
aNum.GetLevelVal()[ GetRealLevel(nLevel) ]++;
|
2004-03-30 15:05:30 +00:00
|
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
2004-11-26 12:24:12 +00:00
|
|
|
|
nInitLevels &= ~( 1 << GetRealLevel(nLevel) );
|
|
|
|
|
aNum.SetLevel( GetRealLevel(nLevel) );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
2005-02-04 10:14:52 +00:00
|
|
|
|
aNum.SetNoNum(! IsNum(nLevel));
|
|
|
|
|
|
2004-03-30 15:05:30 +00:00
|
|
|
|
// OD 10.12.2002 #106111# - reset numbers of all sublevels and
|
|
|
|
|
// note in <nInitLevels> that numbering of all sublevels have
|
|
|
|
|
// to be restarted.
|
2004-11-26 12:24:12 +00:00
|
|
|
|
for ( int nSubLvl = GetRealLevel(nLevel)+1;
|
|
|
|
|
nSubLvl < MAXLEVEL; ++nSubLvl)
|
2004-03-30 15:05:30 +00:00
|
|
|
|
{
|
|
|
|
|
aNum.GetLevelVal()[ nSubLvl ] = 0;
|
|
|
|
|
nInitLevels |= ( 1 << nSubLvl );
|
|
|
|
|
}
|
2002-12-10 15:03:17 +00:00
|
|
|
|
|
2004-03-30 15:05:30 +00:00
|
|
|
|
pStt->UpdateNum( aNum );
|
|
|
|
|
}
|
2005-03-29 13:37:07 +00:00
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
for ( int nSubLvl = GetRealLevel(nLevel)+1;
|
|
|
|
|
nSubLvl < MAXLEVEL; ++nSubLvl)
|
|
|
|
|
{
|
|
|
|
|
aNum.GetLevelVal()[ nSubLvl ] = 0;
|
|
|
|
|
nInitLevels |= ( 1 << nSubLvl );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//FEATURE::CONDCOLL
|
|
|
|
|
if( RES_CONDTXTFMTCOLL == pStt->GetFmtColl()->Which() )
|
|
|
|
|
pStt->ChkCondColl();
|
|
|
|
|
else if( !pOutlNd && NO_NUMBERING !=
|
|
|
|
|
((SwTxtFmtColl*)pStt->GetFmtColl())->GetOutlineLevel() )
|
|
|
|
|
pOutlNd = pStt;
|
|
|
|
|
|
|
|
|
|
//FEATURE::CONDCOLL
|
|
|
|
|
|
|
|
|
|
#ifndef NUM_RELSPACE
|
|
|
|
|
// hat sich eine Level - Aenderung ergeben, so setze jetzt die
|
|
|
|
|
// gueltigen Einzuege
|
2004-06-16 08:38:19 +00:00
|
|
|
|
if (( nLevel != nNdOldLvl || pStt->IsSetNumLSpace())
|
2000-09-18 23:08:29 +00:00
|
|
|
|
&& GetRealLevel( nLevel ) < MAXLEVEL )
|
|
|
|
|
{
|
|
|
|
|
SvxLRSpaceItem aLR( ((SvxLRSpaceItem&)pStt->SwCntntNode::GetAttr(
|
|
|
|
|
RES_LR_SPACE )) );
|
|
|
|
|
|
|
|
|
|
const SwNumFmt& rNFmt = pRule->Get( GetRealLevel( nLevel ));
|
|
|
|
|
|
|
|
|
|
// ohne Nummer immer ohne FirstLineOffset!!!!
|
|
|
|
|
short nFOfst = rNFmt.GetFirstLineOffset();
|
2004-11-26 12:24:12 +00:00
|
|
|
|
if( ! IsNum(GetRealLevel(nLevel))) nFOfst = 0;
|
2000-09-18 23:08:29 +00:00
|
|
|
|
aLR.SetTxtFirstLineOfstValue( nFOfst );
|
|
|
|
|
aLR.SetTxtLeft( rNFmt.GetAbsLSpace() );
|
|
|
|
|
|
|
|
|
|
pStt->SwCntntNode::SetAttr( aLR );
|
|
|
|
|
}
|
|
|
|
|
// Flag immer loeschen!
|
|
|
|
|
pStt->SetNumLSpace( FALSE );
|
|
|
|
|
#endif
|
|
|
|
|
aNum.SetStart( FALSE );
|
|
|
|
|
aNum.SetSetValue( USHRT_MAX );
|
|
|
|
|
}
|
2004-03-30 15:05:30 +00:00
|
|
|
|
#if 0
|
2000-09-18 23:08:29 +00:00
|
|
|
|
if( pOutlNd )
|
|
|
|
|
GetNodes().UpdtOutlineIdx( *pOutlNd );
|
2004-03-30 15:05:30 +00:00
|
|
|
|
#endif
|
2000-09-18 23:08:29 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ASSERT( pRule, "die NumRule sollte schon vorhanden sein!" );
|
|
|
|
|
if( pRule )
|
|
|
|
|
pRule->SetInvalidRule( FALSE );
|
|
|
|
|
}
|
2004-03-08 11:24:21 +00:00
|
|
|
|
// <- #111955#
|
2004-04-14 10:00:12 +00:00
|
|
|
|
|
2004-05-17 15:13:16 +00:00
|
|
|
|
// -> #i27615#
|
|
|
|
|
void SwDoc::SetMarkedNumLevel(SwNumRule & rNumRule, BYTE nLevel, BOOL nValue)
|
|
|
|
|
{
|
|
|
|
|
/*
|
|
|
|
|
- Set new marked level.
|
|
|
|
|
- Notify all affected nodes of the changed mark.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
SwBitArray aChangedLevels = rNumRule.SetLevelMarked(nLevel, nValue);
|
|
|
|
|
|
|
|
|
|
SwNumRuleInfo aInfo(rNumRule.GetName());
|
|
|
|
|
|
|
|
|
|
aInfo.MakeList(*this, FALSE);
|
|
|
|
|
|
|
|
|
|
for (int i = 0; i < aInfo.GetList().Count(); i++)
|
|
|
|
|
{
|
|
|
|
|
SwTxtNode * pTxtNd = aInfo.GetList().GetObject(i);
|
|
|
|
|
const SwNodeNum * pNdNum = pTxtNd->GetNum();
|
|
|
|
|
|
|
|
|
|
if (pNdNum && aChangedLevels.Get(pNdNum->GetRealLevel()))
|
|
|
|
|
pTxtNd->NumRuleChgd();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void SwDoc::SetMarkedNumLevel(const String & sNumRule, BYTE nLevel,
|
|
|
|
|
BOOL bValue)
|
|
|
|
|
{
|
|
|
|
|
SwNumRule * pNumRule = FindNumRulePtr(sNumRule);
|
|
|
|
|
|
|
|
|
|
if (pNumRule)
|
|
|
|
|
SetMarkedNumLevel(*pNumRule, nLevel, bValue);
|
|
|
|
|
}
|
|
|
|
|
// <- #i27615#
|
|
|
|
|
|
2004-04-14 10:00:12 +00:00
|
|
|
|
// #i23726#
|
|
|
|
|
BOOL SwDoc::IsFirstOfNumRule(SwPosition & rPos)
|
|
|
|
|
{
|
|
|
|
|
BOOL bResult = FALSE;
|
|
|
|
|
SwTxtNode * pTxtNode = rPos.nNode.GetNode().GetTxtNode();
|
|
|
|
|
|
|
|
|
|
if (pTxtNode)
|
|
|
|
|
{
|
|
|
|
|
SwNumRule * pNumRule = pTxtNode->GetNumRule();
|
|
|
|
|
|
|
|
|
|
if (pNumRule)
|
|
|
|
|
{
|
|
|
|
|
SwNumRuleInfo aNumInfo(pNumRule->GetName());
|
|
|
|
|
aNumInfo.MakeList(*this);
|
|
|
|
|
|
|
|
|
|
if (aNumInfo.GetList().Count() > 0 &&
|
|
|
|
|
aNumInfo.GetList().GetObject(0) == pTxtNode)
|
|
|
|
|
bResult = TRUE;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return bResult;
|
|
|
|
|
}
|
|
|
|
|
|
2004-09-08 14:17:53 +00:00
|
|
|
|
// #i23726#
|
|
|
|
|
void SwDoc::IndentNumRule(SwPosition & rPos, short nAmount)
|
|
|
|
|
{
|
|
|
|
|
if (SwTxtNode * pTxtNode = rPos.nNode.GetNode().GetTxtNode())
|
|
|
|
|
{
|
|
|
|
|
if (SwNumRule * pNumRule = pTxtNode->GetNumRule())
|
|
|
|
|
{
|
|
|
|
|
pNumRule->Indent(nAmount);
|
|
|
|
|
UpdateNumRule();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|