summaryrefslogtreecommitdiffstats
path: root/src/sp-object.cpp
diff options
context:
space:
mode:
authorJabier Arraiza Cenoz <jabier.arraiza@marker.es>2014-04-09 10:45:20 +0000
committerJabiertxof <jtx@jtx.marker.es>2014-04-09 10:45:20 +0000
commitf0c6ea33bcb5a03352f6276bac82d56c39c3f5fe (patch)
tree28159b96674a5c003fb36948ff04f3eaae3ec864 /src/sp-object.cpp
parentRefactor of end anchors. (diff)
parentMake extension tests compatible with VPATH builds. (diff)
downloadinkscape-f0c6ea33bcb5a03352f6276bac82d56c39c3f5fe.tar.gz
inkscape-f0c6ea33bcb5a03352f6276bac82d56c39c3f5fe.zip
update to trunk
(bzr r11950.1.326)
Diffstat (limited to 'src/sp-object.cpp')
-rw-r--r--src/sp-object.cpp17
1 files changed, 17 insertions, 0 deletions
diff --git a/src/sp-object.cpp b/src/sp-object.cpp
index be3a1ab9d..65228ec0a 100644
--- a/src/sp-object.cpp
+++ b/src/sp-object.cpp
@@ -460,6 +460,23 @@ void SPObject::deleteObject(bool propagate, bool propagate_descendants)
sp_object_unref(this, NULL);
}
+void SPObject::cropToObject(SPObject *except)
+{
+ std::vector<SPObject*> toDelete;
+ for ( SPObject *child = this->firstChild(); child; child = child->getNext() ) {
+ if (SP_IS_ITEM(child)) {
+ if (child->isAncestorOf(except)) {
+ child->cropToObject(except);
+ } else if(child != except) {
+ toDelete.push_back(child);
+ }
+ }
+ }
+ for (std::size_t i = 0; i < toDelete.size(); ++i) {
+ (toDelete[i])->deleteObject(true, true);
+ }
+}
+
void SPObject::attach(SPObject *object, SPObject *prev)
{
//g_return_if_fail(parent != NULL);