summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sc/inc/dptabres.hxx2
-rw-r--r--sc/inc/dptabsrc.hxx2
-rw-r--r--sc/source/core/data/dptabres.cxx24
-rw-r--r--sc/source/core/data/dptabsrc.cxx13
4 files changed, 16 insertions, 25 deletions
diff --git a/sc/inc/dptabres.hxx b/sc/inc/dptabres.hxx
index 4528c406d0da..a462ade90d8f 100644
--- a/sc/inc/dptabres.hxx
+++ b/sc/inc/dptabres.hxx
@@ -368,7 +368,7 @@ public:
OUString GetName() const;
OUString GetDisplayName( bool bLocaleIndependent ) const;
- void FillItemData( ScDPItemData& rData ) const;
+ ScDPItemData FillItemData() const;
bool IsValid() const;
bool IsVisible() const;
long GetSize(long nMeasure) const;
diff --git a/sc/inc/dptabsrc.hxx b/sc/inc/dptabsrc.hxx
index 998f77491cec..035aa1b85b01 100644
--- a/sc/inc/dptabsrc.hxx
+++ b/sc/inc/dptabsrc.hxx
@@ -741,7 +741,7 @@ public:
ScDPMember& operator=(const ScDPMember&) = delete;
OUString GetNameStr( bool bLocaleIndependent ) const;
- void FillItemData( ScDPItemData& rData ) const;
+ ScDPItemData FillItemData() const;
const ScDPItemData* GetItemData() const;
SCROW GetItemDataId() const { return mnDataId; }
bool IsNamedItem(SCROW nIndex) const;
diff --git a/sc/source/core/data/dptabres.cxx b/sc/source/core/data/dptabres.cxx
index 12a40ccef9a7..2d5e72d4c9f6 100644
--- a/sc/source/core/data/dptabres.cxx
+++ b/sc/source/core/data/dptabres.cxx
@@ -965,8 +965,7 @@ OUString ScDPResultMember::GetDisplayName( bool bLocaleIndependent ) const
if (!pDPMember)
return OUString();
- ScDPItemData aItem;
- pDPMember->FillItemData(aItem);
+ ScDPItemData aItem(pDPMember->FillItemData());
if (aParentDimData.mpParentDim)
{
long nDim = aParentDimData.mpParentDim->GetDimension();
@@ -976,13 +975,12 @@ OUString ScDPResultMember::GetDisplayName( bool bLocaleIndependent ) const
return aItem.GetString();
}
-void ScDPResultMember::FillItemData( ScDPItemData& rData ) const
+ScDPItemData ScDPResultMember::FillItemData() const
{
- const ScDPMember* pMemberDesc = GetDPMember();
+ const ScDPMember* pMemberDesc = GetDPMember();
if (pMemberDesc)
- pMemberDesc->FillItemData( rData );
- else
- rData.SetString( ScGlobal::GetRscString(STR_PIVOT_TOTAL) ); // root member
+ return pMemberDesc->FillItemData();
+ return ScDPItemData(ScGlobal::GetRscString(STR_PIVOT_TOTAL)); // root member
}
bool ScDPResultMember::IsNamedItem( SCROW nIndex ) const
@@ -1322,8 +1320,7 @@ void ScDPResultMember::FillMemberResults(
}
else
{
- ScDPItemData aItemData;
- FillItemData( aItemData );
+ ScDPItemData aItemData(FillItemData());
if (aParentDimData.mpParentDim)
{
long nDim = aParentDimData.mpParentDim->GetDimension();
@@ -2694,8 +2691,7 @@ bool ScDPGroupCompare::TestIncluded( const ScDPMember& rMember )
{
// need to check all previous groups
//TODO: get array of groups (or indexes) before loop?
- ScDPItemData aMemberData;
- rMember.FillItemData( aMemberData );
+ ScDPItemData aMemberData(rMember.FillItemData());
const std::vector<ScDPInitState::Member>& rMemStates = rInitState.GetMembers();
std::vector<ScDPInitState::Member>::const_iterator it = rMemStates.begin(), itEnd = rMemStates.end();
@@ -2714,8 +2710,7 @@ bool ScDPGroupCompare::TestIncluded( const ScDPMember& rMember )
// -> look for other groups using the same base
//TODO: get array of groups (or indexes) before loop?
- ScDPItemData aMemberData;
- rMember.FillItemData( aMemberData );
+ ScDPItemData aMemberData(rMember.FillItemData());
const std::vector<ScDPInitState::Member>& rMemStates = rInitState.GetMembers();
std::vector<ScDPInitState::Member>::const_iterator it = rMemStates.begin(), itEnd = rMemStates.end();
for (; it != itEnd && bInclude; ++it)
@@ -3510,8 +3505,7 @@ void ScDPResultDimension::FillVisibilityData(ScDPResultVisibilityData& rData) co
ScDPResultMember* pMember = *itr;
if (pMember->IsValid())
{
- ScDPItemData aItem;
- pMember->FillItemData(aItem);
+ ScDPItemData aItem(pMember->FillItemData());
rData.addVisibleMember(GetName(), aItem);
pMember->FillVisibilityData(rData);
}
diff --git a/sc/source/core/data/dptabsrc.cxx b/sc/source/core/data/dptabsrc.cxx
index 859b0caa929f..390bc0e89c1c 100644
--- a/sc/source/core/data/dptabsrc.cxx
+++ b/sc/source/core/data/dptabsrc.cxx
@@ -463,8 +463,7 @@ Sequence< Sequence<Any> > SAL_CALL ScDPSource::getDrillDownData(const Sequence<s
sal_Int32 nIndex = pMembers->GetIndexFromName( rFilter.MatchValueName );
if ( nIndex >= 0 )
{
- ScDPItemData aItem;
- pMembers->getByIndex(nIndex)->FillItemData( aItem );
+ ScDPItemData aItem(pMembers->getByIndex(nIndex)->FillItemData());
aFilterCriteria.push_back( ScDPFilteredCache::Criterion() );
aFilterCriteria.back().mnFieldIndex = nCol;
aFilterCriteria.back().mpFilter.reset(
@@ -737,8 +736,7 @@ void ScDPSource::FilterCacheByPageDimensions()
ScDPMember* pMem = pMems->getByIndex(j);
if (pMem->isVisible())
{
- ScDPItemData aData;
- pMem->FillItemData(aData);
+ ScDPItemData aData(pMem->FillItemData());
pGrpFilter->addMatchItem(aData);
}
}
@@ -1450,8 +1448,7 @@ const ScDPItemData& ScDPDimension::GetSelectedData()
ScDPMember* pMember = pMembers->getByIndex(i);
if (aSelectedPage.equals(pMember->GetNameStr( false)))
{
- pSelectedData = new ScDPItemData();
- pMember->FillItemData( *pSelectedData );
+ pSelectedData = new ScDPItemData(pMember->FillItemData());
}
}
}
@@ -2582,12 +2579,12 @@ sal_Int32 ScDPMember::Compare( const ScDPMember& rOther ) const
return pSource->GetData()->Compare( pSource->GetSourceDim(nDim),mnDataId,rOther.GetItemDataId());
}
-void ScDPMember::FillItemData( ScDPItemData& rData ) const
+ScDPItemData ScDPMember::FillItemData() const
{
//TODO: handle date hierarchy...
const ScDPItemData* pData = GetItemData();
- rData = (pData ? *pData : ScDPItemData());
+ return (pData ? *pData : ScDPItemData());
}
const OUString* ScDPMember::GetLayoutName() const