2010-10-27 06:43:08 -05:00
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
2010-02-03 10:59:00 -06:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
|
|
*
|
|
|
|
* Copyright IBM Corporation 2009.
|
|
|
|
* Copyright 2009 by Sun Microsystems, Inc.
|
|
|
|
*
|
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
|
|
|
*
|
|
|
|
* This file is part of OpenOffice.org.
|
|
|
|
*
|
|
|
|
* OpenOffice.org is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Lesser General Public License version 3
|
|
|
|
* only, as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* OpenOffice.org is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Lesser General Public License version 3 for more details
|
|
|
|
* (a copy is included in the LICENSE file that accompanied this code).
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* version 3 along with OpenOffice.org. If not, see
|
|
|
|
* <http://www.openoffice.org/license.html>
|
|
|
|
* for a copy of the LGPLv3 License.
|
|
|
|
*
|
|
|
|
************************************************************************/
|
2010-11-12 15:34:27 -06:00
|
|
|
#ifndef SC_DPTABLECACHE_HXX
|
|
|
|
#define SC_DPTABLECACHE_HXX
|
|
|
|
|
2010-02-03 10:59:00 -06:00
|
|
|
#include "global.hxx"
|
2010-02-05 08:35:28 -06:00
|
|
|
#include <svl/zforlist.hxx>
|
2010-02-03 10:59:00 -06:00
|
|
|
#include "dpglobal.hxx"
|
|
|
|
|
|
|
|
#include <com/sun/star/sdbc/DataType.hpp>
|
|
|
|
#include <com/sun/star/sdbc/XRow.hpp>
|
|
|
|
#include <com/sun/star/sdbc/XRowSet.hpp>
|
|
|
|
|
2011-01-20 00:44:56 -06:00
|
|
|
#include <vector>
|
|
|
|
#include <boost/ptr_container/ptr_vector.hpp>
|
|
|
|
|
2010-04-01 09:52:08 -05:00
|
|
|
struct ScQueryParam;
|
|
|
|
|
2011-02-28 23:24:37 -06:00
|
|
|
/**
|
|
|
|
* This class represents the cached data part of the datapilot cache table
|
|
|
|
* implementation.
|
|
|
|
*/
|
|
|
|
class SC_DLLPUBLIC ScDPCache
|
2010-02-03 10:59:00 -06:00
|
|
|
{
|
2011-01-20 01:08:28 -06:00
|
|
|
public:
|
|
|
|
typedef ::boost::ptr_vector<ScDPItemData> DataListType;
|
|
|
|
private:
|
|
|
|
typedef ::boost::ptr_vector<DataListType> DataGridType;
|
|
|
|
typedef ::boost::ptr_vector< ::std::vector<SCROW> > RowGridType;
|
2011-01-20 00:44:56 -06:00
|
|
|
|
2010-02-03 10:59:00 -06:00
|
|
|
ScDocument* mpDoc;
|
2011-02-28 21:02:53 -06:00
|
|
|
long mnColumnCount;
|
2010-11-12 17:03:35 -06:00
|
|
|
|
2011-04-29 18:38:19 -05:00
|
|
|
/**
|
|
|
|
* This container stores only the unique instances of item data in each
|
|
|
|
* column. Duplicates are not allowed.
|
|
|
|
*/
|
|
|
|
DataGridType maTableDataValues;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This container stores indices within maTableDataValues pointing to the
|
|
|
|
* data. The order of data are exactly as they appear in the original
|
|
|
|
* data source.
|
|
|
|
*/
|
|
|
|
RowGridType maSourceData;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This container stores indices within maTableDataValues. The order of
|
|
|
|
* indices in each column represents ascending order of the actual data.
|
|
|
|
*/
|
|
|
|
RowGridType maGlobalOrder;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This container stores the ranks of each unique data represented by
|
|
|
|
* their index.
|
|
|
|
*/
|
|
|
|
mutable RowGridType maIndexOrder;
|
|
|
|
|
|
|
|
DataListType maLabelNames; // Stores dimension names.
|
|
|
|
std::vector<bool> mbEmptyRow; // Keeps track of empty rows.
|
2010-11-12 17:03:35 -06:00
|
|
|
|
2011-01-12 21:54:55 -06:00
|
|
|
mutable ScDPItemDataPool maAdditionalData;
|
2010-02-03 10:59:00 -06:00
|
|
|
|
|
|
|
public:
|
2011-05-02 17:15:14 -05:00
|
|
|
SCROW GetIdByItemData( long nDim, const String& sItemData ) const;
|
2010-02-03 10:59:00 -06:00
|
|
|
SCROW GetIdByItemData( long nDim, const ScDPItemData& rData ) const;
|
|
|
|
|
2011-05-02 17:15:14 -05:00
|
|
|
SCROW GetAdditionalItemID ( const String& sItemData ) const;
|
2011-02-28 17:14:22 -06:00
|
|
|
SCROW GetAdditionalItemID( const ScDPItemData& rData ) const;
|
2010-02-03 10:59:00 -06:00
|
|
|
|
|
|
|
SCCOL GetDimensionIndex( String sName) const;
|
|
|
|
const ScDPItemData* GetSortedItemData( SCCOL nDim, SCROW nOrder ) const;
|
2011-01-17 06:20:22 -06:00
|
|
|
sal_uLong GetNumType ( sal_uLong nFormat ) const;
|
|
|
|
sal_uLong GetNumberFormat( long nDim ) const;
|
2010-11-12 15:34:27 -06:00
|
|
|
bool IsDateDimension( long nDim ) const ;
|
2011-01-17 06:20:22 -06:00
|
|
|
sal_uLong GetDimNumType( SCCOL nDim) const;
|
2010-02-03 10:59:00 -06:00
|
|
|
SCROW GetDimMemberCount( SCCOL nDim ) const;
|
2011-04-29 20:11:21 -05:00
|
|
|
SCROW GetOrder( long nDim, SCROW nIndex ) const;
|
2010-02-03 10:59:00 -06:00
|
|
|
|
|
|
|
SCROW GetSortedItemDataId( SCCOL nDim, SCROW nOrder ) const;
|
2011-01-20 01:08:28 -06:00
|
|
|
const DataListType& GetDimMemberValues( SCCOL nDim ) const;
|
2011-01-12 21:54:55 -06:00
|
|
|
bool InitFromDoc(ScDocument* pDoc, const ScRange& rRange);
|
|
|
|
bool InitFromDataBase(const ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XRowSet>& xRowSet, const Date& rNullDate);
|
|
|
|
|
|
|
|
SCROW GetRowCount() const;
|
2011-03-10 15:55:21 -06:00
|
|
|
SCROW GetItemDataId( sal_uInt16 nDim, SCROW nRow, bool bRepeatIfEmpty ) const;
|
|
|
|
String GetDimensionName( sal_uInt16 nColumn ) const;
|
|
|
|
bool IsEmptyMember( SCROW nRow, sal_uInt16 nColumn ) const;
|
2011-01-12 21:54:55 -06:00
|
|
|
bool IsRowEmpty( SCROW nRow ) const;
|
|
|
|
bool IsValid() const;
|
2011-11-14 15:54:44 -06:00
|
|
|
bool ValidQuery(SCROW nRow, const ScQueryParam& rQueryParam) const;
|
2010-02-03 10:59:00 -06:00
|
|
|
|
|
|
|
ScDocument* GetDoc() const;//ms-cache-core
|
|
|
|
long GetColumnCount() const;
|
|
|
|
|
|
|
|
const ScDPItemData* GetItemDataById( long nDim, SCROW nId ) const;
|
|
|
|
|
2011-02-28 23:24:37 -06:00
|
|
|
bool operator== ( const ScDPCache& r ) const;
|
2010-02-03 10:59:00 -06:00
|
|
|
|
2011-02-28 23:24:37 -06:00
|
|
|
ScDPCache(ScDocument* pDoc);
|
2011-04-29 19:54:25 -05:00
|
|
|
~ScDPCache();
|
2010-02-03 10:59:00 -06:00
|
|
|
|
|
|
|
private:
|
2011-01-12 21:54:55 -06:00
|
|
|
void AddLabel( ScDPItemData* pData);
|
2011-04-29 18:38:19 -05:00
|
|
|
bool AddData(long nDim, ScDPItemData* pData);
|
2010-02-03 10:59:00 -06:00
|
|
|
};
|
|
|
|
|
2010-11-12 17:03:35 -06:00
|
|
|
#endif
|
2010-10-27 06:43:08 -05:00
|
|
|
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|