Files
libreoffice/sc/source/ui/docshell/pagedata.cxx

140 lines
3.4 KiB
C++
Raw Normal View History

2000-09-18 16:07:07 +00:00
/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
2000-09-18 16:07:07 +00:00
*
* Copyright 2000, 2010 Oracle and/or its affiliates.
2000-09-18 16:07:07 +00:00
*
* OpenOffice.org - a multi-platform office productivity suite
2000-09-18 16:07:07 +00:00
*
* This file is part of OpenOffice.org.
2000-09-18 16:07:07 +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 16:07:07 +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 16:07:07 +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 16:07:07 +00:00
*
************************************************************************/
// MARKER(update_precomp.py): autogen include statement, do not remove
#include "precompiled_sc.hxx"
2000-09-18 16:07:07 +00:00
#include <string.h>
#include <tools/debug.hxx>
#include "pagedata.hxx"
//============================================================================
ScPrintRangeData::ScPrintRangeData()
{
nPagesX = nPagesY = 0;
pPageEndX = NULL;
pPageEndY = NULL;
2000-09-18 16:07:07 +00:00
bTopDown = bAutomatic = TRUE;
nFirstPage = 1;
}
ScPrintRangeData::~ScPrintRangeData()
{
delete[] pPageEndX;
delete[] pPageEndY;
}
void ScPrintRangeData::SetPagesX( size_t nCount, const SCCOL* pData )
2000-09-18 16:07:07 +00:00
{
delete[] pPageEndX;
if ( nCount )
{
pPageEndX = new SCCOL[nCount];
memcpy( pPageEndX, pData, nCount * sizeof(SCCOL) );
2000-09-18 16:07:07 +00:00
}
else
pPageEndX = NULL;
nPagesX = nCount;
}
void ScPrintRangeData::SetPagesY( size_t nCount, const SCROW* pData )
2000-09-18 16:07:07 +00:00
{
delete[] pPageEndY;
if ( nCount )
{
pPageEndY = new SCROW[nCount];
memcpy( pPageEndY, pData, nCount * sizeof(SCROW) );
2000-09-18 16:07:07 +00:00
}
else
pPageEndY = NULL;
nPagesY = nCount;
}
//============================================================================
ScPageBreakData::ScPageBreakData(size_t nMax)
2000-09-18 16:07:07 +00:00
{
nUsed = 0;
if (nMax)
pData = new ScPrintRangeData[nMax];
else
pData = NULL;
nAlloc = nMax;
}
ScPageBreakData::~ScPageBreakData()
{
delete[] pData;
}
ScPrintRangeData& ScPageBreakData::GetData(size_t nPos)
2000-09-18 16:07:07 +00:00
{
DBG_ASSERT(nPos < nAlloc, "ScPageBreakData::GetData bumm");
if ( nPos >= nUsed )
{
DBG_ASSERT(nPos == nUsed, "ScPageBreakData::GetData falsche Reihenfolge");
nUsed = nPos+1;
}
return pData[nPos];
}
BOOL ScPageBreakData::IsEqual( const ScPageBreakData& rOther ) const
{
if ( nUsed != rOther.nUsed )
return FALSE;
for (USHORT i=0; i<nUsed; i++)
if ( pData[i].GetPrintRange() != rOther.pData[i].GetPrintRange() )
return FALSE;
//! ScPrintRangeData komplett vergleichen ??
return TRUE;
}
void ScPageBreakData::AddPages()
{
if ( nUsed > 1 )
{
long nPage = pData[0].GetFirstPage();
for (USHORT i=0; sal::static_int_cast<size_t>(i+1)<nUsed; i++)
2000-09-18 16:07:07 +00:00
{
nPage += ((long)pData[i].GetPagesX())*pData[i].GetPagesY();
pData[i+1].SetFirstPage( nPage );
}
}
}