d4cd867788
This reduces the total time required for populating the pivot cache by ~60%. Change-Id: I6a8511959c20231a8a5dbd0b0a9a3d0930a1fa0c Reviewed-on: https://gerrit.libreoffice.org/37971 Tested-by: Jenkins <ci@libreoffice.org> Reviewed-by: Kohei Yoshida <libreoffice@kohei.us>
176 lines
4.8 KiB
C++
176 lines
4.8 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/.
|
|
*/
|
|
|
|
#ifndef INCLUDED_SC_INC_CELLVALUE_HXX
|
|
#define INCLUDED_SC_INC_CELLVALUE_HXX
|
|
|
|
#include "global.hxx"
|
|
|
|
class ScDocument;
|
|
class ScFormulaCell;
|
|
class EditTextObject;
|
|
class ScColumn;
|
|
struct ScRefCellValue;
|
|
|
|
namespace svl {
|
|
|
|
class SharedString;
|
|
|
|
}
|
|
|
|
/**
|
|
* Store arbitrary cell value of any kind. It only stores cell value and
|
|
* nothing else. It creates a copy of the original cell value, and manages
|
|
* the life cycle of the copied value.
|
|
*/
|
|
struct SC_DLLPUBLIC ScCellValue
|
|
{
|
|
CellType meType;
|
|
union {
|
|
double mfValue;
|
|
svl::SharedString* mpString;
|
|
EditTextObject* mpEditText;
|
|
ScFormulaCell* mpFormula;
|
|
};
|
|
|
|
ScCellValue();
|
|
ScCellValue( const ScRefCellValue& rCell );
|
|
ScCellValue( double fValue );
|
|
ScCellValue( const svl::SharedString& rString );
|
|
ScCellValue( const ScCellValue& r );
|
|
~ScCellValue();
|
|
|
|
void clear();
|
|
|
|
void set( double fValue );
|
|
void set( const svl::SharedString& rStr );
|
|
void set( const EditTextObject& rEditText );
|
|
void set( EditTextObject* pEditText );
|
|
void set( ScFormulaCell* pFormula );
|
|
|
|
/**
|
|
* Take cell value from specified position in specified document.
|
|
*/
|
|
void assign( const ScDocument& rDoc, const ScAddress& rPos );
|
|
|
|
void assign(const ScCellValue& rOther, ScDocument& rDestDoc, ScCloneFlags nCloneFlags = ScCloneFlags::Default);
|
|
|
|
/**
|
|
* Set cell value at specified position in specified document.
|
|
*/
|
|
void commit( ScDocument& rDoc, const ScAddress& rPos ) const;
|
|
|
|
void commit( ScColumn& rColumn, SCROW nRow ) const;
|
|
|
|
/**
|
|
* Set cell value at specified position in specified document. But unlike
|
|
* commit(), this method sets the original value to the document without
|
|
* copying. After this call, the value gets cleared.
|
|
*/
|
|
void release( ScDocument& rDoc, const ScAddress& rPos );
|
|
|
|
void release( ScColumn& rColumn, SCROW nRow, sc::StartListeningType eListenType = sc::SingleCellListening );
|
|
|
|
OUString getString( const ScDocument* pDoc );
|
|
|
|
bool isEmpty() const;
|
|
|
|
bool equalsWithoutFormat( const ScCellValue& r ) const;
|
|
|
|
ScCellValue& operator= ( const ScCellValue& r );
|
|
ScCellValue& operator= ( const ScRefCellValue& r );
|
|
|
|
void swap( ScCellValue& r );
|
|
};
|
|
|
|
/**
|
|
* This is very similar to ScCellValue, except that it references the
|
|
* original value instead of copying it. As such, don't hold an instance of
|
|
* this class any longer than necessary, and absolutely not after the
|
|
* original cell has been destroyed.
|
|
*/
|
|
struct SC_DLLPUBLIC ScRefCellValue
|
|
{
|
|
CellType meType;
|
|
union {
|
|
double mfValue;
|
|
const svl::SharedString* mpString;
|
|
const EditTextObject* mpEditText;
|
|
ScFormulaCell* mpFormula;
|
|
};
|
|
|
|
ScRefCellValue();
|
|
ScRefCellValue( double fValue );
|
|
ScRefCellValue( const svl::SharedString* pString );
|
|
ScRefCellValue( const EditTextObject* pEditText );
|
|
ScRefCellValue( ScFormulaCell* pFormula );
|
|
|
|
/**
|
|
* Take cell value from specified position in specified document.
|
|
*/
|
|
ScRefCellValue( ScDocument& rDoc, const ScAddress& rPos );
|
|
|
|
void clear();
|
|
|
|
/**
|
|
* Take cell value from specified position in specified document.
|
|
*/
|
|
void assign( ScDocument& rDoc, const ScAddress& rPos );
|
|
|
|
/**
|
|
* Set cell value at specified position in specified document.
|
|
*/
|
|
void commit( ScDocument& rDoc, const ScAddress& rPos ) const;
|
|
|
|
bool hasString() const;
|
|
|
|
bool hasNumeric() const;
|
|
|
|
bool hasError() const;
|
|
|
|
double getValue();
|
|
|
|
/**
|
|
* Retrieve a numeric value without modifying the states of any objects in
|
|
* the referenced document store.
|
|
*/
|
|
double getRawValue() const;
|
|
|
|
/**
|
|
* Retrieve string value.
|
|
*
|
|
* Note that this method is NOT thread-safe.
|
|
*
|
|
* @param pDoc
|
|
* Needed to resolve EditCells' field contents, obtain a
|
|
* ScFieldEditEngine from that document. May be NULL if there is
|
|
* no ScDocument in the calling context but then the document
|
|
* specific fields can not be resolved. See
|
|
* ScEditUtil::GetString().
|
|
*/
|
|
OUString getString( const ScDocument* pDoc );
|
|
|
|
/**
|
|
* Retrieve a string value without modifying the states of any objects in
|
|
* the referenced document store.
|
|
*
|
|
* This method is thread-safe.
|
|
*/
|
|
OUString getRawString( const ScDocument* pDoc ) const;
|
|
|
|
bool isEmpty() const;
|
|
|
|
bool hasEmptyValue();
|
|
|
|
bool equalsWithoutFormat( const ScRefCellValue& r ) const;
|
|
};
|
|
|
|
#endif
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|