1 /************************************************************************* 2 * 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * Copyright 2000, 2010 Oracle and/or its affiliates. 6 * 7 * OpenOffice.org - a multi-platform office productivity suite 8 * 9 * This file is part of OpenOffice.org. 10 * 11 * OpenOffice.org is free software: you can redistribute it and/or modify 12 * it under the terms of the GNU Lesser General Public License version 3 13 * only, as published by the Free Software Foundation. 14 * 15 * OpenOffice.org is distributed in the hope that it will be useful, 16 * but WITHOUT ANY WARRANTY; without even the implied warranty of 17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18 * GNU Lesser General Public License version 3 for more details 19 * (a copy is included in the LICENSE file that accompanied this code). 20 * 21 * You should have received a copy of the GNU Lesser General Public License 22 * version 3 along with OpenOffice.org. If not, see 23 * <http://www.openoffice.org/license.html> 24 * for a copy of the LGPLv3 License. 25 * 26 ************************************************************************/ 27 28 // MARKER(update_precomp.py): autogen include statement, do not remove 29 #include "precompiled_sw.hxx" 30 31 32 #include <doc.hxx> 33 #include <pamtyp.hxx> 34 35 36 sal_Bool SwPaM::Find( const SwFmt& rFmt, SwMoveFn fnMove, 37 const SwPaM *pRegion, sal_Bool bInReadOnly ) 38 { 39 sal_Bool bFound = sal_False; 40 sal_Bool bSrchForward = fnMove == fnMoveForward; 41 SwPaM* pPam = MakeRegion( fnMove, pRegion ); 42 43 // Wenn am Anfang/Ende, aus dem Node moven 44 if( bSrchForward 45 ? pPam->GetPoint()->nContent.GetIndex() == pPam->GetCntntNode()->Len() 46 : !pPam->GetPoint()->nContent.GetIndex() ) 47 { 48 if( !(*fnMove->fnNds)( &pPam->GetPoint()->nNode, sal_False )) 49 { 50 delete pPam; 51 return sal_False; 52 } 53 SwCntntNode *pNd = pPam->GetPoint()->nNode.GetNode().GetCntntNode(); 54 xub_StrLen nTmpPos = bSrchForward ? 0 : pNd->Len(); 55 pPam->GetPoint()->nContent.Assign( pNd, nTmpPos ); 56 } 57 58 sal_Bool bFirst = sal_True; 59 SwCntntNode* pNode; 60 while( !bFound && 61 0 != ( pNode = ::GetNode( *pPam, bFirst, fnMove, bInReadOnly ))) 62 { 63 if( 0 != ( bFound = pNode->GetFmtColl() == &rFmt )) 64 { 65 // wurde die FormatCollection gefunden, dann handelt es sich auf 66 // jedenfall um einen SwCntntNode !! 67 68 // FORWARD: SPoint an das Ende, GetMark zum Anfanf vom Node 69 // BACKWARD: SPoint zum Anfang, GetMark an das Ende vom Node 70 // und immer nach der Logik: inkl. Start, exkl. End !!! 71 *GetPoint() = *pPam->GetPoint(); 72 SetMark(); 73 pNode->MakeEndIndex( &GetPoint()->nContent ); 74 GetMark()->nContent = 0; 75 if( !bSrchForward ) // rueckwaerts Suche? 76 Exchange(); // SPoint und GetMark tauschen 77 break; 78 } 79 } 80 delete pPam; 81 return bFound; 82 } 83 84 85