/************************************************************** * * 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 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * *************************************************************/ #ifndef SC_DPGROUP_HXX #define SC_DPGROUP_HXX #include #include #include #include "dptabdat.hxx" #include "scdllapi.h" // Wang Xu Ming -- 2009-8-17 // DataPilot Migration - Cache&&Performance #include "dpglobal.hxx" // End Comments class ScDocument; class SvNumberFormatter; // -------------------------------------------------------------------- //! API struct? struct ScDPNumGroupInfo { sal_Bool Enable; sal_Bool DateValues; sal_Bool AutoStart; sal_Bool AutoEnd; double Start; double End; double Step; ScDPNumGroupInfo() : Enable(sal_False), DateValues(sal_False), AutoStart(sal_False), AutoEnd(sal_False), Start(0.0), End(0.0), Step(0.0) {} }; // -------------------------------------------------------------------- // ScDPDateGroupHelper is used as part of ScDPGroupDimension (additional dim.) // or ScDPNumGroupDimension (innermost, replaces the original dim.). // Source index, name and result collection are stored at the parent. class ScDPDateGroupHelper { ScDPNumGroupInfo aNumInfo; // only start and end (incl. auto flags) are used sal_Int32 nDatePart; // single part public: ScDPDateGroupHelper( const ScDPNumGroupInfo& rInfo, sal_Int32 nPart ); ~ScDPDateGroupHelper(); sal_Int32 GetDatePart() const { return nDatePart; } const ScDPNumGroupInfo& GetNumInfo() const { return aNumInfo; } // Wang Xu Ming -- 2009-9-8 // DataPilot Migration - Cache&&Performance void FillColumnEntries( SCCOL nSourceDim, ScDPTableDataCache* pCahe , std::vector< SCROW >& rEntries, const std::vector< SCROW >& rOriginal ) const; // End Comments }; // -------------------------------------------------------------------- typedef ::std::vector ScDPItemDataVec; class ScDPGroupItem { ScDPItemData aGroupName; // name of group item ScDPItemDataVec aElements; // names of items in original dimension public: ScDPGroupItem( const ScDPItemData& rName ); ~ScDPGroupItem(); void AddElement( const ScDPItemData& rName ); const ScDPItemData& GetName() const { return aGroupName; } bool HasElement( const ScDPItemData& rData ) const; bool HasCommonElement( const ScDPGroupItem& rOther ) const; void FillGroupFilter( ScDPCacheTable::GroupFilter& rFilter ) const; }; typedef ::std::vector ScDPGroupItemVec; class ScDPGroupDimension { long nSourceDim; long nGroupDim; String aGroupName; ScDPDateGroupHelper* pDateHelper; ScDPGroupItemVec aItems; // Wang Xu Ming -- 2009-9-4 // DataPilot Migration - Cache&&Performance mutable ::std::vector< SCROW > maMemberEntries; // End Comments public: ScDPGroupDimension( long nSource, const String& rNewName ); ScDPGroupDimension( const ScDPGroupDimension& rOther ); ~ScDPGroupDimension(); ScDPGroupDimension& operator=( const ScDPGroupDimension& rOther ); void AddItem( const ScDPGroupItem& rItem ); void SetGroupDim( long nDim ); // called from AddGroupDimension long GetSourceDim() const { return nSourceDim; } long GetGroupDim() const { return nGroupDim; } const String& GetName() const { return aGroupName; } // Wang Xu Ming -- 2009-9-2 // DataPilot Migration - Cache&&Performance const std::vector< SCROW >& GetColumnEntries( const ScDPCacheTable& rCacheTable, const std::vector< SCROW >& rOriginal ) const; // End Comments const ScDPGroupItem* GetGroupForData( const ScDPItemData& rData ) const; // rData = entry in original dim. const ScDPGroupItem* GetGroupForName( const ScDPItemData& rName ) const; // rName = entry in group dim. const ScDPGroupItem* GetGroupByIndex( size_t nIndex ) const; const ScDPDateGroupHelper* GetDateHelper() const { return pDateHelper; } void MakeDateHelper( const ScDPNumGroupInfo& rInfo, sal_Int32 nPart ); void DisposeData(); size_t GetItemCount() const { return aItems.size(); } }; typedef ::std::vector ScDPGroupDimensionVec; // -------------------------------------------------------------------- class SC_DLLPUBLIC ScDPNumGroupDimension { ScDPNumGroupInfo aGroupInfo; // settings ScDPDateGroupHelper* pDateHelper; // Wang Xu Ming -- 2009-9-4 // DataPilot Migration - Cache&&Performance mutable ::std::vector< SCROW > maMemberEntries; // End Comments mutable bool bHasNonInteger; // initialized in GetNumEntries mutable sal_Unicode cDecSeparator; // initialized in GetNumEntries public: ScDPNumGroupDimension(); ScDPNumGroupDimension( const ScDPNumGroupInfo& rInfo ); ScDPNumGroupDimension( const ScDPNumGroupDimension& rOther ); ~ScDPNumGroupDimension(); ScDPNumGroupDimension& operator=( const ScDPNumGroupDimension& rOther ); const ScDPNumGroupInfo& GetInfo() const { return aGroupInfo; } bool HasNonInteger() const { return bHasNonInteger; } sal_Unicode GetDecSeparator() const { return cDecSeparator; } const ScDPDateGroupHelper* GetDateHelper() const { return pDateHelper; } const std::vector< SCROW >& GetNumEntries( SCCOL nSourceDim, ScDPTableDataCache* pCache, const std::vector< SCROW >& rOriginal ) const; void MakeDateHelper( const ScDPNumGroupInfo& rInfo, sal_Int32 nPart ); void DisposeData(); }; // -------------------------------------------------------------------- // // proxy implementation of ScDPTableData to add grouped items // class ScDPGroupTableData : public ScDPTableData { typedef ::std::hash_set< ::rtl::OUString, ::rtl::OUStringHash, ::std::equal_to< ::rtl::OUString > > StringHashSet; ::boost::shared_ptr pSourceData; long nSourceCount; ScDPGroupDimensionVec aGroups; ScDPNumGroupDimension* pNumGroups; // array[nSourceCount] ScDocument* pDoc; StringHashSet aGroupNames; // Wang Xu Ming -- 2009-8-17 // DataPilot Migration - Cache&&Performance void FillGroupValues( SCROW* pItemDataIndex, long nCount, const long* pDims ); virtual long GetSourceDim( long nDim ); // End Comments bool IsNumGroupDimension( long nDimension ) const; void GetNumGroupInfo( long nDimension, ScDPNumGroupInfo& rInfo, bool& rNonInteger, sal_Unicode& rDecimal ); void ModifyFilterCriteria(::std::vector& rCriteria); public: // takes ownership of pSource ScDPGroupTableData( const ::boost::shared_ptr& pSource, ScDocument* pDocument ); virtual ~ScDPGroupTableData(); void AddGroupDimension( const ScDPGroupDimension& rGroup ); void SetNumGroupDimension( long nIndex, const ScDPNumGroupDimension& rGroup ); long GetDimensionIndex( const String& rName ); ScDocument* GetDocument() { return pDoc; } virtual long GetColumnCount(); // Wang Xu Ming -- 2009-8-17 // DataPilot Migration - Cache&&Performance virtual long GetMembersCount( long nDim ); virtual const std::vector< SCROW >& GetColumnEntries( long nColumn ) ; virtual const ScDPItemData* GetMemberById( long nDim, long nId); virtual long Compare( long nDim, long nDataId1, long nDataId2); // End Comments virtual String getDimensionName(long nColumn); virtual sal_Bool getIsDataLayoutDimension(long nColumn); virtual sal_Bool IsDateDimension(long nDim); virtual sal_uLong GetNumberFormat(long nDim); virtual void DisposeData(); virtual void SetEmptyFlags( sal_Bool bIgnoreEmptyRows, sal_Bool bRepeatIfEmpty ); virtual bool IsRepeatIfEmpty(); virtual void CreateCacheTable(); virtual void FilterCacheTable(const ::std::vector& rCriteria, const ::std::hash_set& rDataDims); virtual void GetDrillDownData(const ::std::vector& rCriteria, const ::std::hash_set& rCatDims, ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Any > >& rData); virtual void CalcResults(CalcInfo& rInfo, bool bAutoShow); virtual const ScDPCacheTable& GetCacheTable() const; virtual sal_Bool IsBaseForGroup(long nDim) const; virtual long GetGroupBase(long nGroupDim) const; virtual sal_Bool IsNumOrDateGroup(long nDim) const; virtual sal_Bool IsInGroup( const ScDPItemData& rGroupData, long nGroupIndex, const ScDPItemData& rBaseData, long nBaseIndex ) const; virtual sal_Bool HasCommonElement( const ScDPItemData& rFirstData, long nFirstIndex, const ScDPItemData& rSecondData, long nSecondIndex ) const; }; #endif