summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--svx/source/svdraw/svdpage.cxx62
1 files changed, 18 insertions, 44 deletions
diff --git a/svx/source/svdraw/svdpage.cxx b/svx/source/svdraw/svdpage.cxx
index 5be2392abd7f..648a675d078f 100644
--- a/svx/source/svdraw/svdpage.cxx
+++ b/svx/source/svdraw/svdpage.cxx
@@ -577,52 +577,26 @@ SdrObject* SdrObjList::SetObjectOrdNum(size_t nOldObjNum, size_t nNewObjNum)
return NULL;
}
- SdrObject* pObj = maList[nOldObjNum];
- assert(pObj!=NULL && "SdrObjList::SetObjectOrdNum: Object not found.");
- if (nOldObjNum == nNewObjNum)
- return pObj;
- SdrObject* pOtherObj = maList[nNewObjNum];
- assert(pOtherObj!=NULL && "SdrObjList::SetObjectOrdNum: other Object not found.");
-
- assert(pObj->IsInserted() && "SdrObjList::SetObjectOrdNum: ZObjekt does not have status Inserted.");
-
- // Update the navigation positions.
- if (HasObjectNavigationOrder())
- {
- SdrObjectWeakRef aReference (pOtherObj);
- WeakSdrObjectContainerType::iterator iObject (::std::find(
- mxNavigationOrder->begin(),
- mxNavigationOrder->end(),
- aReference));
- if (iObject != mxNavigationOrder->end())
- mxNavigationOrder->erase(iObject);
- mbIsNavigationOrderDirty = true;
- // The new object does not have a user defined position so append it
- // to the list.
- pObj->SetNavigationPosition(mxNavigationOrder->size());
- mxNavigationOrder->push_back(pObj);
- }
-
- maList.erase(maList.begin()+nOldObjNum);
- if (nNewObjNum >= maList.size())
- maList.push_back(pObj);
- else
- maList.insert(maList.begin()+nNewObjNum, pObj);
-
- const size_t nCount = maList.size();
- for (size_t no=nOldObjNum; no<nCount; ++no) {
- maList[no]->SetOrdNum(no);
- }
+ SdrObject* pObj=maList[nOldObjNum];
+ if (nOldObjNum==nNewObjNum) return pObj;
+ DBG_ASSERT(pObj!=NULL,"SdrObjList::SetObjectOrdNum: Object not found.");
+ if (pObj!=NULL) {
+ DBG_ASSERT(pObj->IsInserted(),"SdrObjList::SetObjectOrdNum: ZObjekt does not have status Inserted.");
+ RemoveObjectFromContainer(nOldObjNum);
+ InsertObjectIntoContainer(*pObj,nNewObjNum);
- // No need to delete visualisation data since same object
- // gets inserted again. Also a single ActionChanged is enough
- pObj->ActionChanged();
+ // No need to delete visualisation data since same object
+ // gets inserted again. Also a single ActionChanged is enough
+ pObj->ActionChanged();
- if (pModel!=NULL)
- {
- // TODO: We need a different broadcast here.
- if (pObj->GetPage()!=NULL) pModel->Broadcast(SdrHint(*pObj));
- pModel->SetChanged();
+ pObj->SetOrdNum(nNewObjNum);
+ bObjOrdNumsDirty=true;
+ if (pModel!=NULL)
+ {
+ // TODO: We need a different broadcast here.
+ if (pObj->GetPage()!=NULL) pModel->Broadcast(SdrHint(*pObj));
+ pModel->SetChanged();
+ }
}
return pObj;
}