[Libreoffice-commits] core.git: Branch 'feature/unostyles3' - 73 commits - avmedia/source basctl/source basic/source chart2/source configure.ac cui/source dbaccess/source desktop/source external/icu filter/source framework/inc framework/source i18npool/source include/registry include/sfx2 include/sot include/svl include/svtools include/svx include/tools l10ntools/inc l10ntools/source registry/source reportdesign/source scripting/source sc/sdi sc/source sdext/source sd/qa sd/source sfx2/source sot/source starmath/inc starmath/source stoc/source svgio/source svl/source svtools/source svx/inc svx/source sw/inc sw/source tools/source unoidl/source vcl/source vcl/unx vcl/win

Bjoern Michaelsen bjoern.michaelsen at canonical.com
Thu Mar 17 23:33:27 UTC 2016


Rebased ref, commits from common ancestor:
commit 5e4aec90aefbb86c98ccaba9c775d4a539f1b934
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Wed Mar 16 15:05:39 2016 +0100

    getTypes/queryInterface/getEvents: remove superfluous getArray() and simplify
    
    Change-Id: I5b19d01d2760c95d9c52b15f8d6174dc4aafb4e3

diff --git a/sw/source/core/unocore/unostyle.cxx b/sw/source/core/unocore/unostyle.cxx
index 4c54906..da53140 100644
--- a/sw/source/core/unocore/unostyle.cxx
+++ b/sw/source/core/unocore/unostyle.cxx
@@ -3202,28 +3202,28 @@ const SfxPoolItem* SwXFrameStyle::GetItem(enum RES_FRMATR eAtr)
     return &xStyle->GetItemSet().Get(eAtr);
 }
 
-uno::Sequence< uno::Type > SwXFrameStyle::getTypes(  ) throw(uno::RuntimeException, std::exception)
+uno::Sequence<uno::Type> SwXFrameStyle::getTypes()
+        throw(uno::RuntimeException, std::exception)
 {
-    uno::Sequence< uno::Type > aTypes = SwXStyle::getTypes();
+    uno::Sequence<uno::Type> aTypes = SwXStyle::getTypes();
     sal_Int32 nLen = aTypes.getLength();
     aTypes.realloc(nLen + 1);
-    aTypes.getArray()[nLen] = cppu::UnoType<XEventsSupplier>::get();
+    aTypes[nLen] = cppu::UnoType<XEventsSupplier>::get();
     return aTypes;
 }
 
-uno::Any SwXFrameStyle::queryInterface( const uno::Type& rType ) throw(uno::RuntimeException, std::exception)
+uno::Any SwXFrameStyle::queryInterface(const uno::Type& rType)
+        throw(uno::RuntimeException, std::exception)
 {
-    uno::Any aRet;
     if(rType == cppu::UnoType<XEventsSupplier>::get())
-        aRet <<= uno::Reference<XEventsSupplier>(this);
-    else
-        aRet = SwXStyle::queryInterface(rType);
-    return aRet;
+        return uno::makeAny(uno::Reference<XEventsSupplier>(this));
+    return SwXStyle::queryInterface(rType);
 }
 
-uno::Reference< container::XNameReplace > SwXFrameStyle::getEvents(  ) throw(uno::RuntimeException, std::exception)
+uno::Reference<container::XNameReplace> SwXFrameStyle::getEvents()
+        throw(uno::RuntimeException, std::exception)
 {
-    return new SwFrameStyleEventDescriptor( *this );
+    return new SwFrameStyleEventDescriptor(*this);
 }
 
 // Already implemented autostyle families: 3
commit 47b6239950adef2ced7f4602acc7d6b22b9ca721
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Wed Mar 16 15:02:01 2016 +0100

    GetItem/SetItem: use GetStyleSheetBase()
    
    Change-Id: I7c3b563c6bd095ac9305a5cffdda206c5de94926

diff --git a/sw/source/core/unocore/unostyle.cxx b/sw/source/core/unocore/unostyle.cxx
index adbd801..4c54906 100644
--- a/sw/source/core/unocore/unostyle.cxx
+++ b/sw/source/core/unocore/unostyle.cxx
@@ -3183,34 +3183,22 @@ SwXFrameStyle::~SwXFrameStyle()
 
 void SwXFrameStyle::SetItem(enum RES_FRMATR eAtr, const SfxPoolItem& rItem)
 {
-    // As I was told, for some entirely unobvious reason getting an
-    // item from a style has to look as follows:
-    SfxStyleSheetBasePool* pBasePool = m_pBasePool;
-    if (pBasePool)
-    {
-        SfxStyleSheetBase* pBase = pBasePool->Find(GetStyleName());
-        if (pBase)
-        {
-            rtl::Reference< SwDocStyleSheet > xStyle( new SwDocStyleSheet( *static_cast<SwDocStyleSheet*>(pBase) ) );
-            SfxItemSet& rStyleSet = xStyle->GetItemSet();
-            SfxItemSet aSet(*rStyleSet.GetPool(), eAtr, eAtr);
-            aSet.Put(rItem);
-            xStyle->SetItemSet(aSet);
-        }
-    }
+    SfxStyleSheetBase* pBase = GetStyleSheetBase();
+    if(!pBase)
+        return;
+    rtl::Reference<SwDocStyleSheet> xStyle(new SwDocStyleSheet(*static_cast<SwDocStyleSheet*>(pBase)));
+    SfxItemSet& rStyleSet = xStyle->GetItemSet();
+    SfxItemSet aSet(*rStyleSet.GetPool(), eAtr, eAtr);
+    aSet.Put(rItem);
+    xStyle->SetItemSet(aSet);
 }
 
 const SfxPoolItem* SwXFrameStyle::GetItem(enum RES_FRMATR eAtr)
 {
-    // As I was told, for some entirely unobvious reason getting an
-    // item from a style has to look as follows:
-    SfxStyleSheetBasePool* pBasePool = m_pBasePool;
-    if(!pBasePool)
-        return nullptr;
-    SfxStyleSheetBase* pBase = pBasePool->Find(GetStyleName());
+    SfxStyleSheetBase* pBase = GetStyleSheetBase();
     if(!pBase)
         return nullptr;
-    rtl::Reference< SwDocStyleSheet > xStyle( new SwDocStyleSheet( *static_cast<SwDocStyleSheet*>(pBase)) );
+    rtl::Reference<SwDocStyleSheet> xStyle(new SwDocStyleSheet(*static_cast<SwDocStyleSheet*>(pBase)));
     return &xStyle->GetItemSet().Get(eAtr);
 }
 
commit a4d50fa571ff24fb6d842675e550539de2a9c7da
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Wed Mar 16 14:58:30 2016 +0100

    getPropertyValues, getPropertyValue, setPropertyValue: formatting/whitespace
    
    Change-Id: I9a08b46037eee210fd9beae7670a2efb0e5e8888

diff --git a/sw/source/core/unocore/unostyle.cxx b/sw/source/core/unocore/unostyle.cxx
index a999463..adbd801 100644
--- a/sw/source/core/unocore/unostyle.cxx
+++ b/sw/source/core/unocore/unostyle.cxx
@@ -3134,59 +3134,53 @@ uno::Sequence<uno::Any> SwXPageStyle::GetPropertyValues_Impl(const uno::Sequence
     return aRet;
 }
 
-uno::Sequence< uno::Any > SwXPageStyle::getPropertyValues(
-    const uno::Sequence< OUString >& rPropertyNames )
+uno::Sequence<uno::Any> SwXPageStyle::getPropertyValues(const uno::Sequence<OUString>& rPropertyNames)
         throw(uno::RuntimeException, std::exception)
 {
     SolarMutexGuard aGuard;
-    uno::Sequence< uno::Any > aValues;
+    uno::Sequence<uno::Any> aValues;
 
     // workaround for bad designed API
     try
     {
-        aValues = GetPropertyValues_Impl( rPropertyNames );
+        aValues = GetPropertyValues_Impl(rPropertyNames);
     }
-    catch (beans::UnknownPropertyException &)
+    catch(beans::UnknownPropertyException &)
     {
-        throw uno::RuntimeException("Unknown property exception caught", static_cast < cppu::OWeakObject * > ( this ) );
+        throw uno::RuntimeException("Unknown property exception caught", static_cast<cppu::OWeakObject*>(this));
     }
-    catch (lang::WrappedTargetException &)
+    catch(lang::WrappedTargetException &)
     {
-        throw uno::RuntimeException("WrappedTargetException caught", static_cast < cppu::OWeakObject * > ( this ) );
+        throw uno::RuntimeException("WrappedTargetException caught", static_cast<cppu::OWeakObject*>(this));
     }
 
     return aValues;
 }
 
-uno::Any SwXPageStyle::getPropertyValue(const OUString& rPropertyName) throw(
-    beans::UnknownPropertyException, lang::WrappedTargetException, uno::RuntimeException, std::exception)
+uno::Any SwXPageStyle::getPropertyValue(const OUString& rPropertyName)
+        throw(beans::UnknownPropertyException, lang::WrappedTargetException, uno::RuntimeException, std::exception)
 {
     SolarMutexGuard aGuard;
     const uno::Sequence<OUString> aProperties(&rPropertyName, 1);
-    return GetPropertyValues_Impl(aProperties).getConstArray()[0];
+    return GetPropertyValues_Impl(aProperties)[0];
 }
 
 void SwXPageStyle::setPropertyValue(const OUString& rPropertyName, const uno::Any& rValue)
-    throw( beans::UnknownPropertyException,
-        beans::PropertyVetoException,
-        lang::IllegalArgumentException,
-        lang::WrappedTargetException,
-        uno::RuntimeException, std::exception)
+        throw(beans::UnknownPropertyException, beans::PropertyVetoException, lang::IllegalArgumentException, lang::WrappedTargetException, uno::RuntimeException, std::exception)
 {
     SolarMutexGuard aGuard;
     const uno::Sequence<OUString> aProperties(&rPropertyName, 1);
     const uno::Sequence<uno::Any> aValues(&rValue, 1);
-    SetPropertyValues_Impl( aProperties, aValues );
+    SetPropertyValues_Impl(aProperties, aValues);
 }
 
-SwXFrameStyle::SwXFrameStyle ( SwDoc *pDoc )
-: SwXStyle ( pDoc, SFX_STYLE_FAMILY_FRAME, false)
-{
-}
+SwXFrameStyle::SwXFrameStyle(SwDoc *pDoc)
+    : SwXStyle(pDoc, SFX_STYLE_FAMILY_FRAME, false)
+{ }
 
 SwXFrameStyle::~SwXFrameStyle()
