summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 2d34b2a)
raw | patch | inline | side by side (parent: 2d34b2a)
author | Josh Andler <scislac@gmail.com> | |
Tue, 12 Jan 2010 02:27:16 +0000 (18:27 -0800) | ||
committer | Josh Andler <scislac@gmail.com> | |
Tue, 12 Jan 2010 02:27:16 +0000 (18:27 -0800) |
src/sp-clippath.h | patch | blob | history |
diff --git a/src/sp-clippath.h b/src/sp-clippath.h
index 199b29f3b3f279e72cb5cbdc9dd90321e73f6693..02395f3d2e605bd911320182be32a7b623689724 100644 (file)
--- a/src/sp-clippath.h
+++ b/src/sp-clippath.h
class SPClipPathView;
#include "display/nr-arena-forward.h"
+#include "libnr/nr-forward.h"
#include "sp-object-group.h"
#include "uri-references.h"
-#include <libnr/nr-forward.h>
+#include "xml/node.h"
struct SPClipPath : public SPObjectGroup {
class Reference;
return (SPClipPath *)URIReference::getObject();
}
protected:
+ /**
+ * If the owner element of this reference (the element with <... clippath="...">)
+ * is a child of the clippath it refers to, return false.
+ * \return false if obj is not a clippath or if obj is a parent of this
+ * reference's owner element. True otherwise.
+ */
virtual bool _acceptObject(SPObject *obj) const {
- return SP_IS_CLIPPATH(obj);
+ if (!SP_IS_CLIPPATH(obj)) {
+ return false;
+ }
+ SPObject * const owner = this->getOwner();
+ if (obj->isAncestorOf(owner)) {
+ Inkscape::XML::Node * const owner_repr = owner->repr;
+ Inkscape::XML::Node * const obj_repr = obj->repr;
+ gchar const * owner_name = NULL;
+ gchar const * owner_clippath = NULL;
+ gchar const * obj_name = NULL;
+ gchar const * obj_id = NULL;
+ if (owner_repr != NULL) {
+ owner_name = owner_repr->name();
+ owner_clippath = owner_repr->attribute("clippath");
+ }
+ if (obj_repr != NULL) {
+ obj_name = obj_repr->name();
+ obj_id = obj_repr->attribute("id");
+ }
+ g_warning("Ignoring recursive clippath reference "
+ "<%s clippath=\"%s\"> in <%s id=\"%s\">",
+ owner_name, owner_clippath,
+ obj_name, obj_id);
+ return false;
+ }
+ return true;
}
};