summaryrefslogtreecommitdiffstats
path: root/src/sp-use.cpp
diff options
context:
space:
mode:
authorJabier Arraiza Cenoz <jabier.arraiza@marker.es>2016-10-02 22:44:54 +0000
committerjabiertxof <info@marker.es>2016-10-02 22:44:54 +0000
commit90e142963afd950b2868434075890054aef090b3 (patch)
treeedcaf3d0d85b614e5f327fb58c909ffee5207e26 /src/sp-use.cpp
parentAdded some widgets from caligraphic tool (diff)
parentAdjust dock size to minimum width during canvas table size allocation signal. (diff)
downloadinkscape-90e142963afd950b2868434075890054aef090b3.tar.gz
inkscape-90e142963afd950b2868434075890054aef090b3.zip
Update to trunk and some fixes
(bzr r14865.1.14)
Diffstat (limited to 'src/sp-use.cpp')
-rw-r--r--src/sp-use.cpp33
1 files changed, 12 insertions, 21 deletions
diff --git a/src/sp-use.cpp b/src/sp-use.cpp
index c8a0830c1..6ba03dad9 100644
--- a/src/sp-use.cpp
+++ b/src/sp-use.cpp
@@ -34,7 +34,6 @@
#include "style.h"
#include "sp-symbol.h"
#include "sp-root.h"
-#include "sp-use.h"
#include "sp-use-reference.h"
#include "sp-shape.h"
#include "sp-text.h"
@@ -436,27 +435,23 @@ void SPUse::move_compensate(Geom::Affine const *mp) {
//BUT move clippaths accordingly.
//if clone has a clippath, move it accordingly
if(clip_ref->getObject()){
- SPObject *clip = clip_ref->getObject()->firstChild() ;
- while(clip){
- SPItem *item = (SPItem*) clip;
+ for(auto& clip: clip_ref->getObject()->children){
+ SPItem *item = (SPItem*) &clip;
if(item){
item->transform *= m;
Geom::Affine identity;
- item->doWriteTransform(clip->getRepr(),item->transform, &identity);
+ item->doWriteTransform(clip.getRepr(),item->transform, &identity);
}
- clip = clip->getNext();
}
}
if(mask_ref->getObject()){
- SPObject *mask = mask_ref->getObject()->firstChild() ;
- while(mask){
- SPItem *item = (SPItem*) mask;
+ for(auto& mask: mask_ref->getObject()->children){
+ SPItem *item = (SPItem*) &mask;
if(item){
item->transform *= m;
Geom::Affine identity;
- item->doWriteTransform(mask->getRepr(),item->transform, &identity);
+ item->doWriteTransform(mask.getRepr(),item->transform, &identity);
}
- mask = mask->getNext();
}
}
return;
@@ -480,27 +475,23 @@ void SPUse::move_compensate(Geom::Affine const *mp) {
//if clone has a clippath, move it accordingly
if(clip_ref->getObject()){
- SPObject *clip = clip_ref->getObject()->firstChild() ;
- while(clip){
- SPItem *item = (SPItem*) clip;
+ for(auto& clip: clip_ref->getObject()->children){
+ SPItem *item = (SPItem*) &clip;
if(item){
item->transform *= clone_move.inverse();
Geom::Affine identity;
- item->doWriteTransform(clip->getRepr(),item->transform, &identity);
+ item->doWriteTransform(clip.getRepr(),item->transform, &identity);
}
- clip = clip->getNext();
}
}
if(mask_ref->getObject()){
- SPObject *mask = mask_ref->getObject()->firstChild() ;
- while(mask){
- SPItem *item = (SPItem*) mask;
+ for(auto& mask: mask_ref->getObject()->children){
+ SPItem *item = (SPItem*) &mask;
if(item){
item->transform *= clone_move.inverse();
Geom::Affine identity;
- item->doWriteTransform(mask->getRepr(),item->transform, &identity);
+ item->doWriteTransform(mask.getRepr(),item->transform, &identity);
}
- mask = mask->getNext();
}
}