/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * Version: MPL 1.1 / GPLv3+ / LGPLv3+ * * The contents of this file are subject to the Mozilla Public License Version * 1.1 (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * http://www.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License * for the specific language governing rights and limitations under the * License. * * The Initial Developer of the Original Code is * Kohei Yoshida (Novell, Inc.) * Portions created by the Initial Developer are Copyright (C) 2010 the * Initial Developer. All Rights Reserved. * * Contributor(s): * * Alternatively, the contents of this file may be used under the terms of * either the GNU General Public License Version 3 or later (the "GPLv3+"), or * the GNU Lesser General Public License Version 3 or later (the "LGPLv3+"), * in which case the provisions of the GPLv3+ or the LGPLv3+ are applicable * instead of those above. */ #include "subtotalparam.hxx" ScSubTotalParam::ScSubTotalParam() { for ( sal_uInt16 i=0; i 0) && r.pSubTotals[i] && r.pFunctions[i] ) { nSubTotals[i] = r.nSubTotals[i]; pSubTotals[i] = new SCCOL [r.nSubTotals[i]]; pFunctions[i] = new ScSubTotalFunc [r.nSubTotals[i]]; for (SCCOL j=0; j 0) && pSubTotals[i] && pFunctions[i] ) { for ( SCCOL j=0; j 0 ) { pSubTotals[i] = new SCCOL [r.nSubTotals[i]]; pFunctions[i] = new ScSubTotalFunc [r.nSubTotals[i]]; for (SCCOL j=0; j 0) ) { bEqual = (pSubTotals != NULL) && (pFunctions != NULL); for (SCCOL j=0; (j MAXSUBTOTAL!" ); OSL_ENSURE( ptrSubTotals, "ScSubTotalParam::SetSubTotals(): ptrSubTotals == NULL!" ); OSL_ENSURE( ptrFunctions, "ScSubTotalParam::SetSubTotals(): ptrFunctions == NULL!" ); OSL_ENSURE( (nCount > 0), "ScSubTotalParam::SetSubTotals(): nCount <= 0!" ); if ( ptrSubTotals && ptrFunctions && (nCount > 0) && (nGroup <= MAXSUBTOTAL) ) { // 0 wird als 1 aufgefasst, sonst zum Array-Index dekrementieren if (nGroup != 0) nGroup--; delete [] pSubTotals[nGroup]; delete [] pFunctions[nGroup]; pSubTotals[nGroup] = new SCCOL [nCount]; pFunctions[nGroup] = new ScSubTotalFunc [nCount]; nSubTotals[nGroup] = static_cast(nCount); for ( sal_uInt16 i=0; i