xref: /trunk/main/sw/source/ui/wrtsh/select.cxx (revision ca62e2c2083b5d0995f1245bad6c2edfb455fbec)
1efeef26fSAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3efeef26fSAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4efeef26fSAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5efeef26fSAndrew Rist  * distributed with this work for additional information
6efeef26fSAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7efeef26fSAndrew Rist  * to you under the Apache License, Version 2.0 (the
8efeef26fSAndrew Rist  * "License"); you may not use this file except in compliance
9efeef26fSAndrew Rist  * with the License.  You may obtain a copy of the License at
10cdf0e10cSrcweir  *
11efeef26fSAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12cdf0e10cSrcweir  *
13efeef26fSAndrew Rist  * Unless required by applicable law or agreed to in writing,
14efeef26fSAndrew Rist  * software distributed under the License is distributed on an
15efeef26fSAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16efeef26fSAndrew Rist  * KIND, either express or implied.  See the License for the
17efeef26fSAndrew Rist  * specific language governing permissions and limitations
18efeef26fSAndrew Rist  * under the License.
19cdf0e10cSrcweir  *
20efeef26fSAndrew Rist  *************************************************************/
21efeef26fSAndrew Rist 
22efeef26fSAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
25cdf0e10cSrcweir #include "precompiled_sw.hxx"
26cdf0e10cSrcweir 
27cdf0e10cSrcweir 
28cdf0e10cSrcweir #include <limits.h>
29cdf0e10cSrcweir #include <hintids.hxx>
30cdf0e10cSrcweir #include <sfx2/bindings.hxx>
31cdf0e10cSrcweir #include <svl/eitem.hxx>
32cdf0e10cSrcweir #include <svl/macitem.hxx>
33cdf0e10cSrcweir #include <unotools/charclass.hxx>
34cdf0e10cSrcweir #include <editeng/scripttypeitem.hxx>
35cdf0e10cSrcweir #include <cmdid.h>
36cdf0e10cSrcweir #include <view.hxx>
37cdf0e10cSrcweir #include <basesh.hxx>
38cdf0e10cSrcweir #include <wrtsh.hxx>
39cdf0e10cSrcweir #include <frmatr.hxx>
40cdf0e10cSrcweir #include <initui.hxx>
41cdf0e10cSrcweir #include <mdiexp.hxx>
42cdf0e10cSrcweir #include <fmtcol.hxx>
43cdf0e10cSrcweir #include <frmfmt.hxx>
44cdf0e10cSrcweir #include <swundo.hxx>                   // fuer Undo-Ids
45cdf0e10cSrcweir #include <swevent.hxx>
46cdf0e10cSrcweir #include <swdtflvr.hxx>
47cdf0e10cSrcweir #include <crsskip.hxx>
48cdf0e10cSrcweir 
49*ca62e2c2SSteve Yin //IAccessibility2 Implementation 2009-----
50*ca62e2c2SSteve Yin #ifndef _DOC_HXX
51*ca62e2c2SSteve Yin #include <doc.hxx>
52*ca62e2c2SSteve Yin #endif
53*ca62e2c2SSteve Yin //-----IAccessibility2 Implementation 2009
54cdf0e10cSrcweir #if OSL_DEBUG_LEVEL > 1
55cdf0e10cSrcweir #include <pam.hxx>
56cdf0e10cSrcweir #endif
57cdf0e10cSrcweir 
58cdf0e10cSrcweir namespace com { namespace sun { namespace star { namespace util {
59cdf0e10cSrcweir     struct SearchOptions;
60cdf0e10cSrcweir } } } }
61cdf0e10cSrcweir 
62cdf0e10cSrcweir using namespace ::com::sun::star::util;
63cdf0e10cSrcweir 
64cdf0e10cSrcweir 
65cdf0e10cSrcweir static long nStartDragX = 0, nStartDragY = 0;
66cdf0e10cSrcweir static sal_Bool  bStartDrag = sal_False;
67cdf0e10cSrcweir 
68cdf0e10cSrcweir void SwWrtShell::Invalidate()
69cdf0e10cSrcweir {
70cdf0e10cSrcweir     // to avoid making the slot volatile, invalidate it everytime if something could have been changed
71cdf0e10cSrcweir     // this is still much cheaper than asking for the state every 200 ms (and avoid background processing)
72cdf0e10cSrcweir     GetView().GetViewFrame()->GetBindings().Invalidate( FN_STAT_SELMODE );
73cdf0e10cSrcweir }
74cdf0e10cSrcweir 
75cdf0e10cSrcweir sal_Bool SwWrtShell::SelNearestWrd()
76cdf0e10cSrcweir {
77cdf0e10cSrcweir     MV_KONTEXT(this);
78cdf0e10cSrcweir     if( !IsInWrd() && !IsEndWrd() && !IsSttWrd() )
79cdf0e10cSrcweir         PrvWrd();
80cdf0e10cSrcweir     if( IsEndWrd() )
81cdf0e10cSrcweir         Left(CRSR_SKIP_CELLS, sal_False, 1, sal_False );
82cdf0e10cSrcweir     return SelWrd();
83cdf0e10cSrcweir }
84cdf0e10cSrcweir 
85cdf0e10cSrcweir 
86cdf0e10cSrcweir 
87cdf0e10cSrcweir sal_Bool SwWrtShell::SelWrd(const Point *pPt, sal_Bool )
88cdf0e10cSrcweir {
89cdf0e10cSrcweir     sal_Bool bRet;
90cdf0e10cSrcweir     {
91cdf0e10cSrcweir         MV_KONTEXT(this);
92cdf0e10cSrcweir         SttSelect();
93cdf0e10cSrcweir         bRet = SwCrsrShell::SelectWord( pPt );
94cdf0e10cSrcweir     }
95cdf0e10cSrcweir     EndSelect();
96cdf0e10cSrcweir     if( bRet )
97cdf0e10cSrcweir     {
98cdf0e10cSrcweir         bSelWrd = sal_True;
99cdf0e10cSrcweir         if(pPt)
100cdf0e10cSrcweir             aStart = *pPt;
101cdf0e10cSrcweir     }
102cdf0e10cSrcweir     return bRet;
103cdf0e10cSrcweir }
104cdf0e10cSrcweir 
105cdf0e10cSrcweir void SwWrtShell::SelSentence(const Point *pPt, sal_Bool )
106cdf0e10cSrcweir {
107cdf0e10cSrcweir     {
108cdf0e10cSrcweir         MV_KONTEXT(this);
109cdf0e10cSrcweir         ClearMark();
110cdf0e10cSrcweir         SwCrsrShell::GoStartSentence();
111cdf0e10cSrcweir         SttSelect();
112cdf0e10cSrcweir         SwCrsrShell::GoEndSentence();
113cdf0e10cSrcweir     }
114cdf0e10cSrcweir     EndSelect();
115cdf0e10cSrcweir     if(pPt)
116cdf0e10cSrcweir         aStart = *pPt;
117cdf0e10cSrcweir     bSelLn = sal_True;
118cdf0e10cSrcweir     bSelWrd = sal_False;    // SelWord abschalten, sonst geht kein SelLine weiter
119cdf0e10cSrcweir }
120cdf0e10cSrcweir 
121cdf0e10cSrcweir void SwWrtShell::SelPara(const Point *pPt, sal_Bool )
122cdf0e10cSrcweir {
123cdf0e10cSrcweir     {
124cdf0e10cSrcweir         MV_KONTEXT(this);
125cdf0e10cSrcweir         ClearMark();
126cdf0e10cSrcweir         SwCrsrShell::MovePara( fnParaCurr, fnParaStart );
127cdf0e10cSrcweir         SttSelect();
128cdf0e10cSrcweir         SwCrsrShell::MovePara( fnParaCurr, fnParaEnd );
129cdf0e10cSrcweir     }
130cdf0e10cSrcweir     EndSelect();
131cdf0e10cSrcweir     if(pPt)
132cdf0e10cSrcweir         aStart = *pPt;
133cdf0e10cSrcweir     bSelLn = sal_False;
134cdf0e10cSrcweir     bSelWrd = sal_False;    // SelWord abschalten, sonst geht kein SelLine weiter
135cdf0e10cSrcweir }
136cdf0e10cSrcweir 
137cdf0e10cSrcweir 
138cdf0e10cSrcweir long SwWrtShell::SelAll()
139cdf0e10cSrcweir {
140cdf0e10cSrcweir     const sal_Bool bLockedView = IsViewLocked();
141cdf0e10cSrcweir     LockView( sal_True );
142cdf0e10cSrcweir     {
143cdf0e10cSrcweir         if(bBlockMode)
144cdf0e10cSrcweir             LeaveBlockMode();
145cdf0e10cSrcweir         MV_KONTEXT(this);
146cdf0e10cSrcweir         sal_Bool bMoveTable = sal_False;
147cdf0e10cSrcweir         SwPosition *pStartPos = 0;
148cdf0e10cSrcweir         SwPosition *pEndPos = 0;
149cdf0e10cSrcweir         SwShellCrsr* pTmpCrsr = 0;
150cdf0e10cSrcweir         if( !HasWholeTabSelection() )
151cdf0e10cSrcweir         {
152cdf0e10cSrcweir             if ( IsSelection() && IsCrsrPtAtEnd() )
153cdf0e10cSrcweir                 SwapPam();
154cdf0e10cSrcweir             pTmpCrsr = getShellCrsr( false );
155cdf0e10cSrcweir             if( pTmpCrsr )
156cdf0e10cSrcweir             {
157cdf0e10cSrcweir                 pStartPos = new SwPosition( *pTmpCrsr->GetPoint() );
158cdf0e10cSrcweir                 pEndPos = new SwPosition( *pTmpCrsr->GetMark() );
159cdf0e10cSrcweir             }
160cdf0e10cSrcweir             Push();
161cdf0e10cSrcweir             sal_Bool bIsFullSel = !MoveSection( fnSectionCurr, fnSectionStart);
162cdf0e10cSrcweir             SwapPam();
163cdf0e10cSrcweir             bIsFullSel &= !MoveSection( fnSectionCurr, fnSectionEnd);
164cdf0e10cSrcweir             Pop(sal_False);
165cdf0e10cSrcweir             GoStart(sal_True, &bMoveTable, sal_False, !bIsFullSel);
166cdf0e10cSrcweir         }
167cdf0e10cSrcweir         else
168cdf0e10cSrcweir         {
169cdf0e10cSrcweir             EnterStdMode();
170cdf0e10cSrcweir             SttEndDoc(sal_True);
171cdf0e10cSrcweir         }
172cdf0e10cSrcweir         SttSelect();
173cdf0e10cSrcweir         GoEnd(sal_True, &bMoveTable);
174*ca62e2c2SSteve Yin 
175*ca62e2c2SSteve Yin         //IAccessibility2 Implementation 2009-----
176*ca62e2c2SSteve Yin         SwDoc *pDoc = GetDoc();
177*ca62e2c2SSteve Yin         if ( pDoc )
178*ca62e2c2SSteve Yin         {
179*ca62e2c2SSteve Yin             pDoc->SetPrepareSelAll();
180*ca62e2c2SSteve Yin         }
181*ca62e2c2SSteve Yin         //-----IAccessibility2 Implementation 2009
182cdf0e10cSrcweir         if( pStartPos )
183cdf0e10cSrcweir         {
184cdf0e10cSrcweir             pTmpCrsr = getShellCrsr( false );
185cdf0e10cSrcweir             if( pTmpCrsr )
186cdf0e10cSrcweir             {
187cdf0e10cSrcweir                 // Some special handling for sections (e.g. TOC) at the beginning of the document body
188cdf0e10cSrcweir                 // to avoid the selection of the first section
189cdf0e10cSrcweir                 // if the last selection was behind the first section or
190cdf0e10cSrcweir                 // if the last selection was already the first section
191cdf0e10cSrcweir                 // In this both cases we select to the end of document
192cdf0e10cSrcweir                 if( *pTmpCrsr->GetPoint() < *pEndPos ||
193cdf0e10cSrcweir                     ( *pStartPos == *pTmpCrsr->GetMark() &&
194cdf0e10cSrcweir                       *pEndPos == *pTmpCrsr->GetPoint() ) )
195cdf0e10cSrcweir                     SwCrsrShell::SttEndDoc(sal_False);
196cdf0e10cSrcweir             }
197cdf0e10cSrcweir             delete pStartPos;
198cdf0e10cSrcweir             delete pEndPos;
199cdf0e10cSrcweir         }
200cdf0e10cSrcweir     }
201cdf0e10cSrcweir     EndSelect();
202cdf0e10cSrcweir     LockView( bLockedView );
203cdf0e10cSrcweir     return 1;
204cdf0e10cSrcweir }
205cdf0e10cSrcweir 
206cdf0e10cSrcweir /*------------------------------------------------------------------------
207cdf0e10cSrcweir  Beschreibung:  Textsuche
208cdf0e10cSrcweir ------------------------------------------------------------------------*/
209cdf0e10cSrcweir 
210cdf0e10cSrcweir 
211cdf0e10cSrcweir sal_uLong SwWrtShell::SearchPattern( const SearchOptions& rSearchOpt, sal_Bool bSearchInNotes,
212cdf0e10cSrcweir                                 SwDocPositions eStt, SwDocPositions eEnd,
213cdf0e10cSrcweir                                 FindRanges eFlags, int bReplace )
214cdf0e10cSrcweir {
215cdf0e10cSrcweir         // keine Erweiterung bestehender Selektionen
216cdf0e10cSrcweir     if(!(eFlags & FND_IN_SEL))
217cdf0e10cSrcweir         ClearMark();
218cdf0e10cSrcweir     sal_Bool bCancel = sal_False;
219cdf0e10cSrcweir     sal_uLong nRet = Find( rSearchOpt, bSearchInNotes, eStt, eEnd, bCancel, eFlags, bReplace );
220cdf0e10cSrcweir     if(bCancel)
221cdf0e10cSrcweir     {
222cdf0e10cSrcweir         Undo(1);
223cdf0e10cSrcweir         nRet = ULONG_MAX;
224cdf0e10cSrcweir     }
225cdf0e10cSrcweir     return nRet;
226cdf0e10cSrcweir }
227cdf0e10cSrcweir /*------------------------------------------------------------------------
228cdf0e10cSrcweir  Beschreibung:  Suche nach Vorlagen
229cdf0e10cSrcweir ------------------------------------------------------------------------*/
230cdf0e10cSrcweir 
231cdf0e10cSrcweir 
232cdf0e10cSrcweir 
233cdf0e10cSrcweir sal_uLong SwWrtShell::SearchTempl( const String &rTempl,
234cdf0e10cSrcweir                                SwDocPositions eStt, SwDocPositions eEnd,
235cdf0e10cSrcweir                                FindRanges eFlags, const String* pReplTempl )
236cdf0e10cSrcweir {
237cdf0e10cSrcweir         // keine Erweiterung bestehender Selektionen
238cdf0e10cSrcweir     if(!(eFlags & FND_IN_SEL))
239cdf0e10cSrcweir         ClearMark();
240cdf0e10cSrcweir     SwTxtFmtColl *pColl = GetParaStyle(rTempl, SwWrtShell::GETSTYLE_CREATESOME);
241cdf0e10cSrcweir     SwTxtFmtColl *pReplaceColl = 0;
242cdf0e10cSrcweir     if( pReplTempl )
243cdf0e10cSrcweir         pReplaceColl = GetParaStyle(*pReplTempl, SwWrtShell::GETSTYLE_CREATESOME );
244cdf0e10cSrcweir 
245cdf0e10cSrcweir     sal_Bool bCancel = sal_False;
246cdf0e10cSrcweir     sal_uLong nRet = Find(pColl? *pColl: GetDfltTxtFmtColl(),
247cdf0e10cSrcweir                                eStt,eEnd, bCancel, eFlags, pReplaceColl);
248cdf0e10cSrcweir     if(bCancel)
249cdf0e10cSrcweir     {
250cdf0e10cSrcweir         Undo(1);
251cdf0e10cSrcweir         nRet = ULONG_MAX;
252cdf0e10cSrcweir     }
253cdf0e10cSrcweir     return nRet;
254cdf0e10cSrcweir }
255cdf0e10cSrcweir 
256cdf0e10cSrcweir // Suche nach Attributen ----------------------------------------------------
257cdf0e10cSrcweir 
258cdf0e10cSrcweir 
259cdf0e10cSrcweir 
260cdf0e10cSrcweir sal_uLong SwWrtShell::SearchAttr( const SfxItemSet& rFindSet, sal_Bool bNoColls,
261cdf0e10cSrcweir                                 SwDocPositions eStart, SwDocPositions eEnde,
262cdf0e10cSrcweir                                 FindRanges eFlags, const SearchOptions* pSearchOpt,
263cdf0e10cSrcweir                                 const SfxItemSet* pReplaceSet )
264cdf0e10cSrcweir {
265cdf0e10cSrcweir     // Keine Erweiterung bestehender Selektionen
266cdf0e10cSrcweir     if (!(eFlags & FND_IN_SEL))
267cdf0e10cSrcweir         ClearMark();
268cdf0e10cSrcweir 
269cdf0e10cSrcweir     // Suchen
270cdf0e10cSrcweir     sal_Bool bCancel = sal_False;
271cdf0e10cSrcweir     sal_uLong nRet = Find( rFindSet, bNoColls, eStart, eEnde, bCancel, eFlags, pSearchOpt, pReplaceSet);
272cdf0e10cSrcweir 
273cdf0e10cSrcweir     if(bCancel)
274cdf0e10cSrcweir     {
275cdf0e10cSrcweir         Undo(1);
276cdf0e10cSrcweir         nRet = ULONG_MAX;
277cdf0e10cSrcweir     }
278cdf0e10cSrcweir     return nRet;
279cdf0e10cSrcweir }
280cdf0e10cSrcweir 
281cdf0e10cSrcweir // ---------- Selektionsmodi ----------
282cdf0e10cSrcweir 
283cdf0e10cSrcweir 
284cdf0e10cSrcweir 
285cdf0e10cSrcweir void SwWrtShell::PushMode()
286cdf0e10cSrcweir {
287cdf0e10cSrcweir     pModeStack = new ModeStack( pModeStack, bIns, bExtMode, bAddMode, bBlockMode );
288cdf0e10cSrcweir }
289cdf0e10cSrcweir 
290cdf0e10cSrcweir 
291cdf0e10cSrcweir 
292cdf0e10cSrcweir void SwWrtShell::PopMode()
293cdf0e10cSrcweir {
294cdf0e10cSrcweir     if ( 0 == pModeStack )
295cdf0e10cSrcweir         return;
296cdf0e10cSrcweir 
297cdf0e10cSrcweir     if ( bExtMode && !pModeStack->bExt )
298cdf0e10cSrcweir         LeaveExtMode();
299cdf0e10cSrcweir     if ( bAddMode && !pModeStack->bAdd )
300cdf0e10cSrcweir         LeaveAddMode();
301cdf0e10cSrcweir     if ( bBlockMode && !pModeStack->bBlock )
302cdf0e10cSrcweir         LeaveBlockMode();
303cdf0e10cSrcweir     bIns = pModeStack->bIns;
304cdf0e10cSrcweir 
305cdf0e10cSrcweir     ModeStack *pTmp = pModeStack->pNext;
306cdf0e10cSrcweir     delete pModeStack;
307cdf0e10cSrcweir     pModeStack = pTmp;
308cdf0e10cSrcweir }
309cdf0e10cSrcweir 
310cdf0e10cSrcweir /*
311cdf0e10cSrcweir  * Zwei Methoden fuer das Cursorsetzen; die erste mappt auf die
312cdf0e10cSrcweir  * gleichnamige Methoden an der CursorShell, die zweite hebt
313cdf0e10cSrcweir  * zuerst alle Selektionen auf.
314cdf0e10cSrcweir  */
315cdf0e10cSrcweir 
316cdf0e10cSrcweir 
317cdf0e10cSrcweir 
318cdf0e10cSrcweir long SwWrtShell::SetCrsr(const Point *pPt, sal_Bool bTextOnly)
319cdf0e10cSrcweir {
320cdf0e10cSrcweir         /*
321cdf0e10cSrcweir         * eine gfs.  bestehende Selektion an der Position des
322cdf0e10cSrcweir         * Mausklicks aufheben
323cdf0e10cSrcweir         */
324cdf0e10cSrcweir     if(!IsInSelect() && ChgCurrPam(*pPt)) {
325cdf0e10cSrcweir         ClearMark();
326cdf0e10cSrcweir     }
327cdf0e10cSrcweir 
328cdf0e10cSrcweir     return SwCrsrShell::SetCrsr(*pPt, bTextOnly);
329cdf0e10cSrcweir }
330cdf0e10cSrcweir 
331cdf0e10cSrcweir 
332cdf0e10cSrcweir long SwWrtShell::SetCrsrKillSel(const Point *pPt, sal_Bool bTextOnly )
333cdf0e10cSrcweir {
334cdf0e10cSrcweir     ACT_KONTEXT(this);
335cdf0e10cSrcweir     ResetSelect(pPt,sal_False);
336cdf0e10cSrcweir     return SwCrsrShell::SetCrsr(*pPt, bTextOnly);
337cdf0e10cSrcweir }
338cdf0e10cSrcweir 
339cdf0e10cSrcweir 
340cdf0e10cSrcweir 
341cdf0e10cSrcweir void SwWrtShell::UnSelectFrm()
342cdf0e10cSrcweir {
343cdf0e10cSrcweir     // Rahmenselektion aufheben mit garantiert ungueltiger Position
344cdf0e10cSrcweir     Point aPt(LONG_MIN, LONG_MIN);
345cdf0e10cSrcweir     SelectObj(aPt, 0);
346cdf0e10cSrcweir     SwTransferable::ClearSelection( *this );
347cdf0e10cSrcweir }
348cdf0e10cSrcweir 
349cdf0e10cSrcweir /*
350cdf0e10cSrcweir  * Aufheben aller Selektionen
351cdf0e10cSrcweir  */
352cdf0e10cSrcweir 
353cdf0e10cSrcweir 
354cdf0e10cSrcweir 
355cdf0e10cSrcweir long SwWrtShell::ResetSelect(const Point *,sal_Bool)
356cdf0e10cSrcweir {
357cdf0e10cSrcweir     if(IsSelFrmMode())
358cdf0e10cSrcweir     {
359cdf0e10cSrcweir         UnSelectFrm();
360cdf0e10cSrcweir         LeaveSelFrmMode();
361cdf0e10cSrcweir     }
362cdf0e10cSrcweir     else
363cdf0e10cSrcweir     {
364cdf0e10cSrcweir         /*  ACT_KONTEXT() macht eine Action auf -
365cdf0e10cSrcweir             um im Basicablauf keine Probleme mit der
366cdf0e10cSrcweir             Shellumschaltung zu bekommen, darf
367cdf0e10cSrcweir             GetChgLnk().Call() erst nach
368cdf0e10cSrcweir             EndAction() gerufen werden.
369cdf0e10cSrcweir         */
370cdf0e10cSrcweir         {
371cdf0e10cSrcweir             ACT_KONTEXT(this);
372cdf0e10cSrcweir             bSelWrd = bSelLn = sal_False;
373cdf0e10cSrcweir             KillPams();
374cdf0e10cSrcweir             ClearMark();
375cdf0e10cSrcweir             fnKillSel = &SwWrtShell::Ignore;
376cdf0e10cSrcweir             fnSetCrsr = &SwWrtShell::SetCrsr;
377cdf0e10cSrcweir         }
378cdf0e10cSrcweir         /*
379cdf0e10cSrcweir             * nach dem Aufheben aller Selektionen koennte ein Update der
380cdf0e10cSrcweir             * Attr-Controls notwendig sein.
381cdf0e10cSrcweir         */
382cdf0e10cSrcweir         GetChgLnk().Call(this);
383cdf0e10cSrcweir     }
384cdf0e10cSrcweir     Invalidate();
385cdf0e10cSrcweir     SwTransferable::ClearSelection( *this );
386cdf0e10cSrcweir     return 1;
387cdf0e10cSrcweir }
388cdf0e10cSrcweir 
389cdf0e10cSrcweir 
390cdf0e10cSrcweir 
391cdf0e10cSrcweir /*
392cdf0e10cSrcweir  * tue nichts
393cdf0e10cSrcweir  */
394cdf0e10cSrcweir long SwWrtShell::Ignore(const Point *, sal_Bool ) {
395cdf0e10cSrcweir     return 1;
396cdf0e10cSrcweir }
397cdf0e10cSrcweir 
398cdf0e10cSrcweir /*
399cdf0e10cSrcweir  * Start eines Selektionsvorganges.
400cdf0e10cSrcweir  */
401cdf0e10cSrcweir 
402cdf0e10cSrcweir 
403cdf0e10cSrcweir 
404cdf0e10cSrcweir void SwWrtShell::SttSelect()
405cdf0e10cSrcweir {
406cdf0e10cSrcweir     if(bInSelect)
407cdf0e10cSrcweir         return;
408cdf0e10cSrcweir     if(!HasMark())
409cdf0e10cSrcweir         SetMark();
410cdf0e10cSrcweir     if( bBlockMode )
411cdf0e10cSrcweir     {
412cdf0e10cSrcweir         SwShellCrsr* pTmp = getShellCrsr( true );
413cdf0e10cSrcweir         if( !pTmp->HasMark() )
414cdf0e10cSrcweir             pTmp->SetMark();
415cdf0e10cSrcweir     }
416cdf0e10cSrcweir     fnKillSel = &SwWrtShell::Ignore;
417cdf0e10cSrcweir     fnSetCrsr = &SwWrtShell::SetCrsr;
418cdf0e10cSrcweir     bInSelect = sal_True;
419cdf0e10cSrcweir     Invalidate();
420cdf0e10cSrcweir     SwTransferable::CreateSelection( *this );
421cdf0e10cSrcweir }
422cdf0e10cSrcweir /*
423cdf0e10cSrcweir  * Ende eines Selektionsvorganges.
424cdf0e10cSrcweir  */
425cdf0e10cSrcweir 
426cdf0e10cSrcweir 
427cdf0e10cSrcweir 
428cdf0e10cSrcweir void SwWrtShell::EndSelect()
429cdf0e10cSrcweir {
430cdf0e10cSrcweir     if(!bInSelect || bExtMode)
431cdf0e10cSrcweir         return;
432cdf0e10cSrcweir     bInSelect = sal_False;
433cdf0e10cSrcweir     (this->*fnLeaveSelect)(0,sal_False);
434cdf0e10cSrcweir     if(!bAddMode) {
435cdf0e10cSrcweir         fnSetCrsr = &SwWrtShell::SetCrsrKillSel;
436cdf0e10cSrcweir         fnKillSel = &SwWrtShell::ResetSelect;
437cdf0e10cSrcweir     }
438cdf0e10cSrcweir }
439cdf0e10cSrcweir /* Methode, um eine bestehende wortweise oder zeilenweise Selektion
440cdf0e10cSrcweir  * zu erweitern.
441cdf0e10cSrcweir  */
442cdf0e10cSrcweir 
443cdf0e10cSrcweir inline sal_Bool operator<(const Point &rP1,const Point &rP2)
444cdf0e10cSrcweir {
445cdf0e10cSrcweir     return rP1.Y() < rP2.Y() || (rP1.Y() == rP2.Y() && rP1.X() < rP2.X());
446cdf0e10cSrcweir }
447cdf0e10cSrcweir 
448cdf0e10cSrcweir 
449cdf0e10cSrcweir 
450cdf0e10cSrcweir long SwWrtShell::ExtSelWrd(const Point *pPt, sal_Bool )
451cdf0e10cSrcweir {
452cdf0e10cSrcweir     MV_KONTEXT(this);
453cdf0e10cSrcweir     if( IsTableMode() )
454cdf0e10cSrcweir         return 1;
455cdf0e10cSrcweir 
456cdf0e10cSrcweir     // Bug 66823: actual crsr has in additional mode no selection?
457cdf0e10cSrcweir     // Then destroy the actual an go to prev, this will be expand
458cdf0e10cSrcweir     if( !HasMark() && GoPrevCrsr() )
459cdf0e10cSrcweir     {
460cdf0e10cSrcweir         sal_Bool bHasMark = HasMark(); // thats wrong!
461cdf0e10cSrcweir         GoNextCrsr();
462cdf0e10cSrcweir         if( bHasMark )
463cdf0e10cSrcweir         {
464cdf0e10cSrcweir             DestroyCrsr();
465cdf0e10cSrcweir             GoPrevCrsr();
466cdf0e10cSrcweir         }
467cdf0e10cSrcweir     }
468cdf0e10cSrcweir 
469cdf0e10cSrcweir     // check the direction of the selection with the new point
470cdf0e10cSrcweir     sal_Bool bRet = sal_False, bMoveCrsr = sal_True, bToTop = sal_False;
471cdf0e10cSrcweir     SwCrsrShell::SelectWord( &aStart );     // select the startword
472cdf0e10cSrcweir     SwCrsrShell::Push();                    // save the cursor
473cdf0e10cSrcweir     SwCrsrShell::SetCrsr( *pPt );           // and check the direction
474cdf0e10cSrcweir 
475cdf0e10cSrcweir     switch( SwCrsrShell::CompareCursor( StackMkCurrPt ))
476cdf0e10cSrcweir     {
477cdf0e10cSrcweir     case -1:    bToTop = sal_False;     break;
478cdf0e10cSrcweir     case 1:     bToTop = sal_True;      break;
479cdf0e10cSrcweir     default:    bMoveCrsr = sal_False;  break;
480cdf0e10cSrcweir     }
481cdf0e10cSrcweir 
482cdf0e10cSrcweir     SwCrsrShell::Pop( sal_False );              // retore the saved cursor
483cdf0e10cSrcweir 
484cdf0e10cSrcweir     if( bMoveCrsr )
485cdf0e10cSrcweir     {
486cdf0e10cSrcweir         // select to Top but cursor select to Bottom? or
487cdf0e10cSrcweir         // select to Bottom but cursor select to Top?       --> swap the cursor
488cdf0e10cSrcweir         if( bToTop )
489cdf0e10cSrcweir             SwapPam();
490cdf0e10cSrcweir 
491cdf0e10cSrcweir         SwCrsrShell::Push();                // save cur cursor
492cdf0e10cSrcweir         if( SwCrsrShell::SelectWord( pPt )) // select the current word
493cdf0e10cSrcweir         {
494cdf0e10cSrcweir             if( bToTop )
495cdf0e10cSrcweir                 SwapPam();
496cdf0e10cSrcweir             Combine();
497cdf0e10cSrcweir             bRet = sal_True;
498cdf0e10cSrcweir         }
499cdf0e10cSrcweir         else
500cdf0e10cSrcweir         {
501cdf0e10cSrcweir             SwCrsrShell::Pop( sal_False );
502cdf0e10cSrcweir             if( bToTop )
503cdf0e10cSrcweir                 SwapPam();
504cdf0e10cSrcweir         }
505cdf0e10cSrcweir     }
506cdf0e10cSrcweir     else
507cdf0e10cSrcweir         bRet = sal_True;
508cdf0e10cSrcweir     return bRet;
509cdf0e10cSrcweir }
510cdf0e10cSrcweir 
511cdf0e10cSrcweir 
512cdf0e10cSrcweir long SwWrtShell::ExtSelLn(const Point *pPt, sal_Bool )
513cdf0e10cSrcweir {
514cdf0e10cSrcweir     MV_KONTEXT(this);
515cdf0e10cSrcweir     SwCrsrShell::SetCrsr(*pPt);
516cdf0e10cSrcweir     if( IsTableMode() )
517cdf0e10cSrcweir         return 1;
518cdf0e10cSrcweir 
519cdf0e10cSrcweir     // Bug 66823: actual crsr has in additional mode no selection?
520cdf0e10cSrcweir     // Then destroy the actual an go to prev, this will be expand
521cdf0e10cSrcweir     if( !HasMark() && GoPrevCrsr() )
522cdf0e10cSrcweir     {
523cdf0e10cSrcweir         sal_Bool bHasMark = HasMark(); // thats wrong!
524cdf0e10cSrcweir         GoNextCrsr();
525cdf0e10cSrcweir         if( bHasMark )
526cdf0e10cSrcweir         {
527cdf0e10cSrcweir             DestroyCrsr();
528cdf0e10cSrcweir             GoPrevCrsr();
529cdf0e10cSrcweir         }
530cdf0e10cSrcweir     }
531cdf0e10cSrcweir 
532cdf0e10cSrcweir     // ggfs. den Mark der Selektion anpassen
533cdf0e10cSrcweir     sal_Bool bToTop = !IsCrsrPtAtEnd();
534cdf0e10cSrcweir     SwapPam();
535cdf0e10cSrcweir 
536cdf0e10cSrcweir     // der "Mark" muss am Zeilenende/-anfang stehen
537cdf0e10cSrcweir     if( bToTop ? !IsEndSentence() : !IsStartSentence() )
538cdf0e10cSrcweir     {
539cdf0e10cSrcweir         if( bToTop )
540cdf0e10cSrcweir         {
541cdf0e10cSrcweir             if( !IsEndPara() )
542cdf0e10cSrcweir                 SwCrsrShell::Right(1,CRSR_SKIP_CHARS);
543cdf0e10cSrcweir             SwCrsrShell::GoEndSentence();
544cdf0e10cSrcweir         }
545cdf0e10cSrcweir         else
546cdf0e10cSrcweir             SwCrsrShell::GoStartSentence();
547cdf0e10cSrcweir     }
548cdf0e10cSrcweir     SwapPam();
549cdf0e10cSrcweir 
550cdf0e10cSrcweir     return bToTop ? SwCrsrShell::GoStartSentence() : SwCrsrShell::GoEndSentence();
551cdf0e10cSrcweir }
552cdf0e10cSrcweir 
553cdf0e10cSrcweir 
554cdf0e10cSrcweir /*
555cdf0e10cSrcweir  * zurueck in den Standard Mode: kein Mode, keine Selektionen.
556cdf0e10cSrcweir  */
557cdf0e10cSrcweir 
558cdf0e10cSrcweir void SwWrtShell::EnterStdMode()
559cdf0e10cSrcweir {
560cdf0e10cSrcweir     if(bAddMode)
561cdf0e10cSrcweir         LeaveAddMode();
562cdf0e10cSrcweir     if(bBlockMode)
563cdf0e10cSrcweir         LeaveBlockMode();
564cdf0e10cSrcweir     bBlockMode = sal_False;
565cdf0e10cSrcweir     bExtMode = sal_False;
566cdf0e10cSrcweir     bInSelect = sal_False;
567cdf0e10cSrcweir     if(IsSelFrmMode())
568cdf0e10cSrcweir     {
569cdf0e10cSrcweir         UnSelectFrm();
570cdf0e10cSrcweir         LeaveSelFrmMode();
571cdf0e10cSrcweir     }
572cdf0e10cSrcweir     else
573cdf0e10cSrcweir     {
574cdf0e10cSrcweir         /*  ACT_KONTEXT() opens and action which has to be
575cdf0e10cSrcweir             closed prior to the call of
576cdf0e10cSrcweir             GetChgLnk().Call()
577cdf0e10cSrcweir         */
578cdf0e10cSrcweir         {
579cdf0e10cSrcweir             ACT_KONTEXT(this);
580cdf0e10cSrcweir             bSelWrd = bSelLn = sal_False;
581cdf0e10cSrcweir             if( !IsRetainSelection() )
582cdf0e10cSrcweir                 KillPams();
583cdf0e10cSrcweir             ClearMark();
584cdf0e10cSrcweir             fnSetCrsr = &SwWrtShell::SetCrsrKillSel;
585cdf0e10cSrcweir             fnKillSel = &SwWrtShell::ResetSelect;
586cdf0e10cSrcweir         }
587cdf0e10cSrcweir     }
588cdf0e10cSrcweir     Invalidate();
589cdf0e10cSrcweir     SwTransferable::ClearSelection( *this );
590cdf0e10cSrcweir }
591cdf0e10cSrcweir 
592cdf0e10cSrcweir /*
593cdf0e10cSrcweir  * Extended Mode
594cdf0e10cSrcweir  */
595cdf0e10cSrcweir 
596cdf0e10cSrcweir 
597cdf0e10cSrcweir 
598cdf0e10cSrcweir void SwWrtShell::EnterExtMode()
599cdf0e10cSrcweir {
600cdf0e10cSrcweir     if(bBlockMode)
601cdf0e10cSrcweir     {
602cdf0e10cSrcweir         LeaveBlockMode();
603cdf0e10cSrcweir         KillPams();
604cdf0e10cSrcweir         ClearMark();
605cdf0e10cSrcweir     }
606cdf0e10cSrcweir     bExtMode = sal_True;
607cdf0e10cSrcweir     bAddMode = sal_False;
608cdf0e10cSrcweir     bBlockMode = sal_False;
609cdf0e10cSrcweir     SttSelect();
610cdf0e10cSrcweir }
611cdf0e10cSrcweir 
612cdf0e10cSrcweir 
613cdf0e10cSrcweir 
614cdf0e10cSrcweir void SwWrtShell::LeaveExtMode()
615cdf0e10cSrcweir {
616cdf0e10cSrcweir     bExtMode = sal_False;
617cdf0e10cSrcweir     EndSelect();
618cdf0e10cSrcweir }
619cdf0e10cSrcweir /*
620cdf0e10cSrcweir  * Ende einer Selektion; falls die Selektion leer ist,
621cdf0e10cSrcweir  * ClearMark().
622cdf0e10cSrcweir  */
623cdf0e10cSrcweir 
624cdf0e10cSrcweir 
625cdf0e10cSrcweir 
626cdf0e10cSrcweir long SwWrtShell::SttLeaveSelect(const Point *, sal_Bool )
627cdf0e10cSrcweir {
628cdf0e10cSrcweir     if(SwCrsrShell::HasSelection() && !IsSelTblCells() && bClearMark) {
629cdf0e10cSrcweir         return 0;
630cdf0e10cSrcweir     }
631cdf0e10cSrcweir //  if( IsSelTblCells() ) aSelTblLink.Call(this);
632cdf0e10cSrcweir     ClearMark();
633cdf0e10cSrcweir     return 1;
634cdf0e10cSrcweir }
635cdf0e10cSrcweir /*
636cdf0e10cSrcweir  * Verlassen des Selektionsmodus in Additional Mode
637cdf0e10cSrcweir  */
638cdf0e10cSrcweir 
639cdf0e10cSrcweir 
640cdf0e10cSrcweir 
641cdf0e10cSrcweir long SwWrtShell::AddLeaveSelect(const Point *, sal_Bool )
642cdf0e10cSrcweir {
643cdf0e10cSrcweir     if(IsTableMode()) LeaveAddMode();
644cdf0e10cSrcweir     else if(SwCrsrShell::HasSelection())
645cdf0e10cSrcweir         CreateCrsr();
646cdf0e10cSrcweir     return 1;
647cdf0e10cSrcweir }
648cdf0e10cSrcweir /*
649cdf0e10cSrcweir  * Additional Mode
650cdf0e10cSrcweir  */
651cdf0e10cSrcweir 
652cdf0e10cSrcweir 
653cdf0e10cSrcweir 
654cdf0e10cSrcweir void SwWrtShell::EnterAddMode()
655cdf0e10cSrcweir {
656cdf0e10cSrcweir     if(IsTableMode()) return;
657cdf0e10cSrcweir     if(bBlockMode)
658cdf0e10cSrcweir         LeaveBlockMode();
659cdf0e10cSrcweir     fnLeaveSelect = &SwWrtShell::AddLeaveSelect;
660cdf0e10cSrcweir     fnKillSel = &SwWrtShell::Ignore;
661cdf0e10cSrcweir     fnSetCrsr = &SwWrtShell::SetCrsr;
662cdf0e10cSrcweir     bAddMode = sal_True;
663cdf0e10cSrcweir     bBlockMode = sal_False;
664cdf0e10cSrcweir     bExtMode = sal_False;
665cdf0e10cSrcweir     if(SwCrsrShell::HasSelection())
666cdf0e10cSrcweir         CreateCrsr();
667cdf0e10cSrcweir     Invalidate();
668cdf0e10cSrcweir }
669cdf0e10cSrcweir 
670cdf0e10cSrcweir 
671cdf0e10cSrcweir 
672cdf0e10cSrcweir void SwWrtShell::LeaveAddMode()
673cdf0e10cSrcweir {
674cdf0e10cSrcweir     fnLeaveSelect = &SwWrtShell::SttLeaveSelect;
675cdf0e10cSrcweir     fnKillSel = &SwWrtShell::ResetSelect;
676cdf0e10cSrcweir     fnSetCrsr = &SwWrtShell::SetCrsrKillSel;
677cdf0e10cSrcweir     bAddMode = sal_False;
678cdf0e10cSrcweir     Invalidate();
679cdf0e10cSrcweir }
680cdf0e10cSrcweir 
681cdf0e10cSrcweir /*
682cdf0e10cSrcweir  * Block Mode
683cdf0e10cSrcweir  */
684cdf0e10cSrcweir 
685cdf0e10cSrcweir void SwWrtShell::EnterBlockMode()
686cdf0e10cSrcweir {
687cdf0e10cSrcweir     bBlockMode = sal_False;
688cdf0e10cSrcweir     EnterStdMode();
689cdf0e10cSrcweir     bBlockMode = sal_True;
690cdf0e10cSrcweir     CrsrToBlockCrsr();
691cdf0e10cSrcweir     Invalidate();
692cdf0e10cSrcweir }
693cdf0e10cSrcweir 
694cdf0e10cSrcweir 
695cdf0e10cSrcweir 
696cdf0e10cSrcweir void SwWrtShell::LeaveBlockMode()
697cdf0e10cSrcweir {
698cdf0e10cSrcweir     bBlockMode = sal_False;
699cdf0e10cSrcweir     BlockCrsrToCrsr();
700cdf0e10cSrcweir     EndSelect();
701cdf0e10cSrcweir     Invalidate();
702cdf0e10cSrcweir }
703cdf0e10cSrcweir 
704cdf0e10cSrcweir // Einfuegemodus
705cdf0e10cSrcweir 
706cdf0e10cSrcweir 
707cdf0e10cSrcweir 
708cdf0e10cSrcweir void SwWrtShell::SetInsMode( sal_Bool bOn )
709cdf0e10cSrcweir {
710cdf0e10cSrcweir     bIns = bOn;
711cdf0e10cSrcweir     SwCrsrShell::SetOverwriteCrsr( !bIns );
712cdf0e10cSrcweir     const SfxBoolItem aTmp( SID_ATTR_INSERT, bIns );
713cdf0e10cSrcweir     GetView().GetViewFrame()->GetBindings().SetState( aTmp );
714cdf0e10cSrcweir     StartAction();
715cdf0e10cSrcweir     EndAction();
716cdf0e10cSrcweir     Invalidate();
717cdf0e10cSrcweir }
718cdf0e10cSrcweir //Overwrite mode is incompatible with red-lining
719cdf0e10cSrcweir void SwWrtShell::SetRedlineModeAndCheckInsMode( sal_uInt16 eMode )
720cdf0e10cSrcweir {
721cdf0e10cSrcweir    SetRedlineMode( eMode );
722cdf0e10cSrcweir    if (IsRedlineOn())
723cdf0e10cSrcweir        SetInsMode( true );
724cdf0e10cSrcweir }
725cdf0e10cSrcweir 
726cdf0e10cSrcweir /*
727cdf0e10cSrcweir  * Rahmen bearbeiten
728cdf0e10cSrcweir  */
729cdf0e10cSrcweir 
730cdf0e10cSrcweir 
731cdf0e10cSrcweir long SwWrtShell::BeginFrmDrag(const Point *pPt, sal_Bool)
732cdf0e10cSrcweir {
733cdf0e10cSrcweir     fnDrag = &SwFEShell::Drag;
734cdf0e10cSrcweir     if(bStartDrag)
735cdf0e10cSrcweir     {
736cdf0e10cSrcweir         Point aTmp( nStartDragX, nStartDragY );
737cdf0e10cSrcweir         SwFEShell::BeginDrag( &aTmp, sal_False );
738cdf0e10cSrcweir     }
739cdf0e10cSrcweir     else
740cdf0e10cSrcweir         SwFEShell::BeginDrag( pPt, sal_False );
741cdf0e10cSrcweir     return 1;
742cdf0e10cSrcweir }
743cdf0e10cSrcweir 
744cdf0e10cSrcweir 
745cdf0e10cSrcweir 
746cdf0e10cSrcweir void SwWrtShell::EnterSelFrmMode(const Point *pPos)
747cdf0e10cSrcweir {
748cdf0e10cSrcweir     if(pPos)
749cdf0e10cSrcweir     {
750cdf0e10cSrcweir         nStartDragX = pPos->X();
751cdf0e10cSrcweir         nStartDragY = pPos->Y();
752cdf0e10cSrcweir         bStartDrag = sal_True;
753cdf0e10cSrcweir     }
754cdf0e10cSrcweir     bNoEdit = bLayoutMode = sal_True;
755cdf0e10cSrcweir     HideCrsr();
756cdf0e10cSrcweir 
757cdf0e10cSrcweir         // gleicher Aufruf von BeginDrag an der SwFEShell
758cdf0e10cSrcweir     fnDrag          = &SwWrtShell::BeginFrmDrag;
759cdf0e10cSrcweir     fnEndDrag       = &SwWrtShell::UpdateLayoutFrm;
760cdf0e10cSrcweir     SwBaseShell::SetFrmMode( FLY_DRAG_START, this );
761cdf0e10cSrcweir     Invalidate();
762cdf0e10cSrcweir }
763cdf0e10cSrcweir 
764cdf0e10cSrcweir 
765cdf0e10cSrcweir 
766cdf0e10cSrcweir void SwWrtShell::LeaveSelFrmMode()
767cdf0e10cSrcweir {
768cdf0e10cSrcweir     fnDrag          = &SwWrtShell::BeginDrag;
769cdf0e10cSrcweir     fnEndDrag       = &SwWrtShell::EndDrag;
770cdf0e10cSrcweir     bLayoutMode = sal_False;
771cdf0e10cSrcweir     bStartDrag = sal_False;
772cdf0e10cSrcweir     Edit();
773cdf0e10cSrcweir     SwBaseShell::SetFrmMode( FLY_DRAG_END, this );
774cdf0e10cSrcweir     Invalidate();
775cdf0e10cSrcweir }
776cdf0e10cSrcweir /*------------------------------------------------------------------------
777cdf0e10cSrcweir  Beschreibung:  Rahmengebundenes Macro ausfuehren
778cdf0e10cSrcweir ------------------------------------------------------------------------*/
779cdf0e10cSrcweir 
780cdf0e10cSrcweir 
781cdf0e10cSrcweir 
782cdf0e10cSrcweir IMPL_LINK( SwWrtShell, ExecFlyMac, void *, pFlyFmt )
783cdf0e10cSrcweir {
784cdf0e10cSrcweir     const SwFrmFmt *pFmt = pFlyFmt ? (SwFrmFmt*)pFlyFmt : GetFlyFrmFmt();
785cdf0e10cSrcweir     ASSERT(pFmt, kein FrameFormat.);
786cdf0e10cSrcweir     const SvxMacroItem &rFmtMac = pFmt->GetMacro();
787cdf0e10cSrcweir 
788cdf0e10cSrcweir     if(rFmtMac.HasMacro(SW_EVENT_OBJECT_SELECT))
789cdf0e10cSrcweir     {
790cdf0e10cSrcweir         const SvxMacro &rMac = rFmtMac.GetMacro(SW_EVENT_OBJECT_SELECT);
791cdf0e10cSrcweir         if( IsFrmSelected() )
792cdf0e10cSrcweir             bLayoutMode = sal_True;
793cdf0e10cSrcweir         CallChgLnk();
794cdf0e10cSrcweir         ExecMacro( rMac );
795cdf0e10cSrcweir     }
796cdf0e10cSrcweir     return 0;
797cdf0e10cSrcweir }
798cdf0e10cSrcweir 
799cdf0e10cSrcweir 
800cdf0e10cSrcweir 
801cdf0e10cSrcweir long SwWrtShell::UpdateLayoutFrm(const Point *pPt, sal_Bool )
802cdf0e10cSrcweir {
803cdf0e10cSrcweir         // voerst Dummy
804cdf0e10cSrcweir     SwFEShell::EndDrag( pPt, sal_False );
805cdf0e10cSrcweir     fnDrag = &SwWrtShell::BeginFrmDrag;
806cdf0e10cSrcweir     return 1;
807cdf0e10cSrcweir }
808cdf0e10cSrcweir 
809cdf0e10cSrcweir /*
810cdf0e10cSrcweir  * Handler fuer das Togglen der Modi. Liefern alten Mode zurueck.
811cdf0e10cSrcweir  */
812cdf0e10cSrcweir 
813cdf0e10cSrcweir 
814cdf0e10cSrcweir 
815cdf0e10cSrcweir long SwWrtShell::ToggleAddMode()
816cdf0e10cSrcweir {
817cdf0e10cSrcweir     bAddMode ? LeaveAddMode(): EnterAddMode();
818cdf0e10cSrcweir     Invalidate();
819cdf0e10cSrcweir     return !bAddMode;
820cdf0e10cSrcweir }
821cdf0e10cSrcweir 
822cdf0e10cSrcweir 
823cdf0e10cSrcweir long SwWrtShell::ToggleBlockMode()
824cdf0e10cSrcweir {
825cdf0e10cSrcweir     bBlockMode ? LeaveBlockMode(): EnterBlockMode();
826cdf0e10cSrcweir     Invalidate();
827cdf0e10cSrcweir     return !bBlockMode;
828cdf0e10cSrcweir }
829cdf0e10cSrcweir 
830cdf0e10cSrcweir 
831cdf0e10cSrcweir long SwWrtShell::ToggleExtMode()
832cdf0e10cSrcweir {
833cdf0e10cSrcweir     bExtMode ? LeaveExtMode() : EnterExtMode();
834cdf0e10cSrcweir     Invalidate();
835cdf0e10cSrcweir     return !bExtMode;
836cdf0e10cSrcweir }
837cdf0e10cSrcweir /*
838cdf0e10cSrcweir  * Draggen im Standard Modus (Selektieren von Inhalt)
839cdf0e10cSrcweir  */
840cdf0e10cSrcweir 
841cdf0e10cSrcweir 
842cdf0e10cSrcweir 
843cdf0e10cSrcweir long SwWrtShell::BeginDrag(const Point * /*pPt*/, sal_Bool )
844cdf0e10cSrcweir {
845cdf0e10cSrcweir     if(bSelWrd)
846cdf0e10cSrcweir     {
847cdf0e10cSrcweir         bInSelect = sal_True;
848cdf0e10cSrcweir         if( !IsCrsrPtAtEnd() )
849cdf0e10cSrcweir             SwapPam();
850cdf0e10cSrcweir 
851cdf0e10cSrcweir         fnDrag = &SwWrtShell::ExtSelWrd;
852cdf0e10cSrcweir         fnSetCrsr = &SwWrtShell::Ignore;
853cdf0e10cSrcweir     }
854cdf0e10cSrcweir     else if(bSelLn)
855cdf0e10cSrcweir     {
856cdf0e10cSrcweir         bInSelect = sal_True;
857cdf0e10cSrcweir         fnDrag = &SwWrtShell::ExtSelLn;
858cdf0e10cSrcweir         fnSetCrsr = &SwWrtShell::Ignore;
859cdf0e10cSrcweir     }
860cdf0e10cSrcweir     else
861cdf0e10cSrcweir     {
862cdf0e10cSrcweir         fnDrag = &SwWrtShell::Drag;
863cdf0e10cSrcweir         SttSelect();
864cdf0e10cSrcweir     }
865cdf0e10cSrcweir 
866cdf0e10cSrcweir     return 1;
867cdf0e10cSrcweir }
868cdf0e10cSrcweir 
869cdf0e10cSrcweir 
870cdf0e10cSrcweir 
871cdf0e10cSrcweir long SwWrtShell::Drag(const Point *, sal_Bool )
872cdf0e10cSrcweir {
873cdf0e10cSrcweir     if( IsSelTblCells() )
874cdf0e10cSrcweir         aSelTblLink.Call(this);
875cdf0e10cSrcweir 
876cdf0e10cSrcweir     return 1;
877cdf0e10cSrcweir }
878cdf0e10cSrcweir 
879cdf0e10cSrcweir 
880cdf0e10cSrcweir 
881cdf0e10cSrcweir long SwWrtShell::EndDrag(const Point * /*pPt*/, sal_Bool )
882cdf0e10cSrcweir {
883cdf0e10cSrcweir     fnDrag = &SwWrtShell::BeginDrag;
884cdf0e10cSrcweir     if( IsExtSel() )
885cdf0e10cSrcweir         LeaveExtSel();
886cdf0e10cSrcweir 
887cdf0e10cSrcweir     if( IsSelTblCells() )
888cdf0e10cSrcweir         aSelTblLink.Call(this);
889cdf0e10cSrcweir     EndSelect();
890cdf0e10cSrcweir     return 1;
891cdf0e10cSrcweir }
892cdf0e10cSrcweir 
893cdf0e10cSrcweir // --> FME 2004-07-30 #i32329# Enhanced table selection
894cdf0e10cSrcweir sal_Bool SwWrtShell::SelectTableRowCol( const Point& rPt, const Point* pEnd, bool bRowDrag )
895cdf0e10cSrcweir {
896cdf0e10cSrcweir     MV_KONTEXT(this);
897cdf0e10cSrcweir     SttSelect();
898cdf0e10cSrcweir     if(SelTblRowCol( rPt, pEnd, bRowDrag ))
899cdf0e10cSrcweir     {
900cdf0e10cSrcweir         fnSetCrsr = &SwWrtShell::SetCrsrKillSel;
901cdf0e10cSrcweir         fnKillSel = &SwWrtShell::ResetSelect;
902cdf0e10cSrcweir         return sal_True;
903cdf0e10cSrcweir     }
904cdf0e10cSrcweir     return sal_False;
905cdf0e10cSrcweir }
906cdf0e10cSrcweir // <--
907cdf0e10cSrcweir 
908cdf0e10cSrcweir /*------------------------------------------------------------------------
909cdf0e10cSrcweir  Beschreibung:  Selektion einer Tabellenzeile / Spalte
910cdf0e10cSrcweir ------------------------------------------------------------------------*/
911cdf0e10cSrcweir 
912cdf0e10cSrcweir sal_Bool SwWrtShell::SelectTableRow()
913cdf0e10cSrcweir {
914cdf0e10cSrcweir     if ( SelTblRow() )
915cdf0e10cSrcweir     {
916cdf0e10cSrcweir         fnSetCrsr = &SwWrtShell::SetCrsrKillSel;
917cdf0e10cSrcweir         fnKillSel = &SwWrtShell::ResetSelect;
918cdf0e10cSrcweir         return sal_True;
919cdf0e10cSrcweir     }
920cdf0e10cSrcweir     return sal_False;
921cdf0e10cSrcweir }
922cdf0e10cSrcweir 
923cdf0e10cSrcweir 
924cdf0e10cSrcweir 
925cdf0e10cSrcweir sal_Bool SwWrtShell::SelectTableCol()
926cdf0e10cSrcweir {
927cdf0e10cSrcweir     if ( SelTblCol() )
928cdf0e10cSrcweir     {
929cdf0e10cSrcweir         fnSetCrsr = &SwWrtShell::SetCrsrKillSel;
930cdf0e10cSrcweir         fnKillSel = &SwWrtShell::ResetSelect;
931cdf0e10cSrcweir         return sal_True;
932cdf0e10cSrcweir     }
933cdf0e10cSrcweir     return sal_False;
934cdf0e10cSrcweir }
935cdf0e10cSrcweir 
936cdf0e10cSrcweir sal_Bool SwWrtShell::SelectTableCell()
937cdf0e10cSrcweir {
938cdf0e10cSrcweir     if ( SelTblBox() )
939cdf0e10cSrcweir     {
940cdf0e10cSrcweir         fnSetCrsr = &SwWrtShell::SetCrsrKillSel;
941cdf0e10cSrcweir         fnKillSel = &SwWrtShell::ResetSelect;
942cdf0e10cSrcweir         return sal_True;
943cdf0e10cSrcweir     }
944cdf0e10cSrcweir     return sal_False;
945cdf0e10cSrcweir }
946cdf0e10cSrcweir /*------------------------------------------------------------------------
947cdf0e10cSrcweir  Beschreibung:    Prueft, ob eine Wortselektion vorliegt.
948cdf0e10cSrcweir                   Gemaess den Regeln fuer intelligentes Cut / Paste
949cdf0e10cSrcweir                   werden umgebende Spaces rausgeschnitten.
950cdf0e10cSrcweir  Return:          Liefert Art der Wortselektion zurueck.
951cdf0e10cSrcweir ------------------------------------------------------------------------*/
952cdf0e10cSrcweir 
953cdf0e10cSrcweir 
954cdf0e10cSrcweir 
955cdf0e10cSrcweir int SwWrtShell::IntelligentCut(int nSelection, sal_Bool bCut)
956cdf0e10cSrcweir {
957cdf0e10cSrcweir         // kein intelligentes Drag and Drop bei Mehrfachselektion
958cdf0e10cSrcweir         // es existieren mehrere Cursor, da ein zweiter bereits
959cdf0e10cSrcweir         // an die Zielposition gesetzt wurde
960cdf0e10cSrcweir     if( IsAddMode() || !(nSelection & nsSelectionType::SEL_TXT) )
961cdf0e10cSrcweir         return sal_False;
962cdf0e10cSrcweir 
963cdf0e10cSrcweir     String sTxt;
964cdf0e10cSrcweir     CharClass& rCC = GetAppCharClass();
965cdf0e10cSrcweir 
966cdf0e10cSrcweir         // wenn das erste und das letzte Zeichen kein Wortzeichen ist,
967cdf0e10cSrcweir         // ist kein Wort selektiert.
968cdf0e10cSrcweir     sal_Unicode cPrev = GetChar(sal_False);
969cdf0e10cSrcweir     sal_Unicode cNext = GetChar(sal_True, -1);
970cdf0e10cSrcweir     if( !cPrev || !cNext ||
971cdf0e10cSrcweir         !rCC.isLetterNumeric( ( sTxt = cPrev), 0 ) ||
972cdf0e10cSrcweir         !rCC.isLetterNumeric( ( sTxt = cNext), 0 ) )
973cdf0e10cSrcweir         return NO_WORD;
974cdf0e10cSrcweir 
975cdf0e10cSrcweir     cPrev = GetChar(sal_False, -1);
976cdf0e10cSrcweir     cNext = GetChar(sal_True);
977cdf0e10cSrcweir 
978cdf0e10cSrcweir     int cWord = NO_WORD;
979cdf0e10cSrcweir         // ist ein Wort selektiert?
980cdf0e10cSrcweir     if(!cWord && cPrev && cNext &&
981cdf0e10cSrcweir         CH_TXTATR_BREAKWORD != cPrev && CH_TXTATR_INWORD != cPrev &&
982cdf0e10cSrcweir         CH_TXTATR_BREAKWORD != cNext && CH_TXTATR_INWORD != cNext &&
983cdf0e10cSrcweir         !rCC.isLetterNumeric( ( sTxt = cPrev), 0 ) &&
984cdf0e10cSrcweir         !rCC.isLetterNumeric( ( sTxt = cNext), 0 ) )
985cdf0e10cSrcweir        cWord = WORD_NO_SPACE;
986cdf0e10cSrcweir 
987cdf0e10cSrcweir     if(cWord == WORD_NO_SPACE && ' ' == cPrev )
988cdf0e10cSrcweir     {
989cdf0e10cSrcweir         cWord = WORD_SPACE_BEFORE;
990cdf0e10cSrcweir             // Space davor loeschen
991cdf0e10cSrcweir         if(bCut)
992cdf0e10cSrcweir         {
993cdf0e10cSrcweir             Push();
994cdf0e10cSrcweir             if(IsCrsrPtAtEnd())
995cdf0e10cSrcweir                 SwapPam();
996cdf0e10cSrcweir             ClearMark();
997cdf0e10cSrcweir             SetMark();
998cdf0e10cSrcweir             SwCrsrShell::Left(1,CRSR_SKIP_CHARS);
999cdf0e10cSrcweir             SwFEShell::Delete();
1000cdf0e10cSrcweir             Pop( sal_False );
1001cdf0e10cSrcweir         }
1002cdf0e10cSrcweir     }
1003cdf0e10cSrcweir     else if(cWord == WORD_NO_SPACE && cNext == ' ')
1004cdf0e10cSrcweir     {
1005cdf0e10cSrcweir         cWord = WORD_SPACE_AFTER;
1006cdf0e10cSrcweir             // Space dahinter loeschen
1007cdf0e10cSrcweir         if(bCut) {
1008cdf0e10cSrcweir             Push();
1009cdf0e10cSrcweir             if(!IsCrsrPtAtEnd()) SwapPam();
1010cdf0e10cSrcweir             ClearMark();
1011cdf0e10cSrcweir             SetMark();
1012cdf0e10cSrcweir             SwCrsrShell::Right(1,CRSR_SKIP_CHARS);
1013cdf0e10cSrcweir             SwFEShell::Delete();
1014cdf0e10cSrcweir             Pop( sal_False );
1015cdf0e10cSrcweir         }
1016cdf0e10cSrcweir     }
1017cdf0e10cSrcweir     return cWord;
1018cdf0e10cSrcweir }
1019cdf0e10cSrcweir 
1020cdf0e10cSrcweir 
1021cdf0e10cSrcweir 
1022cdf0e10cSrcweir     // jump to the next / previous hyperlink - inside text and also
1023cdf0e10cSrcweir     // on graphics
1024cdf0e10cSrcweir sal_Bool SwWrtShell::SelectNextPrevHyperlink( sal_Bool bNext )
1025cdf0e10cSrcweir {
1026cdf0e10cSrcweir     StartAction();
1027cdf0e10cSrcweir     sal_Bool bRet = SwCrsrShell::SelectNxtPrvHyperlink( bNext );
1028cdf0e10cSrcweir     if( !bRet )
1029cdf0e10cSrcweir     {
1030cdf0e10cSrcweir         // will we have this feature?
1031cdf0e10cSrcweir         EnterStdMode();
1032cdf0e10cSrcweir         if( bNext )
1033cdf0e10cSrcweir             SttEndDoc(sal_True);
1034cdf0e10cSrcweir         else
1035cdf0e10cSrcweir             SttEndDoc(sal_False);
1036cdf0e10cSrcweir         bRet = SwCrsrShell::SelectNxtPrvHyperlink( bNext );
1037cdf0e10cSrcweir     }
1038cdf0e10cSrcweir     EndAction();
1039cdf0e10cSrcweir 
1040cdf0e10cSrcweir     sal_Bool bCreateXSelection = sal_False;
1041cdf0e10cSrcweir     const sal_Bool bFrmSelected = IsFrmSelected() || IsObjSelected();
1042cdf0e10cSrcweir     if( IsSelection() )
1043cdf0e10cSrcweir     {
1044cdf0e10cSrcweir         if ( bFrmSelected )
1045cdf0e10cSrcweir             UnSelectFrm();
1046cdf0e10cSrcweir 
1047cdf0e10cSrcweir         // Funktionspointer fuer das Aufheben der Selektion setzen
1048cdf0e10cSrcweir         // bei Cursor setzen
1049cdf0e10cSrcweir         fnKillSel = &SwWrtShell::ResetSelect;
1050cdf0e10cSrcweir         fnSetCrsr = &SwWrtShell::SetCrsrKillSel;
1051cdf0e10cSrcweir         bCreateXSelection = sal_True;
1052cdf0e10cSrcweir     }
1053cdf0e10cSrcweir     else if( bFrmSelected )
1054cdf0e10cSrcweir     {
1055cdf0e10cSrcweir         EnterSelFrmMode();
1056cdf0e10cSrcweir         bCreateXSelection = sal_True;
1057cdf0e10cSrcweir     }
1058cdf0e10cSrcweir     else if( (CNT_GRF | CNT_OLE ) & GetCntType() )
1059cdf0e10cSrcweir     {
1060cdf0e10cSrcweir         SelectObj( GetCharRect().Pos() );
1061cdf0e10cSrcweir         EnterSelFrmMode();
1062cdf0e10cSrcweir         bCreateXSelection = sal_True;
1063cdf0e10cSrcweir     }
1064cdf0e10cSrcweir 
1065cdf0e10cSrcweir     if( bCreateXSelection )
1066cdf0e10cSrcweir         SwTransferable::CreateSelection( *this );
1067cdf0e10cSrcweir 
1068cdf0e10cSrcweir     return bRet;
1069cdf0e10cSrcweir }
1070cdf0e10cSrcweir 
1071cdf0e10cSrcweir 
1072cdf0e10cSrcweir /* fuer den Erhalt der Selektion wird nach SetMark() der Cursor
1073cdf0e10cSrcweir  * nach links bewegt, damit er durch das Einfuegen von Text nicht
1074cdf0e10cSrcweir  * verschoben wird.  Da auf der CORE-Seite am aktuellen Cursor
1075cdf0e10cSrcweir  * eine bestehende Selektion aufgehoben wird, wird der Cursor auf
1076cdf0e10cSrcweir  * den Stack gepushed. Nach dem Verschieben werden sie wieder
1077cdf0e10cSrcweir  * zusammengefasst. */
1078cdf0e10cSrcweir 
1079cdf0e10cSrcweir 
1080cdf0e10cSrcweir 
1081cdf0e10cSrcweir 
1082