2000-09-18 23:08:29 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2008-04-10 13:44:44 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
2000-09-18 23:08:29 +00:00
|
|
|
*
|
2010-02-12 15:01:35 +01:00
|
|
|
* Copyright 2000, 2010 Oracle and/or its affiliates.
|
2000-09-18 23:08:29 +00:00
|
|
|
*
|
2008-04-10 13:44:44 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2000-09-18 23:08:29 +00:00
|
|
|
*
|
2008-04-10 13:44:44 +00:00
|
|
|
* This file is part of OpenOffice.org.
|
2000-09-18 23:08:29 +00:00
|
|
|
*
|
2008-04-10 13:44:44 +00:00
|
|
|
* 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.
|
2000-09-18 23:08:29 +00:00
|
|
|
*
|
2008-04-10 13:44:44 +00:00
|
|
|
* 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).
|
2000-09-18 23:08:29 +00:00
|
|
|
*
|
2008-04-10 13:44:44 +00:00
|
|
|
* 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.
|
2000-09-18 23:08:29 +00:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
2006-09-16 20:18:58 +00:00
|
|
|
// MARKER(update_precomp.py): autogen include statement, do not remove
|
|
|
|
#include "precompiled_sw.hxx"
|
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
#include "doc.hxx"
|
|
|
|
#include "node.hxx"
|
|
|
|
#include <docary.hxx>
|
|
|
|
#include <fmtanchr.hxx>
|
|
|
|
#include "flypos.hxx"
|
|
|
|
#include "frmfmt.hxx"
|
|
|
|
#include "dcontact.hxx"
|
|
|
|
#include "dview.hxx"
|
|
|
|
#include "flyfrm.hxx"
|
|
|
|
#include "dflyobj.hxx"
|
|
|
|
#include "ndindex.hxx"
|
2010-12-17 09:02:23 +01:00
|
|
|
#include "switerator.hxx"
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
SV_IMPL_OP_PTRARR_SORT( SwPosFlyFrms, SwPosFlyFrmPtr )
|
|
|
|
|
|
|
|
SwPosFlyFrm::SwPosFlyFrm( const SwNodeIndex& rIdx, const SwFrmFmt* pFmt,
|
2011-01-17 15:06:54 +01:00
|
|
|
sal_uInt16 nArrPos )
|
2007-09-27 08:02:57 +00:00
|
|
|
: pFrmFmt( pFmt ), pNdIdx( (SwNodeIndex*) &rIdx )
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
2011-01-17 15:06:54 +01:00
|
|
|
sal_Bool bFnd = sal_False;
|
2000-09-18 23:08:29 +00:00
|
|
|
const SwFmtAnchor& rAnchor = pFmt->GetAnchor();
|
2010-01-05 16:37:41 +01:00
|
|
|
if (FLY_AT_PAGE == rAnchor.GetAnchorId())
|
|
|
|
{
|
2000-09-18 23:08:29 +00:00
|
|
|
pNdIdx = new SwNodeIndex( rIdx );
|
2010-01-05 16:37:41 +01:00
|
|
|
}
|
2010-06-13 15:22:56 +02:00
|
|
|
else if( pFmt->GetDoc()->GetCurrentViewShell() ) //swmod 071108//swmod 071225
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
|
|
|
if( RES_FLYFRMFMT == pFmt->Which() )
|
|
|
|
{
|
|
|
|
// Schauen, ob es ein SdrObject dafuer gibt
|
2011-02-09 09:49:44 +01:00
|
|
|
<<<<<<< local
|
2010-12-17 09:02:23 +01:00
|
|
|
SwFlyFrm* pFly = SwIterator<SwFlyFrm,SwFmt>::FirstElement(*pFmt);
|
|
|
|
if( pFly )
|
|
|
|
{
|
|
|
|
nOrdNum = pFly->GetVirtDrawObj()->GetOrdNum();
|
2000-09-18 23:08:29 +00:00
|
|
|
bFnd = TRUE;
|
2011-02-09 09:49:44 +01:00
|
|
|
=======
|
2000-09-18 23:08:29 +00:00
|
|
|
if( aIter.First( TYPE( SwFlyFrm) ) )
|
|
|
|
nOrdNum = ((SwFlyFrm*)aIter())->GetVirtDrawObj()->GetOrdNum(),
|
2011-01-17 15:06:54 +01:00
|
|
|
bFnd = sal_True;
|
2011-02-09 09:49:44 +01:00
|
|
|
>>>>>>> other
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
2010-12-17 09:02:23 +01:00
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
else if( RES_DRAWFRMFMT == pFmt->Which() )
|
|
|
|
{
|
|
|
|
// Schauen, ob es ein SdrObject dafuer gibt
|
2011-02-09 09:49:44 +01:00
|
|
|
<<<<<<< local
|
2010-12-17 09:02:23 +01:00
|
|
|
SwDrawContact* pContact = SwIterator<SwDrawContact,SwFmt>::FirstElement(*pFmt);
|
|
|
|
if( pContact )
|
|
|
|
{
|
|
|
|
nOrdNum = pContact->GetMaster()->GetOrdNum();
|
2000-09-18 23:08:29 +00:00
|
|
|
bFnd = TRUE;
|
2011-02-09 09:49:44 +01:00
|
|
|
=======
|
2000-09-18 23:08:29 +00:00
|
|
|
if( aIter.First( TYPE(SwDrawContact) ) )
|
|
|
|
nOrdNum = ((SwDrawContact*)aIter())->GetMaster()->GetOrdNum(),
|
2011-01-17 15:06:54 +01:00
|
|
|
bFnd = sal_True;
|
2011-02-09 09:49:44 +01:00
|
|
|
>>>>>>> other
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
|
|
|
}
|
2010-12-17 09:02:23 +01:00
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
if( !bFnd )
|
|
|
|
{
|
|
|
|
nOrdNum = pFmt->GetDoc()->GetSpzFrmFmts()->Count();
|
|
|
|
nOrdNum += nArrPos;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
SwPosFlyFrm::~SwPosFlyFrm()
|
|
|
|
{
|
|
|
|
const SwFmtAnchor& rAnchor = pFrmFmt->GetAnchor();
|
2010-01-05 16:37:41 +01:00
|
|
|
if (FLY_AT_PAGE == rAnchor.GetAnchorId())
|
|
|
|
{
|
2000-09-18 23:08:29 +00:00
|
|
|
delete pNdIdx;
|
2010-01-05 16:37:41 +01:00
|
|
|
}
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
|
|
|
|
2011-01-17 15:06:54 +01:00
|
|
|
sal_Bool SwPosFlyFrm::operator==( const SwPosFlyFrm& )
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
2011-01-17 15:06:54 +01:00
|
|
|
return sal_False; // FlyFrames koennen auf der gleichen Position stehen
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
|
|
|
|
2011-01-17 15:06:54 +01:00
|
|
|
sal_Bool SwPosFlyFrm::operator<( const SwPosFlyFrm& rPosFly )
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
|
|
|
if( pNdIdx->GetIndex() == rPosFly.pNdIdx->GetIndex() )
|
|
|
|
{
|
|
|
|
// dann entscheidet die Ordnungsnummer!
|
|
|
|
return nOrdNum < rPosFly.nOrdNum;
|
|
|
|
}
|
|
|
|
return pNdIdx->GetIndex() < rPosFly.pNdIdx->GetIndex();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|