From 5bfbeb4a8dc322fcac11ed23fc2665a35c2b957a Mon Sep 17 00:00:00 2001 From: Jabiertxo Arraiza Cenoz Date: Thu, 26 Apr 2018 11:08:06 +0200 Subject: Fix bug when converting to paths cliped and masked LPE elemets --- src/selection-chemistry.cpp | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) (limited to 'src/selection-chemistry.cpp') diff --git a/src/selection-chemistry.cpp b/src/selection-chemistry.cpp index 622a843e4..128a4712f 100644 --- a/src/selection-chemistry.cpp +++ b/src/selection-chemistry.cpp @@ -2694,15 +2694,21 @@ bool ObjectSet::unlink(const bool skip_undo) Inkscape::URIReference *clip = item->clip_ref; Inkscape::URIReference *mask = item->mask_ref; if ((NULL != clip) && (NULL != clip->getObject())) { - tmp_set.unsetMask(true,true); - unlinked = tmp_set.unlink(true) || unlinked; - tmp_set.setMask(true,false,true); + SPUse * clipuse = dynamic_cast(clip->getObject()); + if (clipuse) { + tmp_set.unsetMask(true,true); + unlinked = tmp_set.unlink(true) || unlinked; + tmp_set.setMask(true,false,true); + } new_select.push_back(tmp_set.singleItem()); } else if ((NULL != mask) && (NULL != mask->getObject())) { - tmp_set.unsetMask(false,true); - unlinked = tmp_set.unlink(true) || unlinked; - tmp_set.setMask(false,false,true); + SPUse * maskuse = dynamic_cast(mask->getObject()); + if (maskuse) { + tmp_set.unsetMask(false,true); + unlinked = tmp_set.unlink(true) || unlinked; + tmp_set.setMask(false,false,true); + } new_select.push_back(tmp_set.singleItem()); } else { -- cgit v1.2.3