summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sw/source/core/inc/unoport.hxx10
-rw-r--r--sw/source/core/unocore/unoport.cxx37
2 files changed, 25 insertions, 22 deletions
diff --git a/sw/source/core/inc/unoport.hxx b/sw/source/core/inc/unoport.hxx
index d0d9b5b64176..5bdade8eda6e 100644
--- a/sw/source/core/inc/unoport.hxx
+++ b/sw/source/core/inc/unoport.hxx
@@ -111,11 +111,11 @@ private:
m_xMeta;
css::uno::Reference<css::text::XTextContent> m_xLineBreak;
css::uno::Reference<css::text::XTextContent> m_xContentControl;
- std::unique_ptr< css::uno::Any > m_pRubyText;
- std::unique_ptr< css::uno::Any > m_pRubyStyle;
- std::unique_ptr< css::uno::Any > m_pRubyAdjust;
- std::unique_ptr< css::uno::Any > m_pRubyIsAbove;
- std::unique_ptr< css::uno::Any > m_pRubyPosition;
+ std::optional< css::uno::Any > m_oRubyText;
+ std::optional< css::uno::Any > m_oRubyStyle;
+ std::optional< css::uno::Any > m_oRubyAdjust;
+ std::optional< css::uno::Any > m_oRubyIsAbove;
+ std::optional< css::uno::Any > m_oRubyPosition;
sw::UnoCursorPointer m_pUnoCursor;
SwFrameFormat* m_pFrameFormat;
diff --git a/sw/source/core/unocore/unoport.cxx b/sw/source/core/unocore/unoport.cxx
index a10da8a9c35f..1a4c065df2cd 100644
--- a/sw/source/core/unocore/unoport.cxx
+++ b/sw/source/core/unocore/unoport.cxx
@@ -100,25 +100,28 @@ SwXTextPortion::SwXTextPortion(
: m_pPropSet(aSwMapProvider.GetPropertySet(
PROPERTY_MAP_TEXTPORTION_EXTENSIONS))
, m_xParentText(std::move(xParent))
- , m_pRubyText ( bIsEnd ? nullptr : new uno::Any )
- , m_pRubyStyle ( bIsEnd ? nullptr : new uno::Any )
- , m_pRubyAdjust ( bIsEnd ? nullptr : new uno::Any )
- , m_pRubyIsAbove( bIsEnd ? nullptr : new uno::Any )
- , m_pRubyPosition( bIsEnd ? nullptr : new uno::Any )
, m_pFrameFormat(nullptr)
, m_ePortionType( bIsEnd ? PORTION_RUBY_END : PORTION_RUBY_START )
, m_bIsCollapsed(false)
{
+ if (!bIsEnd)
+ {
+ m_oRubyText.emplace();
+ m_oRubyStyle.emplace();
+ m_oRubyAdjust.emplace();
+ m_oRubyIsAbove.emplace();
+ m_oRubyPosition.emplace();
+ }
init( pPortionCursor);
if (!bIsEnd)
{
const SfxPoolItem& rItem = rAttr.GetAttr();
- rItem.QueryValue(*m_pRubyText);
- rItem.QueryValue(*m_pRubyStyle, MID_RUBY_CHARSTYLE);
- rItem.QueryValue(*m_pRubyAdjust, MID_RUBY_ADJUST);
- rItem.QueryValue(*m_pRubyIsAbove, MID_RUBY_ABOVE);
- rItem.QueryValue(*m_pRubyPosition, MID_RUBY_POSITION);
+ rItem.QueryValue(*m_oRubyText);
+ rItem.QueryValue(*m_oRubyStyle, MID_RUBY_CHARSTYLE);
+ rItem.QueryValue(*m_oRubyAdjust, MID_RUBY_ADJUST);
+ rItem.QueryValue(*m_oRubyIsAbove, MID_RUBY_ABOVE);
+ rItem.QueryValue(*m_oRubyPosition, MID_RUBY_POSITION);
}
}
@@ -357,17 +360,17 @@ void SwXTextPortion::GetPropertyValue(
break;
case RES_TXTATR_CJK_RUBY:
{
- const uno::Any* pToSet = nullptr;
+ const std::optional<uno::Any>* pToSet = nullptr;
switch(rEntry.nMemberId)
{
- case MID_RUBY_TEXT : pToSet = m_pRubyText.get(); break;
- case MID_RUBY_ADJUST : pToSet = m_pRubyAdjust.get(); break;
- case MID_RUBY_CHARSTYLE:pToSet = m_pRubyStyle.get(); break;
- case MID_RUBY_ABOVE : pToSet = m_pRubyIsAbove.get();break;
- case MID_RUBY_POSITION: pToSet = m_pRubyPosition.get();break;
+ case MID_RUBY_TEXT : pToSet = &m_oRubyText; break;
+ case MID_RUBY_ADJUST : pToSet = &m_oRubyAdjust; break;
+ case MID_RUBY_CHARSTYLE:pToSet = &m_oRubyStyle; break;
+ case MID_RUBY_ABOVE : pToSet = &m_oRubyIsAbove;break;
+ case MID_RUBY_POSITION: pToSet = &m_oRubyPosition;break;
}
if(pToSet)
- rVal = *pToSet;
+ rVal = **pToSet;
}
break;
default: