/* -*- 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 * * for a copy of the LGPLv3 License. * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_svx.hxx" // #i13033# // New mechanism to hold a ist of all original and cloned objects for later // re-creating the connections for contained connectors #include #include #include void CloneList::AddPair(const SdrObject* pOriginal, SdrObject* pClone) { maOriginalList.push_back(pOriginal); maCloneList.push_back(pClone); // look for subobjects, too. sal_Bool bOriginalIsGroup(pOriginal->IsGroupObject()); sal_Bool bCloneIsGroup(pClone->IsGroupObject()); if(bOriginalIsGroup && pOriginal->ISA(E3dObject) && !pOriginal->ISA(E3dScene)) bOriginalIsGroup = sal_False; if(bCloneIsGroup && pClone->ISA(E3dObject) && !pClone->ISA(E3dScene)) bCloneIsGroup = sal_False; if(bOriginalIsGroup && bCloneIsGroup) { const SdrObjList* pOriginalList = pOriginal->GetSubList(); SdrObjList* pCloneList = pClone->GetSubList(); if(pOriginalList && pCloneList && pOriginalList->GetObjCount() == pCloneList->GetObjCount()) { for(sal_uInt32 a(0); a < pOriginalList->GetObjCount(); a++) { // recursive call AddPair(pOriginalList->GetObj(a), pCloneList->GetObj(a)); } } } } sal_uInt32 CloneList::Count() const { return maOriginalList.size(); } const SdrObject* CloneList::GetOriginal(sal_uInt32 nIndex) const { return maOriginalList[nIndex]; } SdrObject* CloneList::GetClone(sal_uInt32 nIndex) const { return maCloneList[nIndex]; } void CloneList::CopyConnections() const { for(sal_uInt32 a = 0; a < maOriginalList.size(); a++) { const SdrEdgeObj* pOriginalEdge = PTR_CAST(SdrEdgeObj, GetOriginal(a)); SdrEdgeObj* pCloneEdge = PTR_CAST(SdrEdgeObj, GetClone(a)); if(pOriginalEdge && pCloneEdge) { SdrObject* pOriginalNode1 = pOriginalEdge->GetConnectedNode(sal_True); SdrObject* pOriginalNode2 = pOriginalEdge->GetConnectedNode(sal_False); if(pOriginalNode1) { std::vector::const_iterator it = std::find(maOriginalList.begin(), maOriginalList.end(), pOriginalNode1); if(it != maOriginalList.end()) { if(pOriginalEdge->GetConnectedNode(sal_True) != *it) pCloneEdge->ConnectToNode(sal_True, const_cast(*it)); } } if(pOriginalNode2) { std::vector::const_iterator it = std::find(maOriginalList.begin(), maOriginalList.end(), pOriginalNode2); if(it != maOriginalList.end()) { if(pOriginalEdge->GetConnectedNode(sal_True) != *it) pCloneEdge->ConnectToNode(sal_True, const_cast(*it)); } } } } } // eof /* vim:set shiftwidth=4 softtabstop=4 expandtab: */