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 _EDITSH_HXX 24 #define _EDITSH_HXX 25 26 #include <com/sun/star/text/HoriOrientation.hpp> 27 #include <com/sun/star/embed/XEmbeddedObject.hpp> 28 #include <tools/string.hxx> 29 #include <svl/svarray.hxx> 30 #include <vcl/font.hxx> 31 #include <editeng/swafopt.hxx> 32 #include "swdllapi.h" 33 #include <crsrsh.hxx> // fuer Basisklasse 34 #include <itabenum.hxx> 35 #include <swdbdata.hxx> 36 #include <com/sun/star/linguistic2/XSpellAlternatives.hpp> 37 #include <com/sun/star/linguistic2/ProofreadingResult.hpp> 38 #include <fldupde.hxx> 39 #include <tblenum.hxx> 40 #include <IMark.hxx> 41 42 #include <vector> 43 #include <swundo.hxx> 44 #include <svtools/embedhlp.hxx> 45 46 class PolyPolygon; 47 class SwDoc; 48 class DateTime; 49 class CommandExtTextInputData; 50 51 class SvUShortsSort; 52 class SvNumberFormatter; 53 class SfxPoolItem; 54 class SfxItemSet; 55 class SvxAutoCorrect; 56 57 class SwField; 58 class SwFieldType; 59 class SwDDEFieldType; 60 class SwNewDBMgr; 61 62 struct SwDocStat; 63 class SvStringsDtor; 64 class SvStringsSort; 65 class SwAutoCompleteWord; 66 67 class SwFmtRefMark; 68 69 class SwNumRule; // Numerierung 70 //class SwNodeNum; // Numerierung 71 72 class SwTxtFmtColl; 73 class SwGrfNode; 74 class SwFlyFrmFmt; 75 76 class SwFrmFmt; // fuer GetTxtNodeFmts() 77 class SwCharFmt; 78 class SwExtTextInput; 79 class SwRootFrm; // fuer CTOR 80 class Graphic; // fuer GetGraphic 81 class GraphicObject; // fuer GetGraphicObj 82 class SwFmtINetFmt; // InsertURL 83 class SwTable; 84 class SwTextBlocks; // fuer GlossaryRW 85 class SwFmtFtn; 86 class SwSection; 87 class SwSectionData; 88 class SwSectionFmt; 89 class SwTOXMarks; 90 class SwTOXBase; 91 class SwTOXType; 92 class SwTableAutoFmt; 93 class SwPageDesc; 94 class SwTxtINetFmt; 95 class SwSeqFldList; 96 class SwGlblDocContent; 97 class SwGlblDocContents; 98 class SwRedline; 99 class SwRedlineData; 100 class SwFtnInfo; 101 class SwEndNoteInfo; 102 class SwLineNumberInfo; 103 class SwAuthEntry; 104 class SwRewriter; 105 struct SwConversionArgs; 106 107 108 namespace com { namespace sun { namespace star { namespace uno { 109 template < class > class Sequence; 110 }}}} 111 112 namespace svx{ 113 struct SpellPortion; 114 typedef std::vector<SpellPortion> SpellPortions; 115 } 116 117 namespace sfx2{ 118 class LinkManager; 119 } 120 121 namespace sw { 122 class UndoRedoContext; 123 } 124 125 #define GETSELTXT_PARABRK_TO_BLANK 0 126 #define GETSELTXT_PARABRK_KEEP 1 127 #define GETSELTXT_PARABRK_TO_ONLYCR 2 128 129 /**************************************************************** 130 * zum Abfragen der INet-Attribute fuer den Navigator 131 ****************************************************************/ 132 struct SwGetINetAttr 133 { 134 String sText; 135 const SwTxtINetFmt& rINetAttr; 136 137 SwGetINetAttr( const String& rTxt, const SwTxtINetFmt& rAttr ) 138 : sText( rTxt ), rINetAttr( rAttr ) 139 {} 140 }; 141 SV_DECL_PTRARR_DEL( SwGetINetAttrs, SwGetINetAttr*, 0, 5 ) 142 143 /**************************************************************** 144 * Typen der Inhaltsformen 145 ****************************************************************/ 146 #define CNT_TXT 0x0001 147 #define CNT_GRF 0x0002 148 #define CNT_OLE 0x0010 149 /* Teste einen sal_uInt16 auf eine bestimmte Inhaltsform */ 150 #define CNT_HasTxt(USH) ((USH)&CNT_TXT) 151 #define CNT_HasGrf(USH) ((USH)&CNT_GRF) 152 #define CNT_HasOLE(USH) ((USH)&CNT_OLE) 153 154 class SW_DLLPUBLIC SwEditShell: public SwCrsrShell 155 { 156 static SvxSwAutoFmtFlags* pAutoFmtFlags; 157 158 // fuer die privaten Methoden DelRange und die vom AutoCorrect 159 friend class SwAutoFormat; 160 friend void _InitCore(); 161 friend void _FinitCore(); 162 // fuer die PamCorrAbs/-Rel Methoden 163 friend class SwUndo; 164 165 SW_DLLPRIVATE SfxPoolItem& _GetChrFmt( SfxPoolItem& ) const; 166 167 /* 168 * liefert einen Pointer auf einen SwGrfNode; dieser wird von 169 * GetGraphic() und GetGraphicSize() verwendet. 170 */ 171 SW_DLLPRIVATE SwGrfNode *_GetGrfNode() const ; 172 173 SW_DLLPRIVATE void DeleteSel( SwPaM& rPam, sal_Bool* pUndo = 0 ); 174 175 SW_DLLPRIVATE void _SetSectionAttr( SwSectionFmt& rSectFmt, const SfxItemSet& rSet ); 176 177 using ViewShell::UpdateFlds; 178 using SwModify::GetInfo; 179 180 public: 181 // Editieren (immer auf allen selektierten Bereichen) 182 void Insert( sal_Unicode, sal_Bool bOnlyCurrCrsr = sal_False ); 183 void Insert2( const String &, const bool bForceExpandHints = false ); 184 void Overwrite( const String & ); 185 186 // Ersetz einen selektierten Bereich in einem TextNode mit dem 187 // String. Ist fuers Suchen&Ersetzen gedacht. 188 // bRegExpRplc - ersetze Tabs (\\t) und setze den gefundenen String 189 // ein ( nicht \& ) 190 // z.B.: Fnd: "zzz", Repl: "xx\t\\t..&..\&" 191 // --> "xx\t<Tab>..zzz..&" 192 sal_Bool Replace( const String& rNewStr, sal_Bool bRegExpRplc = sal_False ); 193 194 // loescht den Inhalt aller Bereiche; 195 // werden ganze Nodes selektiert, werden die Nodes geloescht 196 long Delete(); 197 198 // remove a complete paragraph 199 sal_Bool DelFullPara(); 200 201 // change text to Upper/Lower/Hiragana/Katagana/... 202 void TransliterateText( sal_uInt32 nType ); 203 204 // count words in current selection 205 void CountWords( SwDocStat& rStat ) const; 206 207 // loesche den nicht sichtbaren Content aus dem Document, wie z.B.: 208 // versteckte Bereiche, versteckte Absaetze 209 sal_Bool RemoveInvisibleContent(); 210 211 // replace fields by text - mailmerge support 212 sal_Bool ConvertFieldsToText(); 213 // set all numbering start points to a fixed value - mailmerge support 214 void SetNumberingRestart(); 215 216 // embedded alle lokalen Links (Bereiche/Grafiken) 217 sal_uInt16 GetLinkUpdMode(sal_Bool bDocSettings = sal_False) const; 218 void SetLinkUpdMode( sal_uInt16 nMode ); 219 220 // kopiere den Inhalt aller Bereiche an die akt. Cursor-Position 221 // in die angegebene Shell 222 long Copy( SwEditShell* pDestShell = 0 ); 223 224 // fuers Kopieren uebers ClipBoard: 225 // wird Tabelle in Tabelle kopiert, verschiebe aus dieser dann 226 // alle Cursor. Copy und Paste muss aufgrund der FlyFrames in 227 // der FEShell stehen! 228 // kopiere alle Selectionen und das Doc 229 //JP 21.10.96: und fuer die SVX-Autokorrektur 230 sal_Bool _CopySelToDoc( SwDoc* pInsDoc, SwNodeIndex* pNdInsPos = 0 ); 231 232 long SplitNode( sal_Bool bAutoFormat = sal_False, sal_Bool bCheckTableStart = sal_True ); 233 sal_Bool AppendTxtNode(); 234 void AutoFmtBySplitNode(); 235 236 // ist der Cursor in einem INetAttribut, dann wird das komplett 237 // geloescht; inclusive des Hinweistextes (wird beim Drag&Drop gebraucht) 238 sal_Bool DelINetAttrWithText(); 239 240 // ist der Cursor am Ende einer Zeichenvorlage, an der das DontExpand-Flag 241 // noch nicht gesetzt ist, wird dies gesetzt ( => return sal_True; ) 242 sal_Bool DontExpandFmt(); 243 244 // Anwenden / Entfernen von Attributen 245 // liefert Attribute im angeforderten AttributSet. Wenn nicht eindeutig 246 // steht im Set ein DONT_CARE !! 247 // --> OD 2008-01-16 #newlistlevelattrs# 248 // Renaming method to <GetCurAttr(..)> indicating that the attributes at 249 // the current cursors are retrieved. 250 // Introduce 2nd optional parameter <bMergeIndentValuesOfNumRule>. 251 // If <bMergeIndentValuesOfNumRule> == sal_True, the indent attributes of 252 // the corresponding list level of an applied list style is merged into 253 // the requested item set as a LR-SPACE item, if corresponding node has not 254 // its own indent attributes and the position-and-space mode of the list 255 // level is SvxNumberFormat::LABEL_ALIGNMENT. 256 sal_Bool GetCurAttr( SfxItemSet& , 257 const bool bMergeIndentValuesOfNumRule = false ) const; 258 // <-- 259 void SetAttrItem( const SfxPoolItem&, sal_uInt16 nFlags = 0 ); 260 void SetAttrSet( const SfxItemSet&, sal_uInt16 nFlags = 0 ); 261 262 // Setze das Attribut als neues default Attribut im Dokument. 263 void SetDefault( const SfxPoolItem& ); 264 265 // Erfrage das Default Attribut vom Dokument. 266 const SfxPoolItem& GetDefault( sal_uInt16 nFmtHint ) const; 267 268 void ResetAttr( const SvUShortsSort* pAttrs = 0 ); 269 void GCAttr(); 270 271 // returns the scripttpye of the selection 272 sal_uInt16 GetScriptType() const; 273 274 // returns the language at current cursor position 275 sal_uInt16 GetCurLang() const; 276 277 // TABLE 278 sal_uInt16 GetTblFrmFmtCount( sal_Bool bUsed = sal_False ) const; 279 SwFrmFmt& GetTblFrmFmt(sal_uInt16 nFmt, sal_Bool bUsed = sal_False ) const; 280 String GetUniqueTblName() const; 281 282 // CHAR 283 sal_uInt16 GetCharFmtCount() const; 284 SwCharFmt& GetCharFmt(sal_uInt16 nFmt) const; 285 SwCharFmt* GetCurCharFmt() const; 286 void FillByEx(SwCharFmt*, sal_Bool bReset = sal_False); 287 SwCharFmt* MakeCharFmt( const String& rName, SwCharFmt* pDerivedFrom = 0 ); 288 SwCharFmt* FindCharFmtByName( const String& rName ) const; 289 290 291 /* Formatcollections, neu */ 292 /* GetXXXCount() liefert die Anzahl der im Dokument vorhandenen XXX 293 * GetXXX(i) liefert das i-te XXX (ERR_RAISE bei Ueberindizierung!) 294 * DelXXX(i) loescht das i-te XXX (ERR_RAISE bei Ueberindizierung!) 295 * GetCurXXX() liefert das am Cursor oder in den Bereichen 296 * geltende XXX (0, wenn nicht eindeutig!) 297 * SetXXX() setzt am Cursor oder in den Bereichen das XXX 298 * MakeXXX() macht ein XXX, abgeleitet vom pDerivedFrom 299 */ 300 301 // TXT 302 SwTxtFmtColl& GetDfltTxtFmtColl() const; 303 sal_uInt16 GetTxtFmtCollCount() const; 304 SwTxtFmtColl& GetTxtFmtColl( sal_uInt16 nTxtFmtColl) const; 305 SwTxtFmtColl* GetCurTxtFmtColl() const; 306 // --> OD 2007-11-06 #i62675# 307 // Add 2nd optional parameter <bResetListAttrs> - see also <SwDoc::SetTxtFmtColl(..)> 308 void SetTxtFmtColl( SwTxtFmtColl*, 309 bool bResetListAttrs = false ); 310 // <-- 311 SwTxtFmtColl *MakeTxtFmtColl(const String &rFmtCollName, 312 SwTxtFmtColl *pDerivedFrom = 0); 313 void FillByEx(SwTxtFmtColl*, sal_Bool bReset = sal_False); 314 SwTxtFmtColl* FindTxtFmtCollByName( const String& rName ) const; 315 316 // Gebe die "Auto-Collection" mit der Id zurueck. Existiert 317 // sie noch nicht, dann erzuege sie 318 SwTxtFmtColl* GetTxtCollFromPool( sal_uInt16 nId ); 319 // return das geforderte automatische Format - Basis-Klasse ! 320 SwFmt* GetFmtFromPool( sal_uInt16 nId ); 321 // returne die geforderte automatische Seiten-Vorlage 322 SwPageDesc* GetPageDescFromPool( sal_uInt16 nId ); 323 324 // erfrage ob die Absatz-/Zeichen-/Rahmen-/Seiten - Vorlage benutzt wird 325 sal_Bool IsUsed( const SwModify& ) const; 326 327 // returne das geforderte automatische Format 328 SwFrmFmt* GetFrmFmtFromPool( sal_uInt16 nId ) 329 { return (SwFrmFmt*)SwEditShell::GetFmtFromPool( nId ); } 330 SwCharFmt* GetCharFmtFromPool( sal_uInt16 nId ) 331 { return (SwCharFmt*)SwEditShell::GetFmtFromPool( nId ); } 332 333 // Felder 334 void Insert2(SwField&, const bool bForceExpandHints = false); 335 336 void UpdateFlds( SwField & ); // ein einzelnes Feld 337 338 sal_uInt16 GetFldTypeCount(sal_uInt16 nResId = USHRT_MAX, sal_Bool bUsed = sal_False) const; 339 SwFieldType* GetFldType(sal_uInt16 nId, sal_uInt16 nResId = USHRT_MAX, sal_Bool bUsed = sal_False) const; 340 SwFieldType* GetFldType(sal_uInt16 nResId, const String& rName) const; 341 342 void RemoveFldType(sal_uInt16 nId, sal_uInt16 nResId = USHRT_MAX); 343 void RemoveFldType(sal_uInt16 nResId, const String& rName); 344 345 void FieldToText( SwFieldType* pType ); 346 347 void ChangeAuthorityData(const SwAuthEntry* pNewData); 348 349 // Datenbankinfo 350 SwDBData GetDBData() const; 351 const SwDBData& GetDBDesc() const; 352 void ChgDBData(const SwDBData& SwDBData); 353 void ChangeDBFields( const SvStringsDtor& rOldNames, 354 const String& rNewName ); 355 void GetAllUsedDB( SvStringsDtor& rDBNameList, 356 SvStringsDtor* pAllDBNames = 0 ); 357 358 sal_Bool IsAnyDatabaseFieldInDoc()const; 359 //check whether DB fields point to an available data source and returns it 360 sal_Bool IsFieldDataSourceAvailable(String& rUsedDataSource) const; 361 void UpdateExpFlds(sal_Bool bCloseDB = sal_False);// nur alle ExpressionFelder updaten 362 void SetFixFields( sal_Bool bOnlyTimeDate = sal_False, 363 const DateTime* pNewDateTime = 0 ); 364 void LockExpFlds(); 365 void UnlockExpFlds(); 366 367 SwFldUpdateFlags GetFldUpdateFlags(sal_Bool bDocSettings = sal_False) const; 368 void SetFldUpdateFlags( SwFldUpdateFlags eFlags ); 369 370 // fuer die Evaluierung der DBFelder (neuer DB-Manager) 371 SwNewDBMgr* GetNewDBMgr() const; 372 373 SwFieldType* InsertFldType(const SwFieldType &); 374 375 // Aenderungen am Dokument? 376 sal_Bool IsModified() const; 377 void SetModified(); 378 void ResetModified(); 379 void SetUndoNoResetModified(); 380 381 // Dokument - Statistics 382 void UpdateDocStat( SwDocStat& rStat ); 383 384 // Verzeichnismarke einfuegen loeschen 385 void Insert(const SwTOXMark& rMark); 386 void DeleteTOXMark(SwTOXMark* pMark); 387 388 // Alle Markierungen am aktuellen SPoint ermitteln 389 sal_uInt16 GetCurTOXMarks(SwTOXMarks& rMarks) const ; 390 391 // Verzeichnis einfuegen, und bei Bedarf erneuern 392 void InsertTableOf(const SwTOXBase& rTOX, 393 const SfxItemSet* pSet = 0); 394 sal_Bool UpdateTableOf(const SwTOXBase& rTOX, 395 const SfxItemSet* pSet = 0); 396 const SwTOXBase* GetCurTOX() const; 397 const SwTOXBase* GetDefaultTOXBase( TOXTypes eTyp, sal_Bool bCreate = sal_False ); 398 void SetDefaultTOXBase(const SwTOXBase& rBase); 399 400 sal_Bool IsTOXBaseReadonly(const SwTOXBase& rTOXBase) const; 401 void SetTOXBaseReadonly(const SwTOXBase& rTOXBase, sal_Bool bReadonly); 402 403 sal_uInt16 GetTOXCount() const; 404 const SwTOXBase* GetTOX( sal_uInt16 nPos ) const; 405 sal_Bool DeleteTOX( const SwTOXBase& rTOXBase, sal_Bool bDelNodes = sal_False ); 406 407 // nach einlesen einer Datei alle Verzeichnisse updaten 408 void SetUpdateTOX( sal_Bool bFlag = sal_True ); 409 sal_Bool IsUpdateTOX() const; 410 411 // Verzeichnis-Typen verwalten 412 sal_uInt16 GetTOXTypeCount(TOXTypes eTyp) const; 413 const SwTOXType* GetTOXType(TOXTypes eTyp, sal_uInt16 nId) const; 414 void InsertTOXType(const SwTOXType& rTyp); 415 416 //AutoMark file 417 const String& GetTOIAutoMarkURL() const; 418 void SetTOIAutoMarkURL(const String& rSet); 419 void ApplyAutoMark(); 420 421 // Schluessel fuer die Indexverwaltung 422 sal_uInt16 GetTOIKeys( SwTOIKeyType eTyp, SvStringsSort& rArr ) const; 423 424 void SetOutlineNumRule(const SwNumRule&); 425 const SwNumRule* GetOutlineNumRule() const; 426 // Gliederung - hoch-/runterstufen 427 sal_Bool OutlineUpDown( short nOffset = 1 ); 428 // Gliederung - hoch-/runtermoven 429 sal_Bool MoveOutlinePara( short nOffset = 1); 430 // Outlines and SubOutline are protected ? 431 sal_Bool IsProtectedOutlinePara() const; 432 433 434 const SwNumRule* GetNumRuleAtCurrCrsrPos() const; 435 436 // Returns the numbering rule found at the paragraphs of the current selection, 437 // if all paragraphs of the current selection have the same or none numbering rule applied. 438 const SwNumRule* GetNumRuleAtCurrentSelection() const; 439 440 // Optional parameter <bResetIndentAttrs> (default value sal_False). 441 // If <bResetIndentAttrs> equals true, the indent attributes "before text" 442 // and "first line indent" are additionally reset at the current selection, 443 // if the list style makes use of the new list level attributes. 444 // Parameters <bCreateNewList> and <sContinuedListId> 445 // <bCreateNewList> indicates, if a new list is created by applying the given list style. 446 // If <bCreateNewList> equals false, <sContinuedListId> may contain the 447 // list Id of a list, which has to be continued by applying the given list style 448 void SetCurNumRule( const SwNumRule&, 449 const bool bCreateNewList /*= false*/, 450 const String sContinuedListId = String(), 451 const bool bResetIndentAttrs = false ); 452 453 // Absaetze ohne Numerierung, aber mit Einzuegen 454 sal_Bool NoNum(); 455 // Loeschen, Splitten der Aufzaehlungsliste 456 void DelNumRules(); 457 // Hoch-/Runterstufen 458 sal_Bool NumUpDown( sal_Bool bDown = sal_True ); 459 // Hoch-/Runtermoven sowohl innerhalb als auch ausserhalb von Numerierungen 460 sal_Bool MoveParagraph( long nOffset = 1 ); 461 sal_Bool MoveNumParas( sal_Bool bUpperLower, sal_Bool bUpperLeft ); 462 // No-/Numerierung ueber Delete/Backspace ein/abschalten #115901# 463 sal_Bool NumOrNoNum( sal_Bool bDelete = sal_False, sal_Bool bChkStart = sal_True ); 464 // -> #i23726# 465 466 void ChangeIndentOfAllListLevels( const short nDiff ); 467 void SetIndent(short nIndent, const SwPosition & rPos); 468 bool IsFirstOfNumRuleAtCrsrPos() const; 469 470 sal_Bool IsNoNum( sal_Bool bChkStart = sal_True ) const; 471 // returne den Num-Level des Nodes, in dem sich der Point vom 472 // Cursor befindet. Return kann sein : 473 // - NO_NUMBERING, 0..MAXLEVEL-1, NO_NUMLEVEL .. NO_NUMLEVEL|MAXLEVEL-1 474 sal_uInt8 GetNumLevel() const; 475 476 // detect highest and lowest level to check moving of outline levels 477 void GetCurrentOutlineLevels( sal_uInt8& rUpper, sal_uInt8& rLower ); 478 479 480 // get Outline level of current paragraph 481 int GetCurrentParaOutlineLevel( ) const;// #outlinelevel add by zhaojianwei 482 483 // -> i29560 484 sal_Bool HasNumber() const; 485 sal_Bool HasBullet() const; 486 // <- i29560 487 488 sal_Bool SelectionHasNumber() const; 489 sal_Bool SelectionHasBullet() const; 490 491 String GetUniqueNumRuleName( const String* pChkStr = 0, sal_Bool bAutoNum = sal_True ) const; 492 void ChgNumRuleFmts( const SwNumRule& rRule ); 493 // setze und erfrage, ob an aktueller PointPos eine Numerierung mit 494 // dem StartFlag startet 495 void SetNumRuleStart( sal_Bool bFlag = sal_True ); 496 sal_Bool IsNumRuleStart() const; 497 void SetNodeNumStart( sal_uInt16 nStt ); 498 // --> OD 2008-02-29 #refactorlists# 499 sal_uInt16 GetNodeNumStart() const; 500 // <-- 501 sal_Bool ReplaceNumRule( const String& rOldRule, const String& rNewRule ); 502 // Searches for a text node with a numbering rule. 503 // --> OD 2008-03-18 #refactorlists# - add output parameter <sListId> 504 // in case a list style is found, <sListId> holds the list id, to which the 505 // text node belongs, which applies the found list style. 506 const SwNumRule * SearchNumRule(const bool bForward, 507 const bool bNum, 508 const bool bOutline, 509 int nNonEmptyAllowed, 510 String& sListId ); 511 // <-- 512 513 // Undo 514 // UndoHistory am Dokument pflegen 515 // bei Save, SaveAs, Create wird UndoHistory zurueckgesetzt ??? 516 void DoUndo( sal_Bool bOn = sal_True ); 517 sal_Bool DoesUndo() const; 518 void DoGroupUndo( sal_Bool bUn = sal_True ); 519 sal_Bool DoesGroupUndo() const; 520 void DelAllUndoObj(); 521 522 // macht rueckgaengig: 523 // setzt Undoklammerung auf, liefert nUndoId der Klammerung 524 SwUndoId StartUndo( SwUndoId eUndoId = UNDO_EMPTY, const SwRewriter * pRewriter = 0 ); 525 // schliesst Klammerung der nUndoId, nicht vom UI benutzt 526 SwUndoId EndUndo( SwUndoId eUndoId = UNDO_EMPTY, const SwRewriter * pRewriter = 0 ); 527 528 bool GetLastUndoInfo(::rtl::OUString *const o_pStr, 529 SwUndoId *const o_pId) const; 530 bool GetFirstRedoInfo(::rtl::OUString *const o_pStr) const; 531 SwUndoId GetRepeatInfo(::rtl::OUString *const o_pStr) const; 532 533 /// is it forbidden to modify cursors via API calls? 534 bool CursorsLocked() const; 535 /// set selections to those contained in the UndoRedoContext 536 /// should only be called by sw::UndoManager! 537 void HandleUndoRedoContext(::sw::UndoRedoContext & rContext); 538 539 bool Undo(sal_uInt16 const nCount = 1); 540 bool Redo(sal_uInt16 const nCount = 1); 541 bool Repeat(sal_uInt16 const nCount); 542 543 // fuer alle Sichten auf dieses Dokument 544 void StartAllAction(); 545 void EndAllAction(); 546 547 //Damit Start-/EndActions aufgesetzt werden koennen. 548 void CalcLayout(); 549 550 // Inhaltsform bestimmen, holen, liefert Type am CurCrsr->SPoint 551 sal_uInt16 GetCntType() const; 552 sal_Bool HasOtherCnt() const; // gibt es Rahmen, Fussnoten, ... 553 554 /* Anwenden der ViewOptions mit Start-/EndAction */ 555 virtual void ApplyViewOptions( const SwViewOption &rOpt ); 556 557 // Text innerhalb der Selektion erfragen 558 // Returnwert liefert sal_False, wenn der selektierte Bereich 559 // zu gross ist, um in den Stringpuffer kopiert zu werden 560 // oder andere Fehler auftreten 561 sal_Bool GetSelectedText( String &rBuf, 562 int nHndlParaBreak = GETSELTXT_PARABRK_TO_BLANK ); 563 564 /* 565 * liefert eine Graphic, wenn CurCrsr->Point() auf einen 566 * SwGrfNode zeigt (und Mark nicht gesetzt ist oder auf die 567 * gleiche Graphic zeigt), sonst gibt's was auf die Finger 568 */ 569 // --> OD 2005-02-09 #119353# - robust 570 const Graphic* GetGraphic( sal_Bool bWait = sal_True ) const; 571 const GraphicObject* GetGraphicObj() const; 572 // <-- 573 sal_Bool IsGrfSwapOut( sal_Bool bOnlyLinked = sal_False ) const; 574 sal_uInt16 GetGraphicType() const; 575 576 const PolyPolygon *GetGraphicPolygon() const; 577 void SetGraphicPolygon( const PolyPolygon *pPoly ); 578 579 // If there's an automatic, not manipulated polygon at the selected 580 // notxtnode, it has to be deleted, e.g. cause the object has changed. 581 void ClearAutomaticContour(); 582 583 /* 584 * liefert die Groesse einer Graphic in Twips, wenn der Cursor 585 * auf einer Graphic steht; sal_Bool liefert sal_False, wenn s.o. 586 */ 587 sal_Bool GetGrfSize(Size&) const; 588 /* 589 * liefert den Namen und den Filter einer Graphic, wenn der Cursor 590 * auf einer Graphic steht, sonst gibt's was auf die Finger! 591 * Ist ein String-Ptr != 0 dann returne den entsp. Namen 592 */ 593 void GetGrfNms( String* pGrfName, String* pFltName, 594 const SwFlyFrmFmt* = 0 ) const; 595 /* 596 * erneutes Einlesen, falls Graphic nicht Ok ist. Die 597 * aktuelle wird durch die neue ersetzt. 598 */ 599 void ReRead( const String& rGrfName, const String& rFltName, 600 const Graphic* pGraphic = 0, 601 const GraphicObject* pGrafObj = 0 ); 602 603 // // alternativen Text einer Grafik/OLe-Objectes abfragen/setzen 604 // const String& GetAlternateText() const; 605 // void SetAlternateText( const String& rTxt ); 606 607 //eindeutige Identifikation des Objektes (fuer ImageMapDlg) 608 void *GetIMapInventor() const; 609 // --> OD 2007-03-01 #i73788# 610 // remove default parameter, because method always called this default value 611 Graphic GetIMapGraphic() const; //liefert eine Graphic fuer alle Flys! 612 // <-- 613 const SwFlyFrmFmt* FindFlyByName( const String& rName, sal_uInt8 nNdTyp = 0 ) const; 614 615 //liefert ein ClientObject, wenn CurCrsr->Point() auf einen 616 //SwOLENode zeigt (und Mark nicht gesetzt ist oder auf das 617 //gleiche ClientObject zeigt), sonst gibt's was auf die 618 //Finger. 619 svt::EmbeddedObjectRef& GetOLEObject() const; 620 //Gibt es ein OleObject mit diesem Namen (SwFmt)? 621 sal_Bool HasOLEObj( const String &rName ) const; 622 623 //Liefert den Pointer auf die Daten des Chart, indem sich der Crsr 624 //befindet. 625 void SetChartName( const String &rName ); 626 627 //Updaten der Inhalte aller Charts zu der Tabelle mit dem angegeben Namen 628 void UpdateCharts( const String &rName ); 629 630 // aktuelles Wort erfragen 631 String GetCurWord(); 632 633 // Textbaustein aus dem Textbausteindokument in 634 // das aktuelle Dokument, Vorlagen nur wenn es nicht schon gibt 635 void InsertGlossary( SwTextBlocks& rGlossary, const String& ); 636 // aktuelle Selektion zum Textbaustein machen und ins 637 // Textbausteindokument einfuegen, einschliesslich Vorlagen 638 sal_uInt16 MakeGlossary( SwTextBlocks& rToFill, const String& rName, 639 const String& rShortName, sal_Bool bSaveRelFile = sal_False, 640 const String* pOnlyTxt=0 ); 641 // speicher den gesamten Inhalt des Docs als Textbaustein 642 sal_uInt16 SaveGlossaryDoc( SwTextBlocks& rGlossary, const String& rName, 643 const String& rShortName, 644 sal_Bool bSaveRelFile = sal_False, 645 sal_Bool bOnlyTxt = sal_False ); 646 647 // Linguistik 648 // Selektionen sichern 649 void HyphStart( SwDocPositions eStart, SwDocPositions eEnde ); 650 // Selektionen wiederherstellen 651 void HyphEnd(); 652 com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface> 653 HyphContinue( sal_uInt16* pPageCnt, sal_uInt16* pPageSt ); 654 // zu trennendes Wort ignorieren 655 void HyphIgnore(); 656 657 // zum Einfuegen des SoftHyphens, Position ist der Offset 658 // innerhalb des getrennten Wortes. 659 void InsertSoftHyph( const xub_StrLen nHyphPos ); 660 661 //Tabelle 662 const SwTable& InsertTable( const SwInsertTableOptions& rInsTblOpts, // ALL_TBL_INS_ATTR 663 sal_uInt16 nRows, sal_uInt16 nCols, 664 sal_Int16 eAdj = com::sun::star::text::HoriOrientation::FULL, 665 const SwTableAutoFmt* pTAFmt = 0 ); 666 667 void InsertDDETable( const SwInsertTableOptions& rInsTblOpts, // HEADLINE_NO_BORDER 668 SwDDEFieldType* pDDEType, 669 sal_uInt16 nRows, sal_uInt16 nCols, 670 sal_Int16 eAdj = com::sun::star::text::HoriOrientation::FULL ); 671 672 void UpdateTable(); 673 void SetTableName( SwFrmFmt& rTblFmt, const String &rNewName ); 674 675 SwFrmFmt *GetTableFmt(); 676 sal_Bool TextToTable( const SwInsertTableOptions& rInsTblOpts, //ALL_TBL_INS_ATTR 677 sal_Unicode cCh, 678 sal_Int16 eAdj = com::sun::star::text::HoriOrientation::FULL, 679 const SwTableAutoFmt* pTAFmt = 0 ); 680 sal_Bool TableToText( sal_Unicode cCh ); 681 sal_Bool IsTextToTableAvailable() const; 682 683 sal_Bool GetTblBoxFormulaAttrs( SfxItemSet& rSet ) const; 684 void SetTblBoxFormulaAttrs( const SfxItemSet& rSet ); 685 686 sal_Bool IsTableBoxTextFormat() const; 687 String GetTableBoxText() const; 688 689 // Change Modus erfragen/setzen 690 TblChgMode GetTblChgMode() const; 691 void SetTblChgMode( TblChgMode eMode ); 692 693 // Tabelle an der Cursor Position aufsplitten 694 sal_Bool SplitTable( sal_uInt16 eMode ); 695 // Tabellen verbinden 696 // CanMerge kann feststellen, ob Prev oder Next moeglich ist. Wird 697 // der Pointer pChkNxtPrv uebergeben, wird festgestellt in welche 698 // Richtung es moeglich ist. 699 sal_Bool CanMergeTable( sal_Bool bWithPrev = sal_True, sal_Bool* pChkNxtPrv = 0 ) const; 700 sal_Bool MergeTable( sal_Bool bWithPrev = sal_True, sal_uInt16 nMode = 0 ); 701 // setze das InsertDB als Tabelle Undo auf: 702 void AppendUndoForInsertFromDB( sal_Bool bIsTable ); 703 704 /* 705 functions used for spell checking and text conversion 706 */ 707 708 // Selektionen sichern 709 void SpellStart( SwDocPositions eStart, SwDocPositions eEnde, 710 SwDocPositions eCurr, SwConversionArgs *pConvArgs = 0 ); 711 // Selektionen wiederherstellen 712 void SpellEnd( SwConversionArgs *pConvArgs = 0, bool bRestoreSelection = true ); 713 ::com::sun::star::uno::Any SpellContinue( 714 sal_uInt16* pPageCnt, sal_uInt16* pPageSt, 715 SwConversionArgs *pConvArgs = 0 ); 716 717 // spells on a sentence basis - the SpellPortions are needed 718 // returns false if no error could be found 719 bool SpellSentence(::svx::SpellPortions& rToFill, bool bIsGrammarCheck ); 720 // make SpellIter start with the current sentence when called next time 721 void PutSpellingToSentenceStart(); 722 // moves the continuation position to the end of the currently checked sentence 723 void MoveContinuationPosToEndOfCheckedSentence(); 724 //applies a changed sentence 725 void ApplyChangedSentence(const ::svx::SpellPortions& rNewPortions, bool bRecheck); 726 727 728 // check SwSpellIter data to see if the last sentence got grammar checked 729 bool HasLastSentenceGotGrammarChecked() const; 730 // Is text conversion active somewhere else? 731 sal_Bool HasConvIter() const; 732 // Is hyphenation active somewhere else? 733 sal_Bool HasHyphIter() const; 734 735 ::com::sun::star::uno::Reference< 736 ::com::sun::star::linguistic2::XSpellAlternatives > 737 GetCorrection( const Point* pPt, SwRect& rSelectRect ); 738 739 740 bool GetGrammarCorrection( ::com::sun::star::linguistic2::ProofreadingResult /*out*/ &rResult, 741 sal_Int32 /*out*/ &rErrorPosInText, 742 sal_Int32 /*out*/ &rErrorIndexInResult, 743 ::com::sun::star::uno::Sequence< rtl::OUString > /*out*/ &rSuggestions, 744 const Point* pPt, SwRect& rSelectRect ); 745 746 void IgnoreGrammarErrorAt( SwPaM& rErrorPosition ); 747 void SetLinguRange( SwDocPositions eStart, SwDocPositions eEnde ); 748 749 // returne zum Namen die im Doc gesetzte Referenz 750 const SwFmtRefMark* GetRefMark( const String& rName ) const; 751 // returne die Namen aller im Doc gesetzten Referenzen 752 // Ist der ArrayPointer 0 dann returne nur, ob im Doc. eine RefMark 753 // gesetzt ist 754 sal_uInt16 GetRefMarks( SvStringsDtor* = 0 ) const; 755 756 // rufe die Autokorrektur auf 757 void AutoCorrect( SvxAutoCorrect& rACorr, sal_Bool bInsertMode = sal_True, 758 sal_Unicode cChar = ' ' ); 759 sal_Bool GetPrevAutoCorrWord( SvxAutoCorrect& rACorr, String& rWord ); 760 761 // dann setze nach entsprechenden Regeln unsere Vorlagen 762 void AutoFormat( const SvxSwAutoFmtFlags* pAFlags = 0 ); 763 764 static SvxSwAutoFmtFlags* GetAutoFmtFlags(); 765 static void SetAutoFmtFlags(SvxSwAutoFmtFlags *); 766 767 // errechnet die Selektion 768 String Calculate(); 769 770 sal_Bool InsertURL( const SwFmtINetFmt& rFmt, const String& rStr, 771 sal_Bool bKeepSelection = sal_False ); 772 sal_uInt16 GetINetAttrs( SwGetINetAttrs& rArr ); 773 774 //SS Fuer holen/ersetzen DropCap-Inhalt 775 String GetDropTxt( const sal_uInt16 nChars ) const; 776 void ReplaceDropTxt( const String &rStr ); 777 778 // may an outline be moved or copied? 779 // Check whether it's in text body, not in table, and not read-only (move) 780 sal_Bool IsOutlineMovable( sal_uInt16 nIdx ) const; 781 sal_Bool IsOutlineCopyable( sal_uInt16 nIdx ) const; 782 783 sal_uInt16 GetLineCount( sal_Bool bActPos = sal_True ); 784 785 // erfrage und setze den Fussnoten-Text/Nummer. Set.. auf akt. SSelection! 786 sal_Bool GetCurFtn( SwFmtFtn* pToFillFtn = 0 ); 787 bool SetCurFtn( const SwFmtFtn& rFillFtn ); 788 bool HasFtns( bool bEndNotes = false ) const; 789 //z.Zt nicht benoetigt sal_uInt16 GetFtnCnt( sal_Bool bEndNotes = sal_False ) const; 790 // gebe Liste aller Fussnoten und deren Anfangstexte 791 sal_uInt16 GetSeqFtnList( SwSeqFldList& rList, bool bEndNotes = false ); 792 793 SwSection const* InsertSection( 794 SwSectionData & rNewData, SfxItemSet const*const = 0 ); 795 sal_Bool IsInsRegionAvailable() const; 796 const SwSection* GetCurrSection() const; 797 // liefert wie GetCurrSection() den aktuellen Bereich, allerdings geht diese Funktion 798 // ueber die Frames und erwischt dabei auch den Bereich, wenn der Cursor in einer 799 // Fussnote steht, deren Referenz in einem spaltigen Bereich steckt. 800 // Wenn man bOutOfTab setzt, wird der Bereich gesucht, 801 // der die Tabelle umfasst, nicht etwa ein innerer. 802 const SwSection* GetAnySection( sal_Bool bOutOfTab = sal_False, const Point* pPt = 0 ) const; 803 804 sal_uInt16 GetSectionFmtCount() const; 805 sal_uInt16 GetSectionFmtPos( const SwSectionFmt& ) const; 806 const SwSectionFmt& GetSectionFmt(sal_uInt16 nFmt) const; 807 void DelSectionFmt( sal_uInt16 nFmt ); 808 void UpdateSection(sal_uInt16 const nSect, SwSectionData &, 809 SfxItemSet const*const = 0); 810 sal_Bool IsAnySectionInDoc( sal_Bool bChkReadOnly = sal_False, 811 sal_Bool bChkHidden = sal_False, 812 sal_Bool BChkTOX = sal_False ) const; 813 814 String GetUniqueSectionName( const String* pChkStr = 0 ) const; 815 816 //Attribute setzen 817 void SetSectionAttr(const SfxItemSet& rSet, SwSectionFmt* pSectFmt = 0); 818 819 // search inside the cursor selection for full selected sections. 820 // if any part of section in the selection return 0. 821 // if more than one in the selection return the count 822 sal_uInt16 GetFullSelectedSectionCount() const; 823 824 // special insert: Insert a new text node just before or after a section or 825 // table, if the cursor is positioned at the start/end of said 826 // section/table. The purpose of the method is to allow users to inert text 827 // at certain 'impossible' position, e.g. before a table at the document 828 // start or between to sections. 829 bool DoSpecialInsert(); 830 bool CanSpecialInsert() const; 831 832 // Optimierung UI 833 void SetNewDoc(sal_Bool bNew = sal_True); 834 835 sfx2::LinkManager& GetLinkManager(); 836 inline const sfx2::LinkManager& GetLinkManager() const; 837 838 // linken Rand ueber Objectleiste einstellen (aenhlich dem Stufen von 839 // Numerierungen), optional kann man "um" den Offset stufen oder "auf" 840 // die Position gestuft werden (bModulus = sal_True) 841 sal_Bool IsMoveLeftMargin( sal_Bool bRight = sal_True, sal_Bool bModulus = sal_True ) const; 842 void MoveLeftMargin( sal_Bool bRight = sal_True, sal_Bool bModulus = sal_True ); 843 844 // Numberformatter vom Doc erfragen 845 SvNumberFormatter* GetNumberFormatter(); 846 const SvNumberFormatter* GetNumberFormatter() const 847 { return ((SwEditShell*)this)->GetNumberFormatter(); } 848 849 // Schnitstellen fuers GlobalDokument 850 sal_Bool IsGlobalDoc() const; 851 void SetGlblDocSaveLinks( sal_Bool bFlag = sal_True ); 852 sal_Bool IsGlblDocSaveLinks() const; 853 sal_uInt16 GetGlobalDocContent( SwGlblDocContents& rArr ) const; 854 sal_Bool InsertGlobalDocContent( const SwGlblDocContent& rPos, 855 SwSectionData & rNew ); 856 sal_Bool InsertGlobalDocContent( const SwGlblDocContent& rPos, 857 const SwTOXBase& rTOX ); 858 sal_Bool InsertGlobalDocContent( const SwGlblDocContent& rPos ); 859 sal_Bool DeleteGlobalDocContent( const SwGlblDocContents& rArr, 860 sal_uInt16 nPos ); 861 sal_Bool MoveGlobalDocContent( const SwGlblDocContents& rArr , 862 sal_uInt16 nFromPos, sal_uInt16 nToPos, 863 sal_uInt16 nNewPos ); 864 sal_Bool GotoGlobalDocContent( const SwGlblDocContent& rPos ); 865 866 // alles fuers Redlining 867 sal_uInt16 GetRedlineMode() const; 868 void SetRedlineMode( sal_uInt16 eMode ); 869 sal_Bool IsRedlineOn() const; 870 sal_uInt16 GetRedlineCount() const; 871 const SwRedline& GetRedline( sal_uInt16 nPos ) const; 872 sal_Bool AcceptRedline( sal_uInt16 nPos ); 873 sal_Bool RejectRedline( sal_uInt16 nPos ); 874 // suche das Redline zu diesem Data und returne die Pos im Array 875 // USHRT_MAX wird returnt, falls nicht vorhanden 876 sal_uInt16 FindRedlineOfData( const SwRedlineData& ) const; 877 878 // Kommentar am Redline an der Position setzen 879 sal_Bool SetRedlineComment( const String& rS ); 880 const SwRedline* GetCurrRedline() const; 881 882 // Redline Anzeigeattribute wurden geaendert, Views updaten 883 void UpdateRedlineAttr(); 884 885 // vergleiche zwei Dokument mit einander 886 long CompareDoc( const SwDoc& rDoc ); 887 // merge zweier Dokumente 888 long MergeDoc( const SwDoc& rDoc ); 889 890 // Dokumentglobale Fussnoteneigenschaften 891 const SwFtnInfo& GetFtnInfo() const; 892 void SetFtnInfo(const SwFtnInfo& rInfo); 893 const SwEndNoteInfo& GetEndNoteInfo() const; 894 void SetEndNoteInfo(const SwEndNoteInfo& rInfo); 895 896 //Einstellungen fuer Zeilennummierung 897 const SwLineNumberInfo &GetLineNumberInfo() const; 898 void SetLineNumberInfo( const SwLineNumberInfo& rInfo); 899 900 // Etiketten: Bereiche synchronisieren 901 void SetLabelDoc( sal_Bool bFlag = sal_True ); 902 sal_Bool IsLabelDoc() const; 903 904 // Schnittstelle fuer die TextInputDaten - ( fuer die Texteingabe 905 // von japanischen/chinesischen Zeichen) 906 SwExtTextInput* CreateExtTextInput(LanguageType eInputLanguage); 907 String DeleteExtTextInput( SwExtTextInput* pDel = 0, sal_Bool bInsText = sal_True); 908 // SwExtTextInput* GetExtTextInput() const; 909 void SetExtTextInputData( const CommandExtTextInputData& ); 910 911 // Schnistelle fuer den Zugriff auf die AutoComplete-Liste 912 static SwAutoCompleteWord& GetAutoCompleteWords(); 913 914 // returns a scaling factor of selected text. Used for the rotated 915 // character attribut dialog. 916 sal_uInt16 GetScalingOfSelectedText() const; 917 918 // ctor/dtor 919 SwEditShell( SwDoc&, Window*, const SwViewOption *pOpt = 0 ); 920 // verkleideter Copy-Constructor 921 SwEditShell( SwEditShell&, Window* ); 922 virtual ~SwEditShell(); 923 924 private: 925 // fuer METWARE: 926 // es wird nicht kopiert und nicht zugewiesen 927 SwEditShell(const SwEditShell &); 928 const SwEditShell &operator=(const SwEditShell &); 929 }; 930 931 inline const sfx2::LinkManager& SwEditShell::GetLinkManager() const 932 { return ((SwEditShell*)this)->GetLinkManager(); } 933 934 /* 935 * Klasse fuer den automatisierten Aufruf von Start- und 936 * EndAction(); 937 */ 938 class SwActKontext { 939 SwEditShell *pSh; 940 public: 941 SwActKontext(SwEditShell *pShell); 942 ~SwActKontext(); 943 }; 944 945 #define ACT_KONTEXT(x) SwActKontext _aActKontext_(x) 946 947 /* 948 * Klasse fuer den automatisierten Aufruf von Start- und 949 * EndCrsrMove(); 950 */ 951 class SwMvKontext { 952 SwEditShell *pSh; 953 public: 954 SwMvKontext(SwEditShell *pShell ); 955 ~SwMvKontext(); 956 }; 957 958 #define MV_KONTEXT(x) SwMvKontext _aMvKontext_(x) 959 960 961 962 #endif 963