[Libreoffice-commits] core.git: Branch 'libreoffice-6-2' - sw/source
Caolán McNamara (via logerrit)
logerrit at kemper.freedesktop.org
Wed Apr 24 09:32:39 UTC 2019
sw/source/core/doc/doclay.cxx | 44 ++++++++++++++++++++++++++++++++----------
1 file changed, 34 insertions(+), 10 deletions(-)
New commits:
commit 771be5a31c6cb40e1be30f71c2f02708292f2518
Author: Caolán McNamara <caolanm at redhat.com>
AuthorDate: Mon Apr 22 19:10:58 2019 +0100
Commit: Michael Stahl <Michael.Stahl at cib.de>
CommitDate: Wed Apr 24 11:31:45 2019 +0200
Resolves: tdf#122487 take groups into account
interate and recurse through their contents for name collision check
Change-Id: Ide7d1d051f6b9420b7ef7b3f6bed669dbde5697a
Reviewed-on: https://gerrit.libreoffice.org/71078
Tested-by: Jenkins
Reviewed-by: Michael Stahl <Michael.Stahl at cib.de>
diff --git a/sw/source/core/doc/doclay.cxx b/sw/source/core/doc/doclay.cxx
index e964255f7add..fb7c6d29436a 100644
--- a/sw/source/core/doc/doclay.cxx
+++ b/sw/source/core/doc/doclay.cxx
@@ -22,6 +22,7 @@
#include <hintids.hxx>
#include <sfx2/progress.hxx>
#include <svx/svdmodel.hxx>
+#include <svx/svdogrp.hxx>
#include <svx/svdpage.hxx>
#include <editeng/keepitem.hxx>
#include <editeng/ulspitem.hxx>
@@ -1285,6 +1286,36 @@ SwFlyFrameFormat* SwDoc::InsertDrawLabel(
return pNewFormat;
}
+static void lcl_SetNumUsedBit(std::vector<sal_uInt8>& rSetFlags, size_t nFormatSize, sal_Int32 nNmLen, const OUString& rName, const OUString& rCmpName)
+{
+ if (rName.startsWith(rCmpName))
+ {
+ // Only get and set the Flag
+ const sal_Int32 nNum = rName.copy(nNmLen).toInt32()-1;
+ if (nNum >= 0 && static_cast<SwFrameFormats::size_type>(nNum) < nFormatSize)
+ rSetFlags[ nNum / 8 ] |= (0x01 << ( nNum & 0x07 ));
+ }
+}
+
+static void lcl_SetNumUsedBit(std::vector<sal_uInt8>& rSetFlags, size_t nFormatSize, sal_Int32 nNmLen, const SdrObject& rObj, const OUString& rCmpName)
+{
+ OUString sName = rObj.GetName();
+ lcl_SetNumUsedBit(rSetFlags, nFormatSize, nNmLen, sName, rCmpName);
+ // tdf#122487 take groups into account, interate and recurse through their
+ // contents for name collision check
+ if (rObj.IsGroupObject())
+ {
+ const SdrObjGroup &rGroupObj = static_cast<const SdrObjGroup&>(rObj);
+ for (size_t i = 0, nCount = rGroupObj.GetObjCount(); i < nCount; ++i)
+ {
+ SdrObject* pObj = rGroupObj.GetObj(i);
+ if (!pObj)
+ continue;
+ lcl_SetNumUsedBit(rSetFlags, nFormatSize, nNmLen, *pObj, rCmpName);
+ }
+ }
+}
+
static OUString lcl_GetUniqueFlyName(const SwDoc* pDoc, const char* pDefStrId, sal_uInt16 eType)
{
assert(eType >= RES_FMT_BEGIN && eType < RES_FMT_END);
@@ -1308,23 +1339,16 @@ static OUString lcl_GetUniqueFlyName(const SwDoc* pDoc, const char* pDefStrId, s
const SwFrameFormat* pFlyFormat = rFormats[ n ];
if (eType != pFlyFormat->Which())
continue;
- OUString sName;
if (eType == RES_DRAWFRMFMT)
{
const SdrObject *pObj = pFlyFormat->FindSdrObject();
if (pObj)
- sName = pObj->GetName();
+ lcl_SetNumUsedBit(aSetFlags, rFormats.size(), nNmLen, *pObj, aName);
}
else
{
- sName = pFlyFormat->GetName();
- }
- if (sName.startsWith(aName))
- {
- // Only get and set the Flag
- const sal_Int32 nNum = sName.copy(nNmLen).toInt32()-1;
- if( nNum >= 0 && static_cast<SwFrameFormats::size_type>(nNum) < rFormats.size() )
- aSetFlags[ nNum / 8 ] |= (0x01 << ( nNum & 0x07 ));
+ OUString sName = pFlyFormat->GetName();
+ lcl_SetNumUsedBit(aSetFlags, rFormats.size(), nNmLen, sName, aName);
}
}
More information about the Libreoffice-commits
mailing list