diff options
author | Bjoern Michaelsen <bjoern.michaelsen@canonical.com> | 2011-08-23 15:10:47 +0200 |
---|---|---|
committer | Bjoern Michaelsen <bjoern.michaelsen@canonical.com> | 2011-08-23 15:10:47 +0200 |
commit | 5047523157e7e60ae8cda8874d9a612901519e49 (patch) | |
tree | faa36aaa54a39b1db9a6e6cfbc5a7e9a9e585c52 /binfilter/bf_svx/source/svdraw/svx_svdviter.cxx | |
parent | 94844f1a5db3657d0e649069f5a7f4d890b80568 (diff) |
recreated tag libreoffice-3.3.3.1 which had these commits:
commit 1bcb7c0787a73a4caaf385d9c7a0668f6ce0c712 (tag: refs/tags/libreoffice-3.3.3.1)
Author: Petr Mladek <pmladek@suse.cz>
Date: Tue May 31 17:39:05 2011 +0200
Version 3.3.3.1, tag libreoffice-3.3.3.1 (3.3.3-rc1)
commit d74a6ab18ffdb0f1eb796dc9211e7d2109d348c8
Author: Caolán McNamara <caolanm@redhat.com>
Date: Wed Apr 6 21:37:47 2011 +0100
avoid possibility of accessing out of range ObjTimes
lotuswordpro/source/filter/lwpidxmgr.hxx | 2 +-
lotuswordpro/source/filter/lwpobjid.cxx | 4 ++--
2 files changed, 3 insertions(+), 3 deletions(-)
Notes
split repo tag: filters_libreoffice-3.3.3.1
split repo tag: filters_libreoffice-3.3.4.1
Diffstat (limited to 'binfilter/bf_svx/source/svdraw/svx_svdviter.cxx')
-rw-r--r-- | binfilter/bf_svx/source/svdraw/svx_svdviter.cxx | 196 |
1 files changed, 196 insertions, 0 deletions
diff --git a/binfilter/bf_svx/source/svdraw/svx_svdviter.cxx b/binfilter/bf_svx/source/svdraw/svx_svdviter.cxx new file mode 100644 index 000000000000..3de19e113612 --- /dev/null +++ b/binfilter/bf_svx/source/svdraw/svx_svdviter.cxx @@ -0,0 +1,196 @@ +/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/************************************************************************* + * + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * Copyright 2000, 2010 Oracle and/or its affiliates. + * + * OpenOffice.org - a multi-platform office productivity suite + * + * This file is part of OpenOffice.org. + * + * OpenOffice.org is free software: you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License version 3 + * only, as published by the Free Software Foundation. + * + * OpenOffice.org is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License version 3 for more details + * (a copy is included in the LICENSE file that accompanied this code). + * + * You should have received a copy of the GNU Lesser General Public License + * version 3 along with OpenOffice.org. If not, see + * <http://www.openoffice.org/license.html> + * for a copy of the LGPLv3 License. + * + ************************************************************************/ + +#include "svdviter.hxx" +#include "svdpage.hxx" +#include "svdview.hxx" +#include "svdpagv.hxx" + +namespace binfilter { + +//////////////////////////////////////////////////////////////////////////////////////////////////// + +/*N*/ void SdrViewIter::ImpInitVars() +/*N*/ { +/*N*/ nListenerNum=0; +/*N*/ nPageViewNum=0; +/*N*/ nOutDevNum=0; +/*N*/ pAktView=NULL; +/*N*/ } + +//////////////////////////////////////////////////////////////////////////////////////////////////// + + +//////////////////////////////////////////////////////////////////////////////////////////////////// + + +//////////////////////////////////////////////////////////////////////////////////////////////////// + +/*N*/ SdrViewIter::SdrViewIter(const SdrObject* pObject_, FASTBOOL bNoMasterPage_) +/*N*/ { +/*N*/ pObject=pObject_; +/*N*/ pModel=pObject_!=NULL ? pObject_->GetModel() : NULL; +/*N*/ pPage=pObject_!=NULL ? pObject_->GetPage() : NULL; +/*N*/ bNoMasterPage=bNoMasterPage_; +/*N*/ if (pModel==NULL || pPage==NULL) { +/*N*/ pModel=NULL; +/*N*/ pPage=NULL; +/*N*/ } +/*N*/ ImpInitVars(); +/*N*/ } + +//////////////////////////////////////////////////////////////////////////////////////////////////// + +/*N*/ FASTBOOL SdrViewIter::ImpCheckPageView(SdrPageView* pPV) const +/*N*/ { +/*N*/ if (pPage!=NULL) { +/*N*/ FASTBOOL bMaster=pPage->IsMasterPage(); +/*N*/ USHORT nPageNum=pPage->GetPageNum(); +/*N*/ SdrPage* pPg=pPV->GetPage(); +/*N*/ if (pPg==pPage) { +/*N*/ if (pObject!=NULL) { +/*N*/ // Objekt gewuenscht? Na dann erstmal sehen, ob +/*N*/ // das Obj in dieser PageView auch sichtbar ist. +/*N*/ SetOfByte aObjLay; +/*N*/ pObject->GetLayer(aObjLay); +/*N*/ aObjLay&=pPV->GetVisibleLayers(); +/*N*/ return !aObjLay.IsEmpty(); +/*N*/ } else { +/*N*/ return TRUE; +/*N*/ } +/*N*/ } else { +/*N*/ if (!bNoMasterPage && bMaster && (pObject==NULL || !pObject->IsNotVisibleAsMaster())) { +/*N*/ USHORT nMasterPageAnz=pPg->GetMasterPageCount(); +/*N*/ USHORT nMasterPagePos=0; +/*N*/ while (nMasterPagePos<nMasterPageAnz) { +/*N*/ if (nPageNum==pPg->GetMasterPageNum(nMasterPagePos)) { +/*N*/ // Aha, die gewuenschte Page ist also MasterPage in dieser PageView +/*N*/ if (pObject!=NULL) { +/*N*/ // Objekt gewuenscht? Na dann erstmal sehen, ob +/*N*/ // das Obj in dieser PageView auch sichtbar ist. +/*N*/ SetOfByte aObjLay; +/*N*/ pObject->GetLayer(aObjLay); +/*N*/ aObjLay&=pPV->GetVisibleLayers(); +/*N*/ aObjLay&=pPg->GetMasterPageVisibleLayers(nMasterPagePos); +/*N*/ if (!aObjLay.IsEmpty()) { +/*N*/ return TRUE; +/*N*/ } // ansonsten die naechste MasterPage der Page ansehen... +/*N*/ } else { +/*N*/ return TRUE; +/*N*/ } +/*N*/ } +/*N*/ nMasterPagePos++; +/*N*/ } +/*N*/ } +/*N*/ // MasterPage nicht erlaubt oder keine passende gefunden +/*N*/ return FALSE; +/*N*/ } +/*N*/ } else { +/*N*/ return TRUE; +/*N*/ } +/*N*/ } + +//////////////////////////////////////////////////////////////////////////////////////////////////// + +/*N*/ SdrView* SdrViewIter::ImpFindView() +/*N*/ { +/*N*/ if (pModel!=NULL) { +/*N*/ USHORT nLsAnz=pModel->GetListenerCount(); +/*N*/ while (nListenerNum<nLsAnz) { +/*N*/ SfxListener* pLs=pModel->GetListener(nListenerNum); +/*N*/ pAktView=PTR_CAST(SdrView,pLs); +/*N*/ if (pAktView!=NULL) { +/*N*/ if (pPage!=NULL) { +/*N*/ USHORT nPvAnz=pAktView->GetPageViewCount(); +/*N*/ USHORT nPvNum=0; +/*N*/ while (nPvNum<nPvAnz) { +/*N*/ SdrPageView* pPV=pAktView->GetPageViewPvNum(nPvNum); +/*N*/ if (ImpCheckPageView(pPV)) { +/*N*/ return pAktView; +/*N*/ } +/*N*/ nPvNum++; +/*N*/ } +/*N*/ } else { +/*N*/ return pAktView; +/*N*/ } +/*N*/ } +/*N*/ nListenerNum++; +/*N*/ } +/*N*/ } +/*N*/ pAktView=NULL; +/*N*/ return pAktView; +/*N*/ } + +//////////////////////////////////////////////////////////////////////////////////////////////////// + + +//////////////////////////////////////////////////////////////////////////////////////////////////// + + +//////////////////////////////////////////////////////////////////////////////////////////////////// + + +//////////////////////////////////////////////////////////////////////////////////////////////////// + +/*N*/ SdrView* SdrViewIter::FirstView() +/*N*/ { +/*N*/ ImpInitVars(); +/*N*/ return ImpFindView(); +/*N*/ } + +//////////////////////////////////////////////////////////////////////////////////////////////////// + +/*N*/ SdrView* SdrViewIter::NextView() +/*N*/ { +/*N*/ nListenerNum++; +/*N*/ return ImpFindView(); +/*N*/ } + +//////////////////////////////////////////////////////////////////////////////////////////////////// + + +//////////////////////////////////////////////////////////////////////////////////////////////////// + + +//////////////////////////////////////////////////////////////////////////////////////////////////// + + +//////////////////////////////////////////////////////////////////////////////////////////////////// + + +//////////////////////////////////////////////////////////////////////////////////////////////////// + + +//////////////////////////////////////////////////////////////////////////////////////////////////// + + +//////////////////////////////////////////////////////////////////////////////////////////////////// + +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |