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_sc.hxx" 30 31 32 33 //------------------------------------------------------------------ 34 35 // INCLUDE --------------------------------------------------------------- 36 37 #include <svx/svditer.hxx> 38 #include <svx/svdoole2.hxx> 39 #include <svx/svdpage.hxx> 40 41 #include "dbfunc.hxx" 42 #include "drwlayer.hxx" 43 #include "document.hxx" 44 45 // ----------------------------------------------------------------------- 46 47 #ifdef _MSC_VER 48 #pragma optimize ( "", off ) 49 #endif 50 51 using namespace com::sun::star; 52 53 //================================================================== 54 55 // static 56 sal_uInt16 ScDBFunc::DoUpdateCharts( const ScAddress& rPos, ScDocument* pDoc, sal_Bool bAllCharts ) 57 { 58 ScDrawLayer* pModel = pDoc->GetDrawLayer(); 59 if (!pModel) 60 return 0; 61 62 sal_uInt16 nFound = 0; 63 64 sal_uInt16 nPageCount = pModel->GetPageCount(); 65 for (sal_uInt16 nPageNo=0; nPageNo<nPageCount; nPageNo++) 66 { 67 SdrPage* pPage = pModel->GetPage(nPageNo); 68 DBG_ASSERT(pPage,"Page ?"); 69 70 SdrObjListIter aIter( *pPage, IM_DEEPNOGROUPS ); 71 SdrObject* pObject = aIter.Next(); 72 while (pObject) 73 { 74 if ( pObject->GetObjIdentifier() == OBJ_OLE2 && pDoc->IsChart( pObject ) ) 75 { 76 String aName = ((SdrOle2Obj*)pObject)->GetPersistName(); 77 sal_Bool bHit = sal_True; 78 if ( !bAllCharts ) 79 { 80 ScRangeList aRanges; 81 sal_Bool bColHeaders = sal_False; 82 sal_Bool bRowHeaders = sal_False; 83 pDoc->GetOldChartParameters( aName, aRanges, bColHeaders, bRowHeaders ); 84 bHit = aRanges.In( rPos ); 85 } 86 if ( bHit ) 87 { 88 pDoc->UpdateChart( aName ); 89 ++nFound; 90 } 91 } 92 pObject = aIter.Next(); 93 } 94 } 95 return nFound; 96 } 97 98 99 100 101 102 103