2000-09-18 23:08:29 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
|
|
|
* $RCSfile: doc.cxx,v $
|
|
|
|
*
|
2003-09-19 07:44:02 +00:00
|
|
|
* $Revision: 1.20 $
|
2000-09-18 23:08:29 +00:00
|
|
|
*
|
2003-09-19 07:44:02 +00:00
|
|
|
* last change: $Author: rt $ $Date: 2003-09-19 08:44:02 $
|
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
|
|
|
|
|
2002-08-12 07:36:16 +00:00
|
|
|
#ifndef _COM_SUN_STAR_I18N_WORDTYPE_HDL
|
|
|
|
#include <com/sun/star/i18n/WordType.hdl>
|
|
|
|
#endif
|
2000-09-18 23:08:29 +00:00
|
|
|
#ifndef _URLOBJ_HXX //autogen
|
|
|
|
#include <tools/urlobj.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SV_POLY_HXX //autogen
|
|
|
|
#include <vcl/poly.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _IPOBJ_HXX //autogen
|
|
|
|
#include <so3/ipobj.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SFXDOCINF_HXX //autogen
|
|
|
|
#include <sfx2/docinf.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SVX_KEEPITEM_HXX //autogen
|
|
|
|
#include <svx/keepitem.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SVX_CSCOITEM_HXX //autogen
|
|
|
|
#include <svx/cscoitem.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SVX_BRKITEM_HXX //autogen
|
|
|
|
#include <svx/brkitem.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SVXLINKMGR_HXX
|
|
|
|
#include <svx/linkmgr.hxx>
|
|
|
|
#endif
|
2000-10-25 14:39:12 +00:00
|
|
|
#ifndef _UNOTOOLS_CHARCLASS_HXX
|
|
|
|
#include <unotools/charclass.hxx>
|
|
|
|
#endif
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
#ifndef _SWMODULE_HXX //autogen
|
|
|
|
#include <swmodule.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _FMTPDSC_HXX //autogen
|
|
|
|
#include <fmtpdsc.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _FMTANCHR_HXX //autogen
|
|
|
|
#include <fmtanchr.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _FMTRFMRK_HXX //autogen
|
|
|
|
#include <fmtrfmrk.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _FMTINFMT_HXX //autogen
|
|
|
|
#include <fmtinfmt.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _FMTFLD_HXX //autogen
|
|
|
|
#include <fmtfld.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _TXTFLD_HXX //autogen
|
|
|
|
#include <txtfld.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _TXTINET_HXX //autogen
|
|
|
|
#include <txtinet.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _TXTRFMRK_HXX //autogen
|
|
|
|
#include <txtrfmrk.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _FRMATR_HXX
|
|
|
|
#include <frmatr.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _LINKENUM_HXX
|
|
|
|
#include <linkenum.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _DOC_HXX
|
|
|
|
#include <doc.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _ERRHDL_HXX
|
|
|
|
#include <errhdl.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _PAGEFRM_HXX
|
|
|
|
#include <pagefrm.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _ROOTFRM_HXX
|
|
|
|
#include <rootfrm.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SWTABLE_HXX
|
|
|
|
#include <swtable.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _PAM_HXX
|
|
|
|
#include <pam.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _NDTXT_HXX
|
|
|
|
#include <ndtxt.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _FLDBAS_HXX
|
|
|
|
#include <fldbas.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _SWUNDO_HXX
|
|
|
|
#include <swundo.hxx> // fuer die UndoIds
|
|
|
|
#endif
|
|
|
|
#ifndef _UNDOBJ_HXX
|
|
|
|
#include <undobj.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _PAGEDESC_HXX
|
|
|
|
#include <pagedesc.hxx> //DTor
|
|
|
|
#endif
|
2002-08-12 07:36:16 +00:00
|
|
|
#ifndef _BREAKIT_HXX
|
|
|
|
#include <breakit.hxx>
|
|
|
|
#endif
|
2000-09-18 23:08:29 +00:00
|
|
|
#ifndef _HINTS_HXX
|
|
|
|
#include <hints.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _NDOLE_HXX
|
|
|
|
#include <ndole.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _NDGRF_HXX
|
|
|
|
#include <ndgrf.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _ROLBCK_HXX
|
|
|
|
#include <rolbck.hxx> // Undo-Attr
|
|
|
|
#endif
|
|
|
|
#ifndef _BOOKMRK_HXX
|
|
|
|
#include <bookmrk.hxx> // fuer die Bookmarks
|
|
|
|
#endif
|
|
|
|
#ifndef _DOCTXM_HXX
|
|
|
|
#include <doctxm.hxx> // fuer die Verzeichnisse
|
|
|
|
#endif
|
|
|
|
#ifndef _GRFATR_HXX
|
|
|
|
#include <grfatr.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _POOLFMT_HXX
|
|
|
|
#include <poolfmt.hxx> // PoolVorlagen-Id's
|
|
|
|
#endif
|
|
|
|
#ifndef _MVSAVE_HXX
|
|
|
|
#include <mvsave.hxx> // fuer Server-Funktionalitaet
|
|
|
|
#endif
|
|
|
|
#ifndef _WRONG_HXX
|
|
|
|
#include <wrong.hxx> // fuer OnlineSpell-Invalidierung
|
|
|
|
#endif
|
2002-08-12 07:36:16 +00:00
|
|
|
#ifndef _DRAWFONT_HXX
|
|
|
|
#include <drawfont.hxx>
|
|
|
|
#endif
|
2000-09-18 23:08:29 +00:00
|
|
|
#ifndef _ACORRECT_HXX
|
|
|
|
#include <acorrect.hxx> // Autokorrektur
|
|
|
|
#endif
|
|
|
|
#ifndef _SECTION_HXX
|
|
|
|
#include <section.hxx> //
|
|
|
|
#endif
|
|
|
|
#ifndef _MDIEXP_HXX
|
|
|
|
#include <mdiexp.hxx> // Statusanzeige
|
|
|
|
#endif
|
|
|
|
#ifndef _DOCSTAT_HXX
|
|
|
|
#include <docstat.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _DOCARY_HXX
|
|
|
|
#include <docary.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _REDLINE_HXX
|
|
|
|
#include <redline.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _FLDUPDE_HXX
|
|
|
|
#include <fldupde.hxx>
|
|
|
|
#endif
|
2001-03-08 20:28:23 +00:00
|
|
|
#ifndef _SWBASLNK_HXX
|
|
|
|
#include <swbaslnk.hxx>
|
|
|
|
#endif
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
#ifndef _STATSTR_HRC
|
|
|
|
#include <statstr.hrc> // StatLine-String
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// Seiten-Deskriptoren
|
|
|
|
SV_IMPL_PTRARR(SwPageDescs,SwPageDescPtr);
|
|
|
|
// Autoren
|
|
|
|
// IMPL_PTRREGARR_NOTL(Authors,Author) USED?
|
|
|
|
// Verzeichnisse
|
|
|
|
SV_IMPL_PTRARR( SwTOXTypes, SwTOXTypePtr )
|
|
|
|
// FeldTypen
|
|
|
|
SV_IMPL_PTRARR( SwFldTypes, SwFldTypePtr)
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Dokumenteditieren (Doc-SS) zum Fuellen des Dokuments
|
|
|
|
* durch den RTF Parser und fuer die EditShell.
|
|
|
|
*/
|
2001-02-21 11:45:25 +00:00
|
|
|
void SwDoc::ChgDBData(const SwDBData& rNewData)
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
2001-02-21 11:45:25 +00:00
|
|
|
if( rNewData != aDBData )
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
2001-02-21 11:45:25 +00:00
|
|
|
aDBData = rNewData;
|
2000-09-18 23:08:29 +00:00
|
|
|
SetModified();
|
|
|
|
}
|
|
|
|
GetSysFldType(RES_DBNAMEFLD)->UpdateFlds();
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL SwDoc::SplitNode( const SwPosition &rPos, BOOL bChkTableStart )
|
|
|
|
{
|
|
|
|
SwCntntNode *pNode = rPos.nNode.GetNode().GetCntntNode();
|
|
|
|
if(0 == pNode)
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
{
|
|
|
|
// Bug 26675: DataChanged vorm loeschen verschicken, dann bekommt
|
|
|
|
// man noch mit, welche Objecte sich im Bereich befinden.
|
|
|
|
// Danach koennen sie vor/hinter der Position befinden.
|
|
|
|
SwDataChanged aTmp( this, rPos, 0 );
|
|
|
|
}
|
|
|
|
|
|
|
|
SwUndoSplitNode* pUndo = 0;
|
|
|
|
if ( DoesUndo() )
|
|
|
|
{
|
|
|
|
ClearRedo();
|
|
|
|
// einfuegen vom Undo-Object, z.Z. nur beim TextNode
|
|
|
|
if( pNode->IsTxtNode() )
|
|
|
|
AppendUndo( pUndo = new SwUndoSplitNode( this, rPos, bChkTableStart ));
|
|
|
|
}
|
|
|
|
|
|
|
|
//JP 28.01.97: Sonderfall fuer SplitNode am Tabellenanfang:
|
|
|
|
// steht die am Doc/Fly/Footer/..-Anfang oder direkt
|
|
|
|
// hinter einer Tabelle, dann fuege davor
|
|
|
|
// einen Absatz ein
|
|
|
|
if( bChkTableStart && !rPos.nContent.GetIndex() && pNode->IsTxtNode() )
|
|
|
|
{
|
|
|
|
ULONG nPrevPos = rPos.nNode.GetIndex() - 1;
|
|
|
|
const SwTableNode* pTblNd;
|
|
|
|
const SwNode* pNd = GetNodes()[ nPrevPos ];
|
|
|
|
if( pNd->IsStartNode() &&
|
|
|
|
SwTableBoxStartNode == ((SwStartNode*)pNd)->GetStartNodeType() &&
|
|
|
|
0 != ( pTblNd = GetNodes()[ --nPrevPos ]->GetTableNode() ) &&
|
|
|
|
((( pNd = GetNodes()[ --nPrevPos ])->IsStartNode() &&
|
|
|
|
SwTableBoxStartNode != ((SwStartNode*)pNd)->GetStartNodeType() )
|
|
|
|
|| ( pNd->IsEndNode() && pNd->FindStartNode()->IsTableNode() )
|
|
|
|
|| pNd->IsCntntNode() ))
|
|
|
|
{
|
|
|
|
if( pNd->IsCntntNode() )
|
|
|
|
{
|
|
|
|
//JP 30.04.99 Bug 65660:
|
|
|
|
// ausserhalb des normalen BodyBereiches gibt es keine
|
|
|
|
// Seitenumbrueche, also ist das hier kein gueltige
|
|
|
|
// Bedingung fuers einfuegen eines Absatzes
|
|
|
|
if( nPrevPos < GetNodes().GetEndOfExtras().GetIndex() )
|
|
|
|
pNd = 0;
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// Dann nur, wenn die Tabelle Umbrueche traegt!
|
|
|
|
const SwFrmFmt* pFrmFmt = pTblNd->GetTable().GetFrmFmt();
|
|
|
|
if( SFX_ITEM_SET != pFrmFmt->GetItemState(RES_PAGEDESC, FALSE) &&
|
|
|
|
SFX_ITEM_SET != pFrmFmt->GetItemState( RES_BREAK, FALSE ) )
|
|
|
|
pNd = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if( pNd )
|
|
|
|
{
|
|
|
|
SwTxtNode* pTxtNd = GetNodes().MakeTxtNode(
|
|
|
|
SwNodeIndex( *pTblNd ),
|
|
|
|
GetTxtCollFromPool( RES_POOLCOLL_TEXT ));
|
|
|
|
if( pTxtNd )
|
|
|
|
{
|
|
|
|
((SwPosition&)rPos).nNode = pTblNd->GetIndex()-1;
|
|
|
|
((SwPosition&)rPos).nContent.Assign( pTxtNd, 0 );
|
|
|
|
|
|
|
|
// nur im BodyBereich den SeitenUmbruch/-Vorlage umhaengem
|
|
|
|
if( nPrevPos > GetNodes().GetEndOfExtras().GetIndex() )
|
|
|
|
{
|
|
|
|
SwFrmFmt* pFrmFmt = pTblNd->GetTable().GetFrmFmt();
|
|
|
|
const SfxPoolItem *pItem;
|
|
|
|
if( SFX_ITEM_SET == pFrmFmt->GetItemState( RES_PAGEDESC,
|
|
|
|
FALSE, &pItem ) )
|
|
|
|
{
|
|
|
|
pTxtNd->SwCntntNode::SetAttr( *pItem );
|
|
|
|
pFrmFmt->ResetAttr( RES_PAGEDESC );
|
|
|
|
}
|
|
|
|
if( SFX_ITEM_SET == pFrmFmt->GetItemState( RES_BREAK,
|
|
|
|
FALSE, &pItem ) )
|
|
|
|
{
|
|
|
|
pTxtNd->SwCntntNode::SetAttr( *pItem );
|
|
|
|
pFrmFmt->ResetAttr( RES_BREAK );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if( pUndo )
|
|
|
|
pUndo->SetTblFlag();
|
|
|
|
SetModified();
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
SvULongs aBkmkArr( 15, 15 );
|
|
|
|
_SaveCntntIdx( this, rPos.nNode.GetIndex(), rPos.nContent.GetIndex(),
|
|
|
|
aBkmkArr, SAVEFLY_SPLIT );
|
|
|
|
if( 0 != ( pNode = pNode->SplitNode( rPos ) ))
|
|
|
|
{
|
|
|
|
// verschiebe noch alle Bookmarks/TOXMarks/FlyAtCnt
|
|
|
|
if( aBkmkArr.Count() )
|
|
|
|
_RestoreCntntIdx( this, aBkmkArr, rPos.nNode.GetIndex()-1, 0, TRUE );
|
|
|
|
|
|
|
|
if( IsRedlineOn() || (!IsIgnoreRedline() && pRedlineTbl->Count() ))
|
|
|
|
{
|
|
|
|
SwPaM aPam( rPos );
|
|
|
|
aPam.SetMark();
|
|
|
|
aPam.Move( fnMoveBackward );
|
|
|
|
if( IsRedlineOn() )
|
|
|
|
AppendRedline( new SwRedline( REDLINE_INSERT, aPam ));
|
|
|
|
else
|
|
|
|
SplitRedline( aPam );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
SetModified();
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL SwDoc::AppendTxtNode( SwPosition& rPos )
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
* Neuen Node vor EndOfContent erzeugen.
|
|
|
|
*/
|
|
|
|
SwTxtNode *pCurNode = GetNodes()[ rPos.nNode ]->GetTxtNode();
|
|
|
|
if( !pCurNode )
|
|
|
|
{
|
|
|
|
// dann kann ja einer angelegt werden!
|
|
|
|
SwNodeIndex aIdx( rPos.nNode, 1 );
|
|
|
|
pCurNode = GetNodes().MakeTxtNode( aIdx,
|
|
|
|
GetTxtCollFromPool( RES_POOLCOLL_STANDARD ));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
pCurNode = (SwTxtNode*)pCurNode->AppendNode( rPos );
|
|
|
|
|
|
|
|
rPos.nNode++;
|
|
|
|
rPos.nContent.Assign( pCurNode, 0 );
|
|
|
|
|
|
|
|
if( DoesUndo() )
|
|
|
|
{
|
|
|
|
ClearRedo();
|
|
|
|
AppendUndo( new SwUndoInsert( rPos.nNode ));
|
|
|
|
}
|
|
|
|
|
|
|
|
if( IsRedlineOn() || (!IsIgnoreRedline() && pRedlineTbl->Count() ))
|
|
|
|
{
|
|
|
|
SwPaM aPam( rPos );
|
|
|
|
aPam.SetMark();
|
|
|
|
aPam.Move( fnMoveBackward );
|
|
|
|
if( IsRedlineOn() )
|
|
|
|
AppendRedline( new SwRedline( REDLINE_INSERT, aPam ));
|
|
|
|
else
|
|
|
|
SplitRedline( aPam );
|
|
|
|
}
|
|
|
|
|
|
|
|
SetModified();
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL SwDoc::Insert( const SwPaM &rRg, const String &rStr, BOOL bHintExpand )
|
|
|
|
{
|
|
|
|
if( DoesUndo() )
|
|
|
|
ClearRedo();
|
|
|
|
|
|
|
|
const SwPosition* pPos = rRg.GetPoint();
|
|
|
|
|
|
|
|
if( pACEWord ) // Aufnahme in die Autokorrektur
|
|
|
|
{
|
|
|
|
if( 1 == rStr.Len() && pACEWord->IsDeleted() )
|
|
|
|
pACEWord->CheckChar( *pPos, rStr.GetChar( 0 ) );
|
|
|
|
delete pACEWord, pACEWord = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
SwTxtNode *pNode = pPos->nNode.GetNode().GetTxtNode();
|
|
|
|
if(!pNode)
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
const USHORT nInsMode = bHintExpand ? INS_EMPTYEXPAND
|
|
|
|
: INS_NOHINTEXPAND;
|
|
|
|
SwDataChanged aTmp( rRg, 0 );
|
|
|
|
|
|
|
|
if( !DoesUndo() || !DoesGroupUndo() )
|
|
|
|
{
|
|
|
|
pNode->Insert( rStr, pPos->nContent, nInsMode );
|
|
|
|
|
|
|
|
if( DoesUndo() )
|
|
|
|
AppendUndo( new SwUndoInsert( pPos->nNode,
|
|
|
|
pPos->nContent.GetIndex(), rStr.Len() ));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{ // ist Undo und Gruppierung eingeschaltet, ist alles anders !
|
|
|
|
USHORT nUndoSize = pUndos->Count();
|
|
|
|
xub_StrLen nInsPos = pPos->nContent.GetIndex();
|
|
|
|
SwUndoInsert * pUndo;
|
2000-10-25 14:39:12 +00:00
|
|
|
CharClass& rCC = GetAppCharClass();
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
if( 0 == nUndoSize || UNDO_INSERT !=
|
|
|
|
( pUndo = (SwUndoInsert*)(*pUndos)[ --nUndoSize ])->GetId() ||
|
|
|
|
!pUndo->CanGrouping( *pPos ))
|
|
|
|
{
|
|
|
|
pUndo = new SwUndoInsert( pPos->nNode, nInsPos, 0,
|
2000-10-25 14:39:12 +00:00
|
|
|
!rCC.isLetterNumeric( rStr, 0 ) );
|
2000-09-18 23:08:29 +00:00
|
|
|
AppendUndo( pUndo );
|
|
|
|
}
|
|
|
|
|
|
|
|
for( xub_StrLen i = 0; i < rStr.Len(); ++i )
|
|
|
|
{
|
|
|
|
nInsPos++;
|
|
|
|
// wenn CanGrouping() TRUE returnt, ist schon alles erledigt
|
|
|
|
if( !pUndo->CanGrouping( rStr.GetChar( i ) ))
|
|
|
|
{
|
|
|
|
pUndo = new SwUndoInsert( pPos->nNode, nInsPos, 1,
|
2000-10-25 14:39:12 +00:00
|
|
|
!rCC.isLetterNumeric( rStr, i ) );
|
2000-09-18 23:08:29 +00:00
|
|
|
AppendUndo( pUndo );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
pNode->Insert( rStr, pPos->nContent, nInsMode );
|
|
|
|
}
|
|
|
|
|
|
|
|
if( IsRedlineOn() || (!IsIgnoreRedline() && pRedlineTbl->Count() ))
|
|
|
|
{
|
|
|
|
SwPaM aPam( pPos->nNode, aTmp.GetCntnt(),
|
|
|
|
pPos->nNode, pPos->nContent.GetIndex());
|
|
|
|
if( IsRedlineOn() )
|
|
|
|
AppendRedline( new SwRedline( REDLINE_INSERT, aPam ));
|
|
|
|
else
|
|
|
|
SplitRedline( aPam );
|
|
|
|
}
|
|
|
|
|
|
|
|
SetModified();
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
SwFlyFrmFmt* SwDoc::_InsNoTxtNode( const SwPosition& rPos, SwNoTxtNode* pNode,
|
|
|
|
const SfxItemSet* pFlyAttrSet,
|
|
|
|
const SfxItemSet* pGrfAttrSet,
|
|
|
|
SwFrmFmt* pFrmFmt)
|
|
|
|
{
|
|
|
|
SwFlyFrmFmt *pFmt = 0;
|
|
|
|
if( pNode )
|
|
|
|
{
|
|
|
|
pFmt = _MakeFlySection( rPos, *pNode, FLY_AT_CNTNT,
|
|
|
|
pFlyAttrSet, pFrmFmt );
|
|
|
|
if( pGrfAttrSet )
|
|
|
|
pNode->SetAttr( *pGrfAttrSet );
|
|
|
|
}
|
|
|
|
return pFmt;
|
|
|
|
}
|
|
|
|
|
|
|
|
SwFlyFrmFmt* SwDoc::Insert( const SwPaM &rRg,
|
|
|
|
const String& rGrfName,
|
|
|
|
const String& rFltName,
|
|
|
|
const Graphic* pGraphic,
|
|
|
|
const SfxItemSet* pFlyAttrSet,
|
|
|
|
const SfxItemSet* pGrfAttrSet,
|
|
|
|
SwFrmFmt* pFrmFmt )
|
|
|
|
{
|
|
|
|
if( !pFrmFmt )
|
|
|
|
pFrmFmt = GetFrmFmtFromPool( RES_POOLFRM_GRAPHIC );
|
|
|
|
return _InsNoTxtNode( *rRg.GetPoint(), GetNodes().MakeGrfNode(
|
|
|
|
SwNodeIndex( GetNodes().GetEndOfAutotext() ),
|
|
|
|
rGrfName, rFltName, pGraphic,
|
|
|
|
pDfltGrfFmtColl ),
|
|
|
|
pFlyAttrSet, pGrfAttrSet, pFrmFmt );
|
|
|
|
}
|
2000-11-28 19:40:08 +00:00
|
|
|
SwFlyFrmFmt* SwDoc::Insert( const SwPaM &rRg, const GraphicObject& rGrfObj,
|
|
|
|
const SfxItemSet* pFlyAttrSet,
|
|
|
|
const SfxItemSet* pGrfAttrSet,
|
|
|
|
SwFrmFmt* pFrmFmt )
|
|
|
|
{
|
|
|
|
if( !pFrmFmt )
|
|
|
|
pFrmFmt = GetFrmFmtFromPool( RES_POOLFRM_GRAPHIC );
|
|
|
|
return _InsNoTxtNode( *rRg.GetPoint(), GetNodes().MakeGrfNode(
|
|
|
|
SwNodeIndex( GetNodes().GetEndOfAutotext() ),
|
|
|
|
rGrfObj, pDfltGrfFmtColl ),
|
|
|
|
pFlyAttrSet, pGrfAttrSet, pFrmFmt );
|
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
SwFlyFrmFmt* SwDoc::Insert(const SwPaM &rRg, SvInPlaceObject *pObj,
|
|
|
|
const SfxItemSet* pFlyAttrSet,
|
|
|
|
const SfxItemSet* pGrfAttrSet,
|
|
|
|
SwFrmFmt* pFrmFmt )
|
|
|
|
{
|
|
|
|
if( !pFrmFmt )
|
|
|
|
{
|
|
|
|
USHORT nId = RES_POOLFRM_OLE;
|
|
|
|
|
2003-09-19 07:44:02 +00:00
|
|
|
FASTBOOL bMath = SotExchange::IsMath( *pObj->GetSvFactory() );
|
2000-09-18 23:08:29 +00:00
|
|
|
if ( bMath )
|
|
|
|
nId = RES_POOLFRM_FORMEL;
|
|
|
|
|
|
|
|
pFrmFmt = GetFrmFmtFromPool( nId );
|
|
|
|
}
|
|
|
|
return _InsNoTxtNode( *rRg.GetPoint(), GetNodes().MakeOLENode(
|
|
|
|
SwNodeIndex( GetNodes().GetEndOfAutotext() ),
|
|
|
|
pObj,
|
|
|
|
pDfltGrfFmtColl ),
|
|
|
|
pFlyAttrSet, pGrfAttrSet,
|
|
|
|
pFrmFmt );
|
|
|
|
}
|
|
|
|
|
2003-09-01 11:36:24 +00:00
|
|
|
SwFlyFrmFmt* SwDoc::InsertOLE(const SwPaM &rRg, const String& rObjName,
|
2000-11-27 14:38:15 +00:00
|
|
|
const SfxItemSet* pFlyAttrSet,
|
|
|
|
const SfxItemSet* pGrfAttrSet,
|
|
|
|
SwFrmFmt* pFrmFmt )
|
|
|
|
{
|
|
|
|
if( !pFrmFmt )
|
|
|
|
pFrmFmt = GetFrmFmtFromPool( RES_POOLFRM_OLE );
|
|
|
|
|
|
|
|
return _InsNoTxtNode( *rRg.GetPoint(), GetNodes().MakeOLENode(
|
|
|
|
SwNodeIndex( GetNodes().GetEndOfAutotext() ),
|
|
|
|
rObjName,
|
|
|
|
pDfltGrfFmtColl ),
|
|
|
|
pFlyAttrSet, pGrfAttrSet,
|
|
|
|
pFrmFmt );
|
|
|
|
}
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
String SwDoc::GetCurWord( SwPaM& rPaM )
|
|
|
|
{
|
|
|
|
SwTxtNode *pNd = rPaM.GetNode()->GetTxtNode();
|
|
|
|
if( pNd )
|
|
|
|
return pNd->GetCurWord(rPaM.GetPoint()->nContent.GetIndex());
|
|
|
|
return aEmptyStr;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*************************************************************************
|
|
|
|
|* SwDoc::GetFldType()
|
|
|
|
|* Beschreibung: liefert den am Doc eingerichteten Feldtypen zurueck
|
|
|
|
*************************************************************************/
|
|
|
|
|
|
|
|
SwFieldType *SwDoc::GetSysFldType( const USHORT eWhich ) const
|
|
|
|
{
|
|
|
|
for( register int i = 0; i < INIT_FLDTYPES; i++ )
|
|
|
|
if( eWhich == (*pFldTypes)[i]->Which() )
|
|
|
|
return (*pFldTypes)[i];
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
//----- Macro ---------------------------------------------------------
|
|
|
|
|
|
|
|
BOOL SwDoc::HasGlobalMacro( USHORT nEvent ) const
|
|
|
|
{
|
|
|
|
return pMacroTable->IsKeyValid(nEvent);
|
|
|
|
}
|
|
|
|
|
|
|
|
const SvxMacro& SwDoc::GetGlobalMacro( USHORT nEvent ) const
|
|
|
|
{
|
|
|
|
ASSERT(pMacroTable->IsKeyValid(nEvent), "Get fuer nicht ex. Macro");
|
|
|
|
return *(pMacroTable->Get(nEvent));
|
|
|
|
}
|
|
|
|
|
|
|
|
void SwDoc::SetGlobalMacro( USHORT nEvent, const SvxMacro& rMacro )
|
|
|
|
{
|
|
|
|
SvxMacro *pMacro;
|
|
|
|
SetModified();
|
|
|
|
if ( 0 != (pMacro=pMacroTable->Get(nEvent)) )
|
|
|
|
{
|
|
|
|
delete pMacro;
|
|
|
|
pMacroTable->Replace(nEvent, new SvxMacro(rMacro));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
pMacroTable->Insert(nEvent, new SvxMacro(rMacro));
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL SwDoc::DelGlobalMacro(USHORT nEvent)
|
|
|
|
{
|
|
|
|
SetModified();
|
|
|
|
SvxMacro *pMacro = pMacroTable->Remove(nEvent);
|
|
|
|
delete pMacro;
|
|
|
|
return (pMacro != 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*************************************************************************
|
|
|
|
* void SetDocStat( const SwDocStat& rStat );
|
|
|
|
*************************************************************************/
|
|
|
|
|
|
|
|
void SwDoc::SetDocStat( const SwDocStat& rStat )
|
|
|
|
{
|
|
|
|
*pDocStat = rStat;
|
|
|
|
}
|
|
|
|
|
2002-08-13 06:09:29 +00:00
|
|
|
|
2002-09-02 11:24:49 +00:00
|
|
|
sal_uInt16 SwDoc::GetPageCount() const
|
|
|
|
{
|
|
|
|
return GetRootFrm() ? GetRootFrm()->GetPageNum() : 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
const Size SwDoc::GetPageSize( sal_uInt16 nPageNum ) const
|
|
|
|
{
|
|
|
|
Size aSize;
|
|
|
|
if( GetRootFrm() && nPageNum )
|
|
|
|
{
|
|
|
|
const SwPageFrm* pPage = static_cast<const SwPageFrm*>
|
|
|
|
(GetRootFrm()->Lower());
|
|
|
|
while( --nPageNum && pPage->GetNext() )
|
|
|
|
pPage = static_cast<const SwPageFrm*>( pPage->GetNext() );
|
2002-09-09 11:11:22 +00:00
|
|
|
if( pPage->IsEmptyPage() && pPage->GetNext() )
|
|
|
|
pPage = static_cast<const SwPageFrm*>( pPage->GetNext() );
|
2002-09-02 11:24:49 +00:00
|
|
|
aSize = pPage->Frm().SSize();
|
|
|
|
}
|
|
|
|
return aSize;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
/*************************************************************************
|
|
|
|
* void UpdateDocStat( const SwDocStat& rStat );
|
|
|
|
*************************************************************************/
|
|
|
|
|
2002-08-13 06:09:29 +00:00
|
|
|
void SwDoc::UpdateDocStat( SwDocStat& rStat )
|
2002-08-12 07:36:16 +00:00
|
|
|
{
|
|
|
|
if( rStat.bModified )
|
|
|
|
{
|
|
|
|
rStat.Reset();
|
|
|
|
rStat.nPara = 0; // Default ist auf 1 !!
|
|
|
|
SwNode* pNd;
|
|
|
|
|
|
|
|
for( ULONG n = GetNodes().Count(); n; )
|
|
|
|
switch( ( pNd = GetNodes()[ --n ])->GetNodeType() )
|
|
|
|
{
|
|
|
|
case ND_TEXTNODE:
|
|
|
|
{
|
|
|
|
const String& rStr = ((SwTxtNode*)pNd)->GetTxt();
|
|
|
|
|
|
|
|
if( rStr.Len() && pBreakIt->xBreak.is() )
|
|
|
|
{
|
|
|
|
SwScanner aScanner( *((SwTxtNode*)pNd), NULL,
|
2002-08-13 06:09:29 +00:00
|
|
|
::com::sun::star::i18n::WordType::WORD_COUNT,
|
2002-08-12 07:36:16 +00:00
|
|
|
0, rStr.Len(), sal_False, sal_False );
|
|
|
|
|
|
|
|
while ( aScanner.NextWord() )
|
|
|
|
{
|
|
|
|
if ( aScanner.GetLen() > 1 ||
|
|
|
|
CH_TXTATR_BREAKWORD != rStr.GetChar( aScanner.GetBegin() ) )
|
|
|
|
++rStat.nWord;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
rStat.nChar += rStr.Len();
|
|
|
|
++rStat.nPara;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case ND_TABLENODE: ++rStat.nTbl; break;
|
|
|
|
case ND_GRFNODE: ++rStat.nGrf; break;
|
|
|
|
case ND_OLENODE: ++rStat.nOLE; break;
|
|
|
|
case ND_SECTIONNODE: break;
|
|
|
|
}
|
|
|
|
|
2000-11-20 13:47:36 +00:00
|
|
|
rStat.nPage = GetRootFrm() ? GetRootFrm()->GetPageNum() : 0;
|
2000-09-18 23:08:29 +00:00
|
|
|
rStat.bModified = FALSE;
|
|
|
|
SetDocStat( rStat );
|
|
|
|
// event. Stat. Felder Updaten
|
|
|
|
SwFieldType *pType = GetSysFldType(RES_DOCSTATFLD);
|
|
|
|
pType->UpdateFlds();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2002-08-12 07:36:16 +00:00
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
// Dokument - Info
|
|
|
|
|
|
|
|
void SwDoc::DocInfoChgd( const SfxDocumentInfo& rInfo )
|
|
|
|
{
|
|
|
|
delete pSwgInfo;
|
|
|
|
pSwgInfo = new SfxDocumentInfo(rInfo);
|
|
|
|
|
|
|
|
GetSysFldType( RES_DOCINFOFLD )->UpdateFlds();
|
|
|
|
GetSysFldType( RES_TEMPLNAMEFLD )->UpdateFlds();
|
|
|
|
SetModified();
|
|
|
|
}
|
|
|
|
|
|
|
|
// returne zum Namen die im Doc gesetzte Referenz
|
|
|
|
const SwFmtRefMark* SwDoc::GetRefMark( const String& rName ) const
|
|
|
|
{
|
|
|
|
const SfxPoolItem* pItem;
|
|
|
|
USHORT nMaxItems = GetAttrPool().GetItemCount( RES_TXTATR_REFMARK );
|
|
|
|
for( USHORT n = 0; n < nMaxItems; ++n )
|
|
|
|
{
|
|
|
|
if( 0 == (pItem = GetAttrPool().GetItem( RES_TXTATR_REFMARK, n ) ))
|
|
|
|
continue;
|
|
|
|
|
|
|
|
const SwFmtRefMark* pFmtRef = (SwFmtRefMark*)pItem;
|
|
|
|
const SwTxtRefMark* pTxtRef = pFmtRef->GetTxtRefMark();
|
|
|
|
if( pTxtRef && &pTxtRef->GetTxtNode().GetNodes() == &GetNodes() &&
|
|
|
|
rName.Equals( pFmtRef->GetRefName() ) )
|
|
|
|
return pFmtRef;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
// returne die RefMark per Index - fuer Uno
|
|
|
|
const SwFmtRefMark* SwDoc::GetRefMark( USHORT nIndex ) const
|
|
|
|
{
|
|
|
|
const SfxPoolItem* pItem;
|
|
|
|
const SwTxtRefMark* pTxtRef;
|
|
|
|
const SwFmtRefMark* pRet = 0;
|
|
|
|
|
|
|
|
USHORT nMaxItems = GetAttrPool().GetItemCount( RES_TXTATR_REFMARK );
|
|
|
|
USHORT nCount = 0;
|
|
|
|
for( USHORT n = 0; n < nMaxItems; ++n )
|
|
|
|
if( 0 != (pItem = GetAttrPool().GetItem( RES_TXTATR_REFMARK, n )) &&
|
|
|
|
0 != (pTxtRef = ((SwFmtRefMark*)pItem)->GetTxtRefMark()) &&
|
|
|
|
&pTxtRef->GetTxtNode().GetNodes() == &GetNodes() )
|
|
|
|
{
|
|
|
|
if(nCount == nIndex)
|
|
|
|
{
|
|
|
|
pRet = (SwFmtRefMark*)pItem;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
nCount++;
|
|
|
|
}
|
|
|
|
return pRet;
|
|
|
|
}
|
|
|
|
|
|
|
|
// returne die Namen aller im Doc gesetzten Referenzen
|
|
|
|
//JP 24.06.96: Ist der ArrayPointer 0 dann returne nur, ob im Doc. eine
|
|
|
|
// RefMark gesetzt ist
|
|
|
|
// OS 25.06.96: ab jetzt wird immer die Anzahl der Referenzen returnt
|
|
|
|
USHORT SwDoc::GetRefMarks( SvStringsDtor* pNames ) const
|
|
|
|
{
|
|
|
|
const SfxPoolItem* pItem;
|
|
|
|
const SwTxtRefMark* pTxtRef;
|
|
|
|
|
|
|
|
USHORT nMaxItems = GetAttrPool().GetItemCount( RES_TXTATR_REFMARK );
|
|
|
|
USHORT nCount = 0;
|
|
|
|
for( USHORT n = 0; n < nMaxItems; ++n )
|
|
|
|
if( 0 != (pItem = GetAttrPool().GetItem( RES_TXTATR_REFMARK, n )) &&
|
|
|
|
0 != (pTxtRef = ((SwFmtRefMark*)pItem)->GetTxtRefMark()) &&
|
|
|
|
&pTxtRef->GetTxtNode().GetNodes() == &GetNodes() )
|
|
|
|
{
|
|
|
|
if( pNames )
|
|
|
|
{
|
|
|
|
String* pTmp = new String( ((SwFmtRefMark*)pItem)->GetRefName() );
|
|
|
|
pNames->Insert( pTmp, nCount );
|
|
|
|
}
|
|
|
|
nCount ++;
|
|
|
|
}
|
|
|
|
|
|
|
|
return nCount;
|
|
|
|
}
|
|
|
|
|
|
|
|
void SwDoc::SetModified()
|
|
|
|
{
|
|
|
|
// dem Link wird der Status returnt, wie die Flags waren und werden
|
|
|
|
// Bit 0: -> alter Zustand
|
|
|
|
// Bit 1: -> neuer Zustand
|
|
|
|
long nCall = bModified ? 3 : 2;
|
|
|
|
bModified = TRUE;
|
|
|
|
pDocStat->bModified = TRUE;
|
|
|
|
if( aOle2Link.IsSet() )
|
|
|
|
{
|
|
|
|
bInCallModified = TRUE;
|
|
|
|
aOle2Link.Call( (void*)nCall );
|
|
|
|
bInCallModified = FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if( pACEWord && !pACEWord->IsDeleted() )
|
|
|
|
delete pACEWord, pACEWord = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void SwDoc::ResetModified()
|
|
|
|
{
|
|
|
|
// dem Link wird der Status returnt, wie die Flags waren und werden
|
|
|
|
// Bit 0: -> alter Zustand
|
|
|
|
// Bit 1: -> neuer Zustand
|
|
|
|
long nCall = bModified ? 1 : 0;
|
|
|
|
bModified = FALSE;
|
|
|
|
nUndoSavePos = nUndoPos;
|
|
|
|
if( nCall && aOle2Link.IsSet() )
|
|
|
|
{
|
|
|
|
bInCallModified = TRUE;
|
|
|
|
aOle2Link.Call( (void*)nCall );
|
|
|
|
bInCallModified = FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void SwDoc::ReRead( SwPaM& rPam, const String& rGrfName,
|
2000-11-28 19:40:08 +00:00
|
|
|
const String& rFltName, const Graphic* pGraphic,
|
|
|
|
const GraphicObject* pGrafObj )
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
|
|
|
SwGrfNode *pGrfNd;
|
|
|
|
if( ( !rPam.HasMark()
|
|
|
|
|| rPam.GetPoint()->nNode.GetIndex() == rPam.GetMark()->nNode.GetIndex() )
|
|
|
|
&& 0 != ( pGrfNd = rPam.GetPoint()->nNode.GetNode().GetGrfNode() ) )
|
|
|
|
{
|
|
|
|
if( DoesUndo() )
|
|
|
|
{
|
|
|
|
ClearRedo();
|
|
|
|
AppendUndo( new SwUndoReRead( rPam, *pGrfNd ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
// Weil nicht bekannt ist, ob sich die Grafik spiegeln laesst,
|
|
|
|
// immer das SpiegelungsAttribut zuruecksetzen
|
|
|
|
if( RES_DONT_MIRROR_GRF != pGrfNd->GetSwAttrSet().
|
|
|
|
GetMirrorGrf().GetValue() )
|
|
|
|
pGrfNd->SetAttr( SwMirrorGrf() );
|
|
|
|
|
2000-11-28 19:40:08 +00:00
|
|
|
pGrfNd->ReRead( rGrfName, rFltName, pGraphic, pGrafObj, TRUE );
|
2000-09-18 23:08:29 +00:00
|
|
|
SetModified();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL lcl_SpellAgain( const SwNodePtr& rpNd, void* pArgs )
|
|
|
|
{
|
|
|
|
SwTxtNode *pTxtNode = (SwTxtNode*)rpNd->GetTxtNode();
|
|
|
|
BOOL bOnlyWrong = *(BOOL*)pArgs;
|
|
|
|
if( pTxtNode )
|
|
|
|
{
|
|
|
|
if( bOnlyWrong )
|
|
|
|
{
|
|
|
|
if( pTxtNode->GetWrong() &&
|
|
|
|
pTxtNode->GetWrong()->InvalidateWrong() )
|
|
|
|
pTxtNode->SetWrongDirty( TRUE );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
pTxtNode->SetWrongDirty( TRUE );
|
|
|
|
if( pTxtNode->GetWrong() )
|
|
|
|
pTxtNode->GetWrong()->SetInvalid( 0, STRING_LEN );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*************************************************************************
|
|
|
|
* SwDoc::SpellItAgainSam( BOOL bInvalid, BOOL bOnlyWrong )
|
|
|
|
*
|
|
|
|
* stoesst das Spelling im Idle-Handler wieder an.
|
|
|
|
* Wird bInvalid als TRUE uebergeben, so werden zusaetzlich die WrongListen
|
|
|
|
* an allen Nodes invalidiert und auf allen Seiten das SpellInvalid-Flag
|
|
|
|
* gesetzt.
|
|
|
|
* Mit bOnlyWrong kann man dann steuern, ob nur die Bereiche mit falschen
|
|
|
|
* Woertern oder die kompletten Bereiche neu ueberprueft werden muessen.
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
void SwDoc::SpellItAgainSam( BOOL bInvalid, BOOL bOnlyWrong )
|
|
|
|
{
|
|
|
|
ASSERT( GetRootFrm(), "SpellAgain: Where's my RootFrm?" );
|
|
|
|
if( bInvalid )
|
|
|
|
{
|
|
|
|
SwPageFrm *pPage = (SwPageFrm*)GetRootFrm()->Lower();
|
|
|
|
while ( pPage )
|
|
|
|
{
|
|
|
|
pPage->InvalidateSpelling();
|
|
|
|
pPage = (SwPageFrm*)pPage->GetNext();
|
|
|
|
}
|
|
|
|
GetNodes().ForEach( lcl_SpellAgain, &bOnlyWrong );
|
|
|
|
}
|
|
|
|
GetRootFrm()->SetIdleFlags();
|
|
|
|
}
|
|
|
|
|
|
|
|
void SwDoc::InvalidateAutoCompleteFlag()
|
|
|
|
{
|
|
|
|
if( GetRootFrm() )
|
|
|
|
{
|
|
|
|
SwPageFrm *pPage = (SwPageFrm*)GetRootFrm()->Lower();
|
|
|
|
while ( pPage )
|
|
|
|
{
|
|
|
|
pPage->InvalidateAutoCompleteWords();
|
|
|
|
pPage = (SwPageFrm*)pPage->GetNext();
|
|
|
|
}
|
|
|
|
for( ULONG nNd = 1, nCnt = GetNodes().Count(); nNd < nCnt; ++nNd )
|
|
|
|
GetNodes()[ nNd ]->SetAutoCompleteWordDirty( TRUE );
|
|
|
|
GetRootFrm()->SetIdleFlags();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const SwFmtINetFmt* SwDoc::FindINetAttr( const String& rName ) const
|
|
|
|
{
|
|
|
|
const SwFmtINetFmt* pItem;
|
|
|
|
const SwTxtINetFmt* pTxtAttr;
|
|
|
|
const SwTxtNode* pTxtNd;
|
|
|
|
USHORT n, nMaxItems = GetAttrPool().GetItemCount( RES_TXTATR_INETFMT );
|
|
|
|
for( n = 0; n < nMaxItems; ++n )
|
|
|
|
if( 0 != (pItem = (SwFmtINetFmt*)GetAttrPool().GetItem(
|
|
|
|
RES_TXTATR_INETFMT, n ) ) &&
|
|
|
|
pItem->GetName().Equals( rName ) &&
|
|
|
|
0 != ( pTxtAttr = pItem->GetTxtINetFmt()) &&
|
|
|
|
0 != ( pTxtNd = pTxtAttr->GetpTxtNode() ) &&
|
|
|
|
&pTxtNd->GetNodes() == &GetNodes() )
|
|
|
|
{
|
|
|
|
return pItem;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void SwDoc::Summary( SwDoc* pExtDoc, BYTE nLevel, BYTE nPara, BOOL bImpress )
|
|
|
|
{
|
|
|
|
const SwOutlineNodes& rOutNds = GetNodes().GetOutLineNds();
|
|
|
|
if( pExtDoc && rOutNds.Count() )
|
|
|
|
{
|
|
|
|
USHORT i;
|
|
|
|
::StartProgress( STR_STATSTR_SUMMARY, 0, rOutNds.Count(), GetDocShell() );
|
|
|
|
SwNodeIndex aEndOfDoc( pExtDoc->GetNodes().GetEndOfContent(), -1 );
|
|
|
|
for( i = 0; i < rOutNds.Count(); ++i )
|
|
|
|
{
|
|
|
|
::SetProgressState( i, GetDocShell() );
|
|
|
|
ULONG nIndex = rOutNds[ i ]->GetIndex();
|
|
|
|
BYTE nLvl = ((SwTxtNode*)GetNodes()[ nIndex ])->GetTxtColl()
|
|
|
|
->GetOutlineLevel();
|
|
|
|
if( nLvl > nLevel )
|
|
|
|
continue;
|
|
|
|
USHORT nEndOfs = 1;
|
|
|
|
BYTE nWish = nPara;
|
|
|
|
ULONG nNextOutNd = i + 1 < rOutNds.Count() ?
|
|
|
|
rOutNds[ i + 1 ]->GetIndex() : GetNodes().Count();
|
|
|
|
BOOL bKeep = FALSE;
|
|
|
|
while( ( nWish || bKeep ) && nIndex + nEndOfs < nNextOutNd &&
|
|
|
|
GetNodes()[ nIndex + nEndOfs ]->IsTxtNode() )
|
|
|
|
{
|
|
|
|
SwTxtNode* pTxtNode = (SwTxtNode*)GetNodes()[ nIndex+nEndOfs ];
|
|
|
|
if( pTxtNode->GetTxt().Len() && nWish )
|
|
|
|
--nWish;
|
|
|
|
bKeep = pTxtNode->GetSwAttrSet().GetKeep().GetValue();
|
|
|
|
++nEndOfs;
|
|
|
|
}
|
|
|
|
|
|
|
|
SwNodeRange aRange( *rOutNds[ i ], 0, *rOutNds[ i ], nEndOfs );
|
|
|
|
GetNodes()._Copy( aRange, aEndOfDoc );
|
|
|
|
}
|
|
|
|
const SwTxtFmtColls *pColl = pExtDoc->GetTxtFmtColls();
|
|
|
|
for( i = 0; i < pColl->Count(); ++i )
|
|
|
|
(*pColl)[ i ]->ResetAttr( RES_PAGEDESC, RES_BREAK );
|
|
|
|
SwNodeIndex aIndx( pExtDoc->GetNodes().GetEndOfExtras() );
|
|
|
|
++aEndOfDoc;
|
|
|
|
while( aIndx < aEndOfDoc )
|
|
|
|
{
|
|
|
|
SwNode *pNode;
|
|
|
|
BOOL bDelete = FALSE;
|
|
|
|
if( (pNode = &aIndx.GetNode())->IsTxtNode() )
|
|
|
|
{
|
|
|
|
SwTxtNode *pNd = (SwTxtNode*)pNode;
|
|
|
|
if( pNd->HasSwAttrSet() )
|
|
|
|
pNd->ResetAttr( RES_PAGEDESC, RES_BREAK );
|
|
|
|
if( bImpress )
|
|
|
|
{
|
|
|
|
SwTxtFmtColl* pColl = pNd->GetTxtColl();
|
|
|
|
USHORT nHeadLine = pColl->GetOutlineLevel()==NO_NUMBERING ?
|
|
|
|
RES_POOLCOLL_HEADLINE2 : RES_POOLCOLL_HEADLINE1;
|
|
|
|
pColl = pExtDoc->GetTxtCollFromPool( nHeadLine );
|
|
|
|
pNd->ChgFmtColl( pColl );
|
|
|
|
}
|
|
|
|
if( !pNd->Len() &&
|
|
|
|
pNd->StartOfSectionIndex()+2 < pNd->EndOfSectionIndex() )
|
|
|
|
{
|
|
|
|
bDelete = TRUE;
|
|
|
|
pExtDoc->GetNodes().Delete( aIndx );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if( !bDelete )
|
|
|
|
++aIndx;
|
|
|
|
}
|
|
|
|
::EndProgress( GetDocShell() );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// loesche den nicht sichtbaren Content aus dem Document, wie z.B.:
|
|
|
|
// versteckte Bereiche, versteckte Absaetze
|
|
|
|
BOOL SwDoc::RemoveInvisibleContent()
|
|
|
|
{
|
|
|
|
BOOL bRet = FALSE;
|
|
|
|
StartUndo( UIUNDO_DELETE_INVISIBLECNTNT );
|
|
|
|
|
|
|
|
{
|
|
|
|
SwTxtNode* pTxtNd;
|
|
|
|
SwClientIter aIter( *GetSysFldType( RES_HIDDENPARAFLD ) );
|
|
|
|
for( SwFmtFld* pFmtFld = (SwFmtFld*)aIter.First( TYPE( SwFmtFld ));
|
|
|
|
pFmtFld; pFmtFld = (SwFmtFld*)aIter.Next() )
|
|
|
|
if( pFmtFld->GetTxtFld() &&
|
|
|
|
0 != ( pTxtNd = (SwTxtNode*)pFmtFld->GetTxtFld()->GetpTxtNode() ) &&
|
|
|
|
pTxtNd->GetpSwpHints() && !pTxtNd->GetpSwpHints()->IsVisible() &&
|
|
|
|
&pTxtNd->GetNodes() == &GetNodes() )
|
|
|
|
{
|
|
|
|
bRet = TRUE;
|
|
|
|
// ein versteckter Absatz -> entfernen oder Inhalt loeschen?
|
|
|
|
SwPaM aPam( *pTxtNd, 0, *pTxtNd, pTxtNd->GetTxt().Len() );
|
|
|
|
|
|
|
|
if( 2 != pTxtNd->EndOfSectionIndex() -
|
|
|
|
pTxtNd->StartOfSectionIndex() )
|
|
|
|
{
|
|
|
|
aPam.DeleteMark();
|
|
|
|
DelFullPara( aPam );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
Delete( aPam );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
// dann noch alle versteckten Bereiche loeschen/leeren
|
|
|
|
SwSectionFmts aSectFmts;
|
|
|
|
SwSectionFmts& rSectFmts = GetSections();
|
|
|
|
for( USHORT n = rSectFmts.Count(); n; )
|
|
|
|
{
|
|
|
|
SwSectionFmt* pSectFmt = rSectFmts[ --n ];
|
|
|
|
SwSection* pSect = pSectFmt->GetSection();
|
|
|
|
if( pSect->CalcHiddenFlag() )
|
|
|
|
{
|
|
|
|
SwSection* pParent = pSect, *pTmp;
|
|
|
|
while( 0 != (pTmp = pParent->GetParent() ))
|
|
|
|
{
|
|
|
|
if( pTmp->IsHiddenFlag() )
|
|
|
|
pSect = pTmp;
|
|
|
|
pParent = pTmp;
|
|
|
|
}
|
|
|
|
|
|
|
|
if( USHRT_MAX == aSectFmts.GetPos( pSect->GetFmt() ) )
|
|
|
|
aSectFmts.Insert( pSect->GetFmt(), 0 );
|
|
|
|
}
|
|
|
|
if( pSect->GetCondition().Len() )
|
|
|
|
{
|
|
|
|
SwSection aSect( pSect->GetType(), pSect->GetName() );
|
|
|
|
aSect = *pSect;
|
|
|
|
aSect.SetCondition( aEmptyStr );
|
|
|
|
aSect.SetHidden( FALSE );
|
|
|
|
ChgSection( n, aSect );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if( 0 != ( n = aSectFmts.Count() ))
|
|
|
|
{
|
|
|
|
while( n )
|
|
|
|
{
|
|
|
|
SwSectionFmt* pSectFmt = aSectFmts[ --n ];
|
|
|
|
SwSectionNode* pSectNd = pSectFmt->GetSectionNode();
|
|
|
|
if( pSectNd )
|
|
|
|
{
|
|
|
|
bRet = TRUE;
|
|
|
|
SwPaM aPam( *pSectNd );
|
|
|
|
|
|
|
|
if( pSectNd->FindStartNode()->StartOfSectionIndex() ==
|
|
|
|
pSectNd->GetIndex() - 1 &&
|
|
|
|
pSectNd->FindStartNode()->EndOfSectionIndex() ==
|
|
|
|
pSectNd->EndOfSectionIndex() + 1 )
|
|
|
|
{
|
|
|
|
// nur den Inhalt loeschen
|
|
|
|
SwCntntNode* pCNd = GetNodes().GoNext(
|
|
|
|
&aPam.GetPoint()->nNode );
|
|
|
|
aPam.GetPoint()->nContent.Assign( pCNd, 0 );
|
|
|
|
aPam.SetMark();
|
|
|
|
aPam.GetPoint()->nNode = *pSectNd->EndOfSectionNode();
|
|
|
|
pCNd = GetNodes().GoPrevious(
|
|
|
|
&aPam.GetPoint()->nNode );
|
|
|
|
aPam.GetPoint()->nContent.Assign( pCNd, pCNd->Len() );
|
|
|
|
|
|
|
|
Delete( aPam );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// die gesamte Section loeschen
|
|
|
|
aPam.SetMark();
|
|
|
|
aPam.GetPoint()->nNode = *pSectNd->EndOfSectionNode();
|
|
|
|
DelFullPara( aPam );
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
aSectFmts.Remove( 0, aSectFmts.Count() );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if( bRet )
|
|
|
|
SetModified();
|
|
|
|
EndUndo( UIUNDO_DELETE_INVISIBLECNTNT );
|
|
|
|
return bRet;
|
|
|
|
}
|
|
|
|
|
|
|
|
// embedded alle lokalen Links (Bereiche/Grafiken)
|
|
|
|
BOOL SwDoc::EmbedAllLinks()
|
|
|
|
{
|
|
|
|
BOOL bRet = FALSE;
|
|
|
|
SvxLinkManager& rLnkMgr = GetLinkManager();
|
2001-03-08 20:28:23 +00:00
|
|
|
const ::so3::SvBaseLinks& rLnks = rLnkMgr.GetLinks();
|
2000-09-18 23:08:29 +00:00
|
|
|
if( rLnks.Count() )
|
|
|
|
{
|
|
|
|
BOOL bDoesUndo = DoesUndo();
|
|
|
|
DoUndo( FALSE );
|
|
|
|
|
|
|
|
for( USHORT n = 0; n < rLnks.Count(); ++n )
|
|
|
|
{
|
2001-03-08 20:28:23 +00:00
|
|
|
::so3::SvBaseLink* pLnk = &(*rLnks[ n ]);
|
2000-09-18 23:08:29 +00:00
|
|
|
if( pLnk &&
|
|
|
|
( OBJECT_CLIENT_GRF == pLnk->GetObjType() ||
|
|
|
|
OBJECT_CLIENT_FILE == pLnk->GetObjType() ) &&
|
|
|
|
pLnk->ISA( SwBaseLink ) )
|
|
|
|
{
|
2001-03-08 20:28:23 +00:00
|
|
|
::so3::SvBaseLinkRef xLink = pLnk;
|
2000-09-18 23:08:29 +00:00
|
|
|
USHORT nCount = rLnks.Count();
|
|
|
|
|
|
|
|
String sFName;
|
2001-03-08 20:28:23 +00:00
|
|
|
rLnkMgr.GetDisplayNames( xLink, 0, &sFName, 0, 0 );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
INetURLObject aURL( sFName );
|
|
|
|
if( INET_PROT_FILE == aURL.GetProtocol() ||
|
|
|
|
INET_PROT_CID == aURL.GetProtocol() )
|
|
|
|
{
|
|
|
|
// dem Link sagen, das er aufgeloest wird!
|
2001-03-08 20:28:23 +00:00
|
|
|
xLink->Closed();
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
// falls einer vergessen hat sich auszutragen
|
|
|
|
if( xLink.Is() )
|
2001-03-08 20:28:23 +00:00
|
|
|
rLnkMgr.Remove( xLink );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
if( nCount != rLnks.Count() + 1 )
|
|
|
|
n = 0; // wieder von vorne anfangen, es wurden
|
|
|
|
// mehrere Links entfernt
|
|
|
|
bRet = TRUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
DelAllUndoObj();
|
|
|
|
DoUndo( bDoesUndo );
|
|
|
|
SetModified();
|
|
|
|
}
|
|
|
|
return bRet;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*--------------------------------------------------------------------
|
|
|
|
Beschreibung:
|
|
|
|
--------------------------------------------------------------------*/
|
|
|
|
|
|
|
|
BOOL SwDoc::IsInsTblFormatNum() const
|
|
|
|
{
|
|
|
|
return SW_MOD()->IsInsTblFormatNum(IsHTMLMode());
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL SwDoc::IsInsTblChangeNumFormat() const
|
|
|
|
{
|
|
|
|
return SW_MOD()->IsInsTblChangeNumFormat(IsHTMLMode());
|
|
|
|
}
|
|
|
|
|
|
|
|
/*--------------------------------------------------------------------
|
|
|
|
Beschreibung:
|
|
|
|
--------------------------------------------------------------------*/
|
|
|
|
|
|
|
|
BOOL SwDoc::IsInsTblAlignNum() const
|
|
|
|
{
|
|
|
|
return SW_MOD()->IsInsTblAlignNum(IsHTMLMode());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
USHORT SwDoc::GetLinkUpdMode() const
|
|
|
|
{
|
|
|
|
USHORT nRet = nLinkUpdMode;
|
|
|
|
if( GLOBALSETTING == nRet )
|
|
|
|
nRet = SW_MOD()->GetLinkUpdMode(IsHTMLMode());
|
|
|
|
return nRet;
|
|
|
|
}
|
|
|
|
|
|
|
|
USHORT SwDoc::GetFldUpdateFlags() const
|
|
|
|
{
|
|
|
|
USHORT nRet = nFldUpdMode;
|
|
|
|
if( AUTOUPD_GLOBALSETTING == nRet )
|
|
|
|
nRet = SW_MOD()->GetFldUpdateFlags(IsHTMLMode());
|
|
|
|
return nRet;
|
|
|
|
}
|
|
|
|
|
2001-02-08 13:32:55 +00:00
|
|
|
// setze das InsertDB als Tabelle Undo auf:
|
|
|
|
void SwDoc::AppendUndoForInsertFromDB( const SwPaM& rPam, BOOL bIsTable )
|
|
|
|
{
|
|
|
|
if( bIsTable )
|
|
|
|
{
|
|
|
|
const SwTableNode* pTblNd = rPam.GetPoint()->nNode.GetNode().FindTableNode();
|
|
|
|
if( pTblNd )
|
|
|
|
{
|
|
|
|
SwUndoCpyTbl* pUndo = new SwUndoCpyTbl;
|
|
|
|
pUndo->SetTableSttIdx( pTblNd->GetIndex() );
|
|
|
|
AppendUndo( pUndo );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if( rPam.HasMark() )
|
|
|
|
{
|
|
|
|
SwUndoCpyDoc* pUndo = new SwUndoCpyDoc( rPam );
|
|
|
|
pUndo->SetInsertRange( rPam, FALSE );
|
|
|
|
AppendUndo( pUndo );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
|