-{
-}
+{ }
+
 void SwXFrameStyle::SetItem(enum RES_FRMATR eAtr, const SfxPoolItem& rItem)
 {
     // As I was told, for some entirely unobvious reason getting an
commit daf39a7626f1ccaf2c0a32c33a4c3edc1b6069fd
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Wed Mar 16 14:30:11 2016 +0100

    refactor GetPropertyValues_Impl
    
    - use GetStyleSheetBase()
    - check preconditions and special cases early
    - limit scope of variables
    
    Change-Id: Idb49f84e97348bcbf8a3a75831b56ad82872720e

diff --git a/sw/source/core/unocore/unostyle.cxx b/sw/source/core/unocore/unostyle.cxx
index 8923871..a999463 100644
--- a/sw/source/core/unocore/unostyle.cxx
+++ b/sw/source/core/unocore/unostyle.cxx
@@ -2950,38 +2950,40 @@ uno::Sequence<uno::Any> SwXPageStyle::GetPropertyValues_Impl(const uno::Sequence
         throw uno::RuntimeException();
 
     sal_Int32 nLength = rPropertyNames.getLength();
-    const OUString* pNames = rPropertyNames.getConstArray();
-    uno::Sequence< uno::Any > aRet ( nLength );
-
-    uno::Any* pRet = aRet.getArray();
+    uno::Sequence<uno::Any> aRet (nLength);
+    if(!m_pBasePool)
+    {
+        if(!IsDescriptor())
+            throw uno::RuntimeException();
+        for(sal_Int32 nProp = 0; nProp < rPropertyNames.getLength(); ++nProp)
+        {
+            const uno::Any* pAny = nullptr;
+            m_pPropertiesImpl->GetProperty(rPropertyNames[nProp], pAny);
+            if (!pAny->hasValue())
+                SwStyleProperties_Impl::GetProperty(rPropertyNames[nProp], m_xStyleData, aRet[nProp]);
+            else
+                aRet[nProp] = *pAny;
+        }
+        return aRet;
+    }
     const SfxItemPropertySet* pPropSet = aSwMapProvider.GetPropertySet(PROPERTY_MAP_PAGE_STYLE);
     const SfxItemPropertyMap& rMap = pPropSet->getPropertyMap();
     SwStyleBase_Impl aBase(*GetDoc(), GetStyleName(), &GetDoc()->GetDfltFrameFormat()->GetAttrSet()); //UUUU add pDfltFrameFormat as parent
-    SfxStyleSheetBase* pBase = nullptr;
-
-    for(sal_Int32 nProp = 0; nProp < nLength; nProp++)
+    SfxStyleSheetBase* pBase = GetStyleSheetBase();
+    if(!pBase)
+        throw uno::RuntimeException();
+    for(sal_Int32 nProp = 0; nProp < nLength; ++nProp)
     {
-        const OUString& rPropName = pNames[nProp];
+        const OUString& rPropName = rPropertyNames[nProp];
         const SfxItemPropertySimpleEntry* pEntry = rMap.getByName(rPropName);
 
         if (!pEntry)
-        {
             throw beans::UnknownPropertyException("Unknown property: " + rPropName, static_cast < cppu::OWeakObject * > ( this ) );
-        }
-
-        if(m_pBasePool)
+        const bool bHeader(rPropName.startsWith("Header"));
+        const bool bFooter(rPropName.startsWith("Footer"));
+        const bool bFirstIsShared(rPropName == UNO_NAME_FIRST_IS_SHARED);
+        if(bHeader || bFooter || bFirstIsShared)
         {
-            if(!pBase)
-            {
-                const sal_uInt16 nSaveMask = m_pBasePool->GetSearchMask();
-                m_pBasePool->SetSearchMask(GetFamily());
-                pBase = m_pBasePool->Find(GetStyleName());
-                m_pBasePool->SetSearchMask(GetFamily(), nSaveMask );
-            }
-
-            sal_uInt16 nRes = 0;
-            const sal_uInt8 nMemberId(pEntry->nMemberId & (~SFX_METRIC_ITEM));
-
             switch(pEntry->nWID)
             {
                 case SID_ATTR_PAGE_ON:
@@ -2996,57 +2998,27 @@ uno::Sequence<uno::Any> SwXPageStyle::GetPropertyValues_Impl(const uno::Sequence
                 case SID_ATTR_PAGE_SIZE:
                 case RES_HEADER_FOOTER_EAT_SPACING:
                 {
-                    // These slots are used for Header, Footer and (partially) for PageStyle directly.
-                    // Check for Header/Footer entry
-                    const bool bHeader(rPropName.startsWith("Header"));
-                    const bool bFooter(rPropName.startsWith("Footer"));
+                    // slot is a Header/Footer slot
+                    rtl::Reference< SwDocStyleSheet > xStyle( new SwDocStyleSheet( *static_cast<SwDocStyleSheet*>(pBase) ) );
+                    const SfxItemSet& rSet = xStyle->GetItemSet();
+                    const SvxSetItem* pSetItem;
 
-                    if(bHeader || bFooter || rPropName == UNO_NAME_FIRST_IS_SHARED)
+                    if (lcl_GetHeaderFooterItem(rSet, rPropName, bFooter, pSetItem))
                     {
-                        // slot is a Header/Footer slot
-                        rtl::Reference< SwDocStyleSheet > xStyle( new SwDocStyleSheet( *static_cast<SwDocStyleSheet*>(pBase) ) );
-                        const SfxItemSet& rSet = xStyle->GetItemSet();
-                        const SvxSetItem* pSetItem;
-
-                        if (lcl_GetHeaderFooterItem(rSet, rPropName, bFooter, pSetItem))
-                        {
-                            // get from SfxItemSet of the corresponding SfxSetItem
-                            const SfxItemSet& rSetSet = pSetItem->GetItemSet();
-                            {
-                                SwStyleBase_Impl::ItemSetOverrider o(aBase, &const_cast< SfxItemSet& >(rSetSet));
-                                pRet[nProp] = GetStyleProperty_Impl(*pEntry, *pPropSet, aBase);
-                            }
-                        }
-                        else if(pEntry->nWID == SID_ATTR_PAGE_ON)
+                        // get from SfxItemSet of the corresponding SfxSetItem
+                        const SfxItemSet& rSetSet = pSetItem->GetItemSet();
                         {
-                            // header/footer is not available, thus off. Default is <false>, though
-                            pRet[nProp] <<= false;
+                            SwStyleBase_Impl::ItemSetOverrider o(aBase, &const_cast< SfxItemSet& >(rSetSet));
+                            aRet[nProp] = GetStyleProperty_Impl(*pEntry, *pPropSet, aBase);
                         }
                     }
-                    else
+                    else if(pEntry->nWID == SID_ATTR_PAGE_ON)
                     {
-                        switch(pEntry->nWID)
-                        {
-                            case SID_ATTR_PAGE_DYNAMIC:
-                            case SID_ATTR_PAGE_SHARED:
-                            case SID_ATTR_PAGE_SHARED_FIRST:
-                            case SID_ATTR_PAGE_ON:
-                            case RES_HEADER_FOOTER_EAT_SPACING:
-                            {
-                                // these slots are exclusive to Header/Footer, thus this is an error
-                                throw beans::UnknownPropertyException(OUString ( RTL_CONSTASCII_USTRINGPARAM ( "Unknown property: " ) ) + rPropName, static_cast < cppu::OWeakObject * > ( this ) );
-                            }
-                            default:
-                            {
-                                // part of PageStyle, fallback to default
-                                pRet[nProp] = GetStyleProperty_Impl(*pEntry, *pPropSet, aBase);
-                            }
-                        }
+                        // header/footer is not available, thus off. Default is <false>, though
+                        aRet[nProp] <<= false;
                     }
-
-                    break;
                 }
-
+                continue;
                 case XATTR_FILLBMP_SIZELOG:
                 case XATTR_FILLBMP_TILEOFFSETX:
                 case XATTR_FILLBMP_TILEOFFSETY:
@@ -3068,130 +3040,97 @@ uno::Sequence<uno::Any> SwXPageStyle::GetPropertyValues_Impl(const uno::Sequence
                 case XATTR_FILLTRANSPARENCE:
                 case XATTR_FILLFLOATTRANSPARENCE:
                 case XATTR_SECONDARYFILLCOLOR:
+                if(bFirstIsShared) // only special handling for headers/footers here
+                    break;
                 {
-                    // This DrawingLayer FillStyle attributes can be part of Header, Footer and PageStyle
-                    // itself, so decide what to do using the name
-                    const bool bHeader(rPropName.startsWith("Header"));
-                    const bool bFooter(rPropName.startsWith("Footer"));
-
-                    if (bHeader || bFooter)
+                    rtl::Reference< SwDocStyleSheet > xStyle( new SwDocStyleSheet( *static_cast<SwDocStyleSheet*>(pBase) ) );
+                    const SfxItemSet& rSet = xStyle->GetItemSet();
+                    const SvxSetItem* pSetItem;
+                    if(SfxItemState::SET == rSet.GetItemState(bFooter ? SID_ATTR_PAGE_FOOTERSET : SID_ATTR_PAGE_HEADERSET, false, reinterpret_cast<const SfxPoolItem**>(&pSetItem)))
                     {
-                        rtl::Reference< SwDocStyleSheet > xStyle( new SwDocStyleSheet( *static_cast<SwDocStyleSheet*>(pBase) ) );
-                        const SfxItemSet& rSet = xStyle->GetItemSet();
-                        const SvxSetItem* pSetItem;
-                        if(SfxItemState::SET == rSet.GetItemState(bFooter ? SID_ATTR_PAGE_FOOTERSET : SID_ATTR_PAGE_HEADERSET, false, reinterpret_cast<const SfxPoolItem**>(&pSetItem)))
+                        // set at SfxItemSet of the corresponding SfxSetItem
+                        const SfxItemSet& rSetSet = pSetItem->GetItemSet();
                         {
-                            // set at SfxItemSet of the corresponding SfxSetItem
-                            const SfxItemSet& rSetSet = pSetItem->GetItemSet();
-                            {
-                                SwStyleBase_Impl::ItemSetOverrider o(aBase, &const_cast<SfxItemSet&>(rSetSet));
-                                pRet[nProp] = GetStyleProperty_Impl(*pEntry, *pPropSet, aBase);
-                            }
+                            SwStyleBase_Impl::ItemSetOverrider o(aBase, &const_cast<SfxItemSet&>(rSetSet));
+                            aRet[nProp] = GetStyleProperty_Impl(*pEntry, *pPropSet, aBase);
                         }
                     }
-                    else
-                    {
-                        // part of PageStyle, fallback to default
-                        pRet[nProp] = GetStyleProperty_Impl(*pEntry, *pPropSet, aBase);
-                    }
-
-                    break;
                 }
-
-                case FN_UNO_HEADER:
-                case FN_UNO_HEADER_LEFT:
-                case FN_UNO_HEADER_FIRST:
-                case FN_UNO_HEADER_RIGHT:
-                case FN_UNO_FOOTER:
-                case FN_UNO_FOOTER_LEFT:
-                case FN_UNO_FOOTER_FIRST:
-                case FN_UNO_FOOTER_RIGHT:
+                continue;
+                default: ;
+            }
+        }
+        switch(pEntry->nWID)
+        {
+            // these slots are exclusive to Header/Footer, thus this is an error
+            case SID_ATTR_PAGE_DYNAMIC:
+            case SID_ATTR_PAGE_SHARED:
+            case SID_ATTR_PAGE_SHARED_FIRST:
+            case SID_ATTR_PAGE_ON:
+            case RES_HEADER_FOOTER_EAT_SPACING:
+                throw beans::UnknownPropertyException(OUString ( RTL_CONSTASCII_USTRINGPARAM ( "Unknown property: " ) ) + rPropName, static_cast < cppu::OWeakObject * > ( this ) );
+            case FN_UNO_HEADER:
+            case FN_UNO_HEADER_LEFT:
+            case FN_UNO_HEADER_FIRST:
+            case FN_UNO_HEADER_RIGHT:
+            case FN_UNO_FOOTER:
+            case FN_UNO_FOOTER_LEFT:
+            case FN_UNO_FOOTER_FIRST:
+            case FN_UNO_FOOTER_RIGHT:
+            {
+                bool bLeft(false);
+                bool bFirst(false);
+                sal_uInt16 nRes = 0;
+                switch(pEntry->nWID)
                 {
-                    //UUUU cleanups for readability (undos removed, rearranged)
-                    bool bHeader(false);
-                    bool bLeft(false);
-                    bool bFirst(false);
-
-                    switch(pEntry->nWID)
-                    {
-                        case FN_UNO_HEADER:       bHeader = true;  nRes = RES_HEADER; break;
-                        case FN_UNO_HEADER_LEFT:  bHeader = true;  nRes = RES_HEADER; bLeft = true;  break;
-                        case FN_UNO_HEADER_FIRST: bHeader = true;  nRes = RES_HEADER; bFirst = true; break;
-                        case FN_UNO_HEADER_RIGHT: bHeader = true;  nRes = RES_HEADER; break;
-                        case FN_UNO_FOOTER:       bHeader = false; nRes = RES_FOOTER; break;
-                        case FN_UNO_FOOTER_LEFT:  bHeader = false; nRes = RES_FOOTER; bLeft = true;  break;
-                        case FN_UNO_FOOTER_FIRST: bHeader = false; nRes = RES_FOOTER; bFirst = true; break;
-                        case FN_UNO_FOOTER_RIGHT: bHeader = false; nRes = RES_FOOTER; break;
-                        default: break;
-                    }
-
-                    const SwPageDesc* pDesc = aBase.GetOldPageDesc();
-                    assert(pDesc);
-                    const SwFrameFormat* pFrameFormat = nullptr;
-                    bool bShare = (bHeader && pDesc->IsHeaderShared()) || (!bHeader && pDesc->IsFooterShared());
-                    bool bShareFirst = pDesc->IsFirstShared();
-                    // TextLeft returns the left content if there is one,
-                    // Text and TextRight return the master content.
-                    // TextRight does the same as Text and is for
-                    // compatibility only.
-                    if( bLeft && !bShare )
-                    {
-                        pFrameFormat = &pDesc->GetLeft();
-                    }
-                    else if (bFirst && !bShareFirst)
-                    {
-                        pFrameFormat = &pDesc->GetFirstMaster();
-                        // no need to make GetFirstLeft() accessible
-                        // since it is always shared
-                    }
-                    else
-                    {
-                        pFrameFormat = &pDesc->GetMaster();
-                    }
-                    const uno::Reference< text::XText > xRet =
-                        lcl_makeHeaderFooter(nRes, bHeader, pFrameFormat);
-                    if (xRet.is())
-                    {
-                        pRet[nProp] <<= xRet;
-                    }
-                    break;
+                    case FN_UNO_HEADER:       nRes = RES_HEADER; break;
+                    case FN_UNO_HEADER_LEFT:  nRes = RES_HEADER; bLeft = true;  break;
+                    case FN_UNO_HEADER_FIRST: nRes = RES_HEADER; bFirst = true; break;
+                    case FN_UNO_HEADER_RIGHT: nRes = RES_HEADER; break;
+                    case FN_UNO_FOOTER:       nRes = RES_FOOTER; break;
+                    case FN_UNO_FOOTER_LEFT:  nRes = RES_FOOTER; bLeft = true;  break;
+                    case FN_UNO_FOOTER_FIRST: nRes = RES_FOOTER; bFirst = true; break;
+                    case FN_UNO_FOOTER_RIGHT: nRes = RES_FOOTER; break;
+                    default: ;
                 }
 
-                case FN_PARAM_FTN_INFO :
+                const SwPageDesc* pDesc = aBase.GetOldPageDesc();
+                assert(pDesc);
+                const SwFrameFormat* pFrameFormat = nullptr;
+                bool bShare = (nRes == RES_HEADER && pDesc->IsHeaderShared()) || (nRes == RES_FOOTER && pDesc->IsFooterShared());
+                bool bShareFirst = pDesc->IsFirstShared();
+                // TextLeft returns the left content if there is one,
+                // Text and TextRight return the master content.
+                // TextRight does the same as Text and is for
+                // compatibility only.
+                if(bLeft && !bShare)
+                    pFrameFormat = &pDesc->GetLeft();
+                else if(bFirst && !bShareFirst)
                 {
-                    rtl::Reference< SwDocStyleSheet > xStyle( new SwDocStyleSheet( *static_cast<SwDocStyleSheet*>(pBase) ) );
-                    const SfxItemSet& rSet = xStyle->GetItemSet();
-                    const SfxPoolItem& rItem = rSet.Get(FN_PARAM_FTN_INFO);
-                    rItem.QueryValue(pRet[nProp], nMemberId);
-                    break;
+                    pFrameFormat = &pDesc->GetFirstMaster();
+                    // no need to make GetFirstLeft() accessible
+                    // since it is always shared
                 }
-                default:
-                {
-                    //UUUU
-                    pRet[nProp] = GetStyleProperty_Impl(*pEntry, *pPropSet, aBase);
-                    break;
-                }
-            }
-        }
-        else if(IsDescriptor())
-        {
-            const uno::Any* pAny = nullptr;
-            m_pPropertiesImpl->GetProperty(rPropName, pAny);
-            if (!pAny->hasValue())
-            {
-                SwStyleProperties_Impl::GetProperty(rPropName, m_xStyleData, pRet[nProp]);
+                else
+                    pFrameFormat = &pDesc->GetMaster();
+                const uno::Reference<text::XText> xRet = lcl_makeHeaderFooter(nRes, nRes == RES_HEADER, pFrameFormat);
+                if (xRet.is())
+                    aRet[nProp] = uno::makeAny(xRet);
             }
-            else
+            break;
+            case FN_PARAM_FTN_INFO:
             {
-                pRet[nProp] = *pAny;
+                rtl::Reference<SwDocStyleSheet> xStyle(new SwDocStyleSheet(*static_cast<SwDocStyleSheet*>(pBase)));
+                const SfxItemSet& rSet = xStyle->GetItemSet();
+                const SfxPoolItem& rItem = rSet.Get(FN_PARAM_FTN_INFO);
+                const sal_uInt8 nMemberId(pEntry->nMemberId & (~SFX_METRIC_ITEM));
+                rItem.QueryValue(aRet[nProp], nMemberId);
             }
-        }
-        else
-        {
-            throw uno::RuntimeException();
+            break;
+            default:
+                aRet[nProp] = GetStyleProperty_Impl(*pEntry, *pPropSet, aBase);
         }
     }
-
     return aRet;
 }
 
commit 281623aa411d5ed9ef2f2f14293af98f07bb0013
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Wed Mar 16 13:04:16 2016 +0100

    formatting: setPropertyValues, lcl_makeHeaderFooter
    
    Change-Id: I55e9d5a0616b5ee8d0d678317086d0fdb2386e1a

diff --git a/sw/source/core/unocore/unostyle.cxx b/sw/source/core/unocore/unostyle.cxx
index e5d5851..8923871 100644
--- a/sw/source/core/unocore/unostyle.cxx
+++ b/sw/source/core/unocore/unostyle.cxx
@@ -2908,9 +2908,7 @@ void SwXPageStyle::SetPropertyValues_Impl(const uno::Sequence<OUString>& rProper
     }
 }
 
-void SwXPageStyle::setPropertyValues(
-    const uno::Sequence< OUString >& rPropertyNames,
-    const uno::Sequence< uno::Any >& rValues )
+void SwXPageStyle::setPropertyValues(const uno::Sequence<OUString>& rPropertyNames, const uno::Sequence<uno::Any>& rValues)
         throw(beans::PropertyVetoException, lang::IllegalArgumentException, lang::WrappedTargetException, uno::RuntimeException, std::exception)
 {
     SolarMutexGuard aGuard;
@@ -2918,7 +2916,7 @@ void SwXPageStyle::setPropertyValues(
     // workaround for bad designed API
     try
     {
-        SetPropertyValues_Impl( rPropertyNames, rValues );
+        SetPropertyValues_Impl(rPropertyNames, rValues);
     }
     catch (const beans::UnknownPropertyException &rException)
     {
@@ -2930,27 +2928,20 @@ void SwXPageStyle::setPropertyValues(
     }
 }
 
-static uno::Reference<text::XText>
-lcl_makeHeaderFooter(
-    const sal_uInt16 nRes, const bool bHeader, SwFrameFormat const*const pFrameFormat)
+static uno::Reference<text::XText> lcl_makeHeaderFooter(const sal_uInt16 nRes, const bool bHeader, SwFrameFormat const*const pFrameFormat)
 {
-    if (!pFrameFormat) { return nullptr; }
-
+    if (!pFrameFormat)
+        return nullptr;
     const SfxItemSet& rSet = pFrameFormat->GetAttrSet();
     const SfxPoolItem* pItem;
-    if (SfxItemState::SET == rSet.GetItemState(nRes, true, &pItem))
-    {
-        SwFrameFormat *const pHeadFootFormat = (bHeader)
-            ? static_cast<SwFormatHeader*>(const_cast<SfxPoolItem*>(pItem))->
-                    GetHeaderFormat()
-            : static_cast<SwFormatFooter*>(const_cast<SfxPoolItem*>(pItem))->
-                    GetFooterFormat();
-        if (pHeadFootFormat)
-        {
-            return SwXHeadFootText::CreateXHeadFootText(*pHeadFootFormat, bHeader);
-        }
-    }
-    return nullptr;
+    if(SfxItemState::SET != rSet.GetItemState(nRes, true, &pItem))
+        return nullptr;
+    SwFrameFormat* const pHeadFootFormat = (bHeader)
+        ? static_cast<SwFormatHeader*>(const_cast<SfxPoolItem*>(pItem))->GetHeaderFormat()
+        : static_cast<SwFormatFooter*>(const_cast<SfxPoolItem*>(pItem))->GetFooterFormat();
+    if(!pHeadFootFormat)
+        return nullptr;
+    return SwXHeadFootText::CreateXHeadFootText(*pHeadFootFormat, bHeader);
 }
 
 uno::Sequence<uno::Any> SwXPageStyle::GetPropertyValues_Impl(const uno::Sequence<OUString>& rPropertyNames)
commit 189ffe46107f10e3da80c4f11bc629bebd584960
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Wed Mar 16 12:20:36 2016 +0100

    refactor SetPropertyValues_Impl
    
    - use GetStyleSheetBase()
    - check preconditions and special cases early
    
    Change-Id: I95eb4cde66b9da2969bb257bd2de6b319b2b3950

diff --git a/sw/source/core/unocore/unostyle.cxx b/sw/source/core/unocore/unostyle.cxx
index e042560..e5d5851 100644
--- a/sw/source/core/unocore/unostyle.cxx
+++ b/sw/source/core/unocore/unostyle.cxx
@@ -2705,9 +2705,7 @@ void SwXStyle::PutItemToSet(const SvxSetItem* pSetItem, const SfxItemPropertySet
     rBaseImpl.GetItemSet().Put(*pNewSetItem);
 }
 
-void SwXPageStyle::SetPropertyValues_Impl(
-    const uno::Sequence< OUString >& rPropertyNames,
-    const uno::Sequence< uno::Any >& rValues )
+void SwXPageStyle::SetPropertyValues_Impl(const uno::Sequence<OUString>& rPropertyNames, const uno::Sequence<uno::Any>& rValues)
 {
     if(!GetDoc())
         throw uno::RuntimeException();
@@ -2715,44 +2713,36 @@ void SwXPageStyle::SetPropertyValues_Impl(
     if(rPropertyNames.getLength() != rValues.getLength())
         throw lang::IllegalArgumentException();
 
-    const OUString* pNames = rPropertyNames.getConstArray();
-    const uno::Any* pValues = rValues.getConstArray();
     const SfxItemPropertySet* pPropSet = aSwMapProvider.GetPropertySet(PROPERTY_MAP_PAGE_STYLE);
     const SfxItemPropertyMap& rMap = pPropSet->getPropertyMap();
     SwStyleBase_Impl aBaseImpl(*GetDoc(), GetStyleName(), &GetDoc()->GetDfltFrameFormat()->GetAttrSet()); //UUUU add pDfltFrameFormat as parent
-    if(m_pBasePool)
+    if(!m_pBasePool)
     {
-        const sal_uInt16 nSaveMask = m_pBasePool->GetSearchMask();
-        m_pBasePool->SetSearchMask(GetFamily());
-        SfxStyleSheetBase* pBase = m_pBasePool->Find(GetStyleName());
-        m_pBasePool->SetSearchMask(GetFamily(), nSaveMask );
-        OSL_ENSURE(pBase, "where is the style?" );
-        if(pBase)
-        {
-            aBaseImpl.setNewBase(new SwDocStyleSheet(*static_cast<SwDocStyleSheet*>(pBase)));
-        }
-        else
-        {
+        if(!IsDescriptor())
             throw uno::RuntimeException();
-        }
+        for(sal_Int32 nProp = 0; nProp < rPropertyNames.getLength(); ++nProp)
+            if(!m_pPropertiesImpl->SetProperty(rPropertyNames[nProp], rValues[nProp]))
+                throw lang::IllegalArgumentException();
+        return;
     }
-
-    for(sal_Int32 nProp = 0; nProp < rPropertyNames.getLength(); nProp++)
+    SfxStyleSheetBase* pBase = GetStyleSheetBase();
+    if(!pBase)
+        throw uno::RuntimeException();
+    aBaseImpl.setNewBase(new SwDocStyleSheet(*static_cast<SwDocStyleSheet*>(pBase)));
+    for(sal_Int32 nProp = 0; nProp < rPropertyNames.getLength(); ++nProp)
     {
-        const OUString& rPropName = pNames[nProp];
+        const OUString& rPropName = rPropertyNames[nProp];
         const SfxItemPropertySimpleEntry* pEntry = rMap.getByName(rPropName);
 
-        if (!pEntry)
-        {
-            throw beans::UnknownPropertyException("Unknown property: " + pNames[nProp], static_cast < cppu::OWeakObject * > ( this ) );
-        }
-
-        if ( pEntry->nFlags & beans::PropertyAttribute::READONLY)
-        {
-            throw beans::PropertyVetoException ("Property is read-only: " + pNames[nProp], static_cast < cppu::OWeakObject * > ( this ) );
-        }
+        if(!pEntry)
+            throw beans::UnknownPropertyException("Unknown property: " + rPropName, static_cast<cppu::OWeakObject*>(this));
+        if(pEntry->nFlags & beans::PropertyAttribute::READONLY)
+            throw beans::PropertyVetoException("Property is read-only: " + rPropName, static_cast<cppu::OWeakObject*>(this));
 
-        if(m_pBasePool)
+        const bool bHeader(rPropName.startsWith("Header"));
+        const bool bFooter(rPropName.startsWith("Footer"));
+        const bool bFirstIsShared(rPropName == UNO_NAME_FIRST_IS_SHARED);
+        if(bHeader || bFooter || bFirstIsShared)
         {
             switch(pEntry->nWID)
             {
@@ -2768,89 +2758,54 @@ void SwXPageStyle::SetPropertyValues_Impl(
                 case SID_ATTR_PAGE_SIZE:
                 case RES_HEADER_FOOTER_EAT_SPACING:
                 {
-                    // these entries are used in Header, Footer and (partially) in the PageStyle itself.
-                    // Check for Header/Footer entry
-                    const bool bHeader(rPropName.startsWith("Header"));
-                    const bool bFooter(rPropName.startsWith("Footer"));
-
-                    if(bHeader || bFooter || rPropName == UNO_NAME_FIRST_IS_SHARED)
+                    // it is a Header/Footer entry, access the SvxSetItem containing it's information
+                    const SvxSetItem* pSetItem = nullptr;
+                    if (lcl_GetHeaderFooterItem(aBaseImpl.GetItemSet(), rPropName, bFooter, pSetItem))
                     {
-                        // it is a Header/Footer entry, access the SvxSetItem containing it's information
-                        const SvxSetItem* pSetItem = nullptr;
-                        if (lcl_GetHeaderFooterItem(aBaseImpl.GetItemSet(),
-                                    rPropName, bFooter, pSetItem))
-                        {
-                            PutItemToSet(pSetItem, *pPropSet, *pEntry, pValues[nProp], aBaseImpl);
+                        PutItemToSet(pSetItem, *pPropSet, *pEntry, rValues[nProp], aBaseImpl);
 
-                            if (pEntry->nWID == SID_ATTR_PAGE_SHARED_FIRST)
-                            {
-                                // Need to add this to the other as well
-                                if (SfxItemState::SET == aBaseImpl.GetItemSet().GetItemState(
-                                            bFooter ? SID_ATTR_PAGE_HEADERSET : SID_ATTR_PAGE_FOOTERSET,
-                                            false, reinterpret_cast<const SfxPoolItem**>(&pSetItem)))
-                                {
-                                    PutItemToSet(pSetItem, *pPropSet, *pEntry, pValues[nProp], aBaseImpl);
-                                }
-                            }
-                        }
-                        else if(pEntry->nWID == SID_ATTR_PAGE_ON)
+                        if (pEntry->nWID == SID_ATTR_PAGE_SHARED_FIRST)
                         {
-                            bool bVal = *static_cast<sal_Bool const *>(pValues[nProp].getValue());
-
-                            if(bVal)
+                            // Need to add this to the other as well
+                            if (SfxItemState::SET == aBaseImpl.GetItemSet().GetItemState(
+                                        bFooter ? SID_ATTR_PAGE_HEADERSET : SID_ATTR_PAGE_FOOTERSET,
+                                        false, reinterpret_cast<const SfxPoolItem**>(&pSetItem)))
                             {
-                                // Header/footer gets switched on, create defaults and the needed SfxSetItem
-                                SfxItemSet aTempSet(*aBaseImpl.GetItemSet().GetPool(),
-                                    RES_FRMATR_BEGIN,RES_FRMATR_END - 1,            // [82
-
-                                    //UUUU FillAttribute support
-                                    XATTR_FILL_FIRST, XATTR_FILL_LAST,              // [1014
-
-                                    SID_ATTR_BORDER_INNER,SID_ATTR_BORDER_INNER,    // [10023
-                                    SID_ATTR_PAGE_SIZE,SID_ATTR_PAGE_SIZE,          // [10051
-                                    SID_ATTR_PAGE_ON,SID_ATTR_PAGE_SHARED,          // [10060
-                                    SID_ATTR_PAGE_SHARED_FIRST,SID_ATTR_PAGE_SHARED_FIRST,
-                                    0);
-
-                                //UUUU set correct parent to get the XFILL_NONE FillStyle as needed
-                                aTempSet.SetParent(&GetDoc()->GetDfltFrameFormat()->GetAttrSet());
-
-                                aTempSet.Put(SfxBoolItem(SID_ATTR_PAGE_ON, true));
-                                aTempSet.Put(SvxSizeItem(SID_ATTR_PAGE_SIZE, Size(MM50, MM50)));
-                                aTempSet.Put(SvxLRSpaceItem(RES_LR_SPACE));
-                                aTempSet.Put(SvxULSpaceItem(RES_UL_SPACE));
-                                aTempSet.Put(SfxBoolItem(SID_ATTR_PAGE_SHARED, true));
-                                aTempSet.Put(SfxBoolItem(SID_ATTR_PAGE_SHARED_FIRST, true));
-                                aTempSet.Put(SfxBoolItem(SID_ATTR_PAGE_DYNAMIC, true));
-
-                                SvxSetItem aNewSetItem(bFooter ? SID_ATTR_PAGE_FOOTERSET : SID_ATTR_PAGE_HEADERSET, aTempSet);
-                                aBaseImpl.GetItemSet().Put(aNewSetItem);
+                                PutItemToSet(pSetItem, *pPropSet, *pEntry, rValues[nProp], aBaseImpl);
                             }
                         }
                     }
-                    else
+                    else if(pEntry->nWID == SID_ATTR_PAGE_ON && rValues[nProp].get<bool>())
                     {
-                        switch(pEntry->nWID)
-                        {
-                            case SID_ATTR_PAGE_DYNAMIC:
-                            case SID_ATTR_PAGE_SHARED:
-                            case SID_ATTR_PAGE_SHARED_FIRST:
-                            case SID_ATTR_PAGE_ON:
-                            case RES_HEADER_FOOTER_EAT_SPACING:
-                            {
-                                // these slots are exclusive to Header/Footer, thus this is an error
-                                throw beans::UnknownPropertyException(OUString ( RTL_CONSTASCII_USTRINGPARAM ( "Unknown property: " ) ) + rPropName, static_cast < cppu::OWeakObject * > ( this ) );
-                            }
-                            default:
-                            {
-                                // part of PageStyle, fallback to default
-                                SetStyleProperty(*pEntry, *pPropSet, pValues[nProp], aBaseImpl);
-                            }
-                        }
+                        // Header/footer gets switched on, create defaults and the needed SfxSetItem
+                        SfxItemSet aTempSet(*aBaseImpl.GetItemSet().GetPool(),
+                            RES_FRMATR_BEGIN,RES_FRMATR_END - 1,            // [82
+
+                            //UUUU FillAttribute support
+                            XATTR_FILL_FIRST, XATTR_FILL_LAST,              // [1014
+
+                            SID_ATTR_BORDER_INNER,SID_ATTR_BORDER_INNER,    // [10023
+                            SID_ATTR_PAGE_SIZE,SID_ATTR_PAGE_SIZE,          // [10051
+                            SID_ATTR_PAGE_ON,SID_ATTR_PAGE_SHARED,          // [10060
+                            SID_ATTR_PAGE_SHARED_FIRST,SID_ATTR_PAGE_SHARED_FIRST,
+                            0);
+
+                        //UUUU set correct parent to get the XFILL_NONE FillStyle as needed
+                        aTempSet.SetParent(&GetDoc()->GetDfltFrameFormat()->GetAttrSet());
+
+                        aTempSet.Put(SfxBoolItem(SID_ATTR_PAGE_ON, true));
+                        aTempSet.Put(SvxSizeItem(SID_ATTR_PAGE_SIZE, Size(MM50, MM50)));
+                        aTempSet.Put(SvxLRSpaceItem(RES_LR_SPACE));
+                        aTempSet.Put(SvxULSpaceItem(RES_UL_SPACE));
+                        aTempSet.Put(SfxBoolItem(SID_ATTR_PAGE_SHARED, true));
+                        aTempSet.Put(SfxBoolItem(SID_ATTR_PAGE_SHARED_FIRST, true));
+                        aTempSet.Put(SfxBoolItem(SID_ATTR_PAGE_DYNAMIC, true));
+
+                        SvxSetItem aNewSetItem(bFooter ? SID_ATTR_PAGE_FOOTERSET : SID_ATTR_PAGE_HEADERSET, aTempSet);
+                        aBaseImpl.GetItemSet().Put(aNewSetItem);
                     }
-                    break;
                 }
-
+                continue;
                 case XATTR_FILLBMP_SIZELOG:
                 case XATTR_FILLBMP_TILEOFFSETX:
                 case XATTR_FILLBMP_TILEOFFSETY:
@@ -2872,85 +2827,70 @@ void SwXPageStyle::SetPropertyValues_Impl(
                 case XATTR_FILLTRANSPARENCE:
                 case XATTR_FILLFLOATTRANSPARENCE:
                 case XATTR_SECONDARYFILLCOLOR:
+                if(bFirstIsShared) // only special handling for headers/footers here
+                    break;
                 {
-                    // This DrawingLayer FillStyle attributes can be part of Header, Footer and PageStyle
-                    // itself, so decide what to do using the name
-                    const bool bHeader(rPropName.startsWith("Header"));
-                    const bool bFooter(rPropName.startsWith("Footer"));
+                    const SvxSetItem* pSetItem = nullptr;
 
-                    if (bHeader || bFooter)
+                    if(SfxItemState::SET == aBaseImpl.GetItemSet().GetItemState(bFooter ? SID_ATTR_PAGE_FOOTERSET : SID_ATTR_PAGE_HEADERSET, false, reinterpret_cast<const SfxPoolItem**>(&pSetItem)))
                     {
-                        const SvxSetItem* pSetItem = nullptr;
+                        // create a new SvxSetItem and get it's ItemSet as new target
+                        std::unique_ptr<SvxSetItem> pNewSetItem(static_cast<SvxSetItem*>(pSetItem->Clone()));
+                        SfxItemSet& rSetSet = pNewSetItem->GetItemSet();
 
-                        if(SfxItemState::SET == aBaseImpl.GetItemSet().GetItemState(bFooter ? SID_ATTR_PAGE_FOOTERSET : SID_ATTR_PAGE_HEADERSET, false, reinterpret_cast<const SfxPoolItem**>(&pSetItem)))
-                        {
-                            // create a new SvxSetItem and get it's ItemSet as new target
-                            SvxSetItem* pNewSetItem = static_cast< SvxSetItem* >(pSetItem->Clone());
-                            SfxItemSet& rSetSet = pNewSetItem->GetItemSet();
-
-                            // set parent to ItemSet to ensure XFILL_NONE as XFillStyleItem
-                            rSetSet.SetParent(&GetDoc()->GetDfltFrameFormat()->GetAttrSet());
+                        // set parent to ItemSet to ensure XFILL_NONE as XFillStyleItem
+                        rSetSet.SetParent(&GetDoc()->GetDfltFrameFormat()->GetAttrSet());
 
-                            // replace the used SfxItemSet at the SwStyleBase_Impl temporarily and use the
-                            // default method to set the property
-                            {
-                                SwStyleBase_Impl::ItemSetOverrider o(aBaseImpl, &rSetSet);
-                                SetStyleProperty(*pEntry, *pPropSet, pValues[nProp], aBaseImpl);
-                            }
+                        // replace the used SfxItemSet at the SwStyleBase_Impl temporarily and use the
+                        // default method to set the property
+                        {
+                            SwStyleBase_Impl::ItemSetOverrider o(aBaseImpl, &rSetSet);
+                            SetStyleProperty(*pEntry, *pPropSet, rValues[nProp], aBaseImpl);
+                        }
 
-                            // reset paret at ItemSet from SetItem
-                            rSetSet.SetParent(nullptr);
+                        // reset paret at ItemSet from SetItem
+                        rSetSet.SetParent(nullptr);
 
-                            // set the new SvxSetItem at the real target and delete it
-                            aBaseImpl.GetItemSet().Put(*pNewSetItem);
-                            delete pNewSetItem;
-                        }
+                        // set the new SvxSetItem at the real target and delete it
+                        aBaseImpl.GetItemSet().Put(*pNewSetItem);
                     }
-                    else
-                    {
-                        // part of PageStyle, fallback to default
-                        SetStyleProperty(*pEntry, *pPropSet, pValues[nProp], aBaseImpl);
-                    }
-
-                    break;
-                }
-                case FN_PARAM_FTN_INFO :
-                {
-                    const SfxPoolItem& rItem = aBaseImpl.GetItemSet().Get(FN_PARAM_FTN_INFO);
-                    SfxPoolItem* pNewFootnoteItem = rItem.Clone();
-                    bool bPut = pNewFootnoteItem->PutValue(pValues[nProp], pEntry->nMemberId);
-                    aBaseImpl.GetItemSet().Put(*pNewFootnoteItem);
-                    delete pNewFootnoteItem;
-                    if(!bPut)
-                        throw lang::IllegalArgumentException();
-                    break;
-                }
-                case  FN_UNO_HEADER       :
-                case  FN_UNO_HEADER_LEFT  :
-                case  FN_UNO_HEADER_RIGHT :
-                case  FN_UNO_HEADER_FIRST :
-                case  FN_UNO_FOOTER       :
-                case  FN_UNO_FOOTER_LEFT  :
-                case  FN_UNO_FOOTER_RIGHT :
-                case  FN_UNO_FOOTER_FIRST :
-                {
-                    throw lang::IllegalArgumentException();
-                }
-                default:
-                {
-                    SetStyleProperty(*pEntry, *pPropSet, pValues[nProp], aBaseImpl);
-                    break;
                 }
+                continue;
+                default: ;
             }
         }
-        else if(IsDescriptor())
+        switch(pEntry->nWID)
         {
-            if(!m_pPropertiesImpl->SetProperty(rPropName, pValues[nProp]))
+            case SID_ATTR_PAGE_DYNAMIC:
+            case SID_ATTR_PAGE_SHARED:
+            case SID_ATTR_PAGE_SHARED_FIRST:
+            case SID_ATTR_PAGE_ON:
+            case RES_HEADER_FOOTER_EAT_SPACING:
+                // these slots are exclusive to Header/Footer, thus this is an error
+                throw beans::UnknownPropertyException(OUString("Unknown property: ") + rPropName, static_cast<cppu::OWeakObject*>(this));
+            case FN_UNO_HEADER:
+            case FN_UNO_HEADER_LEFT:
+            case FN_UNO_HEADER_RIGHT:
+            case FN_UNO_HEADER_FIRST:
+            case FN_UNO_FOOTER:
+            case FN_UNO_FOOTER_LEFT:
+            case FN_UNO_FOOTER_RIGHT:
+            case FN_UNO_FOOTER_FIRST:
                 throw lang::IllegalArgumentException();
-        }
-        else
-        {
-            throw uno::RuntimeException();
+            case FN_PARAM_FTN_INFO:
+            {
+                const SfxPoolItem& rItem = aBaseImpl.GetItemSet().Get(FN_PARAM_FTN_INFO);
+                const std::unique_ptr<SfxPoolItem> pNewFootnoteItem(rItem.Clone());
+                if(!pNewFootnoteItem->PutValue(rValues[nProp], pEntry->nMemberId))
+                    throw lang::IllegalArgumentException();
+                aBaseImpl.GetItemSet().Put(*pNewFootnoteItem);
+                break;
+            }
+            default:
+            {
+                SetStyleProperty(*pEntry, *pPropSet, rValues[nProp], aBaseImpl);
+                break;
+            }
         }
     }
 
commit 83963a33da88f47f6e9b865188f9ec442d1ad770
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Wed Mar 16 12:09:52 2016 +0100

    use unique_ptr instead of manual mem-mgmt
    
    Change-Id: I68a3d1721fd6e1bcc206bdaec8dcf89a256b5ca1

diff --git a/sw/source/core/unocore/unostyle.cxx b/sw/source/core/unocore/unostyle.cxx
index 3f88672..e042560 100644
--- a/sw/source/core/unocore/unostyle.cxx
+++ b/sw/source/core/unocore/unostyle.cxx
@@ -2685,7 +2685,7 @@ SwXPageStyle::~SwXPageStyle()
 void SwXStyle::PutItemToSet(const SvxSetItem* pSetItem, const SfxItemPropertySet& rPropSet, const SfxItemPropertySimpleEntry& rEntry, const uno::Any& rVal, SwStyleBase_Impl& rBaseImpl)
 {
     // create a new SvxSetItem and get it's ItemSet as new target
-    SvxSetItem* pNewSetItem = static_cast< SvxSetItem* >(pSetItem->Clone());
+    const std::unique_ptr<SvxSetItem> pNewSetItem(static_cast<SvxSetItem*>(pSetItem->Clone()));
     SfxItemSet& rSetSet = pNewSetItem->GetItemSet();
 
     // set parent to ItemSet to ensure XFILL_NONE as XFillStyleItem
@@ -2703,7 +2703,6 @@ void SwXStyle::PutItemToSet(const SvxSetItem* pSetItem, const SfxItemPropertySet
 
     // set the new SvxSetItem at the real target and delete it
     rBaseImpl.GetItemSet().Put(*pNewSetItem);
-    delete pNewSetItem;
 }
 
 void SwXPageStyle::SetPropertyValues_Impl(
commit fe60e39ac322303dbba91d49cf215c0c9f3edabe
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Wed Mar 16 11:52:35 2016 +0100

    formatting/whitespace
    
    Change-Id: Ia0cdeefdfe7b3800568b96b4bf904d7d0d62f4b9

diff --git a/sw/source/core/unocore/unostyle.cxx b/sw/source/core/unocore/unostyle.cxx
index 24fec49..3f88672 100644
--- a/sw/source/core/unocore/unostyle.cxx
+++ b/sw/source/core/unocore/unostyle.cxx
@@ -2671,23 +2671,16 @@ void SwXStyle::Invalidate()
     m_xStyleFamily.clear();
 }
 
-SwXPageStyle::SwXPageStyle(SfxStyleSheetBasePool& rPool,
-        SwDocShell* pDocSh, SfxStyleFamily eFam,
-        const OUString& rStyleName):
-    SwXStyle(&rPool, eFam, pDocSh->GetDoc(), rStyleName)
-{
-
-}
+SwXPageStyle::SwXPageStyle(SfxStyleSheetBasePool& rPool, SwDocShell* pDocSh, SfxStyleFamily eFam, const OUString& rStyleName)
+    : SwXStyle(&rPool, eFam, pDocSh->GetDoc(), rStyleName)
+{ }
 
-SwXPageStyle::SwXPageStyle(SwDocShell* pDocSh) :
-    SwXStyle(pDocSh->GetDoc(), SFX_STYLE_FAMILY_PAGE)
-{
-}
+SwXPageStyle::SwXPageStyle(SwDocShell* pDocSh)
+    : SwXStyle(pDocSh->GetDoc(), SFX_STYLE_FAMILY_PAGE)
+{ }
 
 SwXPageStyle::~SwXPageStyle()
-{
-
-}
+{ }
 
 void SwXStyle::PutItemToSet(const SvxSetItem* pSetItem, const SfxItemPropertySet& rPropSet, const SfxItemPropertySimpleEntry& rEntry, const uno::Any& rVal, SwStyleBase_Impl& rBaseImpl)
 {
commit ac378355651a34bd0b88cdbea9de78beed6eac95
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Wed Mar 16 11:50:47 2016 +0100

    refactor Notify
    
    - check preconditions early
    - SfxStyleSheetHintId::ERASED is already handled by first if() branch
    
    Change-Id: I971eb460c3f006f19dde30f7aac30117be41a621

diff --git a/sw/source/core/unocore/unostyle.cxx b/sw/source/core/unocore/unostyle.cxx
index f28f320..24fec49 100644
--- a/sw/source/core/unocore/unostyle.cxx
+++ b/sw/source/core/unocore/unostyle.cxx
@@ -2640,30 +2640,28 @@ uno::Any SwXStyle::getPropertyDefault(const OUString& rPropertyName)
     return getPropertyDefaults(aSequence)[0];
 }
 
-void SwXStyle::Notify( SfxBroadcaster& rBC, const SfxHint& rHint )
+void SwXStyle::Notify(SfxBroadcaster& rBC, const SfxHint& rHint)
 {
     const SfxSimpleHint* pHint = dynamic_cast<const SfxSimpleHint*>(&rHint);
-    if( pHint )
+    if(!pHint)
+        return;
+    if((pHint->GetId() & SFX_HINT_DYING) || (pHint->GetId() & SfxStyleSheetHintId::ERASED))
+    {
+        m_pBasePool = nullptr;
+        EndListening(rBC);
+    }
+    else if(pHint->GetId() & (SfxStyleSheetHintId::CHANGED))
     {
-        if(( pHint->GetId() & SFX_HINT_DYING ) || ( pHint->GetId() & SfxStyleSheetHintId::ERASED))
+        static_cast<SfxStyleSheetBasePool&>(rBC).SetSearchMask(m_rEntry.m_eFamily);
+        SfxStyleSheetBase* pOwnBase = static_cast<SfxStyleSheetBasePool&>(rBC).Find(m_sStyleName);
+        if(!pOwnBase)
         {
-            m_pBasePool = nullptr;
             EndListening(rBC);
-        }
-        else if( pHint->GetId() &(SfxStyleSheetHintId::CHANGED|SfxStyleSheetHintId::ERASED) )
-        {
-            static_cast<SfxStyleSheetBasePool&>(rBC).SetSearchMask(m_rEntry.m_eFamily);
-            SfxStyleSheetBase* pOwnBase = static_cast<SfxStyleSheetBasePool&>(rBC).Find(m_sStyleName);
-            if(!pOwnBase)
-            {
-                EndListening(rBC);
-                Invalidate();
-            }
+            Invalidate();
         }
     }
 }
 
-
 void SwXStyle::Invalidate()
 {
     m_sStyleName.clear();
commit fdf280853d54d6786479e15f231f5d447627fba1
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Wed Mar 16 11:42:48 2016 +0100

    fix plenking, remove superficial getConstArray
    
    Change-Id: I19afc0fe11e5457dfe2efc6b0224a6857d60a74b

diff --git a/sw/source/core/unocore/unostyle.cxx b/sw/source/core/unocore/unostyle.cxx
index 29aa51c..f28f320 100644
--- a/sw/source/core/unocore/unostyle.cxx
+++ b/sw/source/core/unocore/unostyle.cxx
@@ -2634,10 +2634,10 @@ uno::Sequence<uno::Any> SAL_CALL SwXStyle::getPropertyDefaults(const uno::Sequen
 }
 
 uno::Any SwXStyle::getPropertyDefault(const OUString& rPropertyName)
-    throw( beans::UnknownPropertyException, lang::WrappedTargetException, uno::RuntimeException, std::exception )
+    throw(beans::UnknownPropertyException, lang::WrappedTargetException, uno::RuntimeException, std::exception)
 {
-    const uno::Sequence < OUString > aSequence ( &rPropertyName, 1 );
-    return getPropertyDefaults ( aSequence ).getConstArray()[0];
+    const uno::Sequence<OUString> aSequence(&rPropertyName, 1);
+    return getPropertyDefaults(aSequence)[0];
 }
 
 void SwXStyle::Notify( SfxBroadcaster& rBC, const SfxHint& rHint )
commit abb0c77a9bd76bf8eb46ee0ab1277cc4535731ee
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Wed Mar 16 11:33:48 2016 +0100

    refactor getPropertyDefaults
    
    - check preconditions early
    - use GetStyleSheetBase()
    - get nPropSetId from m_rEntry
    
    Change-Id: I45854bf2b232552ccaffaedeeaa13f77fec82ecd

diff --git a/sw/source/core/unocore/unostyle.cxx b/sw/source/core/unocore/unostyle.cxx
index 2add207..29aa51c 100644
--- a/sw/source/core/unocore/unostyle.cxx
+++ b/sw/source/core/unocore/unostyle.cxx
@@ -2592,77 +2592,42 @@ void SAL_CALL SwXStyle::setAllPropertiesToDefault()
     pTargetFormat->ResetAllFormatAttr();
 }
 
-uno::Sequence< uno::Any > SAL_CALL SwXStyle::getPropertyDefaults( const uno::Sequence< OUString >& aPropertyNames )
-    throw (beans::UnknownPropertyException, lang::WrappedTargetException, uno::RuntimeException, std::exception)
+uno::Sequence<uno::Any> SAL_CALL SwXStyle::getPropertyDefaults(const uno::Sequence<OUString>& aPropertyNames)
+        throw (beans::UnknownPropertyException, lang::WrappedTargetException, uno::RuntimeException, std::exception)
 {
     SolarMutexGuard aGuard;
     sal_Int32 nCount = aPropertyNames.getLength();
+    uno::Sequence<uno::Any> aRet(nCount);
+    if(!nCount)
+        return aRet;
+    SfxStyleSheetBase* pBase = GetStyleSheetBase();
+    if(!pBase)
+        throw uno::RuntimeException();
+    rtl::Reference<SwDocStyleSheet> xStyle(new SwDocStyleSheet(*static_cast<SwDocStyleSheet*>(pBase)));
+    const sal_Int8 nPropSetId = m_bIsConditional ? PROPERTY_MAP_CONDITIONAL_PARA_STYLE : m_rEntry.m_nPropMapType;
+    const SfxItemPropertySet* pPropSet = aSwMapProvider.GetPropertySet(nPropSetId);
+    const SfxItemPropertyMap& rMap = pPropSet->getPropertyMap();
 
-    uno::Sequence < uno::Any > aRet(nCount);
-
-    if(nCount)
+    const SfxItemSet &rSet = xStyle->GetItemSet(), *pParentSet = rSet.GetParent();
+    for(sal_Int32 i = 0; i < nCount; ++i)
     {
-        if(m_pBasePool)
-        {
-            m_pBasePool->SetSearchMask(m_rEntry.m_eFamily);
-            SfxStyleSheetBase* pBase = m_pBasePool->Find(m_sStyleName);
-            OSL_ENSURE(pBase, "Doesn't seem to be a style!");
-
-            if(pBase)
-            {
-                rtl::Reference< SwDocStyleSheet > xStyle(new SwDocStyleSheet(*static_cast<SwDocStyleSheet*>(pBase)));
-                sal_Int8 nPropSetId = PROPERTY_MAP_CHAR_STYLE;
-                switch(m_rEntry.m_eFamily)
-                {
-                    case SFX_STYLE_FAMILY_PARA  : nPropSetId = m_bIsConditional ? PROPERTY_MAP_CONDITIONAL_PARA_STYLE : PROPERTY_MAP_PARA_STYLE; break;
-                    case SFX_STYLE_FAMILY_FRAME : nPropSetId = PROPERTY_MAP_FRAME_STYLE; break;
-                    case SFX_STYLE_FAMILY_PAGE  : nPropSetId = PROPERTY_MAP_PAGE_STYLE; break;
-                    case SFX_STYLE_FAMILY_PSEUDO: nPropSetId = PROPERTY_MAP_NUM_STYLE; break;
-                    default: ;
-                }
-                const SfxItemPropertySet* pPropSet = aSwMapProvider.GetPropertySet(nPropSetId);
-                const SfxItemPropertyMap& rMap = pPropSet->getPropertyMap();
-
-                const SfxItemSet &rSet = xStyle->GetItemSet(), *pParentSet = rSet.GetParent();
-                const OUString *pNames = aPropertyNames.getConstArray();
-                uno::Any *pRet = aRet.getArray();
-
-                for(sal_Int32 i = 0; i < nCount; i++)
-                {
-                    const SfxItemPropertySimpleEntry* pEntry = rMap.getByName(pNames[i]);
-
-                    if(!pEntry)
-                    {
-                        throw beans::UnknownPropertyException("Unknown property: " + pNames[i], static_cast < cppu::OWeakObject * >(this));
-                    }
+        const SfxItemPropertySimpleEntry* pEntry = rMap.getByName(aPropertyNames[i]);
 
-                    if (pEntry->nWID >= RES_UNKNOWNATR_END)
-                    {
-                        // these cannot be in an item set, especially not the
-                        // parent set, so the default value is void
-                        continue;
-                    }
-
-                    if(pParentSet)
-                    {
-                        aSwMapProvider.GetPropertySet(nPropSetId)->getPropertyValue(pNames[i], *pParentSet, pRet[i]);
-                    }
-                    else if(pEntry->nWID != rSet.GetPool()->GetSlotId(pEntry->nWID))
-                    {
-                        const SfxPoolItem& rItem = rSet.GetPool()->GetDefaultItem(pEntry->nWID);
+        if(!pEntry)
+            throw beans::UnknownPropertyException("Unknown property: " + aPropertyNames[i], static_cast < cppu::OWeakObject * >(this));
+        // these cannot be in an item set, especially not the
+        // parent set, so the default value is void
+        if (pEntry->nWID >= RES_UNKNOWNATR_END)
+            continue;
 
-                        rItem.QueryValue(pRet[i], pEntry->nMemberId);
-                    }
-                }
-            }
-            else
-            {
-                throw uno::RuntimeException();
-            }
+        if(pParentSet)
+        {
+            aSwMapProvider.GetPropertySet(nPropSetId)->getPropertyValue(aPropertyNames[i], *pParentSet, aRet[i]);
         }
-        else
+        else if(pEntry->nWID != rSet.GetPool()->GetSlotId(pEntry->nWID))
         {
-            throw uno::RuntimeException();
+            const SfxPoolItem& rItem = rSet.GetPool()->GetDefaultItem(pEntry->nWID);
+            rItem.QueryValue(aRet[i], pEntry->nMemberId);
         }
     }
     return aRet;
commit 2ad92da790a65cfb447867e27ce959b85febfea1
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Tue Mar 15 22:33:13 2016 +0100

    refactor setAllPropertiesToDefault
    
    - check preconditions early
    - move the SwDocStyleSheet creation out of lcl_GetFormatForStyle
    
    Change-Id: I877d2d32ca8b631332f234a2cd3eefd43f099d43

diff --git a/sw/source/core/unocore/unostyle.cxx b/sw/source/core/unocore/unostyle.cxx
index bb61514..2add207 100644
--- a/sw/source/core/unocore/unostyle.cxx
+++ b/sw/source/core/unocore/unostyle.cxx
@@ -2442,16 +2442,10 @@ void SwXStyle::setPropertyToDefault(const OUString& rPropertyName)
     setPropertiesToDefault(aSequence);
 }
 
-SwFormat* lcl_GetFormatForStyle(SfxStyleSheetBasePool* pBasePool, SwDoc* pDoc, const OUString& sStyleName, const SfxStyleFamily eFamily)
+SwFormat* lcl_GetFormatForStyle(SwDoc* pDoc, rtl::Reference<SwDocStyleSheet> xStyle, const SfxStyleFamily eFamily)
 {
-    if(!pBasePool)
-        return nullptr;
-    pBasePool->SetSearchMask(eFamily);
-    SfxStyleSheetBase* pBase = pBasePool->Find(sStyleName);
-    SAL_WARN_IF(!pBase, "sw.uno", "Where is the style?");
-    if(pBase)
+    if(!xStyle.is())
         return nullptr;
-    rtl::Reference<SwDocStyleSheet> xStyle(new SwDocStyleSheet(*static_cast<SwDocStyleSheet*>(pBase)));
     switch(eFamily)
     {
         case SFX_STYLE_FAMILY_CHAR: return xStyle->GetCharFormat();
@@ -2464,7 +2458,6 @@ SwFormat* lcl_GetFormatForStyle(SfxStyleSheetBasePool* pBasePool, SwDoc* pDoc, c
                 return &pDesc->GetMaster();
         }
         break;
-        case SFX_STYLE_FAMILY_PSEUDO: break;
         default: ;
     }
     return nullptr;
@@ -2474,7 +2467,8 @@ void SAL_CALL SwXStyle::setPropertiesToDefault(const uno::Sequence<OUString>& aP
         throw (beans::UnknownPropertyException, uno::RuntimeException, std::exception)
 {
     SolarMutexGuard aGuard;
-    SwFormat* pTargetFormat = lcl_GetFormatForStyle(m_pBasePool, m_pDoc, m_sStyleName, m_rEntry.m_eFamily);
+    const rtl::Reference<SwDocStyleSheet> xStyle(new SwDocStyleSheet(*static_cast<SwDocStyleSheet*>(GetStyleSheetBase())));
+    SwFormat* pTargetFormat = lcl_GetFormatForStyle(m_pDoc, xStyle, m_rEntry.m_eFamily);
     if(!pTargetFormat)
     {
         if(!m_bIsDescriptor)
@@ -2516,130 +2510,86 @@ void SAL_CALL SwXStyle::setPropertiesToDefault(const uno::Sequence<OUString>& aP
     }
 }
 
-void SAL_CALL SwXStyle::setAllPropertiesToDefault(  )
-    throw (uno::RuntimeException, std::exception)
+void SAL_CALL SwXStyle::setAllPropertiesToDefault()
+    throw(uno::RuntimeException, std::exception)
 {
     SolarMutexGuard aGuard;
-
-    if(m_pBasePool)
+    if(!m_pBasePool)
     {
-        m_pBasePool->SetSearchMask(m_rEntry.m_eFamily);
-        SfxStyleSheetBase* pBase = m_pBasePool->Find(m_sStyleName);
-        OSL_ENSURE(pBase, "Where is the style?");
-
-        if(pBase)
+        if(!m_bIsDescriptor)
+            throw uno::RuntimeException();
+        m_pPropertiesImpl->ClearAllProperties();
+        return;
+    }
+    const rtl::Reference<SwDocStyleSheet> xStyle(new SwDocStyleSheet(*static_cast<SwDocStyleSheet*>(GetStyleSheetBase())));
+    if(!xStyle.is())
+        throw uno::RuntimeException();
+    if(SFX_STYLE_FAMILY_PAGE == m_rEntry.m_eFamily)
+    {
+        size_t nPgDscPos(0);
+        SwPageDesc* pDesc = m_pDoc->FindPageDesc(xStyle->GetPageDesc()->GetName(), &nPgDscPos);
+        SwFormat* pPageFormat(nullptr);
+        if(pDesc)
         {
-            rtl::Reference< SwDocStyleSheet > xStyle( new SwDocStyleSheet( *static_cast<SwDocStyleSheet*>(pBase) ) );
-            SwFormat *pTargetFormat = nullptr;
-            size_t nPgDscPos = SIZE_MAX;
-            switch(m_rEntry.m_eFamily)
+            pPageFormat = &pDesc->GetMaster();
+            pDesc->SetUseOn(nsUseOnPage::PD_ALL);
+        }
+        else
+            pPageFormat = lcl_GetFormatForStyle(m_pDoc, xStyle, m_rEntry.m_eFamily);
+        SwPageDesc& rPageDesc = m_pDoc->GetPageDesc(nPgDscPos);
+        rPageDesc.ResetAllMasterAttr();
+
+        SvxLRSpaceItem aLR(RES_LR_SPACE);
+        sal_Int32 nSize = GetMetricVal(CM_1) * 2;
+        aLR.SetLeft(nSize);
+        aLR.SetLeft(nSize);
+        SvxULSpaceItem aUL(RES_UL_SPACE);
+        aUL.SetUpper(static_cast<sal_uInt16>(nSize));
+        aUL.SetLower(static_cast<sal_uInt16>(nSize));
+        pPageFormat->SetFormatAttr(aLR);
+        pPageFormat->SetFormatAttr(aUL);
+        SwPageDesc* pStdPgDsc = m_pDoc->getIDocumentStylePoolAccess().GetPageDescFromPool(RES_POOLPAGE_STANDARD);
+        SwFormatFrameSize aFrameSz(ATT_FIX_SIZE);
+
+        if(RES_POOLPAGE_STANDARD == rPageDesc.GetPoolFormatId())
+        {
+            if(m_pDoc->getIDocumentDeviceAccess().getPrinter(false))
             {
-                case SFX_STYLE_FAMILY_CHAR:
-                    pTargetFormat = xStyle->GetCharFormat();
-                    break;
-
-                case SFX_STYLE_FAMILY_PARA:
-                {
-                    pTargetFormat = xStyle->GetCollection();
-                    if(xStyle->GetCollection())
-                    {
-                        xStyle->GetCollection()->DeleteAssignmentToListLevelOfOutlineStyle();
-                    }
-                    break;
-                }
-
-                case SFX_STYLE_FAMILY_FRAME:
-                    pTargetFormat = xStyle->GetFrameFormat();
-                    break;
-
-                case SFX_STYLE_FAMILY_PAGE:
-                {
-                    SwPageDesc *pDesc = m_pDoc->FindPageDesc(xStyle->GetPageDesc()->GetName(), &nPgDscPos);
-                    if( pDesc )
-                    {
-                        pTargetFormat = &pDesc->GetMaster();
-                        pDesc->SetUseOn(nsUseOnPage::PD_ALL);
-                    }
-                    break;
-                }
-
-                case SFX_STYLE_FAMILY_PSEUDO:
-                    break;
-
-                default: ;
+                const Size aPhysSize( SvxPaperInfo::GetPaperSize(
+                    static_cast<Printer*>(m_pDoc->getIDocumentDeviceAccess().getPrinter(false))));
+                aFrameSz.SetSize(aPhysSize);
             }
-
-            if(pTargetFormat)
+            else
             {
-                if(SIZE_MAX != nPgDscPos)
-                {
-                    SwPageDesc& rPageDesc = m_pDoc->GetPageDesc(nPgDscPos);
-                    rPageDesc.ResetAllMasterAttr();
-
-                    SvxLRSpaceItem aLR(RES_LR_SPACE);
-                    sal_Int32 nSize = GetMetricVal(CM_1) * 2;
-                    aLR.SetLeft(nSize);
-                    aLR.SetLeft(nSize);
-                    SvxULSpaceItem aUL(RES_UL_SPACE);
-                    aUL.SetUpper(static_cast <sal_uInt16> (nSize));
-                    aUL.SetLower(static_cast <sal_uInt16> (nSize));
-                    pTargetFormat->SetFormatAttr(aLR);
-                    pTargetFormat->SetFormatAttr(aUL);
-                    SwPageDesc* pStdPgDsc = m_pDoc->getIDocumentStylePoolAccess().GetPageDescFromPool(RES_POOLPAGE_STANDARD);
-                    SwFormatFrameSize aFrameSz(ATT_FIX_SIZE);
-
-                    if(RES_POOLPAGE_STANDARD == rPageDesc.GetPoolFormatId())
-                    {
-                        if(m_pDoc->getIDocumentDeviceAccess().getPrinter(false))
-                        {
-                            const Size aPhysSize( SvxPaperInfo::GetPaperSize(
-                                static_cast<Printer*>(m_pDoc->getIDocumentDeviceAccess().getPrinter(false))));
-                            aFrameSz.SetSize(aPhysSize);
-                        }
-                        else
-                        {
-                            aFrameSz.SetSize(SvxPaperInfo::GetDefaultPaperSize());
-                        }
-
-                    }
-                    else
-                    {
-                        aFrameSz = pStdPgDsc->GetMaster().GetFrameSize();
-                    }
-
-                    if(pStdPgDsc->GetLandscape())
-                    {
-                        SwTwips nTmp = aFrameSz.GetHeight();
-                        aFrameSz.SetHeight(aFrameSz.GetWidth());
-                        aFrameSz.SetWidth(nTmp);
-                    }
-
-                    pTargetFormat->SetFormatAttr( aFrameSz );
-                }
-                else
-                {
-                    pTargetFormat->ResetAllFormatAttr();
-                }
-
-                if(SIZE_MAX != nPgDscPos)
-                {
-                    m_pDoc->ChgPageDesc(nPgDscPos, m_pDoc->GetPageDesc(nPgDscPos));
-                }
+                aFrameSz.SetSize(SvxPaperInfo::GetDefaultPaperSize());
             }
+
         }
         else
         {
-            throw uno::RuntimeException();
+            aFrameSz = pStdPgDsc->GetMaster().GetFrameSize();
         }
+
+        if(pStdPgDsc->GetLandscape())
+        {
+            SwTwips nTmp = aFrameSz.GetHeight();
+            aFrameSz.SetHeight(aFrameSz.GetWidth());
+            aFrameSz.SetWidth(nTmp);
+        }
+
+        pPageFormat->SetFormatAttr(aFrameSz);
+        m_pDoc->ChgPageDesc(nPgDscPos, m_pDoc->GetPageDesc(nPgDscPos));
+        return;
     }
-    else if ( m_bIsDescriptor )
-    {
-        m_pPropertiesImpl->ClearAllProperties();
-    }
-    else
+    if(SFX_STYLE_FAMILY_PARA == m_rEntry.m_eFamily)
     {
-        throw uno::RuntimeException();
+        if(xStyle->GetCollection())
+            xStyle->GetCollection()->DeleteAssignmentToListLevelOfOutlineStyle();
     }
+    SwFormat* const pTargetFormat = lcl_GetFormatForStyle(m_pDoc, xStyle, m_rEntry.m_eFamily);
+    if(!pTargetFormat)
+        return;
+    pTargetFormat->ResetAllFormatAttr();
 }
 
 uno::Sequence< uno::Any > SAL_CALL SwXStyle::getPropertyDefaults( const uno::Sequence< OUString >& aPropertyNames )
commit 36a2245198f8bdbf5840ec9c6b85075184e15503
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Tue Mar 15 13:25:11 2016 +0100

    refactor setPropertyToDefault
    
    - check preconditions early
    - extract finding the SwFormat in a helper function
    - use ranged-for instead of naked pointer arithmetic
    - OSL_ENSURE -> SAL_WARN_IF
    
    Change-Id: I3f5754632c9dab29ce3acc4f59e33cb32e239cbb

diff --git a/sw/source/core/unocore/unostyle.cxx b/sw/source/core/unocore/unostyle.cxx
index 07eb1e5..bb61514 100644
--- a/sw/source/core/unocore/unostyle.cxx
+++ b/sw/source/core/unocore/unostyle.cxx
@@ -2442,113 +2442,76 @@ void SwXStyle::setPropertyToDefault(const OUString& rPropertyName)
     setPropertiesToDefault(aSequence);
 }
 
-void SAL_CALL SwXStyle::setPropertiesToDefault( const uno::Sequence< OUString >& aPropertyNames )
-    throw (beans::UnknownPropertyException, uno::RuntimeException, std::exception)
+SwFormat* lcl_GetFormatForStyle(SfxStyleSheetBasePool* pBasePool, SwDoc* pDoc, const OUString& sStyleName, const SfxStyleFamily eFamily)
 {
-    SolarMutexGuard aGuard;
-    SwFormat *pTargetFormat = nullptr;
-
-    if(m_pBasePool)
+    if(!pBasePool)
+        return nullptr;
+    pBasePool->SetSearchMask(eFamily);
+    SfxStyleSheetBase* pBase = pBasePool->Find(sStyleName);
+    SAL_WARN_IF(!pBase, "sw.uno", "Where is the style?");
+    if(pBase)
+        return nullptr;
+    rtl::Reference<SwDocStyleSheet> xStyle(new SwDocStyleSheet(*static_cast<SwDocStyleSheet*>(pBase)));
+    switch(eFamily)
     {
-        m_pBasePool->SetSearchMask(m_rEntry.m_eFamily);
-        SfxStyleSheetBase* pBase = m_pBasePool->Find(m_sStyleName);
-        OSL_ENSURE(pBase, "Where is the style?");
-
-        if(pBase)
+        case SFX_STYLE_FAMILY_CHAR: return xStyle->GetCharFormat();
+        case SFX_STYLE_FAMILY_PARA: return xStyle->GetCollection();
+        case SFX_STYLE_FAMILY_FRAME: return xStyle->GetFrameFormat();
+        case SFX_STYLE_FAMILY_PAGE:
         {
-            rtl::Reference< SwDocStyleSheet > xStyle( new SwDocStyleSheet( *static_cast<SwDocStyleSheet*>(pBase) ) );
-            switch(m_rEntry.m_eFamily)
-            {
-                case SFX_STYLE_FAMILY_CHAR:
-                    pTargetFormat = xStyle->GetCharFormat();
-                    break;
-
-                case SFX_STYLE_FAMILY_PARA:
-                    pTargetFormat = xStyle->GetCollection();
-                    break;
-
-                case SFX_STYLE_FAMILY_FRAME:
-                    pTargetFormat = xStyle->GetFrameFormat();
-                    break;
-
-                case SFX_STYLE_FAMILY_PAGE:
-                {
-                    SwPageDesc *pDesc = m_pDoc->FindPageDesc(xStyle->GetPageDesc()->GetName());
-                    if( pDesc )
-                        pTargetFormat = &pDesc->GetMaster();
-                    break;
-                }
-                case SFX_STYLE_FAMILY_PSEUDO:
-                    break;
-                default: ;
-            }
+            SwPageDesc* pDesc(pDoc->FindPageDesc(xStyle->GetPageDesc()->GetName()));
+            if(pDesc)
+                return &pDesc->GetMaster();
         }
+        break;
+        case SFX_STYLE_FAMILY_PSEUDO: break;
+        default: ;
     }
+    return nullptr;
+}
 
-    sal_Int8 nPropSetId = PROPERTY_MAP_CHAR_STYLE;
-
-    switch(m_rEntry.m_eFamily)
+void SAL_CALL SwXStyle::setPropertiesToDefault(const uno::Sequence<OUString>& aPropertyNames)
+        throw (beans::UnknownPropertyException, uno::RuntimeException, std::exception)
+{
+    SolarMutexGuard aGuard;
+    SwFormat* pTargetFormat = lcl_GetFormatForStyle(m_pBasePool, m_pDoc, m_sStyleName, m_rEntry.m_eFamily);
+    if(!pTargetFormat)
     {
-        case SFX_STYLE_FAMILY_PARA  : nPropSetId = m_bIsConditional ? PROPERTY_MAP_CONDITIONAL_PARA_STYLE : PROPERTY_MAP_PARA_STYLE; break;
-        case SFX_STYLE_FAMILY_FRAME : nPropSetId = PROPERTY_MAP_FRAME_STYLE; break;
-        case SFX_STYLE_FAMILY_PAGE  : nPropSetId = PROPERTY_MAP_PAGE_STYLE; break;
-        case SFX_STYLE_FAMILY_PSEUDO: nPropSetId = PROPERTY_MAP_NUM_STYLE; break;
-        default: ;
+        if(!m_bIsDescriptor)
+            return;
+        for(const auto& rName : aPropertyNames)
+            m_pPropertiesImpl->ClearProperty(rName);
+        return;
     }
-
+    const sal_Int8 nPropSetId = m_bIsConditional ? PROPERTY_MAP_CONDITIONAL_PARA_STYLE : m_rEntry.m_nPropMapType;
     const SfxItemPropertySet* pPropSet = aSwMapProvider.GetPropertySet(nPropSetId);
     const SfxItemPropertyMap &rMap = pPropSet->getPropertyMap();
-    const OUString* pNames = aPropertyNames.getConstArray();
-
-    if(pTargetFormat)
+    for(const auto& rName : aPropertyNames)
     {
-        for(sal_Int32 nProp = 0, nEnd = aPropertyNames.getLength(); nProp < nEnd; nProp++)
+        const SfxItemPropertySimpleEntry* pEntry = rMap.getByName(rName);
+        if(!pEntry)
+            throw beans::UnknownPropertyException("Unknown property: " + rName, static_cast<cppu::OWeakObject*>(this));
+        if(pEntry->nWID == FN_UNO_FOLLOW_STYLE || pEntry->nWID == FN_UNO_NUM_RULES)
+            throw uno::RuntimeException("Cannot reset: " + rName, static_cast<cppu::OWeakObject*>(this));
+        if(pEntry->nFlags & beans::PropertyAttribute::READONLY)
+            throw uno::RuntimeException("setPropertiesToDefault: property is read-only: " + rName, static_cast<cppu::OWeakObject*>(this));
+        if(pEntry->nWID == RES_PARATR_OUTLINELEVEL)
         {
-            const SfxItemPropertySimpleEntry* pEntry = rMap.getByName(pNames[nProp]);
-
-            if( !pEntry )
-            {
-                throw beans::UnknownPropertyException ( "Unknown property: " + pNames[nProp], static_cast < cppu::OWeakObject * > ( this ) );
-            }
-
-            if ( pEntry->nWID == FN_UNO_FOLLOW_STYLE || pEntry->nWID == FN_UNO_NUM_RULES )
-            {
-                throw uno::RuntimeException ("Cannot reset: " + pNames[nProp], static_cast < cppu::OWeakObject * > ( this ) );
-            }
-
-            if (pEntry->nFlags & beans::PropertyAttribute::READONLY)
-            {
-                throw uno::RuntimeException("setPropertiesToDefault: property is read-only: " + pNames[nProp], static_cast < cppu::OWeakObject * > ( this ) );
-            }
-
-            if( pEntry->nWID == RES_PARATR_OUTLINELEVEL )
-            {
-                static_cast<SwTextFormatColl*>(pTargetFormat)->DeleteAssignmentToListLevelOfOutlineStyle();
-            }
-            else
-            {
-                pTargetFormat->ResetFormatAttr( pEntry->nWID );
-            }
-
-            if(OWN_ATTR_FILLBMP_MODE == pEntry->nWID)
-            {
-                //UUUU
-                SwDoc* pDoc = pTargetFormat->GetDoc();
-                SfxItemSet aSet(pDoc->GetAttrPool(), XATTR_FILL_FIRST, XATTR_FILL_LAST);
-                aSet.SetParent(&pTargetFormat->GetAttrSet());
-
-                aSet.ClearItem(XATTR_FILLBMP_STRETCH);
-                aSet.ClearItem(XATTR_FILLBMP_TILE);
-
-                pTargetFormat->SetFormatAttr(aSet);
-            }
+            static_cast<SwTextFormatColl*>(pTargetFormat)->DeleteAssignmentToListLevelOfOutlineStyle();
+            continue;
         }
-    }
-    else if(m_bIsDescriptor)
-    {
-        for(sal_Int32 nProp = 0, nEnd = aPropertyNames.getLength(); nProp < nEnd; nProp++)
+        pTargetFormat->ResetFormatAttr(pEntry->nWID);
+        if(OWN_ATTR_FILLBMP_MODE == pEntry->nWID)
         {
-            m_pPropertiesImpl->ClearProperty(pNames[nProp]);
+            //UUUU
+            SwDoc* pDoc = pTargetFormat->GetDoc();
+            SfxItemSet aSet(pDoc->GetAttrPool(), XATTR_FILL_FIRST, XATTR_FILL_LAST);
+            aSet.SetParent(&pTargetFormat->GetAttrSet());
+
+            aSet.ClearItem(XATTR_FILLBMP_STRETCH);
+            aSet.ClearItem(XATTR_FILLBMP_TILE);
+
+            pTargetFormat->SetFormatAttr(aSet);
         }
     }
 }
commit ee105a940751bcc31e18643220b631301a82587b
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Tue Mar 15 12:42:42 2016 +0100

    whitespace: fix plenking
    
    Change-Id: Ie5473191f5121eab95a3aaef67738240e5c75393

diff --git a/sw/source/core/unocore/unostyle.cxx b/sw/source/core/unocore/unostyle.cxx
index d1111b9..07eb1e5 100644
--- a/sw/source/core/unocore/unostyle.cxx
+++ b/sw/source/core/unocore/unostyle.cxx
@@ -2436,10 +2436,10 @@ uno::Sequence<beans::PropertyState> SwXStyle::getPropertyStates(const uno::Seque
 }
 
 void SwXStyle::setPropertyToDefault(const OUString& rPropertyName)
-        throw( beans::UnknownPropertyException, uno::RuntimeException, std::exception )
+        throw(beans::UnknownPropertyException, uno::RuntimeException, std::exception)
 {
-    const uno::Sequence < OUString > aSequence ( &rPropertyName, 1 );
-    setPropertiesToDefault ( aSequence );
+    const uno::Sequence<OUString> aSequence(&rPropertyName, 1);
+    setPropertiesToDefault(aSequence);
 }
 
 void SAL_CALL SwXStyle::setPropertiesToDefault( const uno::Sequence< OUString >& aPropertyNames )
commit 4dbc3f0dfb8e7b337477fa70d6fd687a3f1d2ef9
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Tue Mar 15 00:37:36 2016 +0100

    refactor getPropertyStates
    
    - refactor out Header/Footer special casing
    - check preconditions early
    - OSL_ENSURE -> SAL_WARN_IIF
    - use m_rEntry to find nPropSetId
    - remove bDone cludge and use switch/case for remainders
    
    Change-Id: I7fcac7e9c44190b6695bb0ced4278b50bd7f1c46

diff --git a/sw/source/core/unocore/unostyle.cxx b/sw/source/core/unocore/unostyle.cxx
index bc8064b..d1111b9 100644
--- a/sw/source/core/unocore/unostyle.cxx
+++ b/sw/source/core/unocore/unostyle.cxx
@@ -2323,149 +2323,115 @@ beans::PropertyState SwXStyle::getPropertyState(const OUString& rPropertyName)
     return aStates.getConstArray()[0];
 }
 
-uno::Sequence< beans::PropertyState > SwXStyle::getPropertyStates(
-    const uno::Sequence< OUString >& rPropertyNames)
-        throw( beans::UnknownPropertyException, uno::RuntimeException, std::exception )
+// allow to retarget the SfxItemSet working on, default correctly. Only
+// use pSourceSet below this point (except in header/footer processing)
+const SfxItemSet* lcl_GetItemsetForProperty(const SfxItemSet& rSet, SfxStyleFamily eFamily, const OUString& rPropertyName)
+{
+    if(eFamily != SFX_STYLE_FAMILY_PAGE)
+        return &rSet;
+    const bool isFooter = rPropertyName.startsWith("Footer");
+    if(!isFooter && !rPropertyName.startsWith("Header") && rPropertyName != UNO_NAME_FIRST_IS_SHARED)
+        return &rSet;
+    const SvxSetItem* pSetItem;
+    if(!lcl_GetHeaderFooterItem(rSet, rPropertyName, isFooter, pSetItem))
+        return nullptr;
+    return &pSetItem->GetItemSet();
+}
+uno::Sequence<beans::PropertyState> SwXStyle::getPropertyStates(const uno::Sequence<OUString>& rPropertyNames)
+        throw(beans::UnknownPropertyException, uno::RuntimeException, std::exception)
 {
     SolarMutexGuard aGuard;
-    uno::Sequence< beans::PropertyState > aRet(rPropertyNames.getLength());
+    uno::Sequence<beans::PropertyState> aRet(rPropertyNames.getLength());
     beans::PropertyState* pStates = aRet.getArray();
 
-    if(m_pBasePool)
-    {
-        m_pBasePool->SetSearchMask(m_rEntry.m_eFamily );
-        SfxStyleSheetBase* pBase = m_pBasePool->Find(m_sStyleName);
-        OSL_ENSURE(pBase, "where is the style?" );
+    if(!m_pBasePool)
+        throw uno::RuntimeException();
+    m_pBasePool->SetSearchMask(m_rEntry.m_eFamily);
+    SfxStyleSheetBase* pBase = m_pBasePool->Find(m_sStyleName);
 
-        if(pBase)
-        {
-            const OUString* pNames = rPropertyNames.getConstArray();
-            rtl::Reference< SwDocStyleSheet > xStyle( new SwDocStyleSheet( *static_cast<SwDocStyleSheet*>(pBase) ) );
-            sal_Int8 nPropSetId = PROPERTY_MAP_CHAR_STYLE;
+    SAL_WARN_IF(!pBase, "sw.uno", "where is the style?");
+    if(!pBase)
+        throw uno::RuntimeException();
 
-            switch(m_rEntry.m_eFamily)
-            {
-                case SFX_STYLE_FAMILY_PARA  : nPropSetId = m_bIsConditional ? PROPERTY_MAP_CONDITIONAL_PARA_STYLE : PROPERTY_MAP_PARA_STYLE; break;
-                case SFX_STYLE_FAMILY_FRAME : nPropSetId = PROPERTY_MAP_FRAME_STYLE ;break;
-                case SFX_STYLE_FAMILY_PAGE  : nPropSetId = PROPERTY_MAP_PAGE_STYLE;   break;
-                case SFX_STYLE_FAMILY_PSEUDO: nPropSetId = PROPERTY_MAP_NUM_STYLE   ;break;
-                default: ;
-            }
+    const OUString* pNames = rPropertyNames.getConstArray();
+    rtl::Reference<SwDocStyleSheet> xStyle(new SwDocStyleSheet(*static_cast<SwDocStyleSheet*>(pBase)));
+    sal_Int8 nPropSetId = m_bIsConditional ? PROPERTY_MAP_CONDITIONAL_PARA_STYLE : m_rEntry.m_nPropMapType;
 
-            const SfxItemPropertySet* pPropSet = aSwMapProvider.GetPropertySet(nPropSetId);
-            const SfxItemPropertyMap &rMap = pPropSet->getPropertyMap();
-            const SfxItemSet& rSet = xStyle->GetItemSet();
+    const SfxItemPropertySet* pPropSet = aSwMapProvider.GetPropertySet(nPropSetId);
+    const SfxItemPropertyMap& rMap = pPropSet->getPropertyMap();
+    const SfxItemSet& rSet = xStyle->GetItemSet();
 
-            for(sal_Int32 i = 0; i < rPropertyNames.getLength(); i++)
-            {
-                const OUString sPropName = pNames[i];
-                const SfxItemPropertySimpleEntry* pEntry = rMap.getByName(sPropName);
-                bool bDone(false);
+    for(sal_Int32 i = 0; i < rPropertyNames.getLength(); ++i)
+    {
+        const OUString sPropName = pNames[i];
+        const SfxItemPropertySimpleEntry* pEntry = rMap.getByName(sPropName);
 
-                if(!pEntry)
-                {
-                    throw beans::UnknownPropertyException("Unknown property: " + sPropName, static_cast < cppu::OWeakObject * > ( this ) );
-                }
+        if(!pEntry)
+            throw beans::UnknownPropertyException("Unknown property: " + sPropName, static_cast<cppu::OWeakObject*>(this));
 
-                if( FN_UNO_NUM_RULES == pEntry->nWID || FN_UNO_FOLLOW_STYLE == pEntry->nWID )
+        if(FN_UNO_NUM_RULES == pEntry->nWID || FN_UNO_FOLLOW_STYLE == pEntry->nWID)
+        {
+            // handle NumRules first, done
+            pStates[i] = beans::PropertyState_DIRECT_VALUE;
+            continue;
+        }
+        const SfxItemSet* pSourceSet = lcl_GetItemsetForProperty(rSet, m_rEntry.m_eFamily, sPropName);
+        if(!pSourceSet)
+        {
+            // if no SetItem, value is ambigous and we are done
+            pStates[i] = beans::PropertyState_AMBIGUOUS_VALUE;
+            continue;
+        }
+        switch(pEntry->nWID)
+        {
+            case OWN_ATTR_FILLBMP_MODE:
+            {
+                //UUUU
+                if(SfxItemState::SET == pSourceSet->GetItemState(XATTR_FILLBMP_STRETCH, false)
+                    || SfxItemState::SET == pSourceSet->GetItemState(XATTR_FILLBMP_TILE, false))
                 {
-                    // handle NumRules first, done
                     pStates[i] = beans::PropertyState_DIRECT_VALUE;
-                    bDone = true;
                 }
-
-                // allow to retarget the SfxItemSet working on, default correctly. Only
-                // use pSourceSet below this point (except in header/footer processing)
-                const SfxItemSet* pSourceSet = &rSet;
-
-                if(!bDone)
-                {
-                    // check for Header/Footer entry
-                    const bool bHeader(SFX_STYLE_FAMILY_PAGE == m_rEntry.m_eFamily && sPropName.startsWith("Header"));
-                    const bool bFooter(SFX_STYLE_FAMILY_PAGE == m_rEntry.m_eFamily && sPropName.startsWith("Footer"));
-
-                    if(bHeader || bFooter || sPropName == UNO_NAME_FIRST_IS_SHARED)
-                    {
-                        const SvxSetItem* pSetItem;
-
-                        if (lcl_GetHeaderFooterItem(rSet, sPropName, bFooter, pSetItem))
-                        {
-                            // retarget the SfxItemSet to the HeaderFooter SfxSetItem's SfxItenSet
-                            pSourceSet = &pSetItem->GetItemSet();
-                        }
-                        else
-                        {
-                            // if no SetItem, value is ambigous and we are done
-                            pStates[i] = beans::PropertyState_AMBIGUOUS_VALUE;
-                            bDone = true;
-                        }
-                    }
-                }
-
-                if(!bDone && OWN_ATTR_FILLBMP_MODE == pEntry->nWID)
+                else
                 {
-                    //UUUU
-                    if(SfxItemState::SET == pSourceSet->GetItemState(XATTR_FILLBMP_STRETCH, false)
-                        || SfxItemState::SET == pSourceSet->GetItemState(XATTR_FILLBMP_TILE, false))
-                    {
-                        pStates[i] = beans::PropertyState_DIRECT_VALUE;
-                    }
-                    else
-                    {
-                        pStates[i] = beans::PropertyState_AMBIGUOUS_VALUE;
-                    }
-
-                    bDone = true;
+                    pStates[i] = beans::PropertyState_AMBIGUOUS_VALUE;
                 }
-
+            }
+            break;
+            case RES_BACKGROUND:
+            {
                 //UUUU for FlyFrames we need to mark the used properties from type RES_BACKGROUND
                 // as beans::PropertyState_DIRECT_VALUE to let users of this property call
                 // getPropertyValue where the member properties will be mapped from the
                 // fill attributes to the according SvxBrushItem entries
-                if (!bDone && RES_BACKGROUND == pEntry->nWID)
+                if (SWUnoHelper::needToMapFillItemsToSvxBrushItemTypes(*pSourceSet, pEntry->nMemberId))
                 {
-                    if (SWUnoHelper::needToMapFillItemsToSvxBrushItemTypes(*pSourceSet, pEntry->nMemberId))
-                    {
-                        pStates[i] = beans::PropertyState_DIRECT_VALUE;
-                    }
-                    else
-                    {
-                        pStates[i] = beans::PropertyState_DEFAULT_VALUE;
-                    }
-                    bDone = true;
+                    pStates[i] = beans::PropertyState_DIRECT_VALUE;
                 }
+                else
+                {
+                    pStates[i] = beans::PropertyState_DEFAULT_VALUE;
+                }
+            }
+            break;
+            default:
+            {
+                pStates[i] = pPropSet->getPropertyState(*pEntry, *pSourceSet);
 
-                if(!bDone)
+                if(SFX_STYLE_FAMILY_PAGE == m_rEntry.m_eFamily && SID_ATTR_PAGE_SIZE == pEntry->nWID && beans::PropertyState_DIRECT_VALUE == pStates[i])
                 {
-                    pStates[i] = pPropSet->getPropertyState(*pEntry, *pSourceSet);
+                    const SvxSizeItem& rSize = static_cast <const SvxSizeItem&>( rSet.Get(SID_ATTR_PAGE_SIZE));
+                    sal_uInt8 nMemberId = pEntry->nMemberId & 0x7f;
 
-                    if(SFX_STYLE_FAMILY_PAGE == m_rEntry.m_eFamily && SID_ATTR_PAGE_SIZE == pEntry->nWID && beans::PropertyState_DIRECT_VALUE == pStates[i])
+                    if((LONG_MAX == rSize.GetSize().Width() && (MID_SIZE_WIDTH == nMemberId || MID_SIZE_SIZE == nMemberId)) ||
+                        (LONG_MAX == rSize.GetSize().Height() && MID_SIZE_HEIGHT == nMemberId))
                     {
-                        const SvxSizeItem& rSize = static_cast <const SvxSizeItem&>( rSet.Get(SID_ATTR_PAGE_SIZE));
-                        sal_uInt8 nMemberId = pEntry->nMemberId & 0x7f;
-
-                        if( ( LONG_MAX == rSize.GetSize().Width() &&
-                              (MID_SIZE_WIDTH == nMemberId ||
-                               MID_SIZE_SIZE == nMemberId ) ) ||
-                            ( LONG_MAX == rSize.GetSize().Height() &&
-                              MID_SIZE_HEIGHT == nMemberId ) )
-                        {
-                            pStates[i] = beans::PropertyState_DEFAULT_VALUE;
-                        }
+                        pStates[i] = beans::PropertyState_DEFAULT_VALUE;
                     }
                 }
             }
         }
-        else
-        {
-            throw uno::RuntimeException();
-        }
-    }
-    else
-    {
-        throw uno::RuntimeException();
     }
-
     return aRet;
 }
 
commit fee21c82cbabeceb4a7776ebdb46905f5dac769d
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Mon Mar 14 23:10:00 2016 +0100

    minor whitespace fixes
    
    Change-Id: Iea6e6bff9dfbb713b587b01d08e3e570e683609d

diff --git a/sw/source/core/unocore/unostyle.cxx b/sw/source/core/unocore/unostyle.cxx
index 5bce3bb..bc8064b 100644
--- a/sw/source/core/unocore/unostyle.cxx
+++ b/sw/source/core/unocore/unostyle.cxx
@@ -2306,26 +2306,20 @@ uno::Sequence<uno::Any> SwXStyle::getPropertyValues(const uno::Sequence<OUString
 }
 
 void SwXStyle::setPropertyValue(const OUString& rPropertyName, const uno::Any& rValue)
-    throw( beans::UnknownPropertyException,
-        beans::PropertyVetoException,
-        lang::IllegalArgumentException,
-        lang::WrappedTargetException,
-        uno::RuntimeException, std::exception)
+        throw(beans::UnknownPropertyException, beans::PropertyVetoException, lang::IllegalArgumentException, lang::WrappedTargetException, uno::RuntimeException, std::exception)
 {
     SolarMutexGuard aGuard;
     const uno::Sequence<OUString> aProperties(&rPropertyName, 1);
     const uno::Sequence<uno::Any> aValues(&rValue, 1);
-
-    SetPropertyValues_Impl( aProperties, aValues );
+    SetPropertyValues_Impl(aProperties, aValues);
 }
 
-
 beans::PropertyState SwXStyle::getPropertyState(const OUString& rPropertyName)
-        throw( beans::UnknownPropertyException, uno::RuntimeException, std::exception )
+        throw(beans::UnknownPropertyException, uno::RuntimeException, std::exception)
 {
     SolarMutexGuard aGuard;
-    uno::Sequence< OUString > aNames { rPropertyName };
-    uno::Sequence< beans::PropertyState > aStates = getPropertyStates(aNames);
+    uno::Sequence<OUString> aNames{rPropertyName};
+    uno::Sequence<beans::PropertyState> aStates = getPropertyStates(aNames);
     return aStates.getConstArray()[0];
 }
 
commit 454aebe35e63d16348e680286f90883b0f27051c
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Mon Mar 14 00:55:40 2016 +0100

    rename/move main logic from GetPropertyValues_Impl to GetPropertyValue_Impl
    
    Change-Id: Iaf428141383f29da33c3102c40dd5a8f5392edff

diff --git a/sw/source/core/unocore/unostyle.cxx b/sw/source/core/unocore/unostyle.cxx
index 21e9331..5bce3bb 100644
--- a/sw/source/core/unocore/unostyle.cxx
+++ b/sw/source/core/unocore/unostyle.cxx
@@ -295,7 +295,7 @@ protected:
     template<sal_uInt16>
     uno::Any GetStyleProperty(const SfxItemPropertySimpleEntry& rEntry, const SfxItemPropertySet& rPropSet, SwStyleBase_Impl& rBase);
     uno::Any GetStyleProperty_Impl(const SfxItemPropertySimpleEntry& rEntry, const SfxItemPropertySet& rPropSet, SwStyleBase_Impl& rBase);
-    css::uno::Sequence<uno::Any> GetPropertyValues_Impl(const css::uno::Sequence< OUString >& aPropertyNames);
+    uno::Any GetPropertyValue_Impl(const SfxItemPropertySet* pPropSet, SwStyleBase_Impl& rBase, const OUString& rPropertyName);
 
    virtual void Modify( const SfxPoolItem* pOld, const SfxPoolItem *pNew) override;
 public:
@@ -2219,91 +2219,89 @@ uno::Any SwXStyle::GetStyleProperty_Impl(const SfxItemPropertySimpleEntry& rEntr
     return GetStyleProperty<HINT_BEGIN>(rEntry, rPropSet, rBase);
 }
 
-uno::Sequence<uno::Any> SwXStyle::GetPropertyValues_Impl(const uno::Sequence<OUString>& rPropertyNames)
+uno::Any SwXStyle::GetPropertyValue_Impl(const SfxItemPropertySet* pPropSet, SwStyleBase_Impl& rBase, const OUString& rPropertyName)
 {
-    if(!m_pDoc)
-        throw uno::RuntimeException();
-
-    sal_Int8 nPropSetId = m_bIsConditional ? PROPERTY_MAP_CONDITIONAL_PARA_STYLE :  m_rEntry.m_nPropMapType;
-
-    const SfxItemPropertySet* pPropSet = aSwMapProvider.GetPropertySet(nPropSetId);
-    const SfxItemPropertyMap &rMap = pPropSet->getPropertyMap();
-    const OUString* pNames = rPropertyNames.getConstArray();
-    uno::Sequence< uno::Any > aRet(rPropertyNames.getLength());
-    uno::Any* pRet = aRet.getArray();
-    SwStyleBase_Impl aBase(*m_pDoc, m_sStyleName, &GetDoc()->GetDfltTextFormatColl()->GetAttrSet()); //UUUU add pDfltTextFormatColl as parent
-
-    if(!m_pBasePool && !m_bIsDescriptor)
-        throw uno::RuntimeException();
-
-    for(sal_Int32 nProp = 0; nProp < rPropertyNames.getLength(); nProp++)
+    const SfxItemPropertyMap& rMap = pPropSet->getPropertyMap();
+    const SfxItemPropertySimpleEntry* pEntry = rMap.getByName(rPropertyName);
+    if(!pEntry || (!m_bIsConditional && rPropertyName == UNO_NAME_PARA_STYLE_CONDITIONS))
+        throw beans::UnknownPropertyException("Unknown property: " + rPropertyName, static_cast<cppu::OWeakObject*>(this));
+    if(m_pBasePool)
+        return GetStyleProperty_Impl(*pEntry, *pPropSet, rBase);
+    const uno::Any* pAny = nullptr;
+    m_pPropertiesImpl->GetProperty(rPropertyName, pAny);
+    if(pAny->hasValue())
+        return *pAny;
+    uno::Any aValue;
+    switch(m_rEntry.m_eFamily)
     {
-        const SfxItemPropertySimpleEntry* pEntry = rMap.getByName( pNames[nProp]);
-        if(!pEntry || (!m_bIsConditional && pNames[nProp] == UNO_NAME_PARA_STYLE_CONDITIONS))
-            throw beans::UnknownPropertyException("Unknown property: " + pNames[nProp], static_cast<cppu::OWeakObject*>(this));
-        if(m_pBasePool)
-            pRet[nProp] = GetStyleProperty_Impl(*pEntry, *pPropSet, aBase);
-        else
+        case SFX_STYLE_FAMILY_PSEUDO:
+            throw uno::RuntimeException("No default value for: " + rPropertyName);
+        break;
+        case SFX_STYLE_FAMILY_PARA:
+        case SFX_STYLE_FAMILY_PAGE:
+            SwStyleProperties_Impl::GetProperty(rPropertyName, m_xStyleData, aValue);
+        break;
+        case SFX_STYLE_FAMILY_CHAR:
+        case SFX_STYLE_FAMILY_FRAME:
         {
-            const uno::Any* pAny = nullptr;
-            m_pPropertiesImpl->GetProperty(pNames[nProp], pAny);
-            if(pAny->hasValue())
-                pRet[nProp] = *pAny;
+            if(pEntry->nWID < POOLATTR_BEGIN || pEntry->nWID >= RES_UNKNOWNATR_END)
+                throw uno::RuntimeException("No default value for: " + rPropertyName);
+            SwFormat* pFormat;
+            if(m_rEntry.m_eFamily == SFX_STYLE_FAMILY_CHAR)
+                pFormat = m_pDoc->GetDfltCharFormat();
             else
-            {
-                switch(m_rEntry.m_eFamily)
-                {
-                    case SFX_STYLE_FAMILY_PSEUDO:
-                        throw uno::RuntimeException("No default value for: " + pNames[nProp]);
-                    break;
-                    case SFX_STYLE_FAMILY_PARA:
-                    case SFX_STYLE_FAMILY_PAGE:
-                        SwStyleProperties_Impl::GetProperty(pNames[nProp], m_xStyleData, pRet[nProp]);
-                    break;
-                    case SFX_STYLE_FAMILY_CHAR:
-                    case SFX_STYLE_FAMILY_FRAME:
-                    {
-                        if(pEntry->nWID < POOLATTR_BEGIN || pEntry->nWID >= RES_UNKNOWNATR_END)
-                            throw uno::RuntimeException("No default value for: " + pNames[nProp]);
-                        SwFormat* pFormat;
-                        if(m_rEntry.m_eFamily == SFX_STYLE_FAMILY_CHAR)
-                            pFormat = m_pDoc->GetDfltCharFormat();
-                        else
-                            pFormat = m_pDoc->GetDfltFrameFormat();
-                        const SwAttrPool* pPool = pFormat->GetAttrSet().GetPool();
-                        const SfxPoolItem& rItem = pPool->GetDefaultItem(pEntry->nWID);
-                        rItem.QueryValue(pRet[nProp], pEntry->nMemberId);
-                    }
-                    break;
-                    default:
-                        ;
-                }
-            }
+                pFormat = m_pDoc->GetDfltFrameFormat();
+            const SwAttrPool* pPool = pFormat->GetAttrSet().GetPool();
+            const SfxPoolItem& rItem = pPool->GetDefaultItem(pEntry->nWID);
+            rItem.QueryValue(aValue, pEntry->nMemberId);
         }
+        break;
+        default:
+        ;
     }
-    return aRet;
+    return aValue;
 }
 
-uno::Sequence< uno::Any > SwXStyle::getPropertyValues(
-    const uno::Sequence< OUString >& rPropertyNames ) throw(uno::RuntimeException, std::exception)
+uno::Any SwXStyle::getPropertyValue(const OUString& rPropertyName)
+    throw(beans::UnknownPropertyException, lang::WrappedTargetException, uno::RuntimeException, std::exception)
 {
     SolarMutexGuard aGuard;
-    uno::Sequence< uno::Any > aValues;
+    if(!m_pDoc)
+        throw uno::RuntimeException();
+    if(!m_pBasePool && !m_bIsDescriptor)
+        throw uno::RuntimeException();
+    sal_Int8 nPropSetId = m_bIsConditional ? PROPERTY_MAP_CONDITIONAL_PARA_STYLE : m_rEntry.m_nPropMapType;
+    const SfxItemPropertySet* pPropSet = aSwMapProvider.GetPropertySet(nPropSetId);
+    SwStyleBase_Impl aBase(*m_pDoc, m_sStyleName, &m_pDoc->GetDfltTextFormatColl()->GetAttrSet()); //UUUU add pDfltTextFormatColl as parent
+    return GetPropertyValue_Impl(pPropSet, aBase, rPropertyName);
+}
 
+uno::Sequence<uno::Any> SwXStyle::getPropertyValues(const uno::Sequence<OUString>& rPropertyNames)
+    throw(uno::RuntimeException, std::exception)
+{
+    SolarMutexGuard aGuard;
+    if(!m_pDoc)
+        throw uno::RuntimeException();
+    if(!m_pBasePool && !m_bIsDescriptor)
+        throw uno::RuntimeException();
+    sal_Int8 nPropSetId = m_bIsConditional ? PROPERTY_MAP_CONDITIONAL_PARA_STYLE : m_rEntry.m_nPropMapType;
+    const SfxItemPropertySet* pPropSet = aSwMapProvider.GetPropertySet(nPropSetId);
+    SwStyleBase_Impl aBase(*m_pDoc, m_sStyleName, &m_pDoc->GetDfltTextFormatColl()->GetAttrSet()); //UUUU add pDfltTextFormatColl as parent
+    uno::Sequence<uno::Any> aValues(rPropertyNames.getLength());
     // workaround for bad designed API
     try
     {

... etc. - the rest is truncated


More information about the Libreoffice-commits mailing list