summaryrefslogtreecommitdiff
path: root/sc/source
diff options
context:
space:
mode:
authorKohei Yoshida <kohei.yoshida@suse.com>2012-02-09 14:58:06 -0500
committerKohei Yoshida <kohei.yoshida@suse.com>2012-02-09 15:25:09 -0500
commitdc261fc0c4e7f4c29b142c53d4d4e65f8ff3a092 (patch)
tree0c6b1658de8b5dad530753ded9d3b524ddad27ce /sc/source
parent692496aa2e9acbb4b428cd395dbeb2ec8c8abc1e (diff)
Cleaning up ScDPItemData a bit...
Diffstat (limited to 'sc/source')
-rw-r--r--sc/source/core/data/dpglobal.cxx48
-rw-r--r--sc/source/core/data/dptablecache.cxx14
2 files changed, 38 insertions, 24 deletions
diff --git a/sc/source/core/data/dpglobal.cxx b/sc/source/core/data/dpglobal.cxx
index 142c84f98e5f..cb210b1274ba 100644
--- a/sc/source/core/data/dpglobal.cxx
+++ b/sc/source/core/data/dpglobal.cxx
@@ -40,14 +40,20 @@ bool ScDPItemData::isDate( sal_uLong nNumType )
return ((nNumType & NUMBERFORMAT_DATE) != 0) ? 1 : 0;
}
+ScDPItemData::ScDPItemData() :
+ mnNumFormat( 0 ), mfValue(0.0), mbFlag(0) {}
+
+ScDPItemData::ScDPItemData(sal_uLong nNF, const String & rS, double fV, sal_uInt8 bF) :
+ mnNumFormat(nNF), maString(rS), mfValue(fV), mbFlag(bF) {}
+
ScDPItemData::ScDPItemData(const String& rS, double fV, bool bHV, const sal_uLong nNumFormatP, bool bData) :
- nNumFormat( nNumFormatP ), aString(rS), fValue(fV),
- mbFlag( (MK_VAL*!!bHV) | (MK_DATA*!!bData) | (MK_ERR*!!false) | (MK_DATE*!!isDate( nNumFormat ) ) )
+ mnNumFormat( nNumFormatP ), maString(rS), mfValue(fV),
+ mbFlag( (MK_VAL*!!bHV) | (MK_DATA*!!bData) | (MK_ERR*!!false) | (MK_DATE*!!isDate( mnNumFormat ) ) )
{
}
ScDPItemData::ScDPItemData(ScDocument* pDoc, SCCOL nCol, SCROW nRow, SCTAB nDocTab, bool bLabel) :
- nNumFormat( 0 ), fValue(0.0), mbFlag( 0 )
+ mnNumFormat( 0 ), mfValue(0.0), mbFlag( 0 )
{
String aDocStr;
pDoc->GetString( nCol, nRow, nDocTab, aDocStr );
@@ -68,10 +74,10 @@ ScDPItemData::ScDPItemData(ScDocument* pDoc, SCCOL nCol, SCROW nRow, SCTAB nDocT
sal_uLong nFormat = NUMBERFORMAT_NUMBER;
if ( pFormatter )
nFormat = pFormatter->GetType( pDoc->GetNumberFormat( ScAddress( nCol, nRow, nDocTab ) ) );
- aString = aDocStr;
- fValue = fVal;
+ maString = aDocStr;
+ mfValue = fVal;
mbFlag |= MK_VAL|MK_DATA;
- nNumFormat = pDoc->GetNumberFormat( ScAddress( nCol, nRow, nDocTab ) );
+ mnNumFormat = pDoc->GetNumberFormat( ScAddress( nCol, nRow, nDocTab ) );
isDate( nFormat ) ? ( mbFlag |= MK_DATE ) : (mbFlag &= ~MK_DATE);
}
else if (bLabel || pDoc->HasData(nCol, nRow, nDocTab))
@@ -94,23 +100,31 @@ ScDPItemData::ScDPItemData(ScDocument* pDoc, SCCOL nCol, SCROW nRow, SCTAB nDocT
}
}
+void ScDPItemData::SetString( const String& rS )
+{
+ maString = rS;
+ mbFlag &= ~(MK_VAL|MK_DATE);
+ mnNumFormat = 0;
+ mbFlag |= MK_DATA;
+}
+
bool ScDPItemData::IsCaseInsEqual( const ScDPItemData& r ) const
{
//! pass Transliteration?
//! inline?
- return IsValue() ? ( r.IsValue() && rtl::math::approxEqual( fValue, r.fValue ) ) :
+ return IsValue() ? ( r.IsValue() && rtl::math::approxEqual( mfValue, r.mfValue ) ) :
( !r.IsValue() &&
- ScGlobal::GetpTransliteration()->isEqual( aString, r.aString ) );
+ ScGlobal::GetpTransliteration()->isEqual( maString, r.maString ) );
}
size_t ScDPItemData::Hash() const
{
if ( IsValue() )
- return (size_t) rtl::math::approxFloor( fValue );
+ return (size_t) rtl::math::approxFloor( mfValue );
else
// If we do unicode safe case insensitive hash we can drop
// ScDPItemData::operator== and use ::IsCasInsEqual
- return rtl_ustr_hashCode_WithLength( aString.GetBuffer(), aString.Len() );
+ return rtl_ustr_hashCode_WithLength( maString.GetBuffer(), maString.Len() );
}
bool ScDPItemData::operator==( const ScDPItemData& r ) const
@@ -123,7 +137,7 @@ bool ScDPItemData::operator==( const ScDPItemData& r ) const
if ( IsDate() != r.IsDate() )
return false;
else if ( r.IsValue() )
- return rtl::math::approxEqual( fValue, r.fValue );
+ return rtl::math::approxEqual( mfValue, r.mfValue );
else
return false;
}
@@ -131,7 +145,7 @@ bool ScDPItemData::operator==( const ScDPItemData& r ) const
return false;
else
// need exact equality until we have a safe case insensitive string hash
- return aString == r.aString;
+ return maString == r.maString;
}
sal_Int32 ScDPItemData::Compare( const ScDPItemData& rA,
@@ -141,14 +155,14 @@ sal_Int32 ScDPItemData::Compare( const ScDPItemData& rA,
{
if ( rB.IsValue() )
{
- if ( rtl::math::approxEqual( rA.fValue, rB.fValue ) )
+ if ( rtl::math::approxEqual( rA.mfValue, rB.mfValue ) )
{
if ( rA.IsDate() == rB.IsDate() )
return 0;
else
return rA.IsDate() ? 1: -1;
}
- else if ( rA.fValue < rB.fValue )
+ else if ( rA.mfValue < rB.mfValue )
return -1;
else
return 1;
@@ -159,7 +173,7 @@ sal_Int32 ScDPItemData::Compare( const ScDPItemData& rA,
else if ( rB.IsValue() )
return 1; // values first
else
- return ScGlobal::GetCollator()->compareString( rA.aString, rB.aString );
+ return ScGlobal::GetCollator()->compareString( rA.maString, rB.maString );
}
sal_uInt8 ScDPItemData::GetType() const
@@ -191,12 +205,12 @@ bool ScDPItemData::IsValue() const
String ScDPItemData::GetString() const
{
- return aString;
+ return maString;
}
double ScDPItemData::GetValue() const
{
- return fValue;
+ return mfValue;
}
bool ScDPItemData::HasStringData() const
diff --git a/sc/source/core/data/dptablecache.cxx b/sc/source/core/data/dptablecache.cxx
index fc73fb0f09ab..e81d3a52f2f3 100644
--- a/sc/source/core/data/dptablecache.cxx
+++ b/sc/source/core/data/dptablecache.cxx
@@ -595,7 +595,7 @@ bool ScDPCache::AddData(long nDim, ScDPItemData* pData)
// Wrap this instance with scoped pointer to ensure proper deletion.
auto_ptr<ScDPItemData> p(pData);
- pData->SetDate(ScDPItemData::isDate(GetNumType(pData->nNumFormat)));
+ pData->SetDate(ScDPItemData::isDate(GetNumType(pData->mnNumFormat)));
SCROW nIndex = 0;
if (!hasItemInDimension(maTableDataValues[nDim], maGlobalOrder[nDim], *pData, nIndex))
@@ -628,7 +628,7 @@ String ScDPCache::GetDimensionName( sal_uInt16 nColumn ) const
if ( static_cast<size_t>(nColumn+1) < maLabelNames.size() )
{
- return maLabelNames[nColumn+1].aString;
+ return maLabelNames[nColumn+1].maString;
}
else
return String();
@@ -642,16 +642,16 @@ void ScDPCache::AddLabel(ScDPItemData *pData)
maLabelNames.push_back( new ScDPItemData(ScGlobal::GetRscString(STR_PIVOT_DATA)) );
//reset name if needed
- String strNewName = pData->aString;
+ String strNewName = pData->maString;
bool bFound = false;
long nIndex = 1;
do
{
for ( long i= maLabelNames.size()-1; i>=0; i-- )
{
- if( maLabelNames[i].aString == strNewName )
+ if( maLabelNames[i].maString == strNewName )
{
- strNewName = pData->aString;
+ strNewName = pData->maString;
strNewName += String::CreateFromInt32( nIndex );
nIndex ++ ;
bFound = true;
@@ -661,7 +661,7 @@ void ScDPCache::AddLabel(ScDPItemData *pData)
}
while ( !bFound );
- pData->aString = strNewName;
+ pData->maString = strNewName;
maLabelNames.push_back( pData );
}
@@ -732,7 +732,7 @@ sal_uLong ScDPCache::GetNumberFormat( long nDim ) const
nCount = 10;
for (size_t i = 0; i < nCount; ++i)
{
- sal_uLong n = maTableDataValues[nDim][i].nNumFormat;
+ sal_uLong n = maTableDataValues[nDim][i].mnNumFormat;
if (n)
return n;
}