xref: /trunk/main/sw/inc/doc.hxx (revision dec99bbd)
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 #ifndef SW_DOC_HXX
24 #define SW_DOC_HXX
25 
26 /** SwDoc interfaces */
27 
28 #include <IInterface.hxx>
29 #include <IDocumentSettingAccess.hxx>
30 #include <IDocumentDeviceAccess.hxx>
31 #include <IDocumentMarkAccess.hxx>
32 #include <IDocumentRedlineAccess.hxx>
33 #include <IDocumentLinksAdministration.hxx>
34 #include <IDocumentFieldsAccess.hxx>
35 #include <IDocumentContentOperations.hxx>
36 #include <IDocumentStylePoolAccess.hxx>
37 #include <IDocumentLineNumberAccess.hxx>
38 #include <IDocumentStatistics.hxx>
39 #include <IDocumentState.hxx>
40 #include <IDocumentDrawModelAccess.hxx>
41 #include <IDocumentLayoutAccess.hxx>
42 #include <IDocumentTimerAccess.hxx>
43 #include <IDocumentChartDataProviderAccess.hxx>
44 // --> OD 2007-10-26 #i83479#
45 #include <IDocumentOutlineNodes.hxx>
46 #include <IDocumentListItems.hxx>
47 #include <set>
48 // <--
49 // --> OD 2008-03-12 #refactorlists#
50 #include <IDocumentListsAccess.hxx>
51 class SwList;
52 // <--
53 #include <IDocumentExternalData.hxx>
54 #define _SVSTDARR_STRINGSDTOR
55 #include <svl/svstdarr.hxx>
56 #include <com/sun/star/embed/XEmbeddedObject.hpp>
57 #include <com/sun/star/embed/XStorage.hpp>
58 #include <vcl/timer.hxx>
59 #include "swdllapi.h"
60 #include <swtypes.hxx>
61 #include <swatrset.hxx>
62 #include <toxe.hxx>   	  		// enums
63 #include <flyenum.hxx>
64 #include <itabenum.hxx>
65 #include <swdbdata.hxx>
66 #include <chcmprse.hxx>
67 #include <com/sun/star/linguistic2/XSpellChecker1.hpp>
68 #include <com/sun/star/linguistic2/XHyphenatedWord.hpp>
69 #include <vos/ref.hxx>
70 #include <svx/svdtypes.hxx>
71 #include <sfx2/objsh.hxx>
72 #include <svl/style.hxx>
73 #include <editeng/numitem.hxx>
74 #include "comphelper/implementationreference.hxx"
75 #include <com/sun/star/chart2/data/XDataProvider.hpp>
76 #include <com/sun/star/linguistic2/XProofreadingIterator.hpp>
77 #ifdef FUTURE_VBA
78 #include <com/sun/star/script/vba/XVBAEventProcessor.hpp>
79 #endif
80 
81 #include <hash_map>
82 #include <stringhash.hxx>
83 
84 #include <svtools/embedhlp.hxx>
85 #include <vector>
86 #include <set>
87 #include <map>
88 #include <memory>
89 
90 #include <boost/scoped_ptr.hpp>
91 #include <boost/shared_ptr.hpp>
92 #include <flypos.hxx>
93 
94 class SvxForbiddenCharactersTable;
95 class SwExtTextInput;
96 class DateTime;
97 class EditFieldInfo;
98 class JobSetup;
99 class Color;
100 class KeyCode;
101 class Outliner;
102 class OutputDevice;
103 class Point;
104 class SbxArray;
105 class SdrModel;
106 class SdrObject;
107 class SdrUndoAction;
108 class VirtualDevice;
109 class SfxPrinter;
110 class SvNumberFormatter;
111 class SvStringsSort;
112 class SvUShorts;
113 class SvUShortsSort;
114 class SvxMacro;
115 class SvxMacroTableDtor;
116 class SvxBorderLine;
117 class SwAutoCompleteWord;
118 class SwAutoCorrExceptWord;
119 class SwCalc;
120 class SwCellFrm;
121 class SwCharFmt;
122 class SwCharFmts;
123 class SwConditionTxtFmtColl;
124 class SwCrsrShell;
125 class SwCursor;
126 class SwDBNameInfField;
127 class SwDocShell;
128 class SwDocUpdtFld;
129 class SwDrawFrmFmt;
130 class SwDrawView;
131 class SwEditShell;
132 class SwFieldType;
133 class SwField;
134 class SwTxtFld;
135 class SwFldTypes;
136 class SwFlyFrmFmt;
137 class SwFmt;
138 class SwFmtINetFmt;
139 class SwFmtRefMark;
140 class SwFrmFmt;
141 class SwFrmFmts;
142 class SwFtnIdxs;
143 class SwFtnInfo;
144 class SwEndNoteInfo;
145 class GraphicObject;
146 class SwGrfFmtColl;
147 class SwGrfFmtColls;
148 class SwLineNumberInfo;
149 class SwNewDBMgr;
150 class SwNoTxtNode;
151 class SwNodeIndex;
152 class SwNodeRange;
153 class SwNodes;
154 class SwNumRule;
155 class SwNumRuleTbl;
156 class SwPageDesc;
157 class SwPagePreViewPrtData;
158 class SwRedline;
159 class SwRedlineTbl;
160 class SwRootFrm;
161 class SwRubyList;
162 class SwRubyListEntry;
163 class SwSectionFmt;
164 class SwSectionFmts;
165 class SwSectionData;
166 class SwSelBoxes;
167 class SwSpzFrmFmts;
168 class SwTOXBase;
169 class SwTOXBaseSection;
170 class SwTOXMark;
171 class SwTOXMarks;
172 class SwTOXType;
173 class SwTOXTypes;
174 class SwTabCols;
175 class SwTable;
176 class SwTableAutoFmt;
177 class SwTableBox;
178 class SwTableBoxFmt;
179 class SwTableFmt;
180 class SwTableLineFmt;
181 class SwTableNode;
182 class SwTextBlocks;
183 class SwTxtFmtColl;
184 class SwTxtFmtColls;
185 class SwURLStateChanged;
186 class SwUnoCrsr;
187 class SwUnoCrsrTbl;
188 class ViewShell;
189 class _SetGetExpFld;
190 class SwDrawContact;
191 class SwLayouter;
192 class SdrView;
193 class SdrMarkList;
194 class SwAuthEntry;
195 class SwLayoutCache;
196 class IStyleAccess;
197 struct SwCallMouseEvent;
198 struct SwDocStat;
199 struct SwHash;
200 struct SwSortOptions;
201 struct SwDefTOXBase_Impl;
202 class SwPrintData;
203 class SwPrintUIOptions;
204 class SdrPageView;
205 struct SwConversionArgs;
206 class SwRewriter;
207 class SwMsgPoolItem;
208 class SwChartDataProvider;
209 class SwChartLockController_Helper;
210 class IGrammarContact;
211 class SwPrintData;
212 class SwRenderData;
213 class SwPageFrm;
214 class SwViewOption;
215 class IDocumentUndoRedo;
216 
217 namespace sw { namespace mark {
218     class MarkManager;
219 }}
220 namespace sw {
221     class MetaFieldManager;
222     class UndoManager;
223     class IShellCursorSupplier;
224 }
225 
226 namespace com { namespace sun { namespace star {
227 namespace i18n {
228 	struct ForbiddenCharacters;    // comes from the I18N UNO interface
229 }
230 namespace uno {
231 	template < class > class Sequence;
232 }
233 namespace container {
234 	class XNameContainer; // for getXForms()/isXForms()/initXForms() methods
235 }
236 }}}
237 
238 namespace sfx2 {
239 	class SvLinkSource;
240     class IXmlIdRegistry;
241     class LinkManager;
242 }
243 
244 //PageDescriptor-Schnittstelle, Array hier wegen inlines.
245 typedef SwPageDesc* SwPageDescPtr;
246 SV_DECL_PTRARR_DEL( SwPageDescs, SwPageDescPtr, 4, 4 )
247 
248 // forward declartion
249 void SetAllScriptItem( SfxItemSet& rSet, const SfxPoolItem& rItem );
250 
251 // global function to start grammar checking in the document
252 void StartGrammarChecking( SwDoc &rDoc );
253 
254 class SW_DLLPUBLIC SwDoc :
255     public IInterface,
256     public IDocumentSettingAccess,
257     public IDocumentDeviceAccess,
258     public IDocumentRedlineAccess,
259     public IDocumentLinksAdministration,
260     public IDocumentFieldsAccess,
261     public IDocumentContentOperations,
262     public IDocumentStylePoolAccess,
263     public IDocumentLineNumberAccess,
264     public IDocumentStatistics,
265     public IDocumentState,
266     public IDocumentDrawModelAccess,
267     public IDocumentLayoutAccess,
268     public IDocumentTimerAccess,
269     public IDocumentChartDataProviderAccess,
270     // --> OD 2007-10-26 #i83479#
271     public IDocumentListItems,
272     public IDocumentOutlineNodes,
273     // <--
274     // --> OD 2008-03-12 #refactorlists#
275     public IDocumentListsAccess,
276     // <--
277     public IDocumentExternalData
278 {
279 
280 	friend void _InitCore();
281 	friend void _FinitCore();
282 
283     //---------------- private Member --------------------------------
284 
285 	// -------------------------------------------------------------------
286     ::boost::scoped_ptr<SwNodes> m_pNodes;  /// document content (Nodes Array)
287 	SwAttrPool*	mpAttrPool;				// der Attribut Pool
288 	SwPageDescs	aPageDescs;				// PageDescriptoren
289 	Link 		aOle2Link;				// OLE 2.0-Benachrichtigung
290     /* @@@MAINTAINABILITY-HORROR@@@
291        Timer should not be members of the model
292     */
293     Timer       aIdleTimer;             // der eigene IdleTimer
294 	Timer		aOLEModifiedTimer; 		// Timer for update modified OLE-Objecs
295 	SwDBData	aDBData;				// database descriptor
296 	::com::sun::star::uno::Sequence <sal_Int8 > aRedlinePasswd;
297 	String		sTOIAutoMarkURL; 		// ::com::sun::star::util::URL of table of index AutoMark file
298 	SvStringsDtor aPatternNms;			// Array fuer die Namen der Dokument-Vorlagen
299 	com::sun::star::uno::Reference<com::sun::star::container::XNameContainer>
300         xXForms;                        // container with XForms models
301     mutable com::sun::star::uno::Reference< com::sun::star::linguistic2::XProofreadingIterator > m_xGCIterator;
302 
303     const ::boost::scoped_ptr< ::sw::mark::MarkManager> pMarkManager;
304     const ::boost::scoped_ptr< ::sw::MetaFieldManager > m_pMetaFieldManager;
305     const ::boost::scoped_ptr< ::sw::UndoManager > m_pUndoManager;
306 
307 	// -------------------------------------------------------------------
308 	// die Pointer
309 								//Defaultformate
310 	SwFrmFmt		*pDfltFrmFmt;
311  	SwFrmFmt		*pEmptyPageFmt;		// Format fuer die Default-Leerseite.
312 	SwFrmFmt		*pColumnContFmt; 	// Format fuer Spaltencontainer
313 	SwCharFmt		*pDfltCharFmt;
314 	SwTxtFmtColl	*pDfltTxtFmtColl;	// Defaultformatcollections
315 	SwGrfFmtColl	*pDfltGrfFmtColl;
316 
317 	SwFrmFmts		*pFrmFmtTbl;		// Formattabellen
318 	SwCharFmts		*pCharFmtTbl;
319 	SwSpzFrmFmts	*pSpzFrmFmtTbl;
320 	SwSectionFmts	*pSectionFmtTbl;
321 	SwFrmFmts		*pTblFrmFmtTbl;		// spz. fuer Tabellen
322 	SwTxtFmtColls	*pTxtFmtCollTbl;	// FormatCollections
323 	SwGrfFmtColls	*pGrfFmtCollTbl;
324 
325 	SwTOXTypes		*pTOXTypes;			// Verzeichnisse
326 	SwDefTOXBase_Impl * pDefTOXBases;	// defaults of SwTOXBase's
327 
328 	ViewShell		*pCurrentView;	// SwDoc should get a new member pCurrentView//swmod 071225
329 	boost::shared_ptr<SwRootFrm> pLayoutPtr;
330 	SdrModel		*pDrawModel;		// StarView Drawing
331 
332 	SwDocUpdtFld 	*pUpdtFlds;			// Struktur zum Field-Update
333 	SwFldTypes		*pFldTypes;			// Feldtypen
334 	SwNewDBMgr 		*pNewDBMgr;			// Pointer auf den neuen DBMgr fuer
335 										// Evaluierung der DB-Fields
336 
337     VirtualDevice   *pVirDev;           // can be used for formatting
338     SfxPrinter      *pPrt;              // can be used for formatting
339     SwPrintData     *pPrtData;          // Print configuration
340 
341 	SwDoc			*pGlossaryDoc;		// Pointer auf das Glossary-Dokument. Dieses
342 
343 	SwNumRule		*pOutlineRule;
344 	SwFtnInfo		*pFtnInfo;
345 	SwEndNoteInfo 	*pEndNoteInfo;
346     SwLineNumberInfo*pLineNumberInfo;
347 	SwFtnIdxs		*pFtnIdxs;
348 	SwDocStat		*pDocStat;			// Statistic Informationen
349 	SvxMacroTableDtor *pMacroTable; 	// Tabelle der dokumentglobalen Macros
350 
351 	SwDocShell		*pDocShell;			// Ptr auf die SfxDocShell vom Doc
352     SfxObjectShellLock xTmpDocShell;    // A temporary shell that is used to copy OLE-Nodes
353 
354 	sfx2::LinkManager	*pLinkMgr;			// Liste von Verknuepften (Grafiken/DDE/OLE)
355 
356 	SwAutoCorrExceptWord *pACEWord;		// fuer die automatische Uebernahme von
357 										// autokorrigierten Woertern, die "zurueck"
358 										// verbessert werden
359 	SwURLStateChanged *pURLStateChgd;	// SfxClient fuer Aenderungen in der
360 										// INetHistory
361 	SvNumberFormatter *pNumberFormatter;	// NumFormatter fuer die Tabellen/Felder
362 
363     mutable SwNumRuleTbl    *pNumRuleTbl;           // Liste aller benannten NumRules
364 
365     // Hash map to find numrules by name
366     mutable std::hash_map<String, SwNumRule *, StringHash> maNumRuleMap;
367 
368     // --> OD 2008-03-12 #refactorlists#
369     typedef std::hash_map< String, SwList*, StringHash > tHashMapForLists;
370     // container to hold the lists of the text document
371     tHashMapForLists maLists;
372     // relation between list style and its default list
373     tHashMapForLists maListStyleLists;
374     // <--
375 
376 	SwRedlineTbl	*pRedlineTbl;			// Liste aller Redlines
377 	String			*pAutoFmtRedlnComment;	// Kommentar fuer Redlines, die
378 										// uebers Autoformat eingefuegt werden
379 	SwUnoCrsrTbl	*pUnoCrsrTbl;
380 
381 	SwPagePreViewPrtData *pPgPViewPrtData;		// Einzuege/Abstaende fuers
382 										// Drucken der Seitenansicht
383 	SwPaM			*pExtInputRing;
384 
385 	SwLayouter		*pLayouter;		// ::com::sun::star::frame::Controller for complex layout formatting
386 									// like footnote/endnote in sections
387     IStyleAccess    *pStyleAccess;  // handling of automatic styles
388     SwLayoutCache   *pLayoutCache;  // Layout cache to read and save with the
389                                     // document for a faster formatting
390 
391     SwModify *pUnoCallBack;
392     IGrammarContact *mpGrammarContact;   // for grammar checking in paragraphs during editing
393 
394     mutable  comphelper::ImplementationReference< SwChartDataProvider
395         , ::com::sun::star::chart2::data::XDataProvider >
396                                 aChartDataProviderImplRef;
397     SwChartLockController_Helper  *pChartControllerHelper;
398 
399 	// table of forbidden characters of this document
400 	vos::ORef<SvxForbiddenCharactersTable>	xForbiddenCharsTable;
401 #ifdef FUTURE_VBA
402     com::sun::star::uno::Reference< com::sun::star::script::vba::XVBAEventProcessor > mxVbaEvents;
403 #endif
404     // --> OD 2007-10-26 #i83479#
405 public:
406     struct lessThanNodeNum
407     {
408         bool operator()( const SwNodeNum* pNodeNumOne,
409                          const SwNodeNum* pNodeNumTwo ) const;
410     };
411 
412     typedef ::std::set< const SwNodeNum*, lessThanNodeNum > tImplSortedNodeNumList;
413 private:
414     tImplSortedNodeNumList* mpListItemsList;
415     // <--
416 
417     ::std::auto_ptr< ::sfx2::IXmlIdRegistry > m_pXmlIdRegistry;
418 
419 	// -------------------------------------------------------------------
420 	// sonstige
421 
422 	sal_uInt16 nAutoFmtRedlnCommentNo;	// SeqNo fuers UI-seitige zusammenfassen
423 									// von AutoFmt-Redlines. Wird vom SwAutoFmt
424 									// verwaltet!
425 	sal_uInt16	nLinkUpdMode;		// UpdateMode fuer Links
426     SwFldUpdateFlags    eFldUpdMode;        // Mode fuer Felder/Charts automatisch aktualisieren
427 	RedlineMode_t eRedlineMode;		// aktueller Redline Modus
428 	SwCharCompressType eChrCmprType;	// for ASIAN: compress punctuation/kana
429 
430     sal_Int32   mReferenceCount;
431     sal_Int32   mIdleBlockCount;
432 	sal_Int8	nLockExpFld;		// Wenn != 0 hat UpdateExpFlds() keine Wirkung
433 
434     /* Draw Model Layer IDs
435      * LayerIds, Heaven == ueber dem Dokument
436      * Hell   == unter dem Dokument
437      * Controls == ganz oben
438      */
439     SdrLayerID  nHeaven;
440     SdrLayerID  nHell;
441     SdrLayerID  nControls;
442     SdrLayerID  nInvisibleHeaven;
443     SdrLayerID  nInvisibleHell;
444     SdrLayerID  nInvisibleControls;
445 
446     bool mbGlossDoc              : 1;    //sal_True: ist ein Textbaustein Dokument
447     bool mbModified              : 1;    //sal_True: Dokument ist veraendert
448     bool mbDtor                  : 1;    //sal_True: ist im SwDoc DTOR
449                                          //      leider auch temporaer von
450                                          //      SwSwgReader::InLayout(), wenn fehlerhafte
451                                          //      Frames geloescht werden muessen
452     bool mbPageNums              : 1;    // TRUE: es gibt virtuelle Seitennummern
453     bool mbLoaded                : 1;    // TRUE: ein geladenes Doc
454     bool mbUpdateExpFld          : 1;    // TRUE: Expression-Felder updaten
455     bool mbNewDoc                : 1;    // TRUE: neues Doc
456     bool mbNewFldLst             : 1;    // TRUE: Felder-Liste neu aufbauen
457     bool mbCopyIsMove            : 1;    // TRUE: Copy ist ein verstecktes Move
458     bool mbVisibleLinks          : 1;    // TRUE: Links werden sichtbar eingefuegt
459     bool mbInReading             : 1;    // TRUE: Dokument wird gerade gelesen
460     bool mbInXMLImport           : 1;    // TRUE: During xml import, attribute portion building is not necessary
461     bool mbUpdateTOX             : 1;    // TRUE: nach Dokument laden die TOX Updaten
462     bool mbInLoadAsynchron       : 1;    // TRUE: Dokument wird gerade asynchron geladen
463     bool mbHTMLMode              : 1;    // TRUE: Dokument ist im HTMLMode
464     bool mbInCallModified        : 1;    // TRUE: im Set/Reset-Modified Link
465     bool mbIsGlobalDoc           : 1;    // TRUE: es ist ein GlobalDokument
466     bool mbGlblDocSaveLinks      : 1;    // TRUE: im GlobalDoc. gelinkte Sect. mit speichern
467     bool mbIsLabelDoc            : 1;    // TRUE: es ist ein Etiketten-Dokument
468     bool mbIsAutoFmtRedline      : 1;    // TRUE: die Redlines werden vom Autoformat aufgezeichnet
469     bool mbOLEPrtNotifyPending   : 1;    // TRUE: Printer  ist geaendert und beim
470                                          //       Erzeugen der ::com::sun::star::sdbcx::View ist eine Benachrichtigung
471                                          //       der OLE-Objekte PrtOLENotify() notwendig.
472     bool mbAllOLENotify          : 1;    // True: Benachrichtigung aller Objekte ist notwendig
473     bool mbIsRedlineMove         : 1;    // True: die Redlines werden in/aus der Section verschoben
474     bool mbInsOnlyTxtGlssry      : 1;    // True: insert 'only text' glossary into doc
475     bool mbContains_MSVBasic     : 1;    // True: MS-VBasic exist is in our storage
476     bool mbPurgeOLE              : 1;    // sal_True: Purge OLE-Objects
477     bool mbKernAsianPunctuation  : 1;    // sal_True: kerning also for ASIAN punctuation
478     bool mbReadlineChecked       : 1;    // sal_True: if the query was already shown
479     bool mbLinksUpdated          : 1;    // OD 2005-02-11 #i38810#
480                                          // flag indicating, that the links have been updated.
481     bool mbClipBoard             : 1;    // true: this document represents the clipboard
482     bool mbColumnSelection       : 1;    // true: this content has bee created by a column selection
483                                          //       (clipboard docs only)
484 	sal_Bool	bIsPrepareSelAll		:1;
485 
486 #ifdef DBG_UTIL
487     bool mbXMLExport : 1;                // sal_True: during XML export
488 #endif
489 
490     // --> OD 2006-03-21 #b6375613#
491     // Document flag to trigger conversion, which applys the workaround for documents,
492     // which uses a certain layout defect in OOo 1.x to layout the documents.
493     // This conversion is performed, when the frames for the layout are created.
494     // Thus, this document flag has to be set after load a document and before
495     // creating the document view.
496     bool mbApplyWorkaroundForB6375613 : 1;
497     // <--
498 
499     // true: Document contains at least one anchored object, which is anchored AT_PAGE with a content position.
500     //       Thus, certain adjustment needed during formatting for these kind of anchored objects.
501     bool mbContainsAtPageObjWithContentAnchor : 1;
502 
503     //
504     // COMPATIBILITY FLAGS START
505     //
506     //
507     // HISTORY OF THE COMPATIBILITY FLAGS:
508     //
509     // SO5:
510     // mbParaSpaceMax                        def = sal_False, sal_True since SO8
511     // mbParaSpaceMaxAtPages                 def = sal_False, sal_True since SO8
512     //
513     // SO6:
514     // mbTabCompat                           def = sal_False, sal_True since SO8
515     //
516     // SO7:
517     // mbUseVirtualDevice                    def = sal_True
518     // mbAddFlyOffsets                       def = sal_False, hidden
519     //
520     // SO7pp1:
521     // bOldNumbering                        def = sal_False, hidden
522     //
523     // SO8:
524     // mbAddExternalLeading                  def = sal_True
525     // mbUseHiResolutionVirtualDevice        def = sal_True, hidden
526     // mbOldLineSpacing                      def = sal_False
527     // mbAddParaSpacingToTableCells          def = sal_True
528     // mbUseFormerObjectPos                  def = sal_False
529     // mbUseFormerTextWrapping               def = sal_False
530     // mbConsiderWrapOnObjPos                def = sal_False
531     //
532     // SO8pp1:
533     // mbIgnoreFirstLineIndentInNumbering    def = sal_False, hidden
534     // mbDoNotJustifyLinesWithManualBreak    def = sal_False, hidden
535     // mbDoNotResetParaAttrsForNumFont       def = sal_False, hidden
536     //
537     // SO8pp3
538     // mbDoNotCaptureDrawObjsOnPage         def = sal_False, hidden
539     // - Relevant for drawing objects, which don't follow the text flow, but
540     //   whose position is outside the page area:
541     //   sal_False: Such drawing objects are captured on the page area of its anchor.
542     //   sal_True: Such drawing objects can leave the page area, they aren't captured.
543     // mbTableRowKeep                            def = sal_False, hidden
544     // mbIgnoreTabsAndBlanksForLineCalculation   def = sal_False, hidden
545     // mbClipAsCharacterAnchoredWriterFlyFrame   def = sal_False, hidden
546     // - Introduced in order to re-activate clipping of as-character anchored
547     //   Writer fly frames in method <SwFlyInCntFrm::MakeAll()> for documents,
548     //   which are created with version prior SO8/OOo 2.0
549     //
550     // SO8pp4
551     // mbUnixForceZeroExtLeading                def = sal_False, hidden
552     //
553     // SO8pu8
554     // mbOldPrinterMetrics                      def = sal_False, hidden
555     //
556     // SO9
557     // #i24363# tab stops relative to indent
558     // mbTabRelativeToIndent                    def = sal_True, hidden
559     // #i89181# suppress tab stop at left indent for paragraphs in lists, whose
560     // list level position and space mode equals LABEL_ALIGNMENT and whose list
561     // label is followed by a tab character.
562     // mbTabAtLeftIndentForParagraphsInList     def = sal_False, hidden
563 
564     bool mbParaSpaceMax                     : 1;
565     bool mbParaSpaceMaxAtPages              : 1;
566     bool mbTabCompat                        : 1;
567     bool mbUseVirtualDevice                 : 1;
568     bool mbAddFlyOffsets                    : 1;
569     bool mbAddExternalLeading               : 1;
570     bool mbUseHiResolutionVirtualDevice     : 1;
571     bool mbOldLineSpacing                   : 1;    // OD  2004-01-06 #i11859#
572     bool mbAddParaSpacingToTableCells       : 1;    // OD  2004-02-16 #106629#
573     bool mbUseFormerObjectPos               : 1;    // OD  2004-03-12 #i11860#
574     bool mbUseFormerTextWrapping            : 1;    // FME 2005-05-11 #108724#
575     bool mbConsiderWrapOnObjPos             : 1;    // OD  2004-05-05 #i28701#
576                                                     // sal_True: object positioning algorithm has consider the wrapping style of                                                    //       the floating screen objects as given by its attribute 'WrapInfluenceOnObjPos'
577     bool mbMathBaselineAlignment            : 1;    // TL  2010-10-29 #i972#
578 
579     // non-ui-compatibility flags:
580     bool mbOldNumbering                             : 1;   // HBRINKM #111955#
581     bool mbIgnoreFirstLineIndentInNumbering         : 1;   // FME 2005-05-30# i47448#
582     bool mbDoNotJustifyLinesWithManualBreak         : 1;   // FME 2005-06-08 #i49277#
583     bool mbDoNotResetParaAttrsForNumFont            : 1;   // FME 2005-08-11 #i53199#
584     bool mbTableRowKeep                             : 1;   // FME 2006-02-10 #131283#
585     bool mbIgnoreTabsAndBlanksForLineCalculation    : 1;   // FME 2006-03-01 #i3952#
586     bool mbDoNotCaptureDrawObjsOnPage               : 1;   // OD 2006-03-14 #i62875#
587     bool mbOutlineLevelYieldsOutlineRule            : 1;
588     bool mbClipAsCharacterAnchoredWriterFlyFrames   : 1;   // OD 2006-04-13 #b6402800#
589     bool mbUnixForceZeroExtLeading                  : 1;   // FME 2006-10-09 #i60945#
590     bool mbOldPrinterMetrics                        : 1;   // FME 2007-05-14 #147385#
591     bool mbTabRelativeToIndent                      : 1;   // #i24363# tab stops relative to indent
592     bool mbProtectForm                              : 1;
593     bool mbTabAtLeftIndentForParagraphsInList;             // OD 2008-06-05 #i89181# - see above
594 
595     bool mbLastBrowseMode                           : 1;
596 
597 	// #i78591#
598 	sal_uInt32  n32DummyCompatabilityOptions1;
599 	sal_uInt32  n32DummyCompatabilityOptions2;
600     //
601     // COMPATIBILITY FLAGS END
602     //
603 
604     sal_Bool    mbStartIdleTimer                 ;    // idle timer mode start/stop
605 
606 	static SwAutoCompleteWord *pACmpltWords;	// Liste aller Worte fuers AutoComplete
607 
608 	//---------------- private Methoden ------------------------------
609 	void checkRedlining(RedlineMode_t& _rReadlineMode);
610 
611 	DECL_LINK( AddDrawUndo, SdrUndoAction * );
612 										// DrawModel
613 	void DrawNotifyUndoHdl();	// wegen CLOOKs
614 
615 		// nur fuer den internen Gebrauch deshalb privat.
616 		// Kopieren eines Bereiches im oder in ein anderes Dokument !
617 		// Die Position darf nicht im Bereich liegen !!
618     bool CopyImpl( SwPaM&, SwPosition&, const bool MakeNewFrms /*= true */,
619             const bool bCopyAll, SwPaM *const pCpyRng /*= 0*/ ) const;
620 
621 	SwFlyFrmFmt* _MakeFlySection( const SwPosition& rAnchPos,
622 								const SwCntntNode& rNode, RndStdIds eRequestId,
623 								const SfxItemSet* pFlyAttrSet,
624 								SwFrmFmt* = 0 );
625 
626 	SwFlyFrmFmt* _InsNoTxtNode( const SwPosition&rPos, SwNoTxtNode*,
627 								const SfxItemSet* pFlyAttrSet,
628 								const SfxItemSet* pGrfAttrSet,
629 								SwFrmFmt* = 0 );
630 
631     void CopyFlyInFlyImpl(  const SwNodeRange& rRg,
632                             const xub_StrLen nEndContentIndex,
633                             const SwNodeIndex& rStartIdx,
634                             const bool bCopyFlyAtFly = false ) const;
635     sal_Int8 SetFlyFrmAnchor( SwFrmFmt& rFlyFmt, SfxItemSet& rSet, sal_Bool bNewFrms );
636 
637     // --> OD 2005-01-13 #i40550#
638     typedef SwFmt* (SwDoc:: *FNCopyFmt)( const String&, SwFmt*, sal_Bool, sal_Bool );
639     // <--
640 	SwFmt* CopyFmt( const SwFmt& rFmt, const SvPtrarr& rFmtArr,
641 						FNCopyFmt fnCopyFmt, const SwFmt& rDfltFmt );
642 	void CopyFmtArr( const SvPtrarr& rSourceArr, SvPtrarr& rDestArr,
643 						FNCopyFmt fnCopyFmt, SwFmt& rDfltFmt );
644     void CopyPageDescHeaderFooterImpl( bool bCpyHeader,
645 								const SwFrmFmt& rSrcFmt, SwFrmFmt& rDestFmt );
646 	SwFmt* FindFmtByName( const SvPtrarr& rFmtArr,
647 									const String& rName ) const;
648 
649     VirtualDevice& CreateVirtualDevice_() const;
650     SfxPrinter& CreatePrinter_() const;
651 	void		PrtDataChanged();	//Printer oder JobSetup geandert, es muss
652 									//fuer entsprechende Invalidierungen und
653 									//Benachrichtigungen gesorgt werden.
654 
655 	// gcc: aFtnInfo::CopyCtor ist private, also muessen wir uns auch schuetzen
656 	SwDoc( const SwDoc &);
657 
658     // fuer Felder:
659 	void _InitFieldTypes(); 	// wird vom CTOR gerufen!!
660 	void _MakeFldList( int eMode );
661 
662 	// Datenbankfelder:
663 	void UpdateDBNumFlds( SwDBNameInfField& rDBFld, SwCalc& rCalc );
664 	void AddUsedDBToList( SvStringsDtor& rDBNameList,
665 						  const SvStringsDtor& rUsedDBNames );
666 	void AddUsedDBToList( SvStringsDtor& rDBNameList, const String& rDBName );
667 	sal_Bool IsNameInArray( const SvStringsDtor& rOldNames, const String& rName );
668 	void GetAllDBNames( SvStringsDtor& rAllDBNames );
669 	void ReplaceUsedDBs( const SvStringsDtor& rUsedDBNames,
670 						const String& rNewName, String& rFormel );
671 	SvStringsDtor& FindUsedDBs( const SvStringsDtor& rAllDBNames,
672 								const String& rFormel,
673 								SvStringsDtor& rUsedDBNames );
674 
675 	void InitDrawModel();
676 	void ReleaseDrawModel();
677 
678 	void _CreateNumberFormatter();
679 
680 	sal_Bool _UnProtectTblCells( SwTable& rTbl );
681 
682 	// erzeuge Anhand der vorgebenen Collection Teildokumente
683 	// falls keine angegeben ist, nehme die Kapitelvorlage der 1. Ebene
684 	sal_Bool SplitDoc( sal_uInt16 eDocType, const String& rPath,
685 						const SwTxtFmtColl* pSplitColl );
686 	sal_Bool SplitDoc( sal_uInt16 eDocType, const String& rPath, int nOutlineLevel = 0 ); //#outline level,add by zhaijianwei.
687 
688 
689 	// Charts der angegebenen Tabelle updaten
690 	void _UpdateCharts( const SwTable& rTbl, ViewShell& rVSh ) const;
691 
692 	sal_Bool _SelectNextRubyChars( SwPaM& rPam, SwRubyListEntry& rRubyEntry,
693 								sal_uInt16 nMode );
694 
695 	// unser eigener 'IdlTimer' ruft folgende Methode
696 	DECL_LINK( DoIdleJobs, Timer * );
697 	// der CharTimer ruft diese Methode
698 	DECL_LINK( DoUpdateAllCharts, Timer * );
699 	DECL_LINK( DoUpdateModifiedOLE, Timer * );
700 
701      SwFmt *_MakeCharFmt(const String &, SwFmt *, sal_Bool, sal_Bool );
702      SwFmt *_MakeFrmFmt(const String &, SwFmt *, sal_Bool, sal_Bool );
703      SwFmt *_MakeTxtFmtColl(const String &, SwFmt *, sal_Bool, sal_Bool );
704 
705 private:
706 	sal_Bool bReadOnly;
707 	String msDocAccTitle;
708 
709      void InitTOXTypes();
710      void   Paste( const SwDoc& );
711      bool DeleteAndJoinImpl(SwPaM&, const bool);
712      bool DeleteAndJoinWithRedlineImpl(SwPaM&, const bool unused = false);
713      bool DeleteRangeImpl(SwPaM&, const bool unused = false);
714      bool DeleteRangeImplImpl(SwPaM &);
715      bool ReplaceRangeImpl(SwPaM&, String const&, const bool);
716 
717 public:
718 	virtual void setDocReadOnly( sal_Bool b) { bReadOnly = b; }
719 	virtual sal_Bool getDocReadOnly() const { return bReadOnly; }
720 	virtual void setDocAccTitle( const String& rTitle ) { msDocAccTitle = rTitle; }
721 	virtual const String getDocAccTitle() const { return msDocAccTitle; }
722 
723 	enum DocumentType {
724 		DOCTYPE_NATIVE,
725 		DOCTYPE_MSWORD				//This doc medul is come from Ms Word
726 		};
727 	DocumentType	meDocType;
728 	DocumentType	GetDocumentType(){ return meDocType; }
729 	void			SetDocumentType( DocumentType eDocType ) { meDocType = eDocType; }
730 
731     /** Life cycle
732     */
733 	SwDoc();
734 	~SwDoc();
735 
736     inline bool IsInDtor() const { return mbDtor; }
737 
738     /* @@@MAINTAINABILITY-HORROR@@@
739 	   Implementation details made public.
740 	*/
741     SwNodes      & GetNodes()       { return *m_pNodes; }
742     SwNodes const& GetNodes() const { return *m_pNodes; }
743 
744     /** IInterface
745     */
746     virtual sal_Int32 acquire();
747     virtual sal_Int32 release();
748     virtual sal_Int32 getReferenceCount() const;
749 
750     /** IDocumentSettingAccess
751     */
752     virtual bool get(/*[in]*/ DocumentSettingId id) const;
753     virtual void set(/*[in]*/ DocumentSettingId id, /*[in]*/ bool value);
754     virtual const com::sun::star::i18n::ForbiddenCharacters* getForbiddenCharacters(/*[in]*/ sal_uInt16 nLang, /*[in]*/ bool bLocaleData ) const;
755     virtual void setForbiddenCharacters(/*[in]*/ sal_uInt16 nLang, /*[in]*/ const com::sun::star::i18n::ForbiddenCharacters& rForbiddenCharacters );
756     virtual vos::ORef<SvxForbiddenCharactersTable>& getForbiddenCharacterTable();
757     virtual const vos::ORef<SvxForbiddenCharactersTable>& getForbiddenCharacterTable() const;
758     virtual sal_uInt16 getLinkUpdateMode( /*[in]*/bool bGlobalSettings ) const;
759     virtual void setLinkUpdateMode( /*[in]*/ sal_uInt16 nMode );
760     virtual SwFldUpdateFlags getFieldUpdateFlags( /*[in]*/bool bGlobalSettings ) const;
761     virtual void setFieldUpdateFlags( /*[in]*/ SwFldUpdateFlags eMode );
762     virtual SwCharCompressType getCharacterCompressionType() const;
763     virtual void setCharacterCompressionType( /*[in]*/SwCharCompressType nType );
764 
765     /** IDocumentDeviceAccess
766     */
767     virtual SfxPrinter* getPrinter(/*[in]*/ bool bCreate ) const;
768     virtual void setPrinter(/*[in]*/ SfxPrinter* pP,/*[in]*/ bool bDeleteOld,/*[in]*/ bool bCallPrtDataChanged );
769     virtual VirtualDevice* getVirtualDevice(/*[in]*/ bool bCreate ) const;
770     virtual void setVirtualDevice(/*[in]*/ VirtualDevice* pVd,/*[in]*/ bool bDeleteOld, /*[in]*/ bool bCallVirDevDataChanged );
771     virtual OutputDevice* getReferenceDevice(/*[in]*/ bool bCreate ) const;
772     virtual void setReferenceDeviceType(/*[in]*/ bool bNewVirtual,/*[in]*/ bool bNewHiRes );
773     virtual const JobSetup* getJobsetup() const;
774     virtual void setJobsetup(/*[in]*/ const JobSetup& rJobSetup );
775     virtual const SwPrintData & getPrintData() const;
776     virtual void setPrintData(/*[in]*/ const SwPrintData& rPrtData);
777 
778     /** IDocumentMarkAccess
779     */
780     IDocumentMarkAccess* getIDocumentMarkAccess();
781     const IDocumentMarkAccess* getIDocumentMarkAccess() const;
782 
783     /** IDocumentRedlineAccess
784     */
785     virtual RedlineMode_t GetRedlineMode() const;
786 	virtual void SetRedlineMode_intern(/*[in]*/RedlineMode_t eMode);
787 	virtual void SetRedlineMode(/*[in]*/RedlineMode_t eMode);
788 	virtual bool IsRedlineOn() const;
789 	virtual bool IsIgnoreRedline() const;
790     virtual bool IsInRedlines(const SwNode& rNode) const;
791 	virtual const SwRedlineTbl& GetRedlineTbl() const;
792 	virtual bool AppendRedline(/*[in]*/SwRedline* pPtr, /*[in]*/bool bCallDelete);
793 	virtual bool SplitRedline(const SwPaM& rPam);
794 	virtual bool DeleteRedline(/*[in]*/const SwPaM& rPam, /*[in]*/bool bSaveInUndo, /*[in]*/sal_uInt16 nDelType);
795 	virtual bool DeleteRedline(/*[in]*/const SwStartNode& rSection, /*[in]*/bool bSaveInUndo, /*[in]*/sal_uInt16 nDelType);
796     virtual sal_uInt16 GetRedlinePos(/*[in]*/const SwNode& rNode, /*[in]*/sal_uInt16 nType) const;
797 	virtual void CompressRedlines();
798     virtual const SwRedline* GetRedline(/*[in]*/const SwPosition& rPos, /*[in]*/sal_uInt16* pFndPos) const;
799 	virtual bool IsRedlineMove() const;
800 	virtual void SetRedlineMove(/*[in]*/bool bFlag);
801 	virtual bool AcceptRedline(/*[in]*/sal_uInt16 nPos, /*[in]*/bool bCallDelete);
802     virtual bool AcceptRedline(/*[in]*/const SwPaM& rPam, /*[in]*/bool bCallDelete);
803 	virtual bool RejectRedline(/*[in]*/sal_uInt16 nPos, /*[in]*/bool bCallDelete);
804     virtual bool RejectRedline(/*[in]*/const SwPaM& rPam, /*[in]*/bool bCallDelete);
805     virtual const SwRedline* SelNextRedline(/*[in]*/SwPaM& rPam) const;
806 	virtual const SwRedline* SelPrevRedline(/*[in]*/SwPaM& rPam) const;
807 	virtual void UpdateRedlineAttr();
808     virtual sal_uInt16 GetRedlineAuthor();
809 	virtual sal_uInt16 InsertRedlineAuthor(const String& rAuthor);
810 	virtual bool SetRedlineComment(/*[in]*/const SwPaM& rPam, /*[in]*/const String& rComment);
811 	virtual const ::com::sun::star::uno::Sequence <sal_Int8>& GetRedlinePassword() const;
812 	virtual void SetRedlinePassword(/*[in]*/const ::com::sun::star::uno::Sequence <sal_Int8>& rNewPassword);
813 
814     /** IDocumentUndoRedo
815     */
816     IDocumentUndoRedo      & GetIDocumentUndoRedo();
817     IDocumentUndoRedo const& GetIDocumentUndoRedo() const;
818 
819     /** IDocumentLinksAdministration
820     */
821     virtual bool IsVisibleLinks() const;
822 	virtual void SetVisibleLinks(bool bFlag);
823     virtual sfx2::LinkManager& GetLinkManager();
824 	virtual const sfx2::LinkManager& GetLinkManager() const;
825     virtual void UpdateLinks(sal_Bool bUI);
826 	virtual bool GetData(const String& rItem, const String& rMimeType, ::com::sun::star::uno::Any& rValue) const;
827 	virtual bool SetData(const String& rItem, const String& rMimeType, const ::com::sun::star::uno::Any& rValue);
828     virtual ::sfx2::SvLinkSource* CreateLinkSource(const String& rItem);
829 	virtual bool EmbedAllLinks();
830     virtual void SetLinksUpdated(const bool bNewLinksUpdated);
831     virtual bool LinksUpdated() const;
832 
833     /** IDocumentFieldsAccess
834     */
835     virtual const SwFldTypes *GetFldTypes() const;
836 	virtual SwFieldType *InsertFldType(const SwFieldType &);
837 	virtual SwFieldType *GetSysFldType( const sal_uInt16 eWhich ) const;
838 	virtual SwFieldType* GetFldType(sal_uInt16 nResId, const String& rName, bool bDbFieldMatching) const;
839     virtual void RemoveFldType(sal_uInt16 nFld);
840     virtual void UpdateFlds( SfxPoolItem* pNewHt, bool bCloseDB);
841     virtual void InsDeletedFldType(SwFieldType &);
842     virtual bool PutValueToField(const SwPosition & rPos, const com::sun::star::uno::Any& rVal, sal_uInt16 nWhich);
843     virtual bool UpdateFld(SwTxtFld * rDstFmtFld, SwField & rSrcFld, SwMsgPoolItem * pMsgHnt, bool bUpdateTblFlds);
844 	virtual void UpdateRefFlds(SfxPoolItem* pHt);
845     virtual void UpdateTblFlds(SfxPoolItem* pHt);
846     virtual void UpdateExpFlds(SwTxtFld* pFld, bool bUpdateRefFlds);
847     virtual void UpdateUsrFlds();
848     virtual void UpdatePageFlds(SfxPoolItem*);
849     virtual void LockExpFlds();
850     virtual void UnlockExpFlds();
851     virtual bool IsExpFldsLocked() const;
852     virtual SwDocUpdtFld& GetUpdtFlds() const;
853 	virtual bool SetFieldsDirty(bool b, const SwNode* pChk, sal_uLong nLen);
854 	virtual void SetFixFields(bool bOnlyTimeDate, const DateTime* pNewDateTime);
855 	virtual void FldsToCalc(SwCalc& rCalc, sal_uLong nLastNd, sal_uInt16 nLastCnt);
856 	virtual void FldsToCalc(SwCalc& rCalc, const _SetGetExpFld& rToThisFld);
857 	virtual void FldsToExpand(SwHash**& ppTbl, sal_uInt16& rTblSize, const _SetGetExpFld& rToThisFld);
858 	virtual bool IsNewFldLst() const;
859 	virtual void SetNewFldLst( bool bFlag);
860 	virtual void InsDelFldInFldLst(bool bIns, const SwTxtFld& rFld);
861 
862     /** Returns the field at a certain position.
863        @param rPos position to search at
864        @return pointer to field at the given position or NULL in case no field is found
865     */
866     static SwField* GetFieldAtPos(const SwPosition& rPos);
867 
868     /** Returns the field at a certain position.
869        @param rPos position to search at
870        @return pointer to field at the given position or NULL in case no field is found
871     */
872     static SwTxtFld* GetTxtFldAtPos(const SwPosition& rPos);
873 
874     /** IDocumentContentOperations
875     */
876     virtual bool CopyRange(SwPaM&, SwPosition&, const bool bCopyAll) const;
877 	virtual void DeleteSection(SwNode* pNode);
878     virtual bool DeleteRange(SwPaM&);
879 	virtual bool DelFullPara(SwPaM&);
880     // Add optional parameter <bForceJoinNext>, default value <false>
881     // Needed for hiding of deletion redlines
882     virtual bool DeleteAndJoin( SwPaM&,
883                                 const bool bForceJoinNext = false );
884     virtual bool MoveRange(SwPaM&, SwPosition&, SwMoveFlags);
885     virtual bool MoveNodeRange(SwNodeRange&, SwNodeIndex&, SwMoveFlags);
886 	virtual bool MoveAndJoin(SwPaM&, SwPosition&, SwMoveFlags);
887 	virtual bool Overwrite(const SwPaM &rRg, const String& rStr);
888     virtual bool InsertString(const SwPaM &rRg, const String&,
889               const enum InsertFlags nInsertMode = INS_EMPTYEXPAND );
890 	virtual SwFlyFrmFmt* Insert(const SwPaM &rRg, const String& rGrfName, const String& rFltName, const Graphic* pGraphic,
891 						const SfxItemSet* pFlyAttrSet, const SfxItemSet* pGrfAttrSet, SwFrmFmt*);
892 	virtual SwFlyFrmFmt* Insert(const SwPaM& rRg, const GraphicObject& rGrfObj,	const SfxItemSet* pFlyAttrSet,
893 						const SfxItemSet* pGrfAttrSet, SwFrmFmt*);
894     virtual SwDrawFrmFmt* Insert(const SwPaM &rRg, SdrObject& rDrawObj, const SfxItemSet* pFlyAttrSet, SwFrmFmt*);
895     virtual SwFlyFrmFmt* Insert(const SwPaM &rRg, const svt::EmbeddedObjectRef& xObj, const SfxItemSet* pFlyAttrSet,
896 						const SfxItemSet* pGrfAttrSet, SwFrmFmt*);
897 
898     virtual bool InsertPoolItem(
899         const SwPaM &rRg,
900         const SfxPoolItem&,
901         const SetAttrMode nFlags,
902         const bool bExpandCharToPara=false);
903 
904     virtual bool InsertItemSet (const SwPaM &rRg, const SfxItemSet&,
905                                 const SetAttrMode nFlags);
906 	virtual void ReRead(SwPaM&, const String& rGrfName, const String& rFltName, const Graphic* pGraphic, const GraphicObject* pGrfObj);
907     virtual void TransliterateText(const SwPaM& rPaM, utl::TransliterationWrapper&);
908 	virtual SwFlyFrmFmt* InsertOLE(const SwPaM &rRg, const String& rObjName, sal_Int64 nAspect, const SfxItemSet* pFlyAttrSet,
909                            const SfxItemSet* pGrfAttrSet, SwFrmFmt*);
910 	virtual bool SplitNode(const SwPosition &rPos, bool bChkTableStart);
911 	virtual bool AppendTxtNode(SwPosition& rPos);
912         virtual void SetModified(SwPaM &rPaM);
913     virtual bool ReplaceRange(SwPaM& rPam, const String& rNewStr,
914                               const bool bRegExReplace);
915     virtual void RemoveLeadingWhiteSpace(const SwPosition & rPos );
916 
917     /** IDocumentStylePoolAccess
918     */
919     virtual SwTxtFmtColl* GetTxtCollFromPool( sal_uInt16 nId, bool bRegardLanguage = true );
920     virtual SwFmt* GetFmtFromPool( sal_uInt16 nId );
921     virtual SwFrmFmt* GetFrmFmtFromPool( sal_uInt16 nId );
922     virtual SwCharFmt* GetCharFmtFromPool( sal_uInt16 nId );
923     virtual SwPageDesc* GetPageDescFromPool( sal_uInt16 nId, bool bRegardLanguage = true );
924     virtual SwNumRule* GetNumRuleFromPool( sal_uInt16 nId );
925     virtual bool IsPoolTxtCollUsed( sal_uInt16 nId ) const;
926     virtual bool IsPoolFmtUsed( sal_uInt16 nId ) const;
927     virtual bool IsPoolPageDescUsed( sal_uInt16 nId ) const;
928 
929     /** IDocumentLineNumberAccess
930     */
931     virtual const SwLineNumberInfo& GetLineNumberInfo() const;
932     virtual void SetLineNumberInfo(const SwLineNumberInfo& rInfo);
933 
934 	/** IDocumentStatistics
935 	*/
936 	virtual void DocInfoChgd();
937 	virtual const SwDocStat	&GetDocStat() const;
938 	virtual void SetDocStat(const SwDocStat& rStat);
939 	virtual void UpdateDocStat(SwDocStat& rStat);
940 
941 	/** IDocumentState
942 	*/
943 	virtual void SetModified();
944 	virtual void ResetModified();
945 	virtual bool IsModified() const;
946 	virtual bool IsLoaded() const;
947     virtual bool IsUpdateExpFld() const;
948 	virtual bool IsNewDoc() const;
949     virtual bool IsPageNums() const;
950     virtual void SetPageNums(bool b);
951 	virtual void SetNewDoc(bool b);
952 	virtual void SetUpdateExpFldStat(bool b);
953 	virtual void SetLoaded(bool b);
954 
955     /** IDocumentDrawModelAccess
956     */
957     virtual const SdrModel* GetDrawModel() const;
958     virtual SdrModel* GetDrawModel();
959     virtual SdrLayerID GetHeavenId() const;
960     virtual SdrLayerID GetHellId() const;
961     virtual SdrLayerID GetControlsId() const;
962     virtual SdrLayerID GetInvisibleHeavenId() const;
963     virtual SdrLayerID GetInvisibleHellId() const;
964     virtual SdrLayerID GetInvisibleControlsId() const;
965     virtual void NotifyInvisibleLayers( SdrPageView& _rSdrPageView );
966     virtual bool IsVisibleLayerId( const SdrLayerID& _nLayerId ) const;
967     virtual SdrLayerID GetVisibleLayerIdByInvisibleOne( const SdrLayerID& _nInvisibleLayerId );
968     virtual SdrLayerID GetInvisibleLayerIdByVisibleOne( const SdrLayerID& _nVisibleLayerId );
969     virtual SdrModel* _MakeDrawModel();
970     virtual SdrModel* GetOrCreateDrawModel();
971 
972     /** IDocumentLayoutAccess
973     */
974 	virtual void SetCurrentViewShell( ViewShell* pNew );//swmod 071225
975     virtual SwLayouter* GetLayouter();
976     virtual const SwLayouter* GetLayouter() const;
977     virtual void SetLayouter( SwLayouter* pNew );
978     virtual SwFrmFmt* MakeLayoutFmt( RndStdIds eRequest, const SfxItemSet* pSet );
979     virtual void DelLayoutFmt( SwFrmFmt *pFmt );
980     virtual SwFrmFmt* CopyLayoutFmt( const SwFrmFmt& rSrc, const SwFmtAnchor& rNewAnchor, bool bSetTxtFlyAtt, bool bMakeFrms );
981 	virtual const ViewShell *GetCurrentViewShell() const;	//swmod 080219
982 	virtual ViewShell *GetCurrentViewShell();//swmod 080219 It must be able to communicate to a ViewShell.This is going to be removerd later.
983 	virtual const SwRootFrm *GetCurrentLayout() const;
984 	virtual SwRootFrm *GetCurrentLayout();//swmod 080219
985     virtual bool HasLayout() const;
986 
987     /** IDocumentTimerAccess
988     */
989 	virtual void StartIdling();
990 	virtual void StopIdling();
991 	virtual void BlockIdling();
992 	virtual void UnblockIdling();
993 
994     /** IDocumentChartDataProviderAccess
995     */
996     virtual SwChartDataProvider * GetChartDataProvider( bool bCreate = false ) const;
997     virtual void CreateChartInternalDataProviders( const SwTable *pTable );
998     virtual SwChartLockController_Helper & GetChartControllerHelper();
999 
1000     /** IDocumentListItems
1001 
1002         OD 2007-10-26 #i83479#
1003     */
1004     virtual void addListItem( const SwNodeNum& rNodeNum );
1005     virtual void removeListItem( const SwNodeNum& rNodeNum );
1006     virtual String getListItemText( const SwNodeNum& rNodeNum,
1007                                     const bool bWithNumber = true,
1008                                     const bool bWithSpacesForLevel = false ) const;
1009     virtual void getListItems( IDocumentListItems::tSortedNodeNumList& orNodeNumList ) const;
1010     virtual void getNumItems( IDocumentListItems::tSortedNodeNumList& orNodeNumList ) const;
1011 
1012     /** IDocumentOutlineNodes
1013 
1014         OD 2007-11-15 #i83479#
1015     */
1016     virtual sal_Int32 getOutlineNodesCount() const;
1017     virtual int getOutlineLevel( const sal_Int32 nIdx ) const;
1018     virtual String getOutlineText( const sal_Int32 nIdx,
1019                                    const bool bWithNumber,
1020                                    const bool bWithSpacesForLevel ) const;
1021     virtual SwTxtNode* getOutlineNode( const sal_Int32 nIdx ) const;
1022     virtual void getOutlineNodes( IDocumentOutlineNodes::tSortedOutlineNodeList& orOutlineNodeList ) const;
1023 
1024     /** IDocumentListsAccess
1025 
1026         OD 2008-03-26 #refactorlists#
1027     */
1028     virtual SwList* createList( String sListId,
1029                                 const String sDefaultListStyleName );
1030     virtual void deleteList( const String sListId );
1031     virtual SwList* getListByName( const String sListId ) const;
1032     virtual SwList* createListForListStyle( const String sListStyleName );
1033     virtual SwList* getListForListStyle( const String sListStyleName ) const;
1034     virtual void deleteListForListStyle( const String sListStyleName );
1035     // --> OD 2008-07-08 #i91400#
1036     virtual void trackChangeOfListStyleName( const String sListStyleName,
1037                                              const String sNewListStyleName );
1038     // <--
1039 
1040     /** IDocumentExternalData */
1041     virtual void setExternalData(::sw::tExternalDataType eType,
1042                                  ::sw::tExternalDataPointer pPayload);
1043     virtual ::sw::tExternalDataPointer getExternalData(::sw::tExternalDataType eType);
1044 
1045 
1046     /** INextInterface here
1047     */
1048 
1049     DECL_STATIC_LINK( SwDoc, BackgroundDone, SvxBrushItem *);
1050     DECL_LINK(CalcFieldValueHdl, EditFieldInfo*);
1051 
1052     /** OLE ???
1053     */
1054     bool IsOLEPrtNotifyPending() const  { return mbOLEPrtNotifyPending; }
1055     inline void SetOLEPrtNotifyPending( bool bSet = true );
1056 	void PrtOLENotify( sal_Bool bAll );	//Alle oder nur Markierte
1057 
1058 #ifdef DBG_UTIL
1059     bool InXMLExport() const            { return mbXMLExport; }
1060     void SetXMLExport( bool bFlag )     { mbXMLExport = bFlag; }
1061 #endif
1062 	void SetSelAll( sal_Bool bSel )
1063 	{
1064 		bIsPrepareSelAll = bSel;
1065 	}
1066 	sal_Bool IsPrepareSelAll()  { return bIsPrepareSelAll; }
1067 	void SetPrepareSelAll() { bIsPrepareSelAll = sal_True; }
1068 
1069     void SetContainsAtPageObjWithContentAnchor( const bool bFlag )
1070     {
1071         mbContainsAtPageObjWithContentAnchor = bFlag;
1072     }
1073     bool DoesContainAtPageObjWithContentAnchor()
1074     {
1075         return mbContainsAtPageObjWithContentAnchor;
1076     }
1077 
1078 	// liefert zu allen fliegenden Rahmen die Position im Dokument.
1079 	// Wird ein Pam-Pointer uebergeben, muessen die absatzgebundenen
1080 	// FlyFrames von der ::com::sun::star::awt::Selection vollstaendig umschlossen sein
1081 	// ( Start < Pos < End ) !!!
1082 	// (wird fuer die Writer benoetigt)
1083 	SwPosFlyFrms GetAllFlyFmts( const SwPaM* = 0, sal_Bool bDrawAlso = sal_False ) const;
1084 
1085     // wegen swrtf.cxx und define private public, jetzt hier
1086 	SwFlyFrmFmt  *MakeFlyFrmFmt (const String &rFmtName, SwFrmFmt *pDerivedFrom);
1087 	SwDrawFrmFmt *MakeDrawFrmFmt(const String &rFmtName, SwFrmFmt *pDerivedFrom);
1088 
1089     // JP 08.05.98: fuer Flys muss jetzt diese Schnittstelle benutzt
1090 	//				werden. pAnchorPos muss gesetzt sein, wenn keine
1091 	//				Seitenbindung vorliegt UND der ::com::sun::star::chaos::Anchor nicht schon
1092 	//				im FlySet/FrmFmt mit gueltiger CntntPos gesetzt ist
1093     /* #109161# new parameter bCalledFromShell
1094 
1095        sal_True: An existing adjust item at pAnchorPos is propagated to
1096        the content node of the new fly section. That propagation only
1097        takes place if there is no adjust item in the paragraph style
1098        for the new fly section.
1099 
1100        sal_False: no propagation
1101     */
1102 	SwFlyFrmFmt* MakeFlySection( RndStdIds eAnchorType,
1103                                  const SwPosition* pAnchorPos,
1104                                  const SfxItemSet* pSet = 0,
1105                                  SwFrmFmt *pParent = 0,
1106                                  sal_Bool bCalledFromShell = sal_False );
1107 	SwFlyFrmFmt* MakeFlyAndMove( const SwPaM& rPam, const SfxItemSet& rSet,
1108 								const SwSelBoxes* pSelBoxes = 0,
1109 								SwFrmFmt *pParent = 0 );
1110 
1111     void CopyWithFlyInFly(
1112         const SwNodeRange& rRg,
1113         const xub_StrLen nEndContentIndex,
1114         const SwNodeIndex& rInsPos,
1115         const SwPaM* pCopiedPaM = NULL,
1116         const sal_Bool bMakeNewFrms = sal_True,
1117         const sal_Bool bDelRedlines = sal_True,
1118         const sal_Bool bCopyFlyAtFly = sal_False ) const;
1119 
1120     sal_Bool SetFlyFrmAttr( SwFrmFmt& rFlyFmt, SfxItemSet& rSet );
1121 
1122     sal_Bool SetFrmFmtToFly( SwFrmFmt& rFlyFmt, SwFrmFmt& rNewFmt,
1123 						SfxItemSet* pSet = 0, sal_Bool bKeepOrient = sal_False );
1124     // --> OD 2009-07-20 #i73249#
1125     void SetFlyFrmTitle( SwFlyFrmFmt& rFlyFrmFmt,
1126                          const String& sNewTitle );
1127     void SetFlyFrmDescription( SwFlyFrmFmt& rFlyFrmFmt,
1128                                const String& sNewDescription );
1129     // <--
1130 
1131     /** Footnotes
1132     */
1133 	// Fussnoten Informationen
1134 	const SwFtnInfo& GetFtnInfo() const			{ return *pFtnInfo; }
1135 	void SetFtnInfo(const SwFtnInfo& rInfo);
1136 	const SwEndNoteInfo& GetEndNoteInfo() const { return *pEndNoteInfo; }
1137 	void SetEndNoteInfo(const SwEndNoteInfo& rInfo);
1138 		  SwFtnIdxs& GetFtnIdxs() 		{ return *pFtnIdxs; }
1139 	const SwFtnIdxs& GetFtnIdxs() const { return *pFtnIdxs; }
1140     // change footnotes in area
1141     bool SetCurFtn( const SwPaM& rPam, const String& rNumStr,
1142                     sal_uInt16 nNumber, bool bIsEndNote );
1143 
1144     /** Operations on the content of the document e.g.
1145         spell-checking/hyphenating/word-counting
1146     */
1147     ::com::sun::star::uno::Any
1148 			Spell( SwPaM&, ::com::sun::star::uno::Reference<
1149 							::com::sun::star::linguistic2::XSpellChecker1 > &,
1150                    sal_uInt16* pPageCnt, sal_uInt16* pPageSt, bool bGrammarCheck,
1151                    SwConversionArgs *pConvArgs = 0 ) const;
1152 
1153 	::com::sun::star::uno::Reference<
1154 		::com::sun::star::linguistic2::XHyphenatedWord >
1155 			Hyphenate( SwPaM *pPam, const Point &rCrsrPos,
1156 			  		   sal_uInt16* pPageCnt, sal_uInt16* pPageSt );
1157 
1158     // count words in pam
1159     void CountWords( const SwPaM& rPaM, SwDocStat& rStat ) const;
1160 
1161 
1162     /** ???
1163     */
1164     // Textbaustein Dokument?
1165     void SetGlossDoc( bool bGlssDc = true ) { mbGlossDoc = bGlssDc; }
1166     bool IsInsOnlyTextGlossary() const      { return mbInsOnlyTxtGlssry; }
1167 
1168 	// Abstakt fuellen
1169 	void Summary( SwDoc* pExtDoc, sal_uInt8 nLevel, sal_uInt8 nPara, sal_Bool bImpress );
1170 
1171     void ChangeAuthorityData(const SwAuthEntry* pNewData);
1172 
1173     bool IsInCallModified() const      { return mbInCallModified; }
1174 	sal_Bool IsInHeaderFooter( const SwNodeIndex& rIdx ) const;
1175     short GetTextDirection( const SwPosition& rPos,
1176                             const Point* pPt = 0 ) const;
1177     sal_Bool IsInVerticalText( const SwPosition& rPos,
1178 							   const Point* pPt = 0 ) const;
1179     /** Database ???
1180     */
1181 
1182 	/*	Datenbank &&  DB-Manager */
1183 	void SetNewDBMgr( SwNewDBMgr* pNewMgr )		{ pNewDBMgr = pNewMgr; }
1184 	SwNewDBMgr* GetNewDBMgr() const 			{ return pNewDBMgr; }
1185 	void ChangeDBFields( const SvStringsDtor& rOldNames,
1186 						const String& rNewName );
1187 	void SetInitDBFields(sal_Bool b);
1188 	// Von Feldern verwendete Datenbanken herausfinden
1189 	void GetAllUsedDB( SvStringsDtor& rDBNameList,
1190 					   const SvStringsDtor* pAllDBNames = 0 );
1191 
1192 	void ChgDBData( const SwDBData& rNewData );
1193 	SwDBData GetDBData();
1194 	const SwDBData& GetDBDesc();
1195 	const SwDBData& _GetDBDesc() const { return aDBData; }
1196 
1197     /** Some helper functions
1198     */
1199     String GetUniqueGrfName() const;
1200     String GetUniqueOLEName() const;
1201 	String GetUniqueFrameName() const;
1202 
1203 	std::set<SwRootFrm*> GetAllLayouts();//swmod 080225
1204 
1205 	void SetFlyName( SwFlyFrmFmt& rFmt, const String& rName );
1206 	const SwFlyFrmFmt* FindFlyByName( const String& rName, sal_Int8 nNdTyp = 0 ) const;
1207 
1208 	void GetGrfNms( const SwFlyFrmFmt& rFmt, String* pGrfName,
1209 					String* pFltName ) const;
1210 
1211 	// setze bei allen Flys ohne Namen einen gueltigen (Wird von den Readern
1212 	// nach dem Einlesen gerufen )
1213 	void SetAllUniqueFlyNames();
1214 
1215 		//Zuruecksetzen der Attribute; es werden alle TxtHints und bei
1216 		//vollstaendiger Selektion harte Formatierung (AUTO-Formate) entfernt
1217     // --> OD 2008-11-28 #i96644#
1218     // introduce new optional parameter <bSendDataChangedEvents> in order to
1219     // control, if the side effect "send data changed events" is triggered or not.
1220     void ResetAttrs( const SwPaM &rRg,
1221                      sal_Bool bTxtAttr = sal_True,
1222                      const SvUShortsSort* = 0,
1223                      const bool bSendDataChangedEvents = true );
1224     // <--
1225     void RstTxtAttrs(const SwPaM &rRg, sal_Bool bInclRefToxMark = sal_False );
1226 
1227 		// Setze das Attribut im angegebenen Format. Ist Undo aktiv, wird
1228 		// das alte in die Undo-History aufgenommen
1229 	void SetAttr( const SfxPoolItem&, SwFmt& );
1230 	void SetAttr( const SfxItemSet&, SwFmt& );
1231 
1232     // --> OD 2008-02-12 #newlistlevelattrs#
1233     // method to reset a certain attribute at the given format
1234     void ResetAttrAtFormat( const sal_uInt16 nWhichId,
1235                             SwFmt& rChangedFormat );
1236     // <--
1237 
1238 		// Setze das Attribut als neues default Attribut in diesem Dokument.
1239 		// Ist Undo aktiv, wird das alte in die Undo-History aufgenommen
1240 	void SetDefault( const SfxPoolItem& );
1241 	void SetDefault( const SfxItemSet& );
1242 
1243 	// Erfrage das Default Attribut in diesem Dokument.
1244 	const SfxPoolItem& GetDefault( sal_uInt16 nFmtHint ) const;
1245 	// TextAttribute nicht mehr aufspannen lassen
1246 	sal_Bool DontExpandFmt( const SwPosition& rPos, sal_Bool bFlag = sal_True );
1247 
1248 	/* Formate */
1249 	const SwFrmFmts* GetFrmFmts() const 	{ return pFrmFmtTbl; }
1250 		  SwFrmFmts* GetFrmFmts()			{ return pFrmFmtTbl; }
1251 	const SwCharFmts* GetCharFmts() const	{ return pCharFmtTbl;}
1252 
1253 	/* LayoutFormate (Rahmen, DrawObjecte), mal const mal nicht */
1254 	const SwSpzFrmFmts* GetSpzFrmFmts() const	{ return pSpzFrmFmtTbl; }
1255 		  SwSpzFrmFmts* GetSpzFrmFmts() 		{ return pSpzFrmFmtTbl; }
1256 
1257 	const SwFrmFmt *GetDfltFrmFmt() const	{ return pDfltFrmFmt; }
1258 		  SwFrmFmt *GetDfltFrmFmt() 		{ return pDfltFrmFmt; }
1259 	const SwFrmFmt *GetEmptyPageFmt() const { return pEmptyPageFmt; }
1260 		  SwFrmFmt *GetEmptyPageFmt()		{ return pEmptyPageFmt; }
1261 	const SwFrmFmt *GetColumnContFmt() const{ return pColumnContFmt; }
1262 		  SwFrmFmt *GetColumnContFmt()		{ return pColumnContFmt; }
1263 	const SwCharFmt *GetDfltCharFmt() const { return pDfltCharFmt;}
1264 		  SwCharFmt *GetDfltCharFmt()		{ return pDfltCharFmt;}
1265 
1266     // Returns the interface of the management of (auto)styles
1267     IStyleAccess& GetIStyleAccess() { return *pStyleAccess; }
1268 
1269 	// Remove all language dependencies from all existing formats
1270 	void RemoveAllFmtLanguageDependencies();
1271 
1272 	SwFrmFmt  *MakeFrmFmt(const String &rFmtName, SwFrmFmt *pDerivedFrom,
1273                           sal_Bool bBroadcast = sal_False, sal_Bool bAuto = sal_True);
1274 	void	   DelFrmFmt( SwFrmFmt *pFmt, sal_Bool bBroadcast = sal_False );
1275 	SwFrmFmt* FindFrmFmtByName( const String& rName ) const
1276 		{	return (SwFrmFmt*)FindFmtByName( (SvPtrarr&)*pFrmFmtTbl, rName ); }
1277 
1278     // --> OD 2005-01-13 #i40550#
1279     SwCharFmt *MakeCharFmt(const String &rFmtName, SwCharFmt *pDerivedFrom,
1280                            sal_Bool bBroadcast = sal_False,
1281                            sal_Bool bAuto = sal_True );
1282     // <--
1283 	void	   DelCharFmt(sal_uInt16 nFmt, sal_Bool bBroadcast = sal_False);
1284 	void	   DelCharFmt(SwCharFmt* pFmt, sal_Bool bBroadcast = sal_False);
1285 	SwCharFmt* FindCharFmtByName( const String& rName ) const
1286 		{	return (SwCharFmt*)FindFmtByName( (SvPtrarr&)*pCharFmtTbl, rName ); }
1287 
1288 	/* Formatcollections (Vorlagen) */
1289 	// TXT
1290 	const SwTxtFmtColl* GetDfltTxtFmtColl() const { return pDfltTxtFmtColl; }
1291 	const SwTxtFmtColls *GetTxtFmtColls() const { return pTxtFmtCollTbl; }
1292     // --> OD 2005-01-13 #i40550#
1293     SwTxtFmtColl *MakeTxtFmtColl( const String &rFmtName,
1294 								  SwTxtFmtColl *pDerivedFrom,
1295                                   sal_Bool bBroadcast = sal_False,
1296                                   sal_Bool bAuto = sal_True );
1297     // <--
1298 	SwConditionTxtFmtColl* MakeCondTxtFmtColl( const String &rFmtName,
1299 											   SwTxtFmtColl *pDerivedFrom,
1300                                                sal_Bool bBroadcast = sal_False);
1301 	void DelTxtFmtColl(sal_uInt16 nFmt, sal_Bool bBroadcast = sal_False);
1302 	void DelTxtFmtColl( SwTxtFmtColl* pColl, sal_Bool bBroadcast = sal_False );
1303     // --> OD 2007-11-06 #i62675#
1304     // Add 4th optional parameter <bResetListAttrs>.
1305     // 'side effect' of <SetTxtFmtColl> with <bReset = true> is that the hard
1306     // attributes of the affected text nodes are cleared, except the break
1307     // attribute, the page description attribute and the list style attribute.
1308     // The new parameter <bResetListAttrs> indicates, if the list attributes
1309     // (list style, restart at and restart with) are cleared as well in case
1310     // that <bReset = true> and the paragraph style has a list style attribute set.
1311     sal_Bool SetTxtFmtColl( const SwPaM &rRg, SwTxtFmtColl *pFmt,
1312                             bool bReset = true,
1313                             bool bResetListAttrs = false );
1314     // <--
1315 	SwTxtFmtColl* FindTxtFmtCollByName( const String& rName ) const
1316 		{	return (SwTxtFmtColl*)FindFmtByName( (SvPtrarr&)*pTxtFmtCollTbl, rName ); }
1317 
1318     void ChkCondColls();
1319 
1320 		// GRF
1321 	const SwGrfFmtColl* GetDfltGrfFmtColl() const	{ return pDfltGrfFmtColl; }
1322 	const SwGrfFmtColls *GetGrfFmtColls() const		{ return pGrfFmtCollTbl; }
1323 	SwGrfFmtColl *MakeGrfFmtColl(const String &rFmtName,
1324 									SwGrfFmtColl *pDerivedFrom);
1325 	SwGrfFmtColl* FindGrfFmtCollByName( const String& rName ) const
1326 		{	return (SwGrfFmtColl*)FindFmtByName( (SvPtrarr&)*pGrfFmtCollTbl, rName ); }
1327 
1328 		// Tabellen-Formate
1329 	const SwFrmFmts* GetTblFrmFmts() const	{ return pTblFrmFmtTbl; }
1330 		  SwFrmFmts* GetTblFrmFmts()		{ return pTblFrmFmtTbl; }
1331 	sal_uInt16 GetTblFrmFmtCount( sal_Bool bUsed ) const;
1332 	SwFrmFmt& GetTblFrmFmt(sal_uInt16 nFmt, sal_Bool bUsed ) const;
1333 	SwTableFmt* MakeTblFrmFmt(const String &rFmtName, SwFrmFmt *pDerivedFrom);
1334 	void	    DelTblFrmFmt( SwTableFmt* pFmt );
1335 	SwTableFmt* FindTblFmtByName( const String& rName, sal_Bool bAll = sal_False ) const;
1336 
1337 	//Rahmenzugriff
1338 	//iterieren ueber Flys - fuer Basic-Collections
1339 	sal_uInt16 GetFlyCount( FlyCntType eType = FLYCNTTYPE_ALL) const;
1340 	SwFrmFmt* GetFlyNum(sal_uInt16 nIdx, FlyCntType eType = FLYCNTTYPE_ALL);
1341 
1342 
1343 	// kopiere die Formate in die eigenen Arrays und returne diese
1344 	SwFrmFmt  *CopyFrmFmt ( const SwFrmFmt& );
1345 	SwCharFmt *CopyCharFmt( const SwCharFmt& );
1346 	SwTxtFmtColl* CopyTxtColl( const SwTxtFmtColl& rColl );
1347 	SwGrfFmtColl* CopyGrfColl( const SwGrfFmtColl& rColl );
1348 
1349 		// ersetze alle Formate mit denen aus rSource
1350 	void ReplaceStyles( SwDoc& rSource );
1351 
1352 	// erfrage ob die Absatz-/Zeichen-/Rahmen-/Seiten - Vorlage benutzt wird
1353 	sal_Bool IsUsed( const SwModify& ) const;
1354 	sal_Bool IsUsed( const SwNumRule& ) const;
1355 
1356 		// setze den Namen der neu geladenen Dokument-Vorlage
1357 	sal_uInt16 SetDocPattern( const String& rPatternName );
1358         // gebe den Dok-VorlagenNamen zurueck. !!! Kann auch 0 sein !!!
1359 	String* GetDocPattern( sal_uInt16 nPos ) const { return aPatternNms[nPos]; }
1360 
1361 		// Loesche alle nicht referenzierten FeldTypen
1362 	void GCFieldTypes();				// impl. in docfld.cxx
1363 
1364 		// akt. Dokument mit Textbausteindokument verbinden/erfragen
1365 	void SetGlossaryDoc( SwDoc* pDoc ) { pGlossaryDoc = pDoc; }
1366 
1367 	// travel over PaM Ring
1368 	sal_Bool InsertGlossary( SwTextBlocks& rBlock, const String& rEntry,
1369 						SwPaM& rPaM, SwCrsrShell* pShell = 0);
1370 
1371     // get the set of printable pages for the XRenderable API by
1372     // evaluating the respective settings (see implementation)
1373     void CalculatePagesForPrinting( const SwRootFrm& rLayout, SwRenderData &rData, const SwPrintUIOptions &rOptions, bool bIsPDFExport,
1374             sal_Int32 nDocPageCount );
1375     void UpdatePagesForPrintingWithPostItData( SwRenderData &rData, const SwPrintUIOptions &rOptions, bool bIsPDFExport,
1376             sal_Int32 nDocPageCount );
1377     void CalculatePagePairsForProspectPrinting( const SwRootFrm& rLayout, SwRenderData &rData, const SwPrintUIOptions &rOptions,
1378             sal_Int32 nDocPageCount );
1379 
1380 		//PageDescriptor-Schnittstelle
1381 	sal_uInt16 GetPageDescCnt() const { return aPageDescs.Count(); }
1382 	const SwPageDesc& GetPageDesc( const sal_uInt16 i ) const { return *aPageDescs[i]; }
1383 	SwPageDesc* FindPageDescByName( const String& rName,
1384 									sal_uInt16* pPos = 0 ) const;
1385 
1386 		// kopiere den gesamten PageDesc - ueber Dokumentgrenzen und "tief"!
1387 		// optional kann das kopieren der PoolFmtId, -HlpId verhindert werden
1388 	void CopyPageDesc( const SwPageDesc& rSrcDesc, SwPageDesc& rDstDesc,
1389 						sal_Bool bCopyPoolIds = sal_True );
1390 
1391 		// kopiere die Kopzeile (mit dem Inhalt!) aus dem SrcFmt
1392 		// ins DestFmt ( auch ueber Doc grenzen hinaus!)
1393 	void CopyHeader( const SwFrmFmt& rSrcFmt, SwFrmFmt& rDestFmt )
1394         { CopyPageDescHeaderFooterImpl( true, rSrcFmt, rDestFmt ); }
1395 		// kopiere die Fusszeile (mit dem Inhalt!) aus dem SrcFmt
1396 		// ins DestFmt ( auch ueber Doc grenzen hinaus!)
1397 	void CopyFooter( const SwFrmFmt& rSrcFmt, SwFrmFmt& rDestFmt )
1398         { CopyPageDescHeaderFooterImpl( false, rSrcFmt, rDestFmt ); }
1399 
1400 		//fuer Reader
1401 
1402     SwPageDesc * GetPageDesc( const String & rName );
1403 	SwPageDesc& _GetPageDesc( sal_uInt16 i ) const { return *aPageDescs[i]; }
1404 	void ChgPageDesc( const String & rName, const SwPageDesc& );
1405 	void ChgPageDesc( sal_uInt16 i, const SwPageDesc& );
1406     sal_Bool FindPageDesc( const String & rName, sal_uInt16 * pFound );
1407     // -> #116530#
1408     void DelPageDesc( const String & rName, sal_Bool bBroadcast = sal_False);
1409 	void DelPageDesc( sal_uInt16 i, sal_Bool bBroadcast = sal_False );
1410     // <- #116530#
1411     void PreDelPageDesc(SwPageDesc * pDel); // #i7983#
1412     // -> #116530#
1413 	sal_uInt16 MakePageDesc( const String &rName, const SwPageDesc* pCpy = 0,
1414                              sal_Bool bRegardLanguage = sal_True,
1415                              sal_Bool bBroadcast = sal_False);
1416     void BroadcastStyleOperation(String rName, SfxStyleFamily eFamily,
1417                                  sal_uInt16 nOp);
1418     // <- #116530#
1419 
1420 
1421     // --> FME 2005-03-16 #i44963# The html import sometimes overwrites the
1422     // page sizes set in the page descriptions. This function is used to
1423     // correct this.
1424     void CheckDefaultPageFmt();
1425     // <--
1426 
1427 		// Methoden fuer die Verzeichnisse:
1428 		// - Verzeichnismarke einfuegen loeschen travel
1429 	sal_uInt16 GetCurTOXMark( const SwPosition& rPos, SwTOXMarks& ) const;
1430     void DeleteTOXMark( const SwTOXMark* pTOXMark );
1431 	const SwTOXMark& GotoTOXMark( const SwTOXMark& rCurTOXMark,
1432 								SwTOXSearch eDir, sal_Bool bInReadOnly );
1433 
1434 		// - Verzeichnis einfuegen, und bei Bedarf erneuern
1435 	const SwTOXBaseSection* InsertTableOf( const SwPosition& rPos,
1436 											const SwTOXBase& rTOX,
1437 											const SfxItemSet* pSet = 0,
1438 											sal_Bool bExpand = sal_False );
1439 	const SwTOXBaseSection* InsertTableOf( sal_uLong nSttNd, sal_uLong nEndNd,
1440 											const SwTOXBase& rTOX,
1441 											const SfxItemSet* pSet = 0											);
1442 	const SwTOXBase* GetCurTOX( const SwPosition& rPos ) const;
1443 	const SwAttrSet& GetTOXBaseAttrSet(const SwTOXBase& rTOX) const;
1444 
1445 	sal_Bool DeleteTOX( const SwTOXBase& rTOXBase, sal_Bool bDelNodes = sal_False );
1446 	String GetUniqueTOXBaseName( const SwTOXType& rType,
1447 								const String* pChkStr = 0 ) const;
1448 
1449 	sal_Bool SetTOXBaseName(const SwTOXBase& rTOXBase, const String& rName);
1450 	void SetTOXBaseProtection(const SwTOXBase& rTOXBase, sal_Bool bProtect);
1451 
1452 	// nach einlesen einer Datei alle Verzeichnisse updaten
1453     void SetUpdateTOX( bool bFlag = true )     { mbUpdateTOX = bFlag; }
1454     bool IsUpdateTOX() const                   { return mbUpdateTOX; }
1455 
1456 	const String&	GetTOIAutoMarkURL() const {return sTOIAutoMarkURL;}
1457 	void			SetTOIAutoMarkURL(const String& rSet)  {sTOIAutoMarkURL = rSet;}
1458 	void 			ApplyAutoMark();
1459 
1460     bool IsInReading() const                    { return mbInReading; }
1461     void SetInReading( bool bNew )              { mbInReading = bNew; }
1462 
1463     bool IsClipBoard() const                    { return mbClipBoard; }
1464     // N.B.: must be called right after constructor! (@see GetXmlIdRegistry)
1465     void SetClipBoard( bool bNew )              { mbClipBoard = bNew; }
1466 
1467     bool IsColumnSelection() const              { return mbColumnSelection; }
1468     void SetColumnSelection( bool bNew )        { mbColumnSelection = bNew; }
1469 
1470     bool IsInXMLImport() const { return mbInXMLImport; }
1471     void SetInXMLImport( bool bNew ) { mbInXMLImport = bNew; }
1472 
1473 	// - Verzeichnis-Typen verwalten
1474 	sal_uInt16 GetTOXTypeCount( TOXTypes eTyp ) const;
1475 	const SwTOXType* GetTOXType( TOXTypes eTyp, sal_uInt16 nId ) const;
1476 	sal_Bool DeleteTOXType( TOXTypes eTyp, sal_uInt16 nId );
1477 	const SwTOXType* InsertTOXType( const SwTOXType& rTyp );
1478 	const SwTOXTypes& GetTOXTypes() const { return *pTOXTypes; }
1479 
1480 	const SwTOXBase* 	GetDefaultTOXBase( TOXTypes eTyp, sal_Bool bCreate = sal_False );
1481 	void				SetDefaultTOXBase(const SwTOXBase& rBase);
1482 
1483 	// - Schluessel fuer die Indexverwaltung
1484 	sal_uInt16 GetTOIKeys( SwTOIKeyType eTyp, SvStringsSort& rArr ) const;
1485 
1486 	// Sortieren Tabellen Text
1487 	sal_Bool SortTbl(const SwSelBoxes& rBoxes, const SwSortOptions&);
1488 	sal_Bool SortText(const SwPaM&, const SwSortOptions&);
1489 
1490 		// korrigiere die im Dokument angemeldeten SwPosition-Objecte,
1491 		// wie z.B. die ::com::sun::star::text::Bookmarks oder die Verzeichnisse.
1492 		// JP 22.06.95: ist bMoveCrsr gesetzt, verschiebe auch die Crsr
1493 
1494 		// Setzt alles in rOldNode auf rNewPos + Offset
1495 	void CorrAbs( const SwNodeIndex& rOldNode, const SwPosition& rNewPos,
1496 					const xub_StrLen nOffset = 0, sal_Bool bMoveCrsr = sal_False );
1497 		// Setzt alles im Bereich von [rStartNode, rEndNode] nach rNewPos
1498 	void CorrAbs( const SwNodeIndex& rStartNode, const SwNodeIndex& rEndNode,
1499 					const SwPosition& rNewPos, sal_Bool bMoveCrsr = sal_False );
1500 		// Setzt alles im Bereich von rRange nach rNewPos
1501 	void CorrAbs( const SwPaM& rRange, const SwPosition& rNewPos,
1502 					sal_Bool bMoveCrsr = sal_False );
1503 		// Setzt alles in rOldNode auf relative Pos
1504 	void CorrRel( const SwNodeIndex& rOldNode, const SwPosition& rNewPos,
1505 					const xub_StrLen nOffset = 0, sal_Bool bMoveCrsr = sal_False );
1506 
1507 		// GliederungsRegeln erfragen / setzen
1508     // --> OD 2005-11-02 #i51089 - TUNING#
1509     inline SwNumRule* GetOutlineNumRule() const
1510     {
1511         return pOutlineRule;
1512     }
1513     // <--
1514 	void SetOutlineNumRule( const SwNumRule& rRule );
1515     void PropagateOutlineRule();
1516 
1517 	// Gliederung - hoch-/runterstufen
1518 	sal_Bool OutlineUpDown( const SwPaM& rPam, short nOffset = 1 );
1519 	// Gliederung - hoch-/runtermoven
1520 	sal_Bool MoveOutlinePara( const SwPaM& rPam, short nOffset = 1);
1521 		// zu diesem Gliederungspunkt
1522 	sal_Bool GotoOutline( SwPosition& rPos, const String& rName ) const;
1523 	// die Aenderungen an den Gliederungsvorlagen in die OutlineRule uebernehmen
1524 
1525 		// setzt, wenn noch keine Numerierung, sonst wird geaendert
1526 		// arbeitet mit alten und neuen Regeln, nur Differenzen aktualisieren
1527     // --> OD 2005-02-18 #i42921# - re-use unused 3rd parameter
1528     // --> OD 2008-02-08 #newlistlevelattrs#
1529     // Add optional parameter <bResetIndentAttrs> - default value sal_False.
1530     // If <bResetIndentAttrs> equals true, the indent attributes "before text"
1531     // and "first line indent" are additionally reset at the provided PaM, if
1532     // the list style makes use of the new list level attributes.
1533     // --> OD 2008-03-17 #refactorlists#
1534     // introduce parameters <bCreateNewList> and <sContinuedListId>
1535     // <bCreateNewList> indicates, if a new list is created by applying the
1536     // given list style.
1537     void SetNumRule( const SwPaM&,
1538                      const SwNumRule&,
1539                      const bool bCreateNewList,
1540                      const String sContinuedListId = String(),
1541                      sal_Bool bSetItem = sal_True,
1542                      const bool bResetIndentAttrs = false );
1543     // <--
1544     void SetCounted( const SwPaM&, bool bCounted);
1545 
1546     // --> OD 2009-08-25 #i86492#
1547     // no longer needed.
1548     // SwDoc::SetNumRule( rPaM, rNumRule, false, <ListId>, sal_True, true ) have to be used instead.
1549 //    /**
1550 //       Replace numbering rules in a PaM by another numbering rule.
1551 
1552 //       \param rPaM         PaM to replace the numbering rules in
1553 //       \param rNumRule     numbering rule to replace the present numbering rules
1554 //     */
1555 //    void ReplaceNumRule(const SwPaM & rPaM, const SwNumRule & rNumRule);
1556 
1557     void MakeUniqueNumRules(const SwPaM & rPaM);
1558 
1559 	void SetNumRuleStart( const SwPosition& rPos, sal_Bool bFlag = sal_True );
1560     void SetNodeNumStart( const SwPosition& rPos, sal_uInt16 nStt );
1561 
1562 	SwNumRule* GetCurrNumRule( const SwPosition& rPos ) const;
1563 
1564     const SwNumRuleTbl& GetNumRuleTbl() const { return *pNumRuleTbl; }
1565 
1566     // #i36749#
1567     /**
1568        Add numbering rule to document.
1569 
1570        @param pRule    rule to add
1571     */
1572     void AddNumRule(SwNumRule * pRule);
1573 
1574     // --> OD 2008-02-11 #newlistlevelattrs#
1575     // add optional parameter <eDefaultNumberFormatPositionAndSpaceMode>
1576     sal_uInt16 MakeNumRule( const String &rName,
1577         const SwNumRule* pCpy = 0,
1578         sal_Bool bBroadcast = sal_False,
1579         const SvxNumberFormat::SvxNumPositionAndSpaceMode eDefaultNumberFormatPositionAndSpaceMode =
1580             SvxNumberFormat::LABEL_WIDTH_AND_POSITION );
1581     // <--
1582 	sal_uInt16 FindNumRule( const String& rName ) const;
1583 	SwNumRule* FindNumRulePtr( const String& rName ) const;
1584 
1585 	// loeschen geht nur, wenn die ::com::sun::star::chaos::Rule niemand benutzt!
1586     // #106897#
1587     sal_Bool RenameNumRule(const String & aOldName, const String & aNewName,
1588                            sal_Bool bBroadcast = sal_False);
1589 	sal_Bool DelNumRule( const String& rName, sal_Bool bBroadCast = sal_False );
1590 	String GetUniqueNumRuleName( const String* pChkStr = 0, sal_Bool bAutoNum = sal_True ) const;
1591 
1592 	void UpdateNumRule();	// alle invaliden Updaten
1593     // #106897#
1594 	void ChgNumRuleFmts( const SwNumRule& rRule, const String * pOldName = 0 );
1595 	sal_Bool ReplaceNumRule( const SwPosition& rPos, const String& rOldRule,
1596 						const String& rNewRule );
1597 
1598 		// zum naechsten/vorhergehenden Punkt auf gleicher Ebene
1599 	sal_Bool GotoNextNum( SwPosition&, sal_Bool bOverUpper = sal_True,
1600 						sal_uInt8* pUpper = 0, sal_uInt8* pLower = 0 );
1601 	sal_Bool GotoPrevNum( SwPosition&, sal_Bool bOverUpper = sal_True,
1602 						sal_uInt8* pUpper = 0, sal_uInt8* pLower = 0 );
1603 
1604     // #i23731#
1605     /** Searches for a text node with a numbering rule.
1606 
1607        OD 2005-10-24 #i55391# - add optional parameter <bInvestigateStartNode>
1608        OD 2008-03-18 #refactorlists# - add output parameter <sListId>
1609 
1610        \param rPos         position to start search
1611        \param bForward     - sal_True:  search forward
1612                            - sal_False: search backward
1613 	   \param bNum		   - sal_True:  search for enumeration
1614 		                   - sal_False: search for itemize
1615        \param bOutline     - sal_True:  search for outline numbering rule
1616                            - sal_False: search for non-outline numbering rule
1617        \param nNonEmptyAllowed   number of non-empty paragraphs allowed between
1618                                  rPos and found paragraph
1619 
1620         @param sListId
1621         output parameter - in case a list style is found, <sListId> holds the
1622         list id, to which the text node belongs, which applies the found list style.
1623 
1624         @param bInvestigateStartNode
1625         input parameter - boolean, indicating, if start node, determined by given
1626         start position has to be investigated or not.
1627      */
1628     const SwNumRule * SearchNumRule(const SwPosition & rPos,
1629                                     const bool bForward,
1630                                     const bool bNum,
1631                                     const bool bOutline,
1632                                     int nNonEmptyAllowed,
1633                                     String& sListId,
1634                                     const bool bInvestigateStartNode = false );
1635 
1636 		// Absaetze ohne Numerierung, aber mit Einzuegen
1637 	sal_Bool NoNum( const SwPaM& );
1638 		// Loeschen, Splitten der Aufzaehlungsliste
1639     void DelNumRules( const SwPaM& );
1640 
1641     // Invalidates all numrules
1642     void InvalidateNumRules();
1643 
1644 		// Hoch-/Runterstufen
1645 	sal_Bool NumUpDown( const SwPaM&, sal_Bool bDown = sal_True );
1646 		// Bewegt selektierte Absaetze (nicht nur Numerierungen)
1647 		// entsprechend des Offsets. (negativ: zum Doc-Anf.)
1648 	sal_Bool MoveParagraph( const SwPaM&, long nOffset = 1, sal_Bool bIsOutlMv = sal_False );
1649 		// No-/Numerierung ueber Delete/Backspace ein/abschalten #115901#
1650 	sal_Bool NumOrNoNum( const SwNodeIndex& rIdx, sal_Bool bDel = sal_False);
1651 		// Animation der Grafiken stoppen
1652 	void StopNumRuleAnimations( OutputDevice* );
1653 
1654 		// fuege eine neue Tabelle auf der Position rPos ein. (es
1655 		// wird vor dem Node eingefuegt !!)
1656 		//JP 28.10.96:
1657 		// 	fuer AutoFormat bei der Eingabe: dann muessen die Spalten
1658 		//	auf die vordefinierten Breite gesetzt werden. Im Array stehen die
1659 		// 	Positionen der Spalten!! (nicht deren Breite!)
1660     /* #109161# new parameter bCalledFromShell:
1661 
1662        sal_True: called from shell -> propagate existing adjust item at
1663        rPos to every new cell. A existing adjust item in the table
1664        heading or table contents paragraph style prevent that
1665        propagation.
1666 
1667        sal_False: do not propagate
1668     */
1669     const SwTable* InsertTable( const SwInsertTableOptions& rInsTblOpts,  // HEADLINE_NO_BORDER
1670                                 const SwPosition& rPos, sal_uInt16 nRows,
1671                                 sal_uInt16 nCols, short eAdjust,
1672                                 const SwTableAutoFmt* pTAFmt = 0,
1673                                 const SvUShorts* pColArr = 0,
1674                                 sal_Bool bCalledFromShell = sal_False,
1675                                 sal_Bool bNewModel = sal_True );
1676 
1677     // steht der Index in einer Tabelle, dann returne den TableNode sonst 0
1678 				 SwTableNode* IsIdxInTbl( const SwNodeIndex& rIdx );
1679 	inline const SwTableNode* IsIdxInTbl( const SwNodeIndex& rIdx ) const;
1680 
1681 		// erzeuge aus dem makierten Bereich eine ausgeglichene Tabelle
1682     const SwTable* TextToTable( const SwInsertTableOptions& rInsTblOpts, // HEADLINE_NO_BORDER,
1683                                 const SwPaM& rRange, sal_Unicode cCh,
1684                                 short eAdjust,
1685                                 const SwTableAutoFmt* = 0 );
1686     // text to table conversion - API support
1687     const SwTable* TextToTable( const std::vector< std::vector<SwNodeRange> >& rTableNodes );
1688 		// erzeuge aus der Tabelle wieder normalen Text
1689 	sal_Bool TableToText( const SwTableNode* pTblNd, sal_Unicode cCh );
1690 		// einfuegen von Spalten/Zeilen in der Tabelle
1691 	sal_Bool InsertCol( const SwCursor& rCursor,
1692 					sal_uInt16 nCnt = 1, sal_Bool bBehind = sal_True );
1693 	sal_Bool InsertCol( const SwSelBoxes& rBoxes,
1694 					sal_uInt16 nCnt = 1, sal_Bool bBehind = sal_True );
1695 	sal_Bool InsertRow( const SwCursor& rCursor,
1696 					sal_uInt16 nCnt = 1, sal_Bool bBehind = sal_True );
1697 	sal_Bool InsertRow( const SwSelBoxes& rBoxes,
1698 					sal_uInt16 nCnt = 1, sal_Bool bBehind = sal_True );
1699 		// loeschen von Spalten/Zeilen in der Tabelle
1700 	sal_Bool DeleteRowCol( const SwSelBoxes& rBoxes, bool bColumn = false );
1701 	sal_Bool DeleteRow( const SwCursor& rCursor );
1702 	sal_Bool DeleteCol( const SwCursor& rCursor );
1703 		// teilen / zusammenfassen von Boxen in der Tabelle
1704     sal_Bool SplitTbl( const SwSelBoxes& rBoxes, sal_Bool bVert = sal_True,
1705                        sal_uInt16 nCnt = 1, sal_Bool bSameHeight = sal_False );
1706 		// returnt den enum TableMergeErr
1707 	sal_uInt16 MergeTbl( SwPaM& rPam );
1708 	String GetUniqueTblName() const;
1709 	sal_Bool IsInsTblFormatNum() const;
1710 	sal_Bool IsInsTblChangeNumFormat() const;
1711 	sal_Bool IsInsTblAlignNum() const;
1712 
1713 		// aus der FEShell wg.. Undo und bModified
1714     void GetTabCols( SwTabCols &rFill, const SwCursor* pCrsr,
1715 					const SwCellFrm* pBoxFrm = 0 ) const;
1716 	void SetTabCols( const SwTabCols &rNew, sal_Bool bCurRowOnly,
1717 					const SwCursor* pCrsr, const SwCellFrm* pBoxFrm = 0 );
1718     void GetTabRows( SwTabCols &rFill, const SwCursor* pCrsr,
1719                     const SwCellFrm* pBoxFrm = 0 ) const;
1720     void SetTabRows( const SwTabCols &rNew, sal_Bool bCurColOnly, const SwCursor* pCrsr,
1721                      const SwCellFrm* pBoxFrm = 0 );
1722 
1723 
1724 	// Direktzugriff fuer Uno
1725     void SetTabCols(SwTable& rTab, const SwTabCols &rNew, const SwTabCols &rOld,
1726 									const SwTableBox *pStart, sal_Bool bCurRowOnly);
1727 
1728     void SetRowsToRepeat( SwTable &rTable, sal_uInt16 nSet );
1729 
1730 		// AutoFormat fuer die Tabelle/TabellenSelection
1731 	sal_Bool SetTableAutoFmt( const SwSelBoxes& rBoxes, const SwTableAutoFmt& rNew );
1732 		// Erfrage wie attributiert ist
1733 	sal_Bool GetTableAutoFmt( const SwSelBoxes& rBoxes, SwTableAutoFmt& rGet );
1734 		// setze das InsertDB als Tabelle Undo auf:
1735 	void AppendUndoForInsertFromDB( const SwPaM& rPam, sal_Bool bIsTable );
1736 		// setze die Spalten/Zeilen/ZTellen Breite/Hoehe
1737 	sal_Bool SetColRowWidthHeight( SwTableBox& rAktBox, sal_uInt16 eType,
1738 								SwTwips nAbsDiff, SwTwips nRelDiff );
1739 	SwTableBoxFmt* MakeTableBoxFmt();
1740 	SwTableLineFmt* MakeTableLineFmt();
1741 	// teste ob die Box ein numerischen Wert darstellt und aender dann ggfs.
1742 	// das Format der Box
1743 	void ChkBoxNumFmt( SwTableBox& rAktBox, sal_Bool bCallUpdate );
1744 	void SetTblBoxFormulaAttrs( SwTableBox& rBox, const SfxItemSet& rSet );
1745 	void ClearBoxNumAttrs( const SwNodeIndex& rNode );
1746 
1747 	sal_Bool InsCopyOfTbl( SwPosition& rInsPos, const SwSelBoxes& rBoxes,
1748 						const SwTable* pCpyTbl = 0, sal_Bool bCpyName = sal_False,
1749 						sal_Bool bCorrPos = sal_False );
1750 
1751 	sal_Bool UnProtectCells( const String& rTblName );
1752 	sal_Bool UnProtectCells( const SwSelBoxes& rBoxes );
1753 	sal_Bool UnProtectTbls( const SwPaM& rPam );
1754 	sal_Bool HasTblAnyProtection( const SwPosition* pPos,
1755 							  const String* pTblName = 0,
1756 							  sal_Bool* pFullTblProtection = 0 );
1757 
1758 	// Tabelle an der Position in der GrundLine aufsplitten, sprich eine
1759 	// neue Tabelle erzeugen.
1760 	sal_Bool SplitTable( const SwPosition& rPos, sal_uInt16 eMode = 0,
1761 						sal_Bool bCalcNewSize = sal_False );
1762 	// und die Umkehrung davon. rPos muss in der Tabelle stehen, die bestehen
1763 	// bleibt. Das Flag besagt ob die aktuelle mit der davor oder dahinter
1764 	// stehenden vereint wird.
1765 	sal_Bool MergeTable( const SwPosition& rPos, sal_Bool bWithPrev = sal_True,
1766 						sal_uInt16 nMode = 0 );
1767 
1768 	// Charts der angegebenen Tabelle zum Update bewegen
1769 	void UpdateCharts( const String &rName ) const;
1770 	// update all charts, for that exists any table
1771     void UpdateAllCharts()          { DoUpdateAllCharts( 0 ); }
1772 	// Tabelle wird umbenannt und aktualisiert die Charts
1773 	void SetTableName( SwFrmFmt& rTblFmt, const String &rNewName );
1774 
1775 	// returne zum Namen die im Doc gesetzte Referenz
1776 	const SwFmtRefMark* GetRefMark( const String& rName ) const;
1777 	// returne die RefMark per Index - fuer Uno
1778 	const SwFmtRefMark* GetRefMark( sal_uInt16 nIndex ) const;
1779 	// returne die Namen aller im Doc gesetzten Referenzen.
1780 	// 	Ist der ArrayPointer 0 dann returne nur, ob im Doc. eine RefMark
1781 	//	gesetzt ist
1782 	sal_uInt16 GetRefMarks( SvStringsDtor* = 0 ) const;
1783 
1784 	//Einfuegen einer Beschriftung - falls ein FlyFormat erzeugt wird, so
1785 	// returne dieses.
1786     SwFlyFrmFmt* InsertLabel( const SwLabelType eType, const String &rTxt, const String& rSeparator,
1787                     const String& rNumberingSeparator,
1788 					const sal_Bool bBefore, const sal_uInt16 nId, const sal_uLong nIdx,
1789                     const String& rCharacterStyle,
1790 					const sal_Bool bCpyBrd = sal_True );
1791     SwFlyFrmFmt* InsertDrawLabel(
1792         const String &rTxt, const String& rSeparator, const String& rNumberSeparator,
1793         const sal_uInt16 nId, const String& rCharacterStyle, SdrObject& rObj );
1794 
1795 	// erfrage den Attribut Pool
1796 	const SwAttrPool& GetAttrPool() const	{ return *mpAttrPool; }
1797 		  SwAttrPool& GetAttrPool() 		{ return *mpAttrPool; }
1798 
1799 	// suche ueber das Layout eine EditShell und ggfs. eine ViewShell
1800 	SwEditShell* GetEditShell( ViewShell** ppSh = 0 ) const;
1801     ::sw::IShellCursorSupplier * GetIShellCursorSupplier();
1802 
1803 	// OLE 2.0-Benachrichtung
1804 	inline		 void  SetOle2Link(const Link& rLink) {aOle2Link = rLink;}
1805 	inline const Link& GetOle2Link() const {return aOle2Link;}
1806 
1807     // insert section (the ODF kind of section, not the nodesarray kind)
1808     SwSection * InsertSwSection(SwPaM const& rRange, SwSectionData &,
1809             SwTOXBase const*const pTOXBase = 0,
1810             SfxItemSet const*const pAttr = 0, bool const bUpdate = true);
1811 	sal_uInt16 IsInsRegionAvailable( const SwPaM& rRange,
1812 								const SwNode** ppSttNd = 0 ) const;
1813 	SwSection* GetCurrSection( const SwPosition& rPos ) const;
1814 	SwSectionFmts& GetSections() { return *pSectionFmtTbl; }
1815 	const SwSectionFmts& GetSections() const { return *pSectionFmtTbl; }
1816 	SwSectionFmt *MakeSectionFmt( SwSectionFmt *pDerivedFrom );
1817 	void DelSectionFmt( SwSectionFmt *pFmt, sal_Bool bDelNodes = sal_False );
1818     void UpdateSection(sal_uInt16 const nSect, SwSectionData &,
1819             SfxItemSet const*const = 0, bool const bPreventLinkUpdate = false);
1820 	String GetUniqueSectionName( const String* pChkStr = 0 ) const;
1821 
1822     /* @@@MAINTAINABILITY-HORROR@@@
1823        The model should not have anything to do with a shell.
1824        Unnecessary compile/link time dependency.
1825     */
1826 	// Pointer auf die SfxDocShell vom Doc, kann 0 sein !!!
1827 		  SwDocShell* GetDocShell() 		{ return pDocShell; }
1828 	const SwDocShell* GetDocShell() const	{ return pDocShell; }
1829 	void SetDocShell( SwDocShell* pDSh );
1830 
1831 	void ShareLayout( boost::shared_ptr<SwRootFrm>& rPtr);
1832 
1833 	// in case during copying of embedded object a new shell is created,
1834     // it should be set here and cleaned later
1835     void SetTmpDocShell( SfxObjectShellLock rLock )    { xTmpDocShell = rLock; }
1836     SfxObjectShellLock GetTmpDocShell()    { return xTmpDocShell; }
1837 
1838     // fuer die TextBausteine - diese habe nur ein SvPersist zur
1839     // Verfuegung
1840     SfxObjectShell* GetPersist() const;
1841 
1842 	// Pointer auf den Storage des SfxDocShells, kann 0 sein !!!
1843     ::com::sun::star::uno::Reference< ::com::sun::star::embed::XStorage > GetDocStorage();
1844 
1845 		// abfrage/setze Flag, ob das Dokument im asynchronen Laden ist
1846     bool IsInLoadAsynchron() const             { return mbInLoadAsynchron; }
1847     void SetInLoadAsynchron( bool bFlag )       { mbInLoadAsynchron = bFlag; }
1848 
1849 	// erzeuge um das zu Servende Object eine Selektion
1850 	sal_Bool SelectServerObj( const String& rStr, SwPaM*& rpPam,
1851 							SwNodeRange*& rpRange ) const;
1852 
1853 	// fuer Drag&Move: ( z.B. RefMarks "verschieben" erlauben )
1854     bool IsCopyIsMove() const              { return mbCopyIsMove; }
1855     void SetCopyIsMove( bool bFlag )        { mbCopyIsMove = bFlag; }
1856 
1857 	SwDrawContact* GroupSelection( SdrView& );
1858 	void UnGroupSelection( SdrView& );
1859 	sal_Bool DeleteSelection( SwDrawView& );
1860 
1861 	// Invalidiert OnlineSpell-WrongListen
1862 	void SpellItAgainSam( sal_Bool bInvalid, sal_Bool bOnlyWrong, sal_Bool bSmartTags );
1863 	void InvalidateAutoCompleteFlag();
1864 
1865     // <--
1866 	void SetCalcFieldValueHdl(Outliner* pOutliner);
1867 
1868 	// erfrage ob die ::com::sun::star::util::URL besucht war. Uebers Doc, falls nur ein ::com::sun::star::text::Bookmark
1869 	// angegeben ist. Dann muss der Doc. Name davor gesetzt werden!
1870 	sal_Bool IsVisitedURL( const String& rURL ) const;
1871 
1872 	// speicher die akt. Werte fuer die automatische Aufnahme von Ausnahmen
1873 	// in die Autokorrektur
1874 	void SetAutoCorrExceptWord( SwAutoCorrExceptWord* pNew );
1875 	SwAutoCorrExceptWord* GetAutoCorrExceptWord()		{ return pACEWord; }
1876 
1877 	const SwFmtINetFmt* FindINetAttr( const String& rName ) const;
1878 
1879 	// rufe ins dunkle Basic, mit evt. Return String
1880 	sal_Bool ExecMacro( const SvxMacro& rMacro, String* pRet = 0, SbxArray* pArgs = 0 );
1881 	// rufe ins dunkle Basic/JavaScript
1882 	sal_uInt16 CallEvent( sal_uInt16 nEvent, const SwCallMouseEvent& rCallEvent,
1883 						sal_Bool bChkPtr = sal_False, SbxArray* pArgs = 0,
1884 						const Link* pCallBack = 0 );
1885 
1886 	// linken Rand ueber Objectleiste einstellen (aenhlich dem Stufen von
1887 	// Numerierungen), optional kann man "um" den Offset stufen oder "auf"
1888 	// die Position gestuft werden (bModulus = sal_True)
1889 	void MoveLeftMargin( const SwPaM& rPam, sal_Bool bRight = sal_True,
1890 						sal_Bool bModulus = sal_True );
1891 
1892 	// Numberformatter erfragen
1893 	inline	  	 SvNumberFormatter* GetNumberFormatter( sal_Bool bCreate = sal_True );
1894 	inline const SvNumberFormatter* GetNumberFormatter( sal_Bool bCreate = sal_True ) const;
1895 
1896     bool HasInvisibleContent() const;
1897     /// delete invisible content, like hidden sections and paragraphs
1898     bool RemoveInvisibleContent();
1899     /// restore the invisible content if it's available on the undo stack
1900     bool RestoreInvisibleContent();
1901     // replace fields by text - mailmerge support
1902     sal_Bool ConvertFieldsToText();
1903 
1904 	// erzeuge Anhand der vorgebenen Collection Teildokumente
1905 	// falls keine angegeben ist, nehme die Kapitelvorlage der 1. Ebene
1906 	sal_Bool GenerateGlobalDoc( const String& rPath,
1907 								const SwTxtFmtColl* pSplitColl = 0 );
1908 	sal_Bool GenerateGlobalDoc( const String& rPath, int nOutlineLevel = 0 );	//#outline level,add by zhaojianwei
1909 	sal_Bool GenerateHTMLDoc( const String& rPath,
1910 								const SwTxtFmtColl* pSplitColl = 0 );
1911 	sal_Bool GenerateHTMLDoc( const String& rPath, int nOutlineLevel = 0 );	//#outline level,add by zhaojianwei
1912 
1913 	//  vergleiche zwei Dokument miteinander
1914 	long CompareDoc( const SwDoc& rDoc );
1915 	// merge zweier Dokumente
1916 	long MergeDoc( const SwDoc& rDoc );
1917 	// setze Kommentar-Text fuers Redline, das dann per AppendRedline
1918 	// hereinkommt. Wird vom Autoformat benutzt. 0-Pointer setzt den Modus
1919 	// wieder zurueck. Die SequenceNummer ist fuers UI-seitige zusammen-
1920 	// fassen von Redlines.
1921 	void SetAutoFmtRedlineComment( const String* pTxt, sal_uInt16 nSeqNo = 0 );
1922 
1923     bool IsAutoFmtRedline() const           { return mbIsAutoFmtRedline; }
1924     void SetAutoFmtRedline( bool bFlag )    { mbIsAutoFmtRedline = bFlag; }
1925 
1926 	// fuer AutoFormat: mit Undo/Redlining - Behandlung
1927 	void SetTxtFmtCollByAutoFmt( const SwPosition& rPos, sal_uInt16 nPoolId,
1928 								const SfxItemSet* pSet = 0 );
1929 	void SetFmtItemByAutoFmt( const SwPaM& rPam, const SfxItemSet& );
1930 
1931 	// !!!NUR fuer die SW-Textblocks!! beachtet kein LAYOUT!!!
1932 	void ClearDoc(); 		// loescht den gesamten Inhalt.
1933 
1934 	// erfrage / setze die Daten fuer die PagePreView
1935 	const SwPagePreViewPrtData* GetPreViewPrtData() const { return pPgPViewPrtData; }
1936 	// wenn der Pointer == 0 ist, dann wird im Doc der Pointer zerstoert,
1937 	// ansonsten wird das Object kopiert.
1938 	// Der Pointer geht NICHT in den Besitz des Doc's!!
1939 	void SetPreViewPrtData( const SwPagePreViewPrtData* pData );
1940 
1941 	// update all modified OLE-Objects. The modification is called over the
1942 	// StarOne - Interface				--> Bug 67026
1943 	void SetOLEObjModified()
1944 	{	if( GetCurrentViewShell() ) aOLEModifiedTimer.Start(); }	//swmod 071107//swmod 071225
1945 
1946 	// -------------------- Uno - Schnittstellen ---------------------------
1947 	const SwUnoCrsrTbl& GetUnoCrsrTbl() const 		{ return *pUnoCrsrTbl; }
1948 	SwUnoCrsr* CreateUnoCrsr( const SwPosition& rPos, sal_Bool bTblCrsr = sal_False );
1949 	// -------------------- Uno - Schnittstellen ---------------------------
1950 
1951 	// -------------------- FeShell - Schnittstellen -----------------------
1952 	// !!!!! diese gehen immer davon aus, das ein Layout existiert  !!!!
1953     sal_Bool ChgAnchor( const SdrMarkList& _rMrkList,
1954                         RndStdIds _eAnchorType,
1955                         const sal_Bool _bSameOnly,
1956                         const sal_Bool _bPosCorr );
1957 
1958 	void SetRowHeight( const SwCursor& rCursor, const SwFmtFrmSize &rNew );
1959 	void GetRowHeight( const SwCursor& rCursor, SwFmtFrmSize *& rpSz ) const;
1960     void SetRowSplit( const SwCursor& rCursor, const SwFmtRowSplit &rNew );
1961     void GetRowSplit( const SwCursor& rCursor, SwFmtRowSplit *& rpSz ) const;
1962 	sal_Bool BalanceRowHeight( const SwCursor& rCursor, sal_Bool bTstOnly = sal_True );
1963 	void SetRowBackground( const SwCursor& rCursor, const SvxBrushItem &rNew );
1964 	sal_Bool GetRowBackground( const SwCursor& rCursor, SvxBrushItem &rToFill ) const;
1965 	void SetTabBorders( const SwCursor& rCursor, const SfxItemSet& rSet );
1966 	void SetTabLineStyle( const SwCursor& rCursor,
1967 						  const Color* pColor, sal_Bool bSetLine,
1968 						  const SvxBorderLine* pBorderLine );
1969 	void GetTabBorders( const SwCursor& rCursor, SfxItemSet& rSet ) const;
1970 	void SetBoxAttr( const SwCursor& rCursor, const SfxPoolItem &rNew );
1971     sal_Bool GetBoxAttr( const SwCursor& rCursor, SfxPoolItem &rToFill ) const;
1972     void SetBoxAlign( const SwCursor& rCursor, sal_uInt16 nAlign );
1973 	sal_uInt16 GetBoxAlign( const SwCursor& rCursor ) const;
1974 	void AdjustCellWidth( const SwCursor& rCursor, sal_Bool bBalance = sal_False );
1975 
1976 	int Chainable( const SwFrmFmt &rSource, const SwFrmFmt &rDest );
1977 	int Chain( SwFrmFmt &rSource, const SwFrmFmt &rDest );
1978 	void Unchain( SwFrmFmt &rFmt );
1979 
1980 	// fuers Copy/Move aus der FrmShell
1981 	SdrObject* CloneSdrObj( const SdrObject&, sal_Bool bMoveWithinDoc = sal_False,
1982 							sal_Bool bInsInPage = sal_True );
1983 
1984 	//
1985 	// -------------------- FeShell - Schnittstellen Ende ------------------
1986 
1987 
1988 	// Schnittstelle fuer die TextInputDaten - ( fuer die Texteingabe
1989 	// von japanischen/chinesischen Zeichen)
1990 	SwExtTextInput* CreateExtTextInput( const SwPaM& rPam );
1991 	void DeleteExtTextInput( SwExtTextInput* pDel );
1992 	SwExtTextInput* GetExtTextInput( const SwNode& rNd,
1993 								xub_StrLen nCntntPos = STRING_NOTFOUND) const;
1994 	SwExtTextInput* GetExtTextInput() const;
1995 
1996 	// Schnistelle fuer den Zugriff auf die AutoComplete-Liste
1997 	static SwAutoCompleteWord& GetAutoCompleteWords() { return *pACmpltWords; }
1998 
1999     bool ContainsMSVBasic() const          { return mbContains_MSVBasic; }
2000     void SetContainsMSVBasic( bool bFlag )  { mbContains_MSVBasic = bFlag; }
2001 
2002     // Interface for the list of Ruby - texts/attributes
2003 	sal_uInt16 FillRubyList( const SwPaM& rPam, SwRubyList& rList,
2004 						sal_uInt16 nMode );
2005 	sal_uInt16 SetRubyList( const SwPaM& rPam, const SwRubyList& rList,
2006 						sal_uInt16 nMode );
2007 
2008     void ReadLayoutCache( SvStream& rStream );
2009     void WriteLayoutCache( SvStream& rStream );
2010     SwLayoutCache* GetLayoutCache() const { return pLayoutCache; }
2011 
2012     /** Checks if any of the text node contains hidden characters.
2013         Used for optimization. Changing the view option 'view hidden text'
2014         has to trigger a reformatting only if some of the text is hidden.
2015     */
2016     bool ContainsHiddenChars() const;
2017 
2018 	// call back for API wrapper
2019 	SwModify*	GetUnoCallBack() const;
2020 
2021     IGrammarContact* getGrammarContact() const { return mpGrammarContact; }
2022 
2023     // -> #i27615#
2024     /** Marks/Unmarks a list level of a certain list
2025 
2026         OD 2008-04-02 #refactorlists#
2027         levels of a certain lists are marked now
2028 
2029         @param sListId    list Id of the list whose level has to be marked/unmarked
2030         @param nListLevel level to mark
2031         @param bValue     - sal_True  mark the level
2032                           - sal_False unmark the level
2033     */
2034     void MarkListLevel( const String& sListId,
2035                         const int nListLevel,
2036                         const sal_Bool bValue );
2037 
2038     /** Marks/Unmarks a list level of a certain list
2039 
2040         OD 2008-04-02 #refactorlists#
2041         levels of a certain lists are marked now
2042 
2043         @param rList      list whose level has to be marked/unmarked
2044         @param nListLevel level to mark
2045         @param bValue     - sal_True  mark the level
2046                           - sal_False unmark the level
2047      */
2048     void MarkListLevel( SwList& rList,
2049                         const int nListLevel,
2050                         const sal_Bool bValue );
2051     // <- #i27615#
2052 
2053     // Change a format undoable.
2054     void ChgFmt(SwFmt & rFmt, const SfxItemSet & rSet);
2055 
2056     void RenameFmt(SwFmt & rFmt, const String & sNewName,
2057                    sal_Bool bBroadcast = sal_False);
2058 
2059     // Change a TOX undoable.
2060     void ChgTOX(SwTOXBase & rTOX, const SwTOXBase & rNew);
2061 
2062     // #111827#
2063     /**
2064        Returns a textual description of a PaM.
2065 
2066        @param rPaM     the PaM to describe
2067 
2068        If rPaM only spans one paragraph the result is:
2069 
2070             '<text in the PaM>'
2071 
2072        <text in the PaM> is shortened to nUndoStringLength characters.
2073 
2074        If rPaM spans more than one paragraph the result is:
2075 
2076             paragraphs                               (STR_PARAGRAPHS)
2077 
2078        @return the textual description of rPaM
2079      */
2080     String GetPaMDescr(const SwPaM & rPaM) const;
2081 
2082     // -> #i23726#
2083     sal_Bool IsFirstOfNumRule(SwPosition & rPos);
2084     // <- #i23726#
2085 
2086     // --> #i31958# access methods for XForms model(s)
2087 
2088     /// access container for XForms model; will be NULL if !isXForms()
2089 	com::sun::star::uno::Reference<com::sun::star::container::XNameContainer>
2090         getXForms() const;
2091 
2092     com::sun::star::uno::Reference< com::sun::star::linguistic2::XProofreadingIterator > GetGCIterator() const;
2093 
2094     /// is this an XForms document?
2095     bool isXForms() const;
2096 
2097     /// initialize XForms models; turn this into an XForms document
2098     void initXForms( bool bCreateDefaultModel );
2099     // <-- #i31958# access methods for XForms model(s)
2100 
2101     void disposeXForms( );  // #i113606#, for disposing XForms
2102 
2103     // --> OD 2006-03-21 #b6375613#
2104     inline bool ApplyWorkaroundForB6375613() const
2105     {
2106         return mbApplyWorkaroundForB6375613;
2107     }
2108     void SetApplyWorkaroundForB6375613( bool p_bApplyWorkaroundForB6375613 );
2109     // <--
2110 
2111     //Update all the page masters
2112     void SetDefaultPageMode(bool bSquaredPageMode);
2113     sal_Bool IsSquaredPageMode() const;
2114 
2115 	// i#78591#
2116 	void Setn32DummyCompatabilityOptions1( sal_uInt32 CompatabilityOptions1 )
2117 	{
2118 		n32DummyCompatabilityOptions1 = CompatabilityOptions1;
2119 	}
2120 	sal_uInt32 Getn32DummyCompatabilityOptions1( )
2121 	{
2122 		return n32DummyCompatabilityOptions1;
2123 	}
2124 	void Setn32DummyCompatabilityOptions2( sal_uInt32 CompatabilityOptions2 )
2125 	{
2126 		n32DummyCompatabilityOptions2 = CompatabilityOptions2;
2127 	}
2128 	sal_uInt32 Getn32DummyCompatabilityOptions2( )
2129 	{
2130 		return n32DummyCompatabilityOptions2;
2131 	}
2132 #ifdef FUTURE_VBA
2133     com::sun::star::uno::Reference< com::sun::star::script::vba::XVBAEventProcessor > GetVbaEventProcessor();
2134 #endif
2135     ::sfx2::IXmlIdRegistry& GetXmlIdRegistry();
2136     ::sw::MetaFieldManager & GetMetaFieldManager();
2137     ::sw::UndoManager      & GetUndoManager();
2138     ::sw::UndoManager const& GetUndoManager() const;
2139     SfxObjectShell* CreateCopy(bool bCallInitNew) const;
2140 };
2141 
2142 
2143 // Diese Methode wird im Dtor vom SwDoc gerufen und loescht den Cache
2144 // der Konturobjekte
2145 void ClrContourCache();
2146 
2147 
2148 //------------------ inline impl. ---------------------------------
2149 
2150 inline const SwTableNode* SwDoc::IsIdxInTbl( const SwNodeIndex& rIdx ) const
2151 {
2152 	return ((SwDoc*)this)->IsIdxInTbl( rIdx );
2153 }
2154 
2155 inline SvNumberFormatter* SwDoc::GetNumberFormatter( sal_Bool bCreate )
2156 {
2157 	if( bCreate && !pNumberFormatter )
2158 		_CreateNumberFormatter();
2159 	return pNumberFormatter;
2160 }
2161 
2162 inline const SvNumberFormatter* SwDoc::GetNumberFormatter( sal_Bool bCreate ) const
2163 {
2164 	return ((SwDoc*)this)->GetNumberFormatter( bCreate );
2165 }
2166 
2167 inline void SwDoc::SetOLEPrtNotifyPending( bool bSet )
2168 {
2169 	mbOLEPrtNotifyPending = bSet;
2170 	if( !bSet )
2171 		mbAllOLENotify = sal_False;
2172 }
2173 
2174 // --> OD 2006-03-14 #i62875#
2175 // namespace <docfunc> for functions and procedures working on a Writer document.
2176 namespace docfunc
2177 {
2178     /** method to check, if given Writer document contains at least one drawing object
2179 
2180         OD 2006-03-17 #i62875#
2181 
2182         @author OD
2183 
2184         @param p_rDoc
2185         input parameter - reference to the Writer document, which is investigated.
2186     */
2187     bool ExistsDrawObjs( SwDoc& p_rDoc );
2188 
2189     /** method to check, if given Writer document contains only drawing objects,
2190         which are completely on its page.
2191 
2192         OD 2006-03-17 #i62875#
2193 
2194         @author OD
2195 
2196         @param p_rDoc
2197         input parameter - reference to the Writer document, which is investigated.
2198     */
2199     bool AllDrawObjsOnPage( SwDoc& p_rDoc );
2200 
2201     /** method to check, if the outline style has to written as a normal list style
2202 
2203         OD 2006-09-27 #i69627#
2204         The outline style has to written as a normal list style, if a parent
2205         paragraph style of one of the paragraph styles, which are assigned to
2206         the list levels of the outline style, has a list style set or inherits
2207         a list style from its parent paragraphs style.
2208         This information is needed for the OpenDocument file format export.
2209 
2210         @author OD
2211 
2212         @param rDoc
2213         input parameter - reference to the text document, which is investigated.
2214 
2215         @return boolean
2216         indicating, if the outline style has to written as a normal list style
2217     */
2218     bool HasOutlineStyleToBeWrittenAsNormalListStyle( SwDoc& rDoc );
2219 }
2220 // <--
2221 #endif	//_DOC_HXX
2222