xref: /trunk/main/sw/inc/doc.hxx (revision 332f371a)
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(
1496         const SwNodeIndex& rOldNode,
1497         const SwPosition& rNewPos,
1498         const xub_StrLen nOffset = 0,
1499         sal_Bool bMoveCrsr = sal_False );
1500 
1501     // Setzt alles im Bereich von [rStartNode, rEndNode] nach rNewPos
1502     void CorrAbs(
1503         const SwNodeIndex& rStartNode,
1504         const SwNodeIndex& rEndNode,
1505         const SwPosition& rNewPos,
1506         sal_Bool bMoveCrsr = sal_False );
1507 
1508     // Setzt alles im Bereich von rRange nach rNewPos
1509     void CorrAbs(
1510         const SwPaM& rRange,
1511         const SwPosition& rNewPos,
1512         sal_Bool bMoveCrsr = sal_False );
1513 
1514     // Setzt alles in rOldNode auf relative Pos
1515     void CorrRel(
1516         const SwNodeIndex& rOldNode,
1517         const SwPosition& rNewPos,
1518         const xub_StrLen nOffset = 0,
1519         sal_Bool bMoveCrsr = sal_False );
1520 
1521 		// GliederungsRegeln erfragen / setzen
1522     // --> OD 2005-11-02 #i51089 - TUNING#
1523     inline SwNumRule* GetOutlineNumRule() const
1524     {
1525         return pOutlineRule;
1526     }
1527     // <--
1528 	void SetOutlineNumRule( const SwNumRule& rRule );
1529     void PropagateOutlineRule();
1530 
1531 	// Gliederung - hoch-/runterstufen
1532 	sal_Bool OutlineUpDown( const SwPaM& rPam, short nOffset = 1 );
1533 	// Gliederung - hoch-/runtermoven
1534 	sal_Bool MoveOutlinePara( const SwPaM& rPam, short nOffset = 1);
1535 		// zu diesem Gliederungspunkt
1536 	sal_Bool GotoOutline( SwPosition& rPos, const String& rName ) const;
1537 	// die Aenderungen an den Gliederungsvorlagen in die OutlineRule uebernehmen
1538 
1539 		// setzt, wenn noch keine Numerierung, sonst wird geaendert
1540 		// arbeitet mit alten und neuen Regeln, nur Differenzen aktualisieren
1541     // --> OD 2005-02-18 #i42921# - re-use unused 3rd parameter
1542     // --> OD 2008-02-08 #newlistlevelattrs#
1543     // Add optional parameter <bResetIndentAttrs> - default value sal_False.
1544     // If <bResetIndentAttrs> equals true, the indent attributes "before text"
1545     // and "first line indent" are additionally reset at the provided PaM, if
1546     // the list style makes use of the new list level attributes.
1547     // --> OD 2008-03-17 #refactorlists#
1548     // introduce parameters <bCreateNewList> and <sContinuedListId>
1549     // <bCreateNewList> indicates, if a new list is created by applying the
1550     // given list style.
1551     void SetNumRule( const SwPaM&,
1552                      const SwNumRule&,
1553                      const bool bCreateNewList,
1554                      const String sContinuedListId = String(),
1555                      sal_Bool bSetItem = sal_True,
1556                      const bool bResetIndentAttrs = false );
1557     // <--
1558     void SetCounted( const SwPaM&, bool bCounted);
1559 
1560     // --> OD 2009-08-25 #i86492#
1561     // no longer needed.
1562     // SwDoc::SetNumRule( rPaM, rNumRule, false, <ListId>, sal_True, true ) have to be used instead.
1563 //    /**
1564 //       Replace numbering rules in a PaM by another numbering rule.
1565 
1566 //       \param rPaM         PaM to replace the numbering rules in
1567 //       \param rNumRule     numbering rule to replace the present numbering rules
1568 //     */
1569 //    void ReplaceNumRule(const SwPaM & rPaM, const SwNumRule & rNumRule);
1570 
1571     void MakeUniqueNumRules(const SwPaM & rPaM);
1572 
1573 	void SetNumRuleStart( const SwPosition& rPos, sal_Bool bFlag = sal_True );
1574     void SetNodeNumStart( const SwPosition& rPos, sal_uInt16 nStt );
1575 
1576 	SwNumRule* GetCurrNumRule( const SwPosition& rPos ) const;
1577 
1578     const SwNumRuleTbl& GetNumRuleTbl() const { return *pNumRuleTbl; }
1579 
1580     // #i36749#
1581     /**
1582        Add numbering rule to document.
1583 
1584        @param pRule    rule to add
1585     */
1586     void AddNumRule(SwNumRule * pRule);
1587 
1588     // --> OD 2008-02-11 #newlistlevelattrs#
1589     // add optional parameter <eDefaultNumberFormatPositionAndSpaceMode>
1590     sal_uInt16 MakeNumRule( const String &rName,
1591         const SwNumRule* pCpy = 0,
1592         sal_Bool bBroadcast = sal_False,
1593         const SvxNumberFormat::SvxNumPositionAndSpaceMode eDefaultNumberFormatPositionAndSpaceMode =
1594             SvxNumberFormat::LABEL_WIDTH_AND_POSITION );
1595     // <--
1596 	sal_uInt16 FindNumRule( const String& rName ) const;
1597 	SwNumRule* FindNumRulePtr( const String& rName ) const;
1598 
1599 	// loeschen geht nur, wenn die ::com::sun::star::chaos::Rule niemand benutzt!
1600     // #106897#
1601     sal_Bool RenameNumRule(const String & aOldName, const String & aNewName,
1602                            sal_Bool bBroadcast = sal_False);
1603 	sal_Bool DelNumRule( const String& rName, sal_Bool bBroadCast = sal_False );
1604 	String GetUniqueNumRuleName( const String* pChkStr = 0, sal_Bool bAutoNum = sal_True ) const;
1605 
1606 	void UpdateNumRule();	// alle invaliden Updaten
1607     // #106897#
1608 	void ChgNumRuleFmts( const SwNumRule& rRule, const String * pOldName = 0 );
1609 	sal_Bool ReplaceNumRule( const SwPosition& rPos, const String& rOldRule,
1610 						const String& rNewRule );
1611 
1612 		// zum naechsten/vorhergehenden Punkt auf gleicher Ebene
1613 	sal_Bool GotoNextNum( SwPosition&, sal_Bool bOverUpper = sal_True,
1614 						sal_uInt8* pUpper = 0, sal_uInt8* pLower = 0 );
1615 	sal_Bool GotoPrevNum( SwPosition&, sal_Bool bOverUpper = sal_True,
1616 						sal_uInt8* pUpper = 0, sal_uInt8* pLower = 0 );
1617 
1618     // #i23731#
1619     /** Searches for a text node with a numbering rule.
1620 
1621        OD 2005-10-24 #i55391# - add optional parameter <bInvestigateStartNode>
1622        OD 2008-03-18 #refactorlists# - add output parameter <sListId>
1623 
1624        \param rPos         position to start search
1625        \param bForward     - sal_True:  search forward
1626                            - sal_False: search backward
1627 	   \param bNum		   - sal_True:  search for enumeration
1628 		                   - sal_False: search for itemize
1629        \param bOutline     - sal_True:  search for outline numbering rule
1630                            - sal_False: search for non-outline numbering rule
1631        \param nNonEmptyAllowed   number of non-empty paragraphs allowed between
1632                                  rPos and found paragraph
1633 
1634         @param sListId
1635         output parameter - in case a list style is found, <sListId> holds the
1636         list id, to which the text node belongs, which applies the found list style.
1637 
1638         @param bInvestigateStartNode
1639         input parameter - boolean, indicating, if start node, determined by given
1640         start position has to be investigated or not.
1641      */
1642     const SwNumRule * SearchNumRule(const SwPosition & rPos,
1643                                     const bool bForward,
1644                                     const bool bNum,
1645                                     const bool bOutline,
1646                                     int nNonEmptyAllowed,
1647                                     String& sListId,
1648                                     const bool bInvestigateStartNode = false );
1649 
1650 		// Absaetze ohne Numerierung, aber mit Einzuegen
1651 	sal_Bool NoNum( const SwPaM& );
1652 		// Loeschen, Splitten der Aufzaehlungsliste
1653     void DelNumRules( const SwPaM& );
1654 
1655     // Invalidates all numrules
1656     void InvalidateNumRules();
1657 
1658 		// Hoch-/Runterstufen
1659 	sal_Bool NumUpDown( const SwPaM&, sal_Bool bDown = sal_True );
1660 		// Bewegt selektierte Absaetze (nicht nur Numerierungen)
1661 		// entsprechend des Offsets. (negativ: zum Doc-Anf.)
1662 	sal_Bool MoveParagraph( const SwPaM&, long nOffset = 1, sal_Bool bIsOutlMv = sal_False );
1663 		// No-/Numerierung ueber Delete/Backspace ein/abschalten #115901#
1664 	sal_Bool NumOrNoNum( const SwNodeIndex& rIdx, sal_Bool bDel = sal_False);
1665 		// Animation der Grafiken stoppen
1666 	void StopNumRuleAnimations( OutputDevice* );
1667 
1668 		// fuege eine neue Tabelle auf der Position rPos ein. (es
1669 		// wird vor dem Node eingefuegt !!)
1670 		//JP 28.10.96:
1671 		// 	fuer AutoFormat bei der Eingabe: dann muessen die Spalten
1672 		//	auf die vordefinierten Breite gesetzt werden. Im Array stehen die
1673 		// 	Positionen der Spalten!! (nicht deren Breite!)
1674     /* #109161# new parameter bCalledFromShell:
1675 
1676        sal_True: called from shell -> propagate existing adjust item at
1677        rPos to every new cell. A existing adjust item in the table
1678        heading or table contents paragraph style prevent that
1679        propagation.
1680 
1681        sal_False: do not propagate
1682     */
1683     const SwTable* InsertTable( const SwInsertTableOptions& rInsTblOpts,  // HEADLINE_NO_BORDER
1684                                 const SwPosition& rPos, sal_uInt16 nRows,
1685                                 sal_uInt16 nCols, short eAdjust,
1686                                 const SwTableAutoFmt* pTAFmt = 0,
1687                                 const SvUShorts* pColArr = 0,
1688                                 sal_Bool bCalledFromShell = sal_False,
1689                                 sal_Bool bNewModel = sal_True );
1690 
1691     // steht der Index in einer Tabelle, dann returne den TableNode sonst 0
1692 				 SwTableNode* IsIdxInTbl( const SwNodeIndex& rIdx );
1693 	inline const SwTableNode* IsIdxInTbl( const SwNodeIndex& rIdx ) const;
1694 
1695 		// erzeuge aus dem makierten Bereich eine ausgeglichene Tabelle
1696     const SwTable* TextToTable( const SwInsertTableOptions& rInsTblOpts, // HEADLINE_NO_BORDER,
1697                                 const SwPaM& rRange, sal_Unicode cCh,
1698                                 short eAdjust,
1699                                 const SwTableAutoFmt* = 0 );
1700     // text to table conversion - API support
1701     const SwTable* TextToTable( const std::vector< std::vector<SwNodeRange> >& rTableNodes );
1702 		// erzeuge aus der Tabelle wieder normalen Text
1703 	sal_Bool TableToText( const SwTableNode* pTblNd, sal_Unicode cCh );
1704 		// einfuegen von Spalten/Zeilen in der Tabelle
1705 	sal_Bool InsertCol( const SwCursor& rCursor,
1706 					sal_uInt16 nCnt = 1, sal_Bool bBehind = sal_True );
1707 	sal_Bool InsertCol( const SwSelBoxes& rBoxes,
1708 					sal_uInt16 nCnt = 1, sal_Bool bBehind = sal_True );
1709 	sal_Bool InsertRow( const SwCursor& rCursor,
1710 					sal_uInt16 nCnt = 1, sal_Bool bBehind = sal_True );
1711 	sal_Bool InsertRow( const SwSelBoxes& rBoxes,
1712 					sal_uInt16 nCnt = 1, sal_Bool bBehind = sal_True );
1713 		// loeschen von Spalten/Zeilen in der Tabelle
1714 	sal_Bool DeleteRowCol( const SwSelBoxes& rBoxes, bool bColumn = false );
1715 	sal_Bool DeleteRow( const SwCursor& rCursor );
1716 	sal_Bool DeleteCol( const SwCursor& rCursor );
1717 		// teilen / zusammenfassen von Boxen in der Tabelle
1718     sal_Bool SplitTbl( const SwSelBoxes& rBoxes, sal_Bool bVert = sal_True,
1719                        sal_uInt16 nCnt = 1, sal_Bool bSameHeight = sal_False );
1720 		// returnt den enum TableMergeErr
1721 	sal_uInt16 MergeTbl( SwPaM& rPam );
1722 	String GetUniqueTblName() const;
1723 	sal_Bool IsInsTblFormatNum() const;
1724 	sal_Bool IsInsTblChangeNumFormat() const;
1725 	sal_Bool IsInsTblAlignNum() const;
1726 
1727 		// aus der FEShell wg.. Undo und bModified
1728     void GetTabCols( SwTabCols &rFill, const SwCursor* pCrsr,
1729 					const SwCellFrm* pBoxFrm = 0 ) const;
1730 	void SetTabCols( const SwTabCols &rNew, sal_Bool bCurRowOnly,
1731 					const SwCursor* pCrsr, const SwCellFrm* pBoxFrm = 0 );
1732     void GetTabRows( SwTabCols &rFill, const SwCursor* pCrsr,
1733                     const SwCellFrm* pBoxFrm = 0 ) const;
1734     void SetTabRows( const SwTabCols &rNew, sal_Bool bCurColOnly, const SwCursor* pCrsr,
1735                      const SwCellFrm* pBoxFrm = 0 );
1736 
1737 
1738 	// Direktzugriff fuer Uno
1739     void SetTabCols(SwTable& rTab, const SwTabCols &rNew, const SwTabCols &rOld,
1740 									const SwTableBox *pStart, sal_Bool bCurRowOnly);
1741 
1742     void SetRowsToRepeat( SwTable &rTable, sal_uInt16 nSet );
1743 
1744 		// AutoFormat fuer die Tabelle/TabellenSelection
1745 	sal_Bool SetTableAutoFmt( const SwSelBoxes& rBoxes, const SwTableAutoFmt& rNew );
1746 		// Erfrage wie attributiert ist
1747 	sal_Bool GetTableAutoFmt( const SwSelBoxes& rBoxes, SwTableAutoFmt& rGet );
1748 		// setze das InsertDB als Tabelle Undo auf:
1749 	void AppendUndoForInsertFromDB( const SwPaM& rPam, sal_Bool bIsTable );
1750 		// setze die Spalten/Zeilen/ZTellen Breite/Hoehe
1751 	sal_Bool SetColRowWidthHeight( SwTableBox& rAktBox, sal_uInt16 eType,
1752 								SwTwips nAbsDiff, SwTwips nRelDiff );
1753 	SwTableBoxFmt* MakeTableBoxFmt();
1754 	SwTableLineFmt* MakeTableLineFmt();
1755 	// teste ob die Box ein numerischen Wert darstellt und aender dann ggfs.
1756 	// das Format der Box
1757 	void ChkBoxNumFmt( SwTableBox& rAktBox, sal_Bool bCallUpdate );
1758 	void SetTblBoxFormulaAttrs( SwTableBox& rBox, const SfxItemSet& rSet );
1759 	void ClearBoxNumAttrs( const SwNodeIndex& rNode );
1760 
1761 	sal_Bool InsCopyOfTbl( SwPosition& rInsPos, const SwSelBoxes& rBoxes,
1762 						const SwTable* pCpyTbl = 0, sal_Bool bCpyName = sal_False,
1763 						sal_Bool bCorrPos = sal_False );
1764 
1765 	sal_Bool UnProtectCells( const String& rTblName );
1766 	sal_Bool UnProtectCells( const SwSelBoxes& rBoxes );
1767 	sal_Bool UnProtectTbls( const SwPaM& rPam );
1768 	sal_Bool HasTblAnyProtection( const SwPosition* pPos,
1769 							  const String* pTblName = 0,
1770 							  sal_Bool* pFullTblProtection = 0 );
1771 
1772 	// Tabelle an der Position in der GrundLine aufsplitten, sprich eine
1773 	// neue Tabelle erzeugen.
1774 	sal_Bool SplitTable( const SwPosition& rPos, sal_uInt16 eMode = 0,
1775 						sal_Bool bCalcNewSize = sal_False );
1776 	// und die Umkehrung davon. rPos muss in der Tabelle stehen, die bestehen
1777 	// bleibt. Das Flag besagt ob die aktuelle mit der davor oder dahinter
1778 	// stehenden vereint wird.
1779 	sal_Bool MergeTable( const SwPosition& rPos, sal_Bool bWithPrev = sal_True,
1780 						sal_uInt16 nMode = 0 );
1781 
1782 	// Charts der angegebenen Tabelle zum Update bewegen
1783 	void UpdateCharts( const String &rName ) const;
1784 	// update all charts, for that exists any table
1785     void UpdateAllCharts()          { DoUpdateAllCharts( 0 ); }
1786 	// Tabelle wird umbenannt und aktualisiert die Charts
1787 	void SetTableName( SwFrmFmt& rTblFmt, const String &rNewName );
1788 
1789 	// returne zum Namen die im Doc gesetzte Referenz
1790 	const SwFmtRefMark* GetRefMark( const String& rName ) const;
1791 	// returne die RefMark per Index - fuer Uno
1792 	const SwFmtRefMark* GetRefMark( sal_uInt16 nIndex ) const;
1793 	// returne die Namen aller im Doc gesetzten Referenzen.
1794 	// 	Ist der ArrayPointer 0 dann returne nur, ob im Doc. eine RefMark
1795 	//	gesetzt ist
1796 	sal_uInt16 GetRefMarks( SvStringsDtor* = 0 ) const;
1797 
1798 	//Einfuegen einer Beschriftung - falls ein FlyFormat erzeugt wird, so
1799 	// returne dieses.
1800     SwFlyFrmFmt* InsertLabel( const SwLabelType eType, const String &rTxt, const String& rSeparator,
1801                     const String& rNumberingSeparator,
1802 					const sal_Bool bBefore, const sal_uInt16 nId, const sal_uLong nIdx,
1803                     const String& rCharacterStyle,
1804 					const sal_Bool bCpyBrd = sal_True );
1805     SwFlyFrmFmt* InsertDrawLabel(
1806         const String &rTxt, const String& rSeparator, const String& rNumberSeparator,
1807         const sal_uInt16 nId, const String& rCharacterStyle, SdrObject& rObj );
1808 
1809 	// erfrage den Attribut Pool
1810 	const SwAttrPool& GetAttrPool() const	{ return *mpAttrPool; }
1811 		  SwAttrPool& GetAttrPool() 		{ return *mpAttrPool; }
1812 
1813 	// suche ueber das Layout eine EditShell und ggfs. eine ViewShell
1814 	SwEditShell* GetEditShell( ViewShell** ppSh = 0 ) const;
1815     ::sw::IShellCursorSupplier * GetIShellCursorSupplier();
1816 
1817 	// OLE 2.0-Benachrichtung
1818 	inline		 void  SetOle2Link(const Link& rLink) {aOle2Link = rLink;}
1819 	inline const Link& GetOle2Link() const {return aOle2Link;}
1820 
1821     // insert section (the ODF kind of section, not the nodesarray kind)
1822     SwSection * InsertSwSection(SwPaM const& rRange, SwSectionData &,
1823             SwTOXBase const*const pTOXBase = 0,
1824             SfxItemSet const*const pAttr = 0, bool const bUpdate = true);
1825 	sal_uInt16 IsInsRegionAvailable( const SwPaM& rRange,
1826 								const SwNode** ppSttNd = 0 ) const;
1827 	SwSection* GetCurrSection( const SwPosition& rPos ) const;
1828 	SwSectionFmts& GetSections() { return *pSectionFmtTbl; }
1829 	const SwSectionFmts& GetSections() const { return *pSectionFmtTbl; }
1830 	SwSectionFmt *MakeSectionFmt( SwSectionFmt *pDerivedFrom );
1831 	void DelSectionFmt( SwSectionFmt *pFmt, sal_Bool bDelNodes = sal_False );
1832     void UpdateSection(sal_uInt16 const nSect, SwSectionData &,
1833             SfxItemSet const*const = 0, bool const bPreventLinkUpdate = false);
1834 	String GetUniqueSectionName( const String* pChkStr = 0 ) const;
1835 
1836     /* @@@MAINTAINABILITY-HORROR@@@
1837        The model should not have anything to do with a shell.
1838        Unnecessary compile/link time dependency.
1839     */
1840 	// Pointer auf die SfxDocShell vom Doc, kann 0 sein !!!
1841 		  SwDocShell* GetDocShell() 		{ return pDocShell; }
1842 	const SwDocShell* GetDocShell() const	{ return pDocShell; }
1843 	void SetDocShell( SwDocShell* pDSh );
1844 
1845 	void ShareLayout( boost::shared_ptr<SwRootFrm>& rPtr);
1846 
1847 	// in case during copying of embedded object a new shell is created,
1848     // it should be set here and cleaned later
1849     void SetTmpDocShell( SfxObjectShellLock rLock )    { xTmpDocShell = rLock; }
1850     SfxObjectShellLock GetTmpDocShell()    { return xTmpDocShell; }
1851 
1852     // fuer die TextBausteine - diese habe nur ein SvPersist zur
1853     // Verfuegung
1854     SfxObjectShell* GetPersist() const;
1855 
1856 	// Pointer auf den Storage des SfxDocShells, kann 0 sein !!!
1857     ::com::sun::star::uno::Reference< ::com::sun::star::embed::XStorage > GetDocStorage();
1858 
1859 		// abfrage/setze Flag, ob das Dokument im asynchronen Laden ist
1860     bool IsInLoadAsynchron() const             { return mbInLoadAsynchron; }
1861     void SetInLoadAsynchron( bool bFlag )       { mbInLoadAsynchron = bFlag; }
1862 
1863 	// erzeuge um das zu Servende Object eine Selektion
1864 	sal_Bool SelectServerObj( const String& rStr, SwPaM*& rpPam,
1865 							SwNodeRange*& rpRange ) const;
1866 
1867 	// fuer Drag&Move: ( z.B. RefMarks "verschieben" erlauben )
1868     bool IsCopyIsMove() const              { return mbCopyIsMove; }
1869     void SetCopyIsMove( bool bFlag )        { mbCopyIsMove = bFlag; }
1870 
1871 	SwDrawContact* GroupSelection( SdrView& );
1872 	void UnGroupSelection( SdrView& );
1873 	sal_Bool DeleteSelection( SwDrawView& );
1874 
1875 	// Invalidiert OnlineSpell-WrongListen
1876 	void SpellItAgainSam( sal_Bool bInvalid, sal_Bool bOnlyWrong, sal_Bool bSmartTags );
1877 	void InvalidateAutoCompleteFlag();
1878 
1879     // <--
1880 	void SetCalcFieldValueHdl(Outliner* pOutliner);
1881 
1882 	// erfrage ob die ::com::sun::star::util::URL besucht war. Uebers Doc, falls nur ein ::com::sun::star::text::Bookmark
1883 	// angegeben ist. Dann muss der Doc. Name davor gesetzt werden!
1884 	sal_Bool IsVisitedURL( const String& rURL ) const;
1885 
1886 	// speicher die akt. Werte fuer die automatische Aufnahme von Ausnahmen
1887 	// in die Autokorrektur
1888 	void SetAutoCorrExceptWord( SwAutoCorrExceptWord* pNew );
1889 	SwAutoCorrExceptWord* GetAutoCorrExceptWord()		{ return pACEWord; }
1890 
1891 	const SwFmtINetFmt* FindINetAttr( const String& rName ) const;
1892 
1893 	// rufe ins dunkle Basic, mit evt. Return String
1894 	sal_Bool ExecMacro( const SvxMacro& rMacro, String* pRet = 0, SbxArray* pArgs = 0 );
1895 	// rufe ins dunkle Basic/JavaScript
1896 	sal_uInt16 CallEvent( sal_uInt16 nEvent, const SwCallMouseEvent& rCallEvent,
1897 						sal_Bool bChkPtr = sal_False, SbxArray* pArgs = 0,
1898 						const Link* pCallBack = 0 );
1899 
1900 	// linken Rand ueber Objectleiste einstellen (aenhlich dem Stufen von
1901 	// Numerierungen), optional kann man "um" den Offset stufen oder "auf"
1902 	// die Position gestuft werden (bModulus = sal_True)
1903 	void MoveLeftMargin( const SwPaM& rPam, sal_Bool bRight = sal_True,
1904 						sal_Bool bModulus = sal_True );
1905 
1906 	// Numberformatter erfragen
1907 	inline	  	 SvNumberFormatter* GetNumberFormatter( sal_Bool bCreate = sal_True );
1908 	inline const SvNumberFormatter* GetNumberFormatter( sal_Bool bCreate = sal_True ) const;
1909 
1910     bool HasInvisibleContent() const;
1911     /// delete invisible content, like hidden sections and paragraphs
1912     bool RemoveInvisibleContent();
1913     /// restore the invisible content if it's available on the undo stack
1914     bool RestoreInvisibleContent();
1915     // replace fields by text - mailmerge support
1916     sal_Bool ConvertFieldsToText();
1917 
1918 	// erzeuge Anhand der vorgebenen Collection Teildokumente
1919 	// falls keine angegeben ist, nehme die Kapitelvorlage der 1. Ebene
1920 	sal_Bool GenerateGlobalDoc( const String& rPath,
1921 								const SwTxtFmtColl* pSplitColl = 0 );
1922 	sal_Bool GenerateGlobalDoc( const String& rPath, int nOutlineLevel = 0 );	//#outline level,add by zhaojianwei
1923 	sal_Bool GenerateHTMLDoc( const String& rPath,
1924 								const SwTxtFmtColl* pSplitColl = 0 );
1925 	sal_Bool GenerateHTMLDoc( const String& rPath, int nOutlineLevel = 0 );	//#outline level,add by zhaojianwei
1926 
1927 	//  vergleiche zwei Dokument miteinander
1928 	long CompareDoc( const SwDoc& rDoc );
1929 	// merge zweier Dokumente
1930 	long MergeDoc( const SwDoc& rDoc );
1931 	// setze Kommentar-Text fuers Redline, das dann per AppendRedline
1932 	// hereinkommt. Wird vom Autoformat benutzt. 0-Pointer setzt den Modus
1933 	// wieder zurueck. Die SequenceNummer ist fuers UI-seitige zusammen-
1934 	// fassen von Redlines.
1935 	void SetAutoFmtRedlineComment( const String* pTxt, sal_uInt16 nSeqNo = 0 );
1936 
1937     bool IsAutoFmtRedline() const           { return mbIsAutoFmtRedline; }
1938     void SetAutoFmtRedline( bool bFlag )    { mbIsAutoFmtRedline = bFlag; }
1939 
1940 	// fuer AutoFormat: mit Undo/Redlining - Behandlung
1941 	void SetTxtFmtCollByAutoFmt( const SwPosition& rPos, sal_uInt16 nPoolId,
1942 								const SfxItemSet* pSet = 0 );
1943 	void SetFmtItemByAutoFmt( const SwPaM& rPam, const SfxItemSet& );
1944 
1945 	// !!!NUR fuer die SW-Textblocks!! beachtet kein LAYOUT!!!
1946 	void ClearDoc(); 		// loescht den gesamten Inhalt.
1947 
1948 	// erfrage / setze die Daten fuer die PagePreView
1949 	const SwPagePreViewPrtData* GetPreViewPrtData() const { return pPgPViewPrtData; }
1950 	// wenn der Pointer == 0 ist, dann wird im Doc der Pointer zerstoert,
1951 	// ansonsten wird das Object kopiert.
1952 	// Der Pointer geht NICHT in den Besitz des Doc's!!
1953 	void SetPreViewPrtData( const SwPagePreViewPrtData* pData );
1954 
1955 	// update all modified OLE-Objects. The modification is called over the
1956 	// StarOne - Interface				--> Bug 67026
1957 	void SetOLEObjModified()
1958 	{	if( GetCurrentViewShell() ) aOLEModifiedTimer.Start(); }	//swmod 071107//swmod 071225
1959 
1960 	// -------------------- Uno - Schnittstellen ---------------------------
1961 	const SwUnoCrsrTbl& GetUnoCrsrTbl() const 		{ return *pUnoCrsrTbl; }
1962 	SwUnoCrsr* CreateUnoCrsr( const SwPosition& rPos, sal_Bool bTblCrsr = sal_False );
1963 	// -------------------- Uno - Schnittstellen ---------------------------
1964 
1965 	// -------------------- FeShell - Schnittstellen -----------------------
1966 	// !!!!! diese gehen immer davon aus, das ein Layout existiert  !!!!
1967     sal_Bool ChgAnchor( const SdrMarkList& _rMrkList,
1968                         RndStdIds _eAnchorType,
1969                         const sal_Bool _bSameOnly,
1970                         const sal_Bool _bPosCorr );
1971 
1972 	void SetRowHeight( const SwCursor& rCursor, const SwFmtFrmSize &rNew );
1973 	void GetRowHeight( const SwCursor& rCursor, SwFmtFrmSize *& rpSz ) const;
1974     void SetRowSplit( const SwCursor& rCursor, const SwFmtRowSplit &rNew );
1975     void GetRowSplit( const SwCursor& rCursor, SwFmtRowSplit *& rpSz ) const;
1976 	sal_Bool BalanceRowHeight( const SwCursor& rCursor, sal_Bool bTstOnly = sal_True );
1977 	void SetRowBackground( const SwCursor& rCursor, const SvxBrushItem &rNew );
1978 	sal_Bool GetRowBackground( const SwCursor& rCursor, SvxBrushItem &rToFill ) const;
1979 	void SetTabBorders( const SwCursor& rCursor, const SfxItemSet& rSet );
1980 	void SetTabLineStyle( const SwCursor& rCursor,
1981 						  const Color* pColor, sal_Bool bSetLine,
1982 						  const SvxBorderLine* pBorderLine );
1983 	void GetTabBorders( const SwCursor& rCursor, SfxItemSet& rSet ) const;
1984 	void SetBoxAttr( const SwCursor& rCursor, const SfxPoolItem &rNew );
1985     sal_Bool GetBoxAttr( const SwCursor& rCursor, SfxPoolItem &rToFill ) const;
1986     void SetBoxAlign( const SwCursor& rCursor, sal_uInt16 nAlign );
1987 	sal_uInt16 GetBoxAlign( const SwCursor& rCursor ) const;
1988 	void AdjustCellWidth( const SwCursor& rCursor, sal_Bool bBalance = sal_False );
1989 
1990 	int Chainable( const SwFrmFmt &rSource, const SwFrmFmt &rDest );
1991 	int Chain( SwFrmFmt &rSource, const SwFrmFmt &rDest );
1992 	void Unchain( SwFrmFmt &rFmt );
1993 
1994 	// fuers Copy/Move aus der FrmShell
1995 	SdrObject* CloneSdrObj( const SdrObject&, sal_Bool bMoveWithinDoc = sal_False,
1996 							sal_Bool bInsInPage = sal_True );
1997 
1998 	//
1999 	// -------------------- FeShell - Schnittstellen Ende ------------------
2000 
2001 
2002 	// Schnittstelle fuer die TextInputDaten - ( fuer die Texteingabe
2003 	// von japanischen/chinesischen Zeichen)
2004 	SwExtTextInput* CreateExtTextInput( const SwPaM& rPam );
2005 	void DeleteExtTextInput( SwExtTextInput* pDel );
2006 	SwExtTextInput* GetExtTextInput( const SwNode& rNd,
2007 								xub_StrLen nCntntPos = STRING_NOTFOUND) const;
2008 	SwExtTextInput* GetExtTextInput() const;
2009 
2010 	// Schnistelle fuer den Zugriff auf die AutoComplete-Liste
2011 	static SwAutoCompleteWord& GetAutoCompleteWords() { return *pACmpltWords; }
2012 
2013     bool ContainsMSVBasic() const          { return mbContains_MSVBasic; }
2014     void SetContainsMSVBasic( bool bFlag )  { mbContains_MSVBasic = bFlag; }
2015 
2016     // Interface for the list of Ruby - texts/attributes
2017 	sal_uInt16 FillRubyList( const SwPaM& rPam, SwRubyList& rList,
2018 						sal_uInt16 nMode );
2019 	sal_uInt16 SetRubyList( const SwPaM& rPam, const SwRubyList& rList,
2020 						sal_uInt16 nMode );
2021 
2022     void ReadLayoutCache( SvStream& rStream );
2023     void WriteLayoutCache( SvStream& rStream );
2024     SwLayoutCache* GetLayoutCache() const { return pLayoutCache; }
2025 
2026     /** Checks if any of the text node contains hidden characters.
2027         Used for optimization. Changing the view option 'view hidden text'
2028         has to trigger a reformatting only if some of the text is hidden.
2029     */
2030     bool ContainsHiddenChars() const;
2031 
2032 	// call back for API wrapper
2033 	SwModify*	GetUnoCallBack() const;
2034 
2035     IGrammarContact* getGrammarContact() const { return mpGrammarContact; }
2036 
2037     // -> #i27615#
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 sListId    list Id of the 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( const String& sListId,
2049                         const int nListLevel,
2050                         const sal_Bool bValue );
2051 
2052     /** Marks/Unmarks a list level of a certain list
2053 
2054         OD 2008-04-02 #refactorlists#
2055         levels of a certain lists are marked now
2056 
2057         @param rList      list whose level has to be marked/unmarked
2058         @param nListLevel level to mark
2059         @param bValue     - sal_True  mark the level
2060                           - sal_False unmark the level
2061      */
2062     void MarkListLevel( SwList& rList,
2063                         const int nListLevel,
2064                         const sal_Bool bValue );
2065     // <- #i27615#
2066 
2067     // Change a format undoable.
2068     void ChgFmt(SwFmt & rFmt, const SfxItemSet & rSet);
2069 
2070     void RenameFmt(SwFmt & rFmt, const String & sNewName,
2071                    sal_Bool bBroadcast = sal_False);
2072 
2073     // Change a TOX undoable.
2074     void ChgTOX(SwTOXBase & rTOX, const SwTOXBase & rNew);
2075 
2076     // #111827#
2077     /**
2078        Returns a textual description of a PaM.
2079 
2080        @param rPaM     the PaM to describe
2081 
2082        If rPaM only spans one paragraph the result is:
2083 
2084             '<text in the PaM>'
2085 
2086        <text in the PaM> is shortened to nUndoStringLength characters.
2087 
2088        If rPaM spans more than one paragraph the result is:
2089 
2090             paragraphs                               (STR_PARAGRAPHS)
2091 
2092        @return the textual description of rPaM
2093      */
2094     String GetPaMDescr(const SwPaM & rPaM) const;
2095 
2096     // -> #i23726#
2097     sal_Bool IsFirstOfNumRule(SwPosition & rPos);
2098     // <- #i23726#
2099 
2100     // --> #i31958# access methods for XForms model(s)
2101 
2102     /// access container for XForms model; will be NULL if !isXForms()
2103 	com::sun::star::uno::Reference<com::sun::star::container::XNameContainer>
2104         getXForms() const;
2105 
2106     com::sun::star::uno::Reference< com::sun::star::linguistic2::XProofreadingIterator > GetGCIterator() const;
2107 
2108     /// is this an XForms document?
2109     bool isXForms() const;
2110 
2111     /// initialize XForms models; turn this into an XForms document
2112     void initXForms( bool bCreateDefaultModel );
2113     // <-- #i31958# access methods for XForms model(s)
2114 
2115     void disposeXForms( );  // #i113606#, for disposing XForms
2116 
2117     // --> OD 2006-03-21 #b6375613#
2118     inline bool ApplyWorkaroundForB6375613() const
2119     {
2120         return mbApplyWorkaroundForB6375613;
2121     }
2122     void SetApplyWorkaroundForB6375613( bool p_bApplyWorkaroundForB6375613 );
2123     // <--
2124 
2125     //Update all the page masters
2126     void SetDefaultPageMode(bool bSquaredPageMode);
2127     sal_Bool IsSquaredPageMode() const;
2128 
2129 	// i#78591#
2130 	void Setn32DummyCompatabilityOptions1( sal_uInt32 CompatabilityOptions1 )
2131 	{
2132 		n32DummyCompatabilityOptions1 = CompatabilityOptions1;
2133 	}
2134 	sal_uInt32 Getn32DummyCompatabilityOptions1( )
2135 	{
2136 		return n32DummyCompatabilityOptions1;
2137 	}
2138 	void Setn32DummyCompatabilityOptions2( sal_uInt32 CompatabilityOptions2 )
2139 	{
2140 		n32DummyCompatabilityOptions2 = CompatabilityOptions2;
2141 	}
2142 	sal_uInt32 Getn32DummyCompatabilityOptions2( )
2143 	{
2144 		return n32DummyCompatabilityOptions2;
2145 	}
2146 #ifdef FUTURE_VBA
2147     com::sun::star::uno::Reference< com::sun::star::script::vba::XVBAEventProcessor > GetVbaEventProcessor();
2148 #endif
2149     ::sfx2::IXmlIdRegistry& GetXmlIdRegistry();
2150     ::sw::MetaFieldManager & GetMetaFieldManager();
2151     ::sw::UndoManager      & GetUndoManager();
2152     ::sw::UndoManager const& GetUndoManager() const;
2153     SfxObjectShell* CreateCopy(bool bCallInitNew) const;
2154 };
2155 
2156 
2157 // Diese Methode wird im Dtor vom SwDoc gerufen und loescht den Cache
2158 // der Konturobjekte
2159 void ClrContourCache();
2160 
2161 
2162 //------------------ inline impl. ---------------------------------
2163 
2164 inline const SwTableNode* SwDoc::IsIdxInTbl( const SwNodeIndex& rIdx ) const
2165 {
2166 	return ((SwDoc*)this)->IsIdxInTbl( rIdx );
2167 }
2168 
2169 inline SvNumberFormatter* SwDoc::GetNumberFormatter( sal_Bool bCreate )
2170 {
2171 	if( bCreate && !pNumberFormatter )
2172 		_CreateNumberFormatter();
2173 	return pNumberFormatter;
2174 }
2175 
2176 inline const SvNumberFormatter* SwDoc::GetNumberFormatter( sal_Bool bCreate ) const
2177 {
2178 	return ((SwDoc*)this)->GetNumberFormatter( bCreate );
2179 }
2180 
2181 inline void SwDoc::SetOLEPrtNotifyPending( bool bSet )
2182 {
2183 	mbOLEPrtNotifyPending = bSet;
2184 	if( !bSet )
2185 		mbAllOLENotify = sal_False;
2186 }
2187 
2188 // --> OD 2006-03-14 #i62875#
2189 // namespace <docfunc> for functions and procedures working on a Writer document.
2190 namespace docfunc
2191 {
2192     /** method to check, if given Writer document contains at least one drawing object
2193 
2194         OD 2006-03-17 #i62875#
2195 
2196         @author OD
2197 
2198         @param p_rDoc
2199         input parameter - reference to the Writer document, which is investigated.
2200     */
2201     bool ExistsDrawObjs( SwDoc& p_rDoc );
2202 
2203     /** method to check, if given Writer document contains only drawing objects,
2204         which are completely on its page.
2205 
2206         OD 2006-03-17 #i62875#
2207 
2208         @author OD
2209 
2210         @param p_rDoc
2211         input parameter - reference to the Writer document, which is investigated.
2212     */
2213     bool AllDrawObjsOnPage( SwDoc& p_rDoc );
2214 
2215     /** method to check, if the outline style has to written as a normal list style
2216 
2217         OD 2006-09-27 #i69627#
2218         The outline style has to written as a normal list style, if a parent
2219         paragraph style of one of the paragraph styles, which are assigned to
2220         the list levels of the outline style, has a list style set or inherits
2221         a list style from its parent paragraphs style.
2222         This information is needed for the OpenDocument file format export.
2223 
2224         @author OD
2225 
2226         @param rDoc
2227         input parameter - reference to the text document, which is investigated.
2228 
2229         @return boolean
2230         indicating, if the outline style has to written as a normal list style
2231     */
2232     bool HasOutlineStyleToBeWrittenAsNormalListStyle( SwDoc& rDoc );
2233 }
2234 // <--
2235 #endif	//_DOC_HXX
2236