merge the formfield patch from ooo-build
[ooovba.git] / sc / source / ui / docshell / pagedata.cxx
blob61e7f24ff4b61d39d00179b9a6b1b8ff6e0968eb
1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * Copyright 2008 by Sun Microsystems, Inc.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * $RCSfile: pagedata.cxx,v $
10 * $Revision: 1.9 $
12 * This file is part of OpenOffice.org.
14 * OpenOffice.org is free software: you can redistribute it and/or modify
15 * it under the terms of the GNU Lesser General Public License version 3
16 * only, as published by the Free Software Foundation.
18 * OpenOffice.org is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU Lesser General Public License version 3 for more details
22 * (a copy is included in the LICENSE file that accompanied this code).
24 * You should have received a copy of the GNU Lesser General Public License
25 * version 3 along with OpenOffice.org. If not, see
26 * <http://www.openoffice.org/license.html>
27 * for a copy of the LGPLv3 License.
29 ************************************************************************/
31 // MARKER(update_precomp.py): autogen include statement, do not remove
32 #include "precompiled_sc.hxx"
35 #include <string.h>
36 #include <tools/debug.hxx>
39 #include "pagedata.hxx"
41 //============================================================================
43 ScPrintRangeData::ScPrintRangeData()
45 nPagesX = nPagesY = 0;
46 pPageEndX = NULL;
47 pPageEndY = NULL;
48 bTopDown = bAutomatic = TRUE;
49 nFirstPage = 1;
52 ScPrintRangeData::~ScPrintRangeData()
54 delete[] pPageEndX;
55 delete[] pPageEndY;
58 void ScPrintRangeData::SetPagesX( size_t nCount, const SCCOL* pData )
60 delete[] pPageEndX;
61 if ( nCount )
63 pPageEndX = new SCCOL[nCount];
64 memcpy( pPageEndX, pData, nCount * sizeof(SCCOL) );
66 else
67 pPageEndX = NULL;
68 nPagesX = nCount;
71 void ScPrintRangeData::SetPagesY( size_t nCount, const SCROW* pData )
73 delete[] pPageEndY;
74 if ( nCount )
76 pPageEndY = new SCROW[nCount];
77 memcpy( pPageEndY, pData, nCount * sizeof(SCROW) );
79 else
80 pPageEndY = NULL;
81 nPagesY = nCount;
84 //============================================================================
86 ScPageBreakData::ScPageBreakData(size_t nMax)
88 nUsed = 0;
89 if (nMax)
90 pData = new ScPrintRangeData[nMax];
91 else
92 pData = NULL;
93 nAlloc = nMax;
96 ScPageBreakData::~ScPageBreakData()
98 delete[] pData;
101 ScPrintRangeData& ScPageBreakData::GetData(size_t nPos)
103 DBG_ASSERT(nPos < nAlloc, "ScPageBreakData::GetData bumm");
105 if ( nPos >= nUsed )
107 DBG_ASSERT(nPos == nUsed, "ScPageBreakData::GetData falsche Reihenfolge");
108 nUsed = nPos+1;
111 return pData[nPos];
114 BOOL ScPageBreakData::IsEqual( const ScPageBreakData& rOther ) const
116 if ( nUsed != rOther.nUsed )
117 return FALSE;
119 for (USHORT i=0; i<nUsed; i++)
120 if ( pData[i].GetPrintRange() != rOther.pData[i].GetPrintRange() )
121 return FALSE;
123 //! ScPrintRangeData komplett vergleichen ??
125 return TRUE;
128 void ScPageBreakData::AddPages()
130 if ( nUsed > 1 )
132 long nPage = pData[0].GetFirstPage();
133 for (USHORT i=0; sal::static_int_cast<size_t>(i+1)<nUsed; i++)
135 nPage += ((long)pData[i].GetPagesX())*pData[i].GetPagesY();
136 pData[i+1].SetFirstPage( nPage );