xref: /aoo41x/main/sc/source/core/data/pivot2.cxx (revision b3f79822)
1*b3f79822SAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3*b3f79822SAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4*b3f79822SAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5*b3f79822SAndrew Rist  * distributed with this work for additional information
6*b3f79822SAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7*b3f79822SAndrew Rist  * to you under the Apache License, Version 2.0 (the
8*b3f79822SAndrew Rist  * "License"); you may not use this file except in compliance
9*b3f79822SAndrew Rist  * with the License.  You may obtain a copy of the License at
10*b3f79822SAndrew Rist  *
11*b3f79822SAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12*b3f79822SAndrew Rist  *
13*b3f79822SAndrew Rist  * Unless required by applicable law or agreed to in writing,
14*b3f79822SAndrew Rist  * software distributed under the License is distributed on an
15*b3f79822SAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b3f79822SAndrew Rist  * KIND, either express or implied.  See the License for the
17*b3f79822SAndrew Rist  * specific language governing permissions and limitations
18*b3f79822SAndrew Rist  * under the License.
19*b3f79822SAndrew Rist  *
20*b3f79822SAndrew Rist  *************************************************************/
21*b3f79822SAndrew Rist 
22*b3f79822SAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
25cdf0e10cSrcweir #include "precompiled_sc.hxx"
26cdf0e10cSrcweir 
27cdf0e10cSrcweir #ifdef _MSC_VER
28cdf0e10cSrcweir #pragma optimize("",off)
29cdf0e10cSrcweir #endif
30cdf0e10cSrcweir 
31cdf0e10cSrcweir // INCLUDE ---------------------------------------------------------------
32cdf0e10cSrcweir 
33cdf0e10cSrcweir #include "scitems.hxx"
34cdf0e10cSrcweir #include <editeng/boxitem.hxx>
35cdf0e10cSrcweir #include <editeng/wghtitem.hxx>
36cdf0e10cSrcweir #include <svx/algitem.hxx>
37cdf0e10cSrcweir #include <unotools/transliterationwrapper.hxx>
38cdf0e10cSrcweir 
39cdf0e10cSrcweir #include "globstr.hrc"
40cdf0e10cSrcweir #include "subtotal.hxx"
41cdf0e10cSrcweir #include "rangeutl.hxx"
42cdf0e10cSrcweir #include "attrib.hxx"
43cdf0e10cSrcweir #include "patattr.hxx"
44cdf0e10cSrcweir #include "docpool.hxx"
45cdf0e10cSrcweir #include "document.hxx"
46cdf0e10cSrcweir #include "userlist.hxx"
47cdf0e10cSrcweir #include "pivot.hxx"
48cdf0e10cSrcweir #include "rechead.hxx"
49cdf0e10cSrcweir #include "formula/errorcodes.hxx"							// fuer errNoValue
50cdf0e10cSrcweir #include "refupdat.hxx"
51cdf0e10cSrcweir #include "stlpool.hxx"
52cdf0e10cSrcweir #include "stlsheet.hxx"
53cdf0e10cSrcweir 
54cdf0e10cSrcweir using ::com::sun::star::sheet::DataPilotFieldReference;
55cdf0e10cSrcweir using ::rtl::OUString;
56cdf0e10cSrcweir 
57cdf0e10cSrcweir // ============================================================================
58cdf0e10cSrcweir 
Member()59cdf0e10cSrcweir ScDPLabelData::Member::Member() :
60cdf0e10cSrcweir     mbVisible(true),
61cdf0e10cSrcweir     mbShowDetails(true)
62cdf0e10cSrcweir {
63cdf0e10cSrcweir }
64cdf0e10cSrcweir 
getDisplayName() const65cdf0e10cSrcweir OUString ScDPLabelData::Member::getDisplayName() const
66cdf0e10cSrcweir {
67cdf0e10cSrcweir     if (maLayoutName.getLength())
68cdf0e10cSrcweir         return maLayoutName;
69cdf0e10cSrcweir 
70cdf0e10cSrcweir     return maName;
71cdf0e10cSrcweir }
72cdf0e10cSrcweir 
ScDPLabelData(const String & rName,SCCOL nCol,bool bIsValue)73cdf0e10cSrcweir ScDPLabelData::ScDPLabelData( const String& rName, SCCOL nCol, bool bIsValue ) :
74cdf0e10cSrcweir     maName( rName ),
75cdf0e10cSrcweir     mnCol( nCol ),
76cdf0e10cSrcweir     mnFuncMask( PIVOT_FUNC_NONE ),
77cdf0e10cSrcweir     mnUsedHier( 0 ),
78cdf0e10cSrcweir     mnFlags( 0 ),
79cdf0e10cSrcweir     mbShowAll( false ),
80cdf0e10cSrcweir     mbIsValue( bIsValue )
81cdf0e10cSrcweir {
82cdf0e10cSrcweir }
83cdf0e10cSrcweir 
getDisplayName() const84cdf0e10cSrcweir OUString ScDPLabelData::getDisplayName() const
85cdf0e10cSrcweir {
86cdf0e10cSrcweir     if (maLayoutName.getLength())
87cdf0e10cSrcweir         return maLayoutName;
88cdf0e10cSrcweir 
89cdf0e10cSrcweir     return maName;
90cdf0e10cSrcweir }
91cdf0e10cSrcweir 
92cdf0e10cSrcweir // ============================================================================
93cdf0e10cSrcweir 
ScPivotField(SCCOL nNewCol,sal_uInt16 nNewFuncMask)94cdf0e10cSrcweir ScPivotField::ScPivotField( SCCOL nNewCol, sal_uInt16 nNewFuncMask ) :
95cdf0e10cSrcweir     nCol( nNewCol ),
96cdf0e10cSrcweir     nFuncMask( nNewFuncMask ),
97cdf0e10cSrcweir     nFuncCount( 0 )
98cdf0e10cSrcweir {
99cdf0e10cSrcweir }
100cdf0e10cSrcweir 
operator ==(const ScPivotField & r) const101cdf0e10cSrcweir bool ScPivotField::operator==( const ScPivotField& r ) const
102cdf0e10cSrcweir {
103cdf0e10cSrcweir     return (nCol                            == r.nCol)
104cdf0e10cSrcweir         && (nFuncMask                       == r.nFuncMask)
105cdf0e10cSrcweir         && (nFuncCount                      == r.nFuncCount)
106cdf0e10cSrcweir         && (maFieldRef.ReferenceType        == r.maFieldRef.ReferenceType)
107cdf0e10cSrcweir         && (maFieldRef.ReferenceField       == r.maFieldRef.ReferenceField)
108cdf0e10cSrcweir         && (maFieldRef.ReferenceItemType    == r.maFieldRef.ReferenceItemType)
109cdf0e10cSrcweir         && (maFieldRef.ReferenceItemName    == r.maFieldRef.ReferenceItemName);
110cdf0e10cSrcweir }
111cdf0e10cSrcweir 
112cdf0e10cSrcweir // ============================================================================
113cdf0e10cSrcweir 
ScPivotParam()114cdf0e10cSrcweir ScPivotParam::ScPivotParam()
115cdf0e10cSrcweir 	:	nCol( 0 ), nRow( 0 ), nTab( 0 ),
116cdf0e10cSrcweir 		bIgnoreEmptyRows( false ), bDetectCategories( false ),
117cdf0e10cSrcweir 		bMakeTotalCol( true ), bMakeTotalRow( true )
118cdf0e10cSrcweir {
119cdf0e10cSrcweir }
120cdf0e10cSrcweir 
operator ==(const ScPivotParam & r) const121cdf0e10cSrcweir bool ScPivotParam::operator==( const ScPivotParam& r ) const
122cdf0e10cSrcweir {
123cdf0e10cSrcweir 	return
124cdf0e10cSrcweir         (nCol == r.nCol)
125cdf0e10cSrcweir 	 &&	(nRow == r.nRow)
126cdf0e10cSrcweir 	 && (nTab == r.nTab)
127cdf0e10cSrcweir 	 && (bIgnoreEmptyRows  == r.bIgnoreEmptyRows)
128cdf0e10cSrcweir 	 && (bDetectCategories == r.bDetectCategories)
129cdf0e10cSrcweir 	 && (bMakeTotalCol == r.bMakeTotalCol)
130cdf0e10cSrcweir 	 && (bMakeTotalRow == r.bMakeTotalRow)
131cdf0e10cSrcweir      && (maLabelArray.size() == r.maLabelArray.size())  // ! only size??
132cdf0e10cSrcweir      && (maPageArr == r.maPageArr)
133cdf0e10cSrcweir 	 && (maColArr == r.maColArr)
134cdf0e10cSrcweir 	 && (maRowArr == r.maRowArr)
135cdf0e10cSrcweir 	 && (maDataArr == r.maDataArr);
136cdf0e10cSrcweir }
137cdf0e10cSrcweir 
138cdf0e10cSrcweir // ============================================================================
139cdf0e10cSrcweir 
ScPivotFuncData(SCCOL nCol,sal_uInt16 nFuncMask)140cdf0e10cSrcweir ScPivotFuncData::ScPivotFuncData( SCCOL nCol, sal_uInt16 nFuncMask ) :
141cdf0e10cSrcweir     mnCol( nCol ),
142cdf0e10cSrcweir     mnFuncMask( nFuncMask )
143cdf0e10cSrcweir {
144cdf0e10cSrcweir }
145cdf0e10cSrcweir 
ScPivotFuncData(SCCOL nCol,sal_uInt16 nFuncMask,const DataPilotFieldReference & rFieldRef)146cdf0e10cSrcweir ScPivotFuncData::ScPivotFuncData( SCCOL nCol, sal_uInt16 nFuncMask, const DataPilotFieldReference& rFieldRef ) :
147cdf0e10cSrcweir     mnCol( nCol ),
148cdf0e10cSrcweir     mnFuncMask( nFuncMask ),
149cdf0e10cSrcweir     maFieldRef( rFieldRef )
150cdf0e10cSrcweir {
151cdf0e10cSrcweir }
152cdf0e10cSrcweir 
153cdf0e10cSrcweir // ============================================================================
154cdf0e10cSrcweir 
155