1 /************************************************************** 2 * 3 * Licensed to the Apache Software Foundation (ASF) under one 4 * or more contributor license agreements. See the NOTICE file 5 * distributed with this work for additional information 6 * regarding copyright ownership. The ASF licenses this file 7 * to you under the Apache License, Version 2.0 (the 8 * "License"); you may not use this file except in compliance 9 * with the License. You may obtain a copy of the License at 10 * 11 * http://www.apache.org/licenses/LICENSE-2.0 12 * 13 * Unless required by applicable law or agreed to in writing, 14 * software distributed under the License is distributed on an 15 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16 * KIND, either express or implied. See the License for the 17 * specific language governing permissions and limitations 18 * under the License. 19 * 20 *************************************************************/ 21 22 23 24 // MARKER(update_precomp.py): autogen include statement, do not remove 25 #include "precompiled_sw.hxx" 26 #define ROLBCK_HISTORY_ONLY // Der Kampf gegen die CLOOK's 27 #include <doc.hxx> 28 #include <dcontact.hxx> 29 #include <com/sun/star/document/PrinterIndependentLayout.hpp> 30 #include <com/sun/star/document/UpdateDocMode.hpp> 31 #include <com/sun/star/text/XTextDocument.hpp> 32 #include <com/sun/star/linguistic2/XProofreadingIterator.hpp> 33 #include <com/sun/star/text/XFlatParagraphIteratorProvider.hpp> 34 35 #include <unotools/processfactory.hxx> 36 #include <vcl/svapp.hxx> 37 #include <vcl/virdev.hxx> 38 #include <rtl/logfile.hxx> 39 #include <sfx2/printer.hxx> 40 #include <sfx2/docfile.hxx> 41 #include <sfx2/frame.hxx> 42 #include <sfx2/viewfrm.hxx> 43 44 #include <svl/macitem.hxx> 45 #include <svx/svxids.hrc> 46 #include <svx/svdogrp.hxx> 47 #include <sfx2/linkmgr.hxx> 48 #include <editeng/forbiddencharacterstable.hxx> 49 #include <svl/zforlist.hxx> 50 #include <unotools/compatibility.hxx> 51 #include <unotools/lingucfg.hxx> 52 #include <svx/svdpage.hxx> 53 #include <paratr.hxx> 54 #include <fchrfmt.hxx> 55 #include <fmtcntnt.hxx> 56 #include <fmtanchr.hxx> 57 #include <fmtfsize.hxx> 58 #include <fmtfordr.hxx> 59 #include <fmtpdsc.hxx> 60 #include <pvprtdat.hxx> 61 #include <rootfrm.hxx> //Damit der RootDtor gerufen wird. 62 #include <layouter.hxx> 63 #include <pagedesc.hxx> //Damit die PageDescs zerstoert werden koennen. 64 #include <ndtxt.hxx> 65 #include <printdata.hxx> 66 #include <docfld.hxx> 67 #include <ftninfo.hxx> 68 #include <ftnidx.hxx> 69 #include <docstat.hxx> 70 #include <charfmt.hxx> 71 #include <frmfmt.hxx> 72 #include <rolbck.hxx> // Undo-Attr, SwHistory 73 #include <poolfmt.hxx> // fuer die Pool-Vorlage 74 #include <dbmgr.hxx> 75 #include <docsh.hxx> 76 #include <acorrect.hxx> // fuer die autom. Aufnahme von Ausnahmen 77 #include <visiturl.hxx> // fuer die URL-Change Benachrichtigung 78 #include <docary.hxx> 79 #include <lineinfo.hxx> 80 #include <drawdoc.hxx> 81 #include <linkenum.hxx> 82 #include <fldupde.hxx> 83 #include <extinput.hxx> 84 #include <viewsh.hxx> 85 #include <doctxm.hxx> 86 #include <shellres.hxx> 87 #include <breakit.hxx> 88 #include <laycache.hxx> 89 #include <mvsave.hxx> 90 #include <istyleaccess.hxx> 91 #include <swstylemanager.hxx> 92 #include <IGrammarContact.hxx> 93 #include <tblsel.hxx> 94 #include <MarkManager.hxx> 95 #include <UndoManager.hxx> 96 #include <unochart.hxx> 97 98 #include <cmdid.h> // fuer den dflt - Printer in SetJob 99 100 101 // --> OD 2006-04-19 #b6375613# 102 #include <com/sun/star/document/XDocumentInfoSupplier.hpp> 103 #include <com/sun/star/beans/XPropertyContainer.hpp> 104 #include <com/sun/star/beans/PropertyAttribute.hpp> 105 106 // <-- 107 108 // --> OD 2007-03-16 #i73788# 109 #include <pausethreadstarting.hxx> 110 // <-- 111 #include <numrule.hxx> 112 // --> OD 2008-03-13 #refactorlists# 113 #include <list.hxx> 114 #include <listfunc.hxx> 115 // <-- 116 117 #include <com/sun/star/document/XDocumentPropertiesSupplier.hpp> 118 119 #include <sfx2/Metadatable.hxx> 120 #include <fmtmeta.hxx> // MetaFieldManager 121 122 123 using namespace ::com::sun::star; 124 using namespace ::com::sun::star::document; 125 126 const sal_Char __FAR_DATA sFrmFmtStr[] = "Frameformat"; 127 const sal_Char __FAR_DATA sEmptyPageStr[] = "Empty Page"; 128 const sal_Char __FAR_DATA sColumnCntStr[] = "Columncontainer"; 129 const sal_Char __FAR_DATA sCharFmtStr[] = "Zeichenformat"; 130 const sal_Char __FAR_DATA sTxtCollStr[] = "Textformatvorlage"; 131 const sal_Char __FAR_DATA sGrfCollStr[] = "Graphikformatvorlage"; 132 133 SV_IMPL_PTRARR( SwNumRuleTbl, SwNumRulePtr) 134 SV_IMPL_PTRARR( SwTxtFmtColls, SwTxtFmtCollPtr) 135 SV_IMPL_PTRARR( SwGrfFmtColls, SwGrfFmtCollPtr) 136 137 /* 138 * global functions... 139 */ 140 141 uno::Reference< linguistic2::XProofreadingIterator > SwDoc::GetGCIterator() const 142 { 143 if (!m_xGCIterator.is() && SvtLinguConfig().HasGrammarChecker()) 144 { 145 uno::Reference< lang::XMultiServiceFactory > xMgr( utl::getProcessServiceFactory() ); 146 if (xMgr.is()) 147 { 148 try 149 { 150 rtl::OUString aServiceName( rtl::OUString::createFromAscii("com.sun.star.linguistic2.ProofreadingIterator") ); 151 m_xGCIterator = uno::Reference< linguistic2::XProofreadingIterator > 152 ( xMgr->createInstance( aServiceName ), uno::UNO_QUERY_THROW ); 153 } 154 catch (uno::Exception &) 155 { 156 DBG_ERROR( "No GCIterator" ); 157 } 158 } 159 } 160 161 return m_xGCIterator; 162 } 163 164 void StartGrammarChecking( SwDoc &rDoc ) 165 { 166 // check for a visible view 167 bool bVisible = false; 168 const SwDocShell *pDocShell = rDoc.GetDocShell(); 169 SfxViewFrame *pFrame = SfxViewFrame::GetFirst( pDocShell, sal_False ); 170 while (pFrame && !bVisible) 171 { 172 if (pFrame->IsVisible()) 173 bVisible = true; 174 pFrame = SfxViewFrame::GetNext( *pFrame, pDocShell, sal_False ); 175 } 176 177 //!! only documents with visible views need to be checked 178 //!! (E.g. don't check temporary documents created for printing, see printing of notes and selections. 179 //!! Those get created on the fly and get hard deleted a bit later as well, and no one should have 180 //!! a uno reference to them) 181 if (bVisible) 182 { 183 uno::Reference< linguistic2::XProofreadingIterator > xGCIterator( rDoc.GetGCIterator() ); 184 if ( xGCIterator.is() ) 185 { 186 uno::Reference< lang::XComponent > xDoc( rDoc.GetDocShell()->GetBaseModel(), uno::UNO_QUERY ); 187 uno::Reference< text::XFlatParagraphIteratorProvider > xFPIP( xDoc, uno::UNO_QUERY ); 188 189 // start automatic background checking if not active already 190 if ( xFPIP.is() && !xGCIterator->isProofreading( xDoc ) ) 191 xGCIterator->startProofreading( xDoc, xFPIP ); 192 } 193 } 194 } 195 196 /* 197 * interne Funktionen 198 */ 199 200 201 202 sal_Bool lcl_DelFmtIndizes( const SwFrmFmtPtr& rpFmt, void* ) 203 { 204 SwFmtCntnt &rFmtCntnt = (SwFmtCntnt&)rpFmt->GetCntnt(); 205 if ( rFmtCntnt.GetCntntIdx() ) 206 rFmtCntnt.SetNewCntntIdx( 0 ); 207 SwFmtAnchor &rFmtAnchor = (SwFmtAnchor&)rpFmt->GetAnchor(); 208 if ( rFmtAnchor.GetCntntAnchor() ) 209 rFmtAnchor.SetAnchor( 0 ); 210 return sal_True; 211 } 212 213 /* 214 * exportierte Methoden 215 */ 216 217 SwDoc::SwDoc() 218 : m_pNodes( new SwNodes(this) ) 219 , 220 mpAttrPool(new SwAttrPool(this)), 221 pMarkManager(new ::sw::mark::MarkManager(*this)), 222 m_pMetaFieldManager(new ::sw::MetaFieldManager()), 223 m_pUndoManager(new ::sw::UndoManager( 224 ::std::auto_ptr<SwNodes>(new SwNodes(this)), *this, *this, *this)), 225 pDfltFrmFmt( new SwFrmFmt( GetAttrPool(), sFrmFmtStr, 0 ) ), 226 pEmptyPageFmt( new SwFrmFmt( GetAttrPool(), sEmptyPageStr, pDfltFrmFmt ) ), 227 pColumnContFmt( new SwFrmFmt( GetAttrPool(), sColumnCntStr, pDfltFrmFmt ) ), 228 pDfltCharFmt( new SwCharFmt( GetAttrPool(), sCharFmtStr, 0 ) ), 229 pDfltTxtFmtColl( new SwTxtFmtColl( GetAttrPool(), sTxtCollStr ) ), 230 pDfltGrfFmtColl( new SwGrfFmtColl( GetAttrPool(), sGrfCollStr ) ), 231 pFrmFmtTbl( new SwFrmFmts() ), 232 pCharFmtTbl( new SwCharFmts() ), 233 pSpzFrmFmtTbl( new SwSpzFrmFmts() ), 234 pSectionFmtTbl( new SwSectionFmts() ), 235 pTblFrmFmtTbl( new SwFrmFmts() ), 236 pTxtFmtCollTbl( new SwTxtFmtColls() ), 237 pGrfFmtCollTbl( new SwGrfFmtColls() ), 238 pTOXTypes( new SwTOXTypes() ), 239 pDefTOXBases( new SwDefTOXBase_Impl() ), 240 pCurrentView( 0 ), //swmod 071225 241 pDrawModel( 0 ), 242 pUpdtFlds( new SwDocUpdtFld() ), 243 pFldTypes( new SwFldTypes() ), 244 pVirDev( 0 ), 245 pPrt( 0 ), 246 pPrtData( 0 ), 247 pGlossaryDoc( 0 ), 248 pOutlineRule( 0 ), 249 pFtnInfo( new SwFtnInfo ), 250 pEndNoteInfo( new SwEndNoteInfo ), 251 pLineNumberInfo( new SwLineNumberInfo ), 252 pFtnIdxs( new SwFtnIdxs ), 253 pDocStat( new SwDocStat ), 254 pDocShell( 0 ), 255 pLinkMgr( new sfx2::LinkManager( 0 ) ), 256 pACEWord( 0 ), 257 pURLStateChgd( 0 ), 258 pNumberFormatter( 0 ), 259 pNumRuleTbl( new SwNumRuleTbl ), 260 // --> OD 2008-03-26 #refactorlists# 261 maLists(), 262 maListStyleLists(), 263 // <-- 264 pRedlineTbl( new SwRedlineTbl ), 265 pAutoFmtRedlnComment( 0 ), 266 pUnoCrsrTbl( new SwUnoCrsrTbl( 0, 16 ) ), 267 pPgPViewPrtData( 0 ), 268 pExtInputRing( 0 ), 269 pLayouter( 0 ), 270 // --> OD 2008-03-07 #refactorlists# 271 pStyleAccess( 0 ), 272 // <-- 273 pLayoutCache( 0 ), 274 pUnoCallBack(new SwModify(0)), 275 mpGrammarContact( 0 ), 276 aChartDataProviderImplRef(), 277 pChartControllerHelper( 0 ), 278 // --> OD 2007-10-31 #i83479# 279 mpListItemsList( new tImplSortedNodeNumList() ), 280 // <-- 281 m_pXmlIdRegistry(), 282 nAutoFmtRedlnCommentNo( 0 ), 283 nLinkUpdMode( GLOBALSETTING ), 284 eFldUpdMode( AUTOUPD_GLOBALSETTING ), 285 eRedlineMode((RedlineMode_t)(nsRedlineMode_t::REDLINE_SHOW_INSERT | nsRedlineMode_t::REDLINE_SHOW_DELETE)), 286 eChrCmprType( CHARCOMPRESS_NONE ), 287 mReferenceCount(0), 288 mIdleBlockCount(0), 289 nLockExpFld( 0 ), 290 mbReadlineChecked(false), 291 // --> OD 2005-02-11 #i38810# 292 mbLinksUpdated( sal_False ), 293 mbClipBoard( false ), 294 mbColumnSelection( false ), 295 mbContainsAtPageObjWithContentAnchor( false ), 296 // i#78591# 297 mbProtectForm(false), 298 mbLastBrowseMode( false ), 299 n32DummyCompatabilityOptions1(0), 300 n32DummyCompatabilityOptions2(0), 301 mbStartIdleTimer(sal_False), 302 mbSetDrawDefaults(false), 303 meDocType( DOCTYPE_NATIVE ) 304 { 305 RTL_LOGFILE_CONTEXT_AUTHOR( aLog, "SW", "JP93722", "SwDoc::SwDoc" ); 306 307 mbGlossDoc = 308 mbModified = 309 mbDtor = 310 mbPageNums = 311 mbLoaded = 312 mbUpdateExpFld = 313 mbNewDoc = 314 mbCopyIsMove = 315 mbInReading = 316 mbInXMLImport = 317 mbUpdateTOX = 318 mbInLoadAsynchron = 319 mbHTMLMode = 320 mbInCallModified = 321 mbIsGlobalDoc = 322 mbGlblDocSaveLinks = 323 mbIsLabelDoc = 324 mbIsAutoFmtRedline = 325 mbOLEPrtNotifyPending = 326 mbAllOLENotify = 327 mbIsRedlineMove = 328 mbInsOnlyTxtGlssry = 329 mbContains_MSVBasic = 330 mbKernAsianPunctuation = 331 #ifdef DBG_UTIL 332 mbXMLExport = 333 #endif 334 // --> OD 2006-03-21 #b6375613# 335 mbApplyWorkaroundForB6375613 = 336 // <-- 337 false; 338 339 mbNewFldLst = 340 mbVisibleLinks = 341 mbPurgeOLE = 342 true; 343 344 // 345 // COMPATIBILITY FLAGS START 346 // 347 348 // Note: Any non-hidden compatibility flag should obtain its default 349 // by asking SvtCompatibilityOptions, see below. 350 // 351 const SvtCompatibilityOptions aOptions; 352 mbParaSpaceMax = aOptions.IsAddSpacing(); 353 mbParaSpaceMaxAtPages = aOptions.IsAddSpacingAtPages(); 354 mbTabCompat = !aOptions.IsUseOurTabStops(); 355 mbUseVirtualDevice = !aOptions.IsUsePrtDevice(); 356 mbAddExternalLeading = !aOptions.IsNoExtLeading(); 357 mbOldLineSpacing = aOptions.IsUseLineSpacing(); 358 mbAddParaSpacingToTableCells = aOptions.IsAddTableSpacing(); 359 mbUseFormerObjectPos = aOptions.IsUseObjectPositioning(); 360 mbUseFormerTextWrapping = aOptions.IsUseOurTextWrapping(); 361 mbConsiderWrapOnObjPos = aOptions.IsConsiderWrappingStyle(); 362 mbMathBaselineAlignment = false; // default for *old* documents is 'off' 363 mbAddFlyOffsets = false; // hidden 364 mbOldNumbering = false; // hidden 365 mbUseHiResolutionVirtualDevice = true; // hidden 366 mbIgnoreFirstLineIndentInNumbering = false; // hidden 367 mbDoNotJustifyLinesWithManualBreak = !aOptions.IsExpandWordSpace(); 368 mbDoNotResetParaAttrsForNumFont = false; // hidden 369 mbOutlineLevelYieldsOutlineRule = false; // hidden 370 mbTableRowKeep = false; // hidden 371 mbIgnoreTabsAndBlanksForLineCalculation = false; // hidden 372 mbDoNotCaptureDrawObjsOnPage = false; // hidden 373 mbClipAsCharacterAnchoredWriterFlyFrames= false; // hidden 374 mbUnixForceZeroExtLeading = false; // hidden 375 mbOldPrinterMetrics = false; // hidden 376 mbTabRelativeToIndent = true; // hidden 377 // --> OD 2008-06-05 #i89181# 378 mbTabAtLeftIndentForParagraphsInList = false; // hidden 379 // <-- 380 381 // 382 // COMPATIBILITY FLAGS END 383 // 384 385 pMacroTable = new SvxMacroTableDtor; 386 387 mpGrammarContact = ::createGrammarContact(); 388 389 /* 390 * Defaultformate und DefaultFormatsammlungen (FmtColl) 391 * werden an der Position 0 in das jeweilige Array eingetragen. 392 * Die Formate der FmtColls sind von den Defaultformaten 393 * abgeleitet und stehen auch in der Liste. 394 */ 395 /* Formate */ 396 pFrmFmtTbl->Insert(pDfltFrmFmt, 0 ); 397 pCharFmtTbl->Insert(pDfltCharFmt, 0 ); 398 399 /* FmtColls */ 400 // TXT 401 pTxtFmtCollTbl->Insert(pDfltTxtFmtColl, 0 ); 402 // GRF 403 pGrfFmtCollTbl->Insert(pDfltGrfFmtColl, 0 ); 404 405 // PageDesc, EmptyPageFmt und ColumnFmt anlegen 406 if ( !aPageDescs.Count() ) 407 GetPageDescFromPool( RES_POOLPAGE_STANDARD ); 408 409 //Leere Seite Einstellen. 410 pEmptyPageFmt->SetFmtAttr( SwFmtFrmSize( ATT_FIX_SIZE ) ); 411 //BodyFmt fuer Spalten Einstellen. 412 pColumnContFmt->SetFmtAttr( SwFmtFillOrder( ATT_LEFT_TO_RIGHT ) ); 413 414 _InitFieldTypes(); 415 416 // lege (fuer die Filter) eine Default-OutlineNumRule an 417 // --> OD 2008-02-11 #newlistlevelattrs# 418 pOutlineRule = new SwNumRule( String::CreateFromAscii( SwNumRule::GetOutlineRuleName() ), 419 // --> OD 2008-06-06 #i89178# 420 numfunc::GetDefaultPositionAndSpaceMode(), 421 // <-- 422 OUTLINE_RULE ); 423 // <-- 424 // #115901# 425 AddNumRule(pOutlineRule); 426 // --> OD 2005-10-21 - counting of phantoms depends on <IsOldNumbering()> 427 pOutlineRule->SetCountPhantoms( !get(IDocumentSettingAccess::OLD_NUMBERING) ); 428 // <-- 429 430 new SwTxtNode( 431 SwNodeIndex(GetUndoManager().GetUndoNodes().GetEndOfContent()), 432 pDfltTxtFmtColl ); 433 new SwTxtNode( SwNodeIndex( GetNodes().GetEndOfContent() ), 434 GetTxtCollFromPool( RES_POOLCOLL_STANDARD )); 435 436 // den eigenen IdleTimer setzen 437 aIdleTimer.SetTimeout( 600 ); 438 aIdleTimer.SetTimeoutHdl( LINK(this, SwDoc, DoIdleJobs) ); 439 440 aOLEModifiedTimer.SetTimeout( 1000 ); 441 aOLEModifiedTimer.SetTimeoutHdl( LINK( this, SwDoc, DoUpdateModifiedOLE )); 442 443 // DBMgr anlegen 444 pNewDBMgr = new SwNewDBMgr; 445 446 // create TOXTypes 447 InitTOXTypes(); 448 449 // --> OD 2008-03-07 #refactorlists# 450 // pass empty item set containing the paragraph's list attributes 451 // as ignorable items to the stype manager. 452 { 453 SfxItemSet aIgnorableParagraphItems( GetAttrPool(), 454 RES_PARATR_LIST_BEGIN, RES_PARATR_LIST_END-1, 455 0 ); 456 pStyleAccess = createStyleManager( &aIgnorableParagraphItems ); 457 } 458 // <-- 459 460 ResetModified(); 461 } 462 463 /* 464 * Besonderheiten: an der Position 0 des Arrays der Formate und 465 * der GDI-Objekte befindet sich ein Member der Klasse SwDoc. 466 * Dieser darf also keinesfalls durch delete geloescht 467 * werden!!!!!!!!!! 468 */ 469 470 471 SwDoc::~SwDoc() 472 { 473 // nothing here should create Undo actions! 474 GetIDocumentUndoRedo().DoUndo(false); 475 476 if (pDocShell) 477 { 478 pDocShell->SetUndoManager(0); 479 } 480 481 // --> OD 2007-03-16 #i73788# 482 SwPauseThreadStarting aPauseThreadStarting; 483 // <-- 484 485 // --> OD 2007-11-01 #i83479# 486 delete mpListItemsList; 487 mpListItemsList = 0; 488 // <-- 489 490 // clean up chart related structures... 491 // Note: the chart data provider gets already diposed in ~SwDocShell 492 // since all UNO API related functionality requires an existing SwDocShell 493 // this assures that dipose gets called if there is need for it. 494 aChartDataProviderImplRef.reset(); 495 delete pChartControllerHelper; 496 497 delete mpGrammarContact; 498 mpGrammarContact = 0; 499 500 //!! needs to be done to destroy a possible SwFmtDrop format that may 501 //!! be connected to a char format which may not otherwise be removed 502 //!! and thus would leave a unremoved SwFmt object. (TL) 503 //!! (this is case is not possible via UI but via API...) 504 SwFmtDrop aDrop; 505 SetDefault(aDrop); 506 //!! same for SwFmtCharFmt 507 SwFmtCharFmt aCharFmt(NULL); 508 SetDefault(aCharFmt); 509 510 StopIdling(); // stop idle timer 511 512 delete pUnoCallBack, pUnoCallBack = 0; 513 delete pURLStateChgd; 514 515 delete pLayouter; 516 // --> OD 2005-09-05 #125370# 517 pLayouter = 0L; 518 // <-- 519 520 // Undo-Benachrichtigung vom Draw abschalten 521 if( pDrawModel ) 522 { 523 DrawNotifyUndoHdl(); 524 ClrContourCache(); 525 } 526 527 delete pPgPViewPrtData; 528 529 mbDtor = sal_True; 530 pLayoutPtr.reset(); 531 532 delete pRedlineTbl; 533 delete pUnoCrsrTbl; 534 delete pAutoFmtRedlnComment; 535 536 if( pUpdtFlds ) 537 delete pUpdtFlds; 538 539 if( pACEWord ) 540 delete pACEWord; 541 542 // die BaseLinks freigeben. 543 { 544 for( sal_uInt16 n = pLinkMgr->GetServers().Count(); n; ) 545 pLinkMgr->GetServers()[ --n ]->Closed(); 546 547 if( pLinkMgr->GetLinks().Count() ) 548 pLinkMgr->Remove( 0, pLinkMgr->GetLinks().Count() ); 549 } 550 551 // die KapitelNummern / Nummern muessen vor den Vorlage geloescht werden 552 // ansonsten wird noch staendig geupdatet !!! 553 m_pNodes->pOutlineNds->Remove(sal_uInt16(0), m_pNodes->pOutlineNds->Count()); 554 SwNodes & rUndoNodes( GetUndoManager().GetUndoNodes() ); 555 rUndoNodes.pOutlineNds->Remove(sal_uInt16(0), rUndoNodes.pOutlineNds->Count()); 556 557 pFtnIdxs->Remove( sal_uInt16(0), pFtnIdxs->Count() ); 558 559 // indices could be registered in attributes 560 m_pUndoManager->DelAllUndoObj(); 561 562 // in den BookMarks sind Indizies auf den Content. Diese muessen vorm 563 // loesche der Nodes geloescht werden. 564 pMarkManager->clearAllMarks(); 565 DELETEZ( pMacroTable ); 566 567 if( pExtInputRing ) 568 { 569 Ring* pTmp = pExtInputRing; 570 pExtInputRing = 0; 571 while( pTmp->GetNext() != pTmp ) 572 delete pTmp->GetNext(); 573 delete pTmp; 574 } 575 576 //JP: alt - loeschen ohne Flag ist teuer; Modify wird verschickt! 577 // aTOXTypes.DeleteAndDestroy( 0, aTOXTypes.Count() ); 578 { 579 for( sal_uInt16 n = pTOXTypes->Count(); n; ) 580 { 581 (*pTOXTypes)[ --n ]->SetInDocDTOR(); 582 delete (*pTOXTypes)[ n ]; 583 } 584 pTOXTypes->Remove( 0, pTOXTypes->Count() ); 585 } 586 delete pDefTOXBases; 587 588 //Im einen oder anderen FrmFormat koennen noch Indizes angemeldet sein, 589 //Diese muessen spaetestens jetzt zerstoert werden. 590 pFrmFmtTbl->ForEach( &lcl_DelFmtIndizes, this ); 591 pSpzFrmFmtTbl->ForEach( &lcl_DelFmtIndizes, this ); 592 ((SwFrmFmts&)*pSectionFmtTbl).ForEach( &lcl_DelFmtIndizes, this ); 593 594 //Die Formate, die hier hinter stehen sind von den DefaultFormaten 595 //abhaengig. Erst nach dem Loeschen der FmtIndizes weil der Inhalt von 596 //Kopf-/Fussbereichen geloescht wird. Wenn dort noch Indizes von Flys 597 //angemeldet sind gibts was an die Ohren. 598 aPageDescs.DeleteAndDestroy( 0, aPageDescs.Count() ); 599 600 // Inhaltssections loeschen 601 // nicht erst durch den SwNodes-DTOR, damit Formate 602 // keine Abhaengigen mehr haben. 603 m_pNodes->DelNodes( SwNodeIndex(*m_pNodes), m_pNodes->Count() ); 604 rUndoNodes.DelNodes( SwNodeIndex( rUndoNodes ), rUndoNodes.Count() ); 605 606 // Formate loeschen, spaeter mal permanent machen. 607 608 // Delete fuer Collections 609 // damit die Abhaengigen wech sind 610 pFtnInfo->ReleaseCollection(); 611 pEndNoteInfo->ReleaseCollection(); 612 613 ASSERT( pDfltTxtFmtColl == (*pTxtFmtCollTbl)[0], 614 "Default-Text-Collection muss immer am Anfang stehen" ); 615 616 // JP 27.01.98: opt.: ausgehend davon, das Standard als 2. im Array 617 // steht, sollte das als letztes geloescht werden, damit 618 // die ganze Umhaengerei der Formate vermieden wird! 619 if( 2 < pTxtFmtCollTbl->Count() ) 620 pTxtFmtCollTbl->DeleteAndDestroy( 2, pTxtFmtCollTbl->Count()-2 ); 621 pTxtFmtCollTbl->DeleteAndDestroy( 1, pTxtFmtCollTbl->Count()-1 ); 622 delete pTxtFmtCollTbl; 623 624 ASSERT( pDfltGrfFmtColl == (*pGrfFmtCollTbl)[0], 625 "Default-Grf-Collection muss immer am Anfang stehen" ); 626 627 pGrfFmtCollTbl->DeleteAndDestroy( 1, pGrfFmtCollTbl->Count()-1 ); 628 // ergibt sich automatisch - kein _DEL Array! 629 // pGrfFmtCollTbl->Remove( 0, n ); 630 delete pGrfFmtCollTbl; 631 632 /* 633 * Defaultformate und DefaultFormatsammlungen (FmtColl) 634 * sind an der Position 0 der jeweiligen Arrays eingetragen. 635 * Damit sie nicht vom DTOR der Array's zum 2.mal geloescht werden, 636 * nehme sie aus dem Array. 637 */ 638 pFrmFmtTbl->Remove( 0 ); 639 pCharFmtTbl->Remove( 0 ); 640 641 // Delete fuer pPrt 642 DELETEZ( pPrt ); 643 DELETEZ( pNewDBMgr ); 644 645 // Alle Flys muessen vor dem Drawing Model zerstoert werden, 646 // da Flys noch DrawContacts enthalten koennen, wenn wegen 647 // eines Lesefehlers kein Layout aufgebaut wurde. 648 pSpzFrmFmtTbl->DeleteAndDestroy( 0, pSpzFrmFmtTbl->Count() ); 649 650 //Erst jetzt das Model zerstoeren, die Zeichenobjekte - die ja auch 651 //im Undo herumlungern - wollen noch ihre Attribute beim Model entfernen. 652 //Ausserdem koennen vorher noch DrawContacts existieren. 653 ReleaseDrawModel(); 654 //JP 28.01.99: DrawModel vorm LinkManager zerstoeren, da am DrawModel 655 // dieser immer gesetzt ist. 656 DELETEZ( pLinkMgr ); 657 658 //Tables vor dem loeschen der Defaults leeren, sonst GPF wegen Def-Abhaengigen. 659 //Die Arrays sollten (wegen includes) bei Gelegenheit auch zu Pointern werden. 660 delete pFrmFmtTbl; 661 delete pSpzFrmFmtTbl; 662 663 delete pStyleAccess; 664 665 delete pCharFmtTbl; 666 delete pSectionFmtTbl; 667 delete pTblFrmFmtTbl; 668 delete pDfltTxtFmtColl; 669 delete pDfltGrfFmtColl; 670 delete pNumRuleTbl; 671 672 // --> OD 2008-03-26 #refactorlists# 673 { 674 for ( std::hash_map< String, SwList*, StringHash >::iterator 675 aListIter = maLists.begin(); 676 aListIter != maLists.end(); 677 ++aListIter ) 678 { 679 delete (*aListIter).second; 680 } 681 maLists.clear(); 682 } 683 maListStyleLists.clear(); 684 // <-- 685 686 delete pPrtData; 687 delete pNumberFormatter; 688 delete pFtnInfo; 689 delete pEndNoteInfo; 690 delete pLineNumberInfo; 691 delete pFtnIdxs; 692 delete pFldTypes; 693 delete pTOXTypes; 694 delete pDocStat; 695 delete pEmptyPageFmt; 696 delete pColumnContFmt; 697 delete pDfltCharFmt; 698 delete pDfltFrmFmt; 699 delete pLayoutCache; 700 delete pVirDev; 701 702 SfxItemPool::Free(mpAttrPool); 703 } 704 705 //--------------------------------------------------- 706 707 VirtualDevice& SwDoc::CreateVirtualDevice_() const 708 { 709 VirtualDevice* pNewVir = new VirtualDevice( 1 ); 710 711 // <-- 712 pNewVir->SetReferenceDevice( VirtualDevice::REFDEV_MODE_MSO1 ); 713 714 // --> FME 2006-10-09 #i60945# External leading compatibility for unix systems. 715 if ( get(IDocumentSettingAccess::UNIX_FORCE_ZERO_EXT_LEADING ) ) 716 pNewVir->Compat_ZeroExtleadBug(); 717 // <-- 718 719 MapMode aMapMode( pNewVir->GetMapMode() ); 720 aMapMode.SetMapUnit( MAP_TWIP ); 721 pNewVir->SetMapMode( aMapMode ); 722 723 const_cast<SwDoc*>(this)->setVirtualDevice( pNewVir, true, true ); 724 return *pVirDev; 725 } 726 727 //--------------------------------------------------- 728 729 SfxPrinter& SwDoc::CreatePrinter_() const 730 { 731 ASSERT( ! pPrt, "Do not call CreatePrinter_(), call getPrinter() instead" ) 732 733 #if OSL_DEBUG_LEVEL > 1 734 OSL_TRACE( "Printer will be created!" ); 735 #endif 736 737 // wir erzeugen einen default SfxPrinter. 738 // Das ItemSet wird vom Sfx geloescht! 739 SfxItemSet *pSet = new SfxItemSet( ((SwDoc*)this)->GetAttrPool(), 740 FN_PARAM_ADDPRINTER, FN_PARAM_ADDPRINTER, 741 SID_HTML_MODE, SID_HTML_MODE, 742 SID_PRINTER_NOTFOUND_WARN, SID_PRINTER_NOTFOUND_WARN, 743 SID_PRINTER_CHANGESTODOC, SID_PRINTER_CHANGESTODOC, 744 0 ); 745 746 SfxPrinter* pNewPrt = new SfxPrinter( pSet ); 747 const_cast<SwDoc*>(this)->setPrinter( pNewPrt, true, true ); 748 return *pPrt; 749 } 750 //--------------------------------------------------- 751 752 void SwDoc::SetDocShell( SwDocShell* pDSh ) 753 { 754 if( pDocShell != pDSh ) 755 { 756 if (pDocShell) 757 { 758 pDocShell->SetUndoManager(0); 759 } 760 pDocShell = pDSh; 761 if (pDocShell) 762 { 763 pDocShell->SetUndoManager(& GetUndoManager()); 764 } 765 766 pLinkMgr->SetPersist( pDocShell ); 767 //JP 27.08.98: Bug 55570 - DocShell Pointer auch am DrawModel setzen 768 if( pDrawModel ) 769 { 770 ((SwDrawDocument*)pDrawModel)->SetObjectShell( pDocShell ); 771 pDrawModel->SetPersist( pDocShell ); 772 ASSERT( pDrawModel->GetPersist() == GetPersist(), 773 "draw model's persist is out of sync" ); 774 } 775 } 776 } 777 778 779 // Convenience-Methode, um uebermaessige Includes von docsh.hxx 780 // zu vermeiden 781 782 783 784 uno::Reference < embed::XStorage > SwDoc::GetDocStorage() 785 { 786 if( pDocShell ) 787 return pDocShell->GetStorage(); 788 if( pLinkMgr->GetPersist() ) 789 return pLinkMgr->GetPersist()->GetStorage(); 790 return NULL; 791 } 792 793 794 795 SfxObjectShell* SwDoc::GetPersist() const 796 { 797 return pDocShell ? pDocShell : pLinkMgr->GetPersist(); 798 } 799 800 801 void SwDoc::ClearDoc() 802 { 803 GetIDocumentUndoRedo().DelAllUndoObj(); 804 ::sw::UndoGuard const undoGuard(GetIDocumentUndoRedo()); 805 806 // Undo-Benachrichtigung vom Draw abschalten 807 if( pDrawModel ) 808 { 809 DrawNotifyUndoHdl(); 810 ClrContourCache(); 811 } 812 813 // stehen noch FlyFrames rum, loesche auch diese 814 sal_uInt16 n; 815 while ( 0 != (n = GetSpzFrmFmts()->Count()) ) 816 DelLayoutFmt((*pSpzFrmFmtTbl)[n-1]); 817 ASSERT( !pDrawModel || !pDrawModel->GetPage(0)->GetObjCount(), 818 "not all DrawObjects removed from the page" ); 819 820 pRedlineTbl->DeleteAndDestroy( 0, pRedlineTbl->Count() ); 821 822 if( pACEWord ) 823 delete pACEWord; 824 825 // in den BookMarks sind Indizies auf den Content. Diese muessen vorm 826 // loesche der Nodes geloescht werden. 827 pMarkManager->clearAllMarks(); 828 InitTOXTypes(); 829 830 // create a dummy pagedesc for the layout 831 sal_uInt16 nDummyPgDsc = MakePageDesc( String::CreateFromAscii( "?DUMMY?" )); 832 SwPageDesc* pDummyPgDsc = aPageDescs[ nDummyPgDsc ]; 833 834 SwNodeIndex aSttIdx( *GetNodes().GetEndOfContent().StartOfSectionNode(), 1 ); 835 // den ersten immer wieder neu anlegen (ohne Attribute/Vorlagen/...) 836 SwTxtNode* pFirstNd = GetNodes().MakeTxtNode( aSttIdx, pDfltTxtFmtColl ); 837 838 if( pCurrentView ) //swmod 071029//swmod 071225 839 { 840 // set the layout to the dummy pagedesc 841 pFirstNd->SetAttr( SwFmtPageDesc( pDummyPgDsc )); 842 843 SwPosition aPos( *pFirstNd, SwIndex( pFirstNd )); 844 SwPaM const tmpPaM(aSttIdx, SwNodeIndex(GetNodes().GetEndOfContent())); 845 ::PaMCorrAbs(tmpPaM, aPos); 846 } 847 848 GetNodes().Delete( aSttIdx, 849 GetNodes().GetEndOfContent().GetIndex() - aSttIdx.GetIndex() ); 850 851 // --> OD 2006-02-28 #i62440# 852 // destruction of numbering rules and creation of new outline rule 853 // *after* the document nodes are deleted. 854 pOutlineRule = NULL; 855 pNumRuleTbl->DeleteAndDestroy( 0, pNumRuleTbl->Count() ); 856 // --> OD #i114725#,#i115828# 857 { 858 for ( std::hash_map< String, SwList*, StringHash >::iterator 859 aListIter = maLists.begin(); 860 aListIter != maLists.end(); 861 ++aListIter ) 862 { 863 delete (*aListIter).second; 864 } 865 maLists.clear(); 866 } 867 maListStyleLists.clear(); 868 // <-- 869 // creation of new outline numbering rule 870 // --> OD 2008-02-11 #newlistlevelattrs# 871 pOutlineRule = new SwNumRule( String::CreateFromAscii( SwNumRule::GetOutlineRuleName() ), 872 // --> OD 2008-06-06 #i89178# 873 numfunc::GetDefaultPositionAndSpaceMode(), 874 // <-- 875 OUTLINE_RULE ); 876 // <-- 877 AddNumRule(pOutlineRule); 878 // --> OD 2005-10-21 - counting of phantoms depends on <IsOldNumbering()> 879 pOutlineRule->SetCountPhantoms( !get(IDocumentSettingAccess::OLD_NUMBERING) ); 880 // <-- 881 // <-- 882 883 //remove the dummy pagedec from the array and delete all the old ones 884 aPageDescs.Remove( nDummyPgDsc ); 885 aPageDescs.DeleteAndDestroy( 0, aPageDescs.Count() ); 886 887 // Delete fuer Collections 888 // damit die Abhaengigen wech sind 889 pFtnInfo->ReleaseCollection(); 890 pEndNoteInfo->ReleaseCollection(); 891 892 // JP 27.01.98: opt.: ausgehend davon, das Standard als 2. im Array 893 // steht, sollte das als letztes geloescht werden, damit 894 // die ganze Umhaengerei der Formate vermieden wird! 895 if( 2 < pTxtFmtCollTbl->Count() ) 896 pTxtFmtCollTbl->DeleteAndDestroy( 2, pTxtFmtCollTbl->Count()-2 ); 897 pTxtFmtCollTbl->DeleteAndDestroy( 1, pTxtFmtCollTbl->Count()-1 ); 898 pGrfFmtCollTbl->DeleteAndDestroy( 1, pGrfFmtCollTbl->Count()-1 ); 899 pCharFmtTbl->DeleteAndDestroy( 1, pCharFmtTbl->Count()-1 ); 900 901 if( pCurrentView ) 902 { 903 // search the FrameFormat of the root frm. This is not allowed to delete 904 pFrmFmtTbl->Remove( pFrmFmtTbl->GetPos( pCurrentView->GetLayout()->GetFmt() ) ); 905 pFrmFmtTbl->DeleteAndDestroy( 1, pFrmFmtTbl->Count()-1 ); 906 pFrmFmtTbl->Insert( pCurrentView->GetLayout()->GetFmt(), pFrmFmtTbl->Count() ); 907 } 908 else //swmod 071029//swmod 071225 909 pFrmFmtTbl->DeleteAndDestroy( 1, pFrmFmtTbl->Count()-1 ); 910 911 xForbiddenCharsTable.unbind(); 912 913 pFldTypes->DeleteAndDestroy( INIT_FLDTYPES, 914 pFldTypes->Count() - INIT_FLDTYPES ); 915 916 delete pNumberFormatter, pNumberFormatter = 0; 917 918 GetPageDescFromPool( RES_POOLPAGE_STANDARD ); 919 pFirstNd->ChgFmtColl( GetTxtCollFromPool( RES_POOLCOLL_STANDARD )); 920 nDummyPgDsc = aPageDescs.Count(); 921 aPageDescs.Insert( pDummyPgDsc, nDummyPgDsc ); 922 // set the layout back to the new standard pagedesc 923 pFirstNd->ResetAllAttr(); 924 // delete now the dummy pagedesc 925 DelPageDesc( nDummyPgDsc ); 926 } 927 928 void SwDoc::SetPreViewPrtData( const SwPagePreViewPrtData* pNew ) 929 { 930 if( pNew ) 931 { 932 if( pPgPViewPrtData ) 933 *pPgPViewPrtData = *pNew; 934 else 935 pPgPViewPrtData = new SwPagePreViewPrtData( *pNew ); 936 } 937 else if( pPgPViewPrtData ) 938 DELETEZ( pPgPViewPrtData ); 939 SetModified(); 940 } 941 /* -----------------------------06.01.00 14:03-------------------------------- 942 943 ---------------------------------------------------------------------------*/ 944 SwModify* SwDoc::GetUnoCallBack() const 945 { 946 return pUnoCallBack; 947 } 948 949 /*-----------------28.5.2001 10:06------------------ 950 * SwDoc: 951 * Reading and writing of the layout cache. 952 *--------------------------------------------------*/ 953 954 void SwDoc::ReadLayoutCache( SvStream& rStream ) 955 { 956 if( !pLayoutCache ) 957 pLayoutCache = new SwLayoutCache(); 958 if( !pLayoutCache->IsLocked() ) 959 { 960 pLayoutCache->GetLockCount() |= 0x8000; 961 pLayoutCache->Read( rStream ); 962 pLayoutCache->GetLockCount() &= 0x7fff; 963 } 964 } 965 966 void SwDoc::WriteLayoutCache( SvStream& rStream ) 967 { 968 pLayoutCache->Write( rStream, *this ); 969 } 970 971 IGrammarContact* getGrammarContact( const SwTxtNode& rTxtNode ) 972 { 973 const SwDoc* pDoc = rTxtNode.GetDoc(); 974 if( !pDoc || pDoc->IsInDtor() ) 975 return 0; 976 return pDoc->getGrammarContact(); 977 } 978 979 // --> FME 2005-02-25 #i42634# Moved common code of SwReader::Read() and 980 // SwDocShell::UpdateLinks() to new SwDoc::UpdateLinks(): 981 void SwDoc::UpdateLinks( sal_Bool bUI ) 982 { 983 SfxObjectCreateMode eMode; 984 sal_uInt16 nLinkMode = getLinkUpdateMode( true ); 985 sal_uInt16 nUpdateDocMode = GetDocShell()->GetUpdateDocMode(); 986 if( GetDocShell() && 987 (nLinkMode != NEVER || document::UpdateDocMode::FULL_UPDATE == nUpdateDocMode) && 988 GetLinkManager().GetLinks().Count() && 989 SFX_CREATE_MODE_INTERNAL != 990 ( eMode = GetDocShell()->GetCreateMode()) && 991 SFX_CREATE_MODE_ORGANIZER != eMode && 992 SFX_CREATE_MODE_PREVIEW != eMode && 993 !GetDocShell()->IsPreview() ) 994 { 995 ViewShell* pVSh = 0; 996 sal_Bool bAskUpdate = nLinkMode == MANUAL; 997 sal_Bool bUpdate = sal_True; 998 switch(nUpdateDocMode) 999 { 1000 case document::UpdateDocMode::NO_UPDATE: bUpdate = sal_False;break; 1001 case document::UpdateDocMode::QUIET_UPDATE:bAskUpdate = sal_False; break; 1002 case document::UpdateDocMode::FULL_UPDATE: bAskUpdate = sal_True; break; 1003 } 1004 if( bUpdate && (bUI || !bAskUpdate) ) 1005 { 1006 SfxMedium* pMedium = GetDocShell()->GetMedium(); 1007 SfxFrame* pFrm = pMedium ? pMedium->GetLoadTargetFrame() : 0; 1008 Window* pDlgParent = pFrm ? &pFrm->GetWindow() : 0; 1009 if( GetCurrentViewShell() && !GetEditShell( &pVSh ) && !pVSh ) //swmod 071108//swmod 071225 1010 { 1011 ViewShell aVSh( *this, 0, 0 ); 1012 1013 SET_CURR_SHELL( &aVSh ); 1014 GetLinkManager().UpdateAllLinks( bAskUpdate , sal_True, sal_False, pDlgParent ); 1015 } 1016 else 1017 GetLinkManager().UpdateAllLinks( bAskUpdate, sal_True, sal_False, pDlgParent ); 1018 } 1019 } 1020 1021 } 1022 // <-- 1023 // --> OD 2006-04-19 #b6375613# 1024 void SwDoc::SetApplyWorkaroundForB6375613( bool p_bApplyWorkaroundForB6375613 ) 1025 { 1026 if ( mbApplyWorkaroundForB6375613 != p_bApplyWorkaroundForB6375613 ) 1027 { 1028 mbApplyWorkaroundForB6375613 = p_bApplyWorkaroundForB6375613; 1029 1030 uno::Reference< document::XDocumentInfoSupplier > xDoc( 1031 GetDocShell()->GetBaseModel(), 1032 uno::UNO_QUERY); 1033 if ( xDoc.is() ) 1034 { 1035 uno::Reference< beans::XPropertyContainer > xDocInfo( 1036 xDoc->getDocumentInfo(), 1037 uno::UNO_QUERY ); 1038 if ( xDocInfo.is() ) 1039 { 1040 try 1041 { 1042 if ( mbApplyWorkaroundForB6375613 ) 1043 { 1044 xDocInfo->addProperty( 1045 rtl::OUString::createFromAscii("WorkaroundForB6375613Applied"), 1046 beans::PropertyAttribute::TRANSIENT | beans::PropertyAttribute::REMOVABLE, 1047 uno::makeAny( false ) ); 1048 } 1049 else 1050 { 1051 xDocInfo->removeProperty( rtl::OUString::createFromAscii("WorkaroundForB6375613Applied") ); 1052 } 1053 } 1054 catch( uno::Exception& ) 1055 { 1056 } 1057 } 1058 } 1059 } 1060 } 1061 // <-- 1062 1063 ::sfx2::IXmlIdRegistry& 1064 SwDoc::GetXmlIdRegistry() 1065 { 1066 // UGLY: this relies on SetClipBoard being called before GetXmlIdRegistry! 1067 if (!m_pXmlIdRegistry.get()) 1068 { 1069 m_pXmlIdRegistry.reset( ::sfx2::createXmlIdRegistry( IsClipBoard() ) ); 1070 } 1071 return *m_pXmlIdRegistry; 1072 } 1073 1074 ::sw::MetaFieldManager & 1075 SwDoc::GetMetaFieldManager() 1076 { 1077 return *m_pMetaFieldManager; 1078 } 1079 1080 ::sw::UndoManager & 1081 SwDoc::GetUndoManager() 1082 { 1083 return *m_pUndoManager; 1084 } 1085 1086 ::sw::UndoManager const& 1087 SwDoc::GetUndoManager() const 1088 { 1089 return *m_pUndoManager; 1090 } 1091 1092 IDocumentUndoRedo & 1093 SwDoc::GetIDocumentUndoRedo() 1094 { 1095 return *m_pUndoManager; 1096 } 1097 1098 IDocumentUndoRedo const& 1099 SwDoc::GetIDocumentUndoRedo() const 1100 { 1101 return *m_pUndoManager; 1102 } 1103 1104 void SwDoc::InitTOXTypes() 1105 { 1106 ShellResource* pShellRes = ViewShell::GetShellRes(); 1107 SwTOXType * pNew = new SwTOXType(TOX_CONTENT, pShellRes->aTOXContentName ); 1108 pTOXTypes->Insert( pNew, pTOXTypes->Count() ); 1109 pNew = new SwTOXType(TOX_INDEX, pShellRes->aTOXIndexName ); 1110 pTOXTypes->Insert( pNew, pTOXTypes->Count() ); 1111 pNew = new SwTOXType(TOX_USER, pShellRes->aTOXUserName ); 1112 pTOXTypes->Insert( pNew, pTOXTypes->Count() ); 1113 pNew = new SwTOXType(TOX_ILLUSTRATIONS, pShellRes->aTOXIllustrationsName ); 1114 pTOXTypes->Insert( pNew, pTOXTypes->Count() ); 1115 pNew = new SwTOXType(TOX_OBJECTS, pShellRes->aTOXObjectsName ); 1116 pTOXTypes->Insert( pNew, pTOXTypes->Count() ); 1117 pNew = new SwTOXType(TOX_TABLES, pShellRes->aTOXTablesName ); 1118 pTOXTypes->Insert( pNew, pTOXTypes->Count() ); 1119 pNew = new SwTOXType(TOX_AUTHORITIES, pShellRes->aTOXAuthoritiesName ); 1120 pTOXTypes->Insert( pNew, pTOXTypes->Count() ); 1121 } 1122 1123 /*-- 08.05.2009 10:07:57--------------------------------------------------- 1124 1125 -----------------------------------------------------------------------*/ 1126 SfxObjectShell* SwDoc::CreateCopy(bool bCallInitNew ) const 1127 { 1128 SwDoc* pRet = new SwDoc; 1129 //copy settings 1130 sal_uInt16 __FAR_DATA aRangeOfDefaults[] = { 1131 RES_FRMATR_BEGIN, RES_FRMATR_END-1, 1132 RES_CHRATR_BEGIN, RES_CHRATR_END-1, 1133 RES_PARATR_BEGIN, RES_PARATR_END-1, 1134 // --> OD 2008-02-25 #refactorlists## 1135 RES_PARATR_LIST_BEGIN, RES_PARATR_LIST_END-1, 1136 // <-- 1137 RES_UNKNOWNATR_BEGIN, RES_UNKNOWNATR_END-1, 1138 0 1139 }; 1140 1141 SfxItemSet aNewDefaults( pRet->GetAttrPool(), aRangeOfDefaults ); 1142 1143 sal_uInt16 nWhich; 1144 sal_uInt16 nRange = 0; 1145 while( aRangeOfDefaults[nRange] != 0) 1146 { 1147 for( nWhich = aRangeOfDefaults[nRange]; nWhich < aRangeOfDefaults[nRange + 1]; ++nWhich ) 1148 { 1149 const SfxPoolItem& rSourceAttr = mpAttrPool->GetDefaultItem( nWhich ); 1150 if( rSourceAttr != pRet->mpAttrPool->GetDefaultItem( nWhich ) ) 1151 aNewDefaults.Put( rSourceAttr ); 1152 } 1153 nRange += 2; 1154 } 1155 if( aNewDefaults.Count() ) 1156 pRet->SetDefault( aNewDefaults ); 1157 1158 pRet->n32DummyCompatabilityOptions1 = n32DummyCompatabilityOptions1; 1159 pRet->n32DummyCompatabilityOptions2 = n32DummyCompatabilityOptions2; 1160 pRet->mbParaSpaceMax = mbParaSpaceMax ; 1161 pRet->mbParaSpaceMaxAtPages = mbParaSpaceMaxAtPages ; 1162 pRet->mbTabCompat = mbTabCompat ; 1163 pRet->mbUseVirtualDevice = mbUseVirtualDevice ; 1164 pRet->mbAddExternalLeading = mbAddExternalLeading ; 1165 pRet->mbOldLineSpacing = mbOldLineSpacing ; 1166 pRet->mbAddParaSpacingToTableCells = mbAddParaSpacingToTableCells ; 1167 pRet->mbUseFormerObjectPos = mbUseFormerObjectPos ; 1168 pRet->mbUseFormerTextWrapping = mbUseFormerTextWrapping ; 1169 pRet->mbConsiderWrapOnObjPos = mbConsiderWrapOnObjPos ; 1170 pRet->mbAddFlyOffsets = mbAddFlyOffsets ; 1171 pRet->mbOldNumbering = mbOldNumbering ; 1172 pRet->mbUseHiResolutionVirtualDevice = mbUseHiResolutionVirtualDevice ; 1173 pRet->mbIgnoreFirstLineIndentInNumbering = mbIgnoreFirstLineIndentInNumbering ; 1174 pRet->mbDoNotJustifyLinesWithManualBreak = mbDoNotJustifyLinesWithManualBreak ; 1175 pRet->mbDoNotResetParaAttrsForNumFont = mbDoNotResetParaAttrsForNumFont ; 1176 pRet->mbOutlineLevelYieldsOutlineRule = mbOutlineLevelYieldsOutlineRule ; 1177 pRet->mbTableRowKeep = mbTableRowKeep ; 1178 pRet->mbIgnoreTabsAndBlanksForLineCalculation = mbIgnoreTabsAndBlanksForLineCalculation ; 1179 pRet->mbDoNotCaptureDrawObjsOnPage = mbDoNotCaptureDrawObjsOnPage ; 1180 pRet->mbClipAsCharacterAnchoredWriterFlyFrames= mbClipAsCharacterAnchoredWriterFlyFrames; 1181 pRet->mbUnixForceZeroExtLeading = mbUnixForceZeroExtLeading ; 1182 pRet->mbOldPrinterMetrics = mbOldPrinterMetrics ; 1183 pRet->mbTabRelativeToIndent = mbTabRelativeToIndent ; 1184 pRet->mbTabAtLeftIndentForParagraphsInList = mbTabAtLeftIndentForParagraphsInList ; 1185 1186 // 1187 // COMPATIBILITY FLAGS END 1188 // 1189 pRet->ReplaceStyles( * const_cast< SwDoc*>( this )); 1190 1191 // we have to use pointer here, since the callee has to decide whether SfxObjectShellLock or SfxObjectShellRef should be used 1192 // sometimes the object will be returned with refcount set to 0 ( if no DoInitNew is done ) 1193 SfxObjectShell* pRetShell = new SwDocShell( pRet, SFX_CREATE_MODE_STANDARD ); 1194 if( bCallInitNew ) 1195 { 1196 // it could happen that DoInitNew creates model, that increases the refcount of the object 1197 pRetShell->DoInitNew(); 1198 } 1199 1200 //copy content 1201 pRet->Paste( *this ); 1202 1203 // remove the temporary shell if it is there as it was done before 1204 pRet->SetTmpDocShell( (SfxObjectShell*)NULL ); 1205 1206 return pRetShell; 1207 } 1208 /*-- 08.05.2009 10:52:40--------------------------------------------------- 1209 copy document content - code from SwFEShell::Paste( SwDoc* , sal_Bool ) 1210 -----------------------------------------------------------------------*/ 1211 void SwDoc::Paste( const SwDoc& rSource ) 1212 { 1213 // this has to be empty const sal_uInt16 nStartPageNumber = GetPhyPageNum(); 1214 // until the end of the NodesArray 1215 SwNodeIndex aSourceIdx( rSource.GetNodes().GetEndOfExtras(), 2 ); 1216 SwPaM aCpyPam( aSourceIdx ); //DocStart 1217 SwNodeIndex aTargetIdx( GetNodes().GetEndOfExtras(), 2 ); 1218 SwPaM aInsertPam( aTargetIdx ); //replaces PCURCRSR from SwFEShell::Paste() 1219 1220 1221 aCpyPam.SetMark(); 1222 aCpyPam.Move( fnMoveForward, fnGoDoc ); 1223 1224 this->GetIDocumentUndoRedo().StartUndo( UNDO_INSGLOSSARY, NULL ); 1225 this->LockExpFlds(); 1226 1227 { 1228 SwPosition& rInsPos = *aInsertPam.GetPoint(); 1229 //find out if the clipboard document starts with a table 1230 bool bStartWithTable = 0 != aCpyPam.Start()->nNode.GetNode().FindTableNode(); 1231 SwPosition aInsertPosition( rInsPos ); 1232 1233 { 1234 SwNodeIndex aIndexBefore(rInsPos.nNode); 1235 1236 aIndexBefore--; 1237 1238 rSource.CopyRange( aCpyPam, rInsPos, true ); 1239 1240 { 1241 aIndexBefore++; 1242 SwPaM aPaM(SwPosition(aIndexBefore), 1243 SwPosition(rInsPos.nNode)); 1244 1245 MakeUniqueNumRules(aPaM); 1246 } 1247 } 1248 1249 //TODO: Is this necessary here? SaveTblBoxCntnt( &rInsPos ); 1250 if(/*bIncludingPageFrames && */bStartWithTable) 1251 { 1252 //remove the paragraph in front of the table 1253 SwPaM aPara(aInsertPosition); 1254 this->DelFullPara(aPara); 1255 } 1256 //additionally copy page bound frames 1257 if( /*bIncludingPageFrames && */rSource.GetSpzFrmFmts()->Count() ) 1258 { 1259 for ( sal_uInt16 i = 0; i < rSource.GetSpzFrmFmts()->Count(); ++i ) 1260 { 1261 sal_Bool bInsWithFmt = sal_True; 1262 const SwFrmFmt& rCpyFmt = *(*rSource.GetSpzFrmFmts())[i]; 1263 if( bInsWithFmt ) 1264 { 1265 SwFmtAnchor aAnchor( rCpyFmt.GetAnchor() ); 1266 if (FLY_AT_PAGE == aAnchor.GetAnchorId()) 1267 { 1268 aAnchor.SetPageNum( aAnchor.GetPageNum() /*+ nStartPageNumber - */); 1269 } 1270 else 1271 continue; 1272 this->CopyLayoutFmt( rCpyFmt, aAnchor, true, true ); 1273 } 1274 } 1275 } 1276 } 1277 1278 this->GetIDocumentUndoRedo().EndUndo( UNDO_INSGLOSSARY, NULL ); 1279 1280 UnlockExpFlds(); 1281 UpdateFlds(NULL, false); 1282 } 1283