diff options
author | RĂ¼diger Timm <rt@openoffice.org> | 2008-09-04 09:18:20 +0000 |
---|---|---|
committer | RĂ¼diger Timm <rt@openoffice.org> | 2008-09-04 09:18:20 +0000 |
commit | 5eeb3dbf5b236670be2a0b256406427cdd8d856f (patch) | |
tree | c2ac48b3751fe5c6c9ecded6781be28b3922f32a /sw/source/core/crsr/crbm.cxx | |
parent | 80ea418955848274cec219b7d346dadb677e2ab6 (diff) |
INTEGRATION: CWS swenhancedfields2 (1.7.42); FILE MERGED
2008/08/11 09:46:36 b_michaelsen 1.7.42.4: marked TODOs clearly
2008/08/06 15:39:29 b_michaelsen 1.7.42.3: fixed formatting in crbm.cxx pam.cxx and docbm.cxx
2008/08/04 14:18:16 b_michaelsen 1.7.42.2: RESYNC: (1.7-1.8); FILE MERGED
2008/04/23 14:29:16 ama 1.7.42.1: #i33737#: Enhanced fields
Diffstat (limited to 'sw/source/core/crsr/crbm.cxx')
-rw-r--r-- | sw/source/core/crsr/crbm.cxx | 80 |
1 files changed, 72 insertions, 8 deletions
diff --git a/sw/source/core/crsr/crbm.cxx b/sw/source/core/crsr/crbm.cxx index cc1d7069458c..0714701517df 100644 --- a/sw/source/core/crsr/crbm.cxx +++ b/sw/source/core/crsr/crbm.cxx @@ -7,7 +7,7 @@ * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: crbm.cxx,v $ - * $Revision: 1.8 $ + * $Revision: 1.9 $ * * This file is part of OpenOffice.org. * @@ -40,6 +40,7 @@ #include "callnk.hxx" #include "swcrsr.hxx" #include <IDocumentBookmarkAccess.hxx> +#include <IDocumentSettingAccess.hxx> /* * Methoden der SwCrsrShell fuer Bookmark @@ -166,6 +167,70 @@ BOOL SwCrsrShell::GoNextBookmark() } +bool SwCrsrShell::IsFormProtected() +{ + return getIDocumentSettingAccess()->get(IDocumentSettingAccess::PROTECT_FORM); +} + +SwBookmark* SwCrsrShell::IsInFieldBookmark() +{ + // TODO: Refactor + SwPosition pos(*GetCrsr()->GetPoint()); + return getIDocumentBookmarkAccess()->getFieldBookmarkFor(pos); +} + +SwFieldBookmark* SwCrsrShell::IsInFormFieldBookmark() +{ + // TODO: Refactor + SwPosition pos(*GetCrsr()->GetPoint()); + return (SwFieldBookmark*)getIDocumentBookmarkAccess()->getFormFieldBookmarkFor(pos); +} + +SwBookmark* SwCrsrShell::GetNextFieldBookmark() +{ + SwPosition pos(*GetCrsr()->GetPoint()); + return getIDocumentBookmarkAccess()->getNextFieldBookmarkFor(pos); +} + +SwBookmark* SwCrsrShell::GetPrevFieldBookmark() +{ + SwPosition pos(*GetCrsr()->GetPoint()); + return getIDocumentBookmarkAccess()->getPrevFieldBookmarkFor(pos); +} + +bool SwCrsrShell::GotoFieldBookmark(SwBookmark *pBkmk) +{ + if(pBkmk==NULL) return false; + // Crsr-Moves ueberwachen, evt. Link callen + bool bRet = true; + SwCallLink aLk( *this ); + SwCursor* pCrsr = GetSwCrsr(); + SwCrsrSaveState aSaveState( *pCrsr ); + + *pCrsr->GetPoint() = pBkmk->GetBookmarkPos(); + if( pBkmk->GetOtherBookmarkPos() ) + { + pCrsr->SetMark(); + *pCrsr->GetMark() = *pBkmk->GetOtherBookmarkPos(); + if( *pCrsr->GetMark() > *pCrsr->GetPoint() ) + pCrsr->Exchange(); + } + pCrsr->GetPoint()->nContent--; + pCrsr->GetMark()->nContent++; + + + if( pCrsr->IsSelOvr( nsSwCursorSelOverFlags::SELOVER_CHECKNODESSECTION | nsSwCursorSelOverFlags::SELOVER_TOGGLE ) ) + { + pCrsr->DeleteMark(); + pCrsr->RestoreSavePos(); + bRet = false; + } + else + UpdateCrsr(SwCrsrShell::SCROLLWIN|SwCrsrShell::CHKRANGE|SwCrsrShell::READONLY); + + return bRet; +} + BOOL SwCrsrShell::GoPrevBookmark() { const SwBookmarks& rBkmks = getIDocumentBookmarkAccess()->getBookmarks(); @@ -179,7 +244,8 @@ BOOL SwCrsrShell::GoPrevBookmark() const SwBookmark* pBkmk; // alle die Inhaltlich auf der gleichen Position stehen, ueberspringen - do { + do + { if ( nPos == 0 ) return FALSE; } while( aBM < *(pBkmk = rBkmks[--nPos]) || aBM.IsEqualPos( *pBkmk )); @@ -188,7 +254,8 @@ BOOL SwCrsrShell::GoPrevBookmark() SwCrsrSaveState aSaveState( *pCrsr ); BOOL bRet = FALSE; - do { + do + { pBkmk = rBkmks[ nPos ]; // --> OD 2007-09-27 #i81002# - refactoring @@ -258,12 +325,9 @@ USHORT SwCrsrShell::FindBookmark( const String& rName ) } - // erzeugt einen eindeutigen Namen. Der Name selbst muss vorgegeben - // werden, es wird dann bei gleichen Namen nur durchnumeriert. +// erzeugt einen eindeutigen Namen. Der Name selbst muss vorgegeben +// werden, es wird dann bei gleichen Namen nur durchnumeriert. void SwCrsrShell::MakeUniqueBookmarkName( String& rName ) { getIDocumentBookmarkAccess()->makeUniqueBookmarkName( rName ); } - - - |