office-gobmx/sc/inc/pivot.hxx
Luboš Luňák 50a125464e remove MAXCOLCOUNT from calc pivot implementation
It appears that PIVOT_DATA_FIELD is just a custom special value
that's outside of the valid column range, but otherwise the value
doesn't matter, and -1 is generic.

Change-Id: Ieac1d4e3391f76350dc420e6b2ae9ed9f35d35f7
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/130124
Tested-by: Jenkins
Reviewed-by: Luboš Luňák <l.lunak@collabora.com>
2022-02-18 13:40:44 +01:00

174 lines
5.4 KiB
C++

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (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.apache.org/licenses/LICENSE-2.0 .
*/
/*
IMPORTANT:
Strictly adhere to the following sequence when creating a pivot table:
pPivot->SetColFields(aColArr, aColCount)
pPivot->SetRowFields(aRowArr, aRowCount)
pPivot->SetDataFields(aDataArr, aDataCount)
if (pPivot->CreateData())
{
pPivotDrawData();
pPivotReleaseData();
}
Make sure that either ColArr or RowArr contains a PivotDataField entry.
*/
#pragma once
#include <rtl/ustring.hxx>
#include <tools/long.hxx>
#include "types.hxx"
#include "scdllapi.h"
#include "dpglobal.hxx"
#include "calcmacros.hxx"
#include <vector>
#include <memory>
#include <com/sun/star/uno/Sequence.hxx>
#include <com/sun/star/sheet/DataPilotFieldReference.hpp>
#include <com/sun/star/sheet/DataPilotFieldSortInfo.hpp>
#include <com/sun/star/sheet/DataPilotFieldLayoutInfo.hpp>
#include <com/sun/star/sheet/DataPilotFieldAutoShowInfo.hpp>
#define PIVOT_DATA_FIELD (SCCOL(-1))
struct SC_DLLPUBLIC ScDPName
{
OUString maName; ///< Original name of the dimension.
OUString maLayoutName; ///< Layout name (display name)
sal_uInt8 mnDupCount;
ScDPName();
explicit ScDPName(const OUString& rName, const OUString& rLayoutName, sal_uInt8 nDupCount);
};
struct ScDPLabelData
{
OUString maName; ///< Original name of the dimension.
OUString maLayoutName; ///< Layout name (display name)
OUString maSubtotalName;
SCCOL mnCol; ///< 0-based field index (not the source column index)
tools::Long mnOriginalDim; ///< original dimension index (>= 0 for duplicated dimension)
PivotFunc mnFuncMask; ///< Page/Column/Row subtotal function.
sal_Int32 mnUsedHier; ///< Used hierarchy.
sal_Int32 mnFlags; ///< Flags from the DataPilotSource dimension
sal_uInt8 mnDupCount;
bool mbShowAll:1; ///< true = Show all (also empty) results.
bool mbIsValue:1; ///< true = Sum or count in data field.
bool mbDataLayout:1;
bool mbRepeatItemLabels:1;
struct Member
{
OUString maName;
OUString maLayoutName;
bool mbVisible;
bool mbShowDetails;
Member();
/**
* @return the name that should be displayed in the dp dialogs i.e.
* when the layout name is present, use it, or else use the original
* name.
*/
SC_DLLPUBLIC OUString const & getDisplayName() const;
};
std::vector<Member> maMembers;
css::uno::Sequence<OUString> maHiers; ///< Hierarchies.
css::sheet::DataPilotFieldSortInfo maSortInfo; ///< Sorting info.
css::sheet::DataPilotFieldLayoutInfo maLayoutInfo; ///< Layout info.
css::sheet::DataPilotFieldAutoShowInfo maShowInfo; ///< AutoShow info.
ScDPLabelData();
/**
* @return the name that should be displayed in the dp dialogs i.e. when
* the layout name is present, use it, or else use the original name.
*/
SC_DLLPUBLIC OUString const & getDisplayName() const;
};
typedef std::vector< std::unique_ptr<ScDPLabelData> > ScDPLabelDataVector;
struct ScPivotField
{
css::sheet::DataPilotFieldReference maFieldRef;
tools::Long mnOriginalDim; ///< >= 0 for duplicated field.
PivotFunc nFuncMask;
SCCOL nCol; ///< 0-based dimension index (not source column index)
sal_uInt8 mnDupCount;
explicit ScPivotField( SCCOL nNewCol = 0 );
tools::Long getOriginalDim() const;
};
typedef std::vector< ScPivotField > ScPivotFieldVector;
struct ScPivotParam
{
SCCOL nCol; ///< Cursor Position /
SCROW nRow; ///< or start of destination area
SCTAB nTab;
ScDPLabelDataVector maLabelArray;
ScPivotFieldVector maPageFields;
ScPivotFieldVector maColFields;
ScPivotFieldVector maRowFields;
ScPivotFieldVector maDataFields;
bool bIgnoreEmptyRows;
bool bDetectCategories;
bool bMakeTotalCol;
bool bMakeTotalRow;
ScPivotParam();
ScPivotParam( const ScPivotParam& r );
~ScPivotParam();
ScPivotParam& operator= ( const ScPivotParam& r );
void SetLabelData(const ScDPLabelDataVector& r);
};
struct ScPivotFuncData
{
css::sheet::DataPilotFieldReference maFieldRef;
tools::Long mnOriginalDim;
PivotFunc mnFuncMask;
SCCOL mnCol;
sal_uInt8 mnDupCount;
explicit ScPivotFuncData( SCCOL nCol, PivotFunc nFuncMask );
#if DEBUG_PIVOT_TABLE
void Dump() const;
#endif
};
typedef std::vector<ScDPName> ScDPNameVec;
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */