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