summaryrefslogtreecommitdiffstats
path: root/src/sp-shape.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/sp-shape.cpp')
-rw-r--r--src/sp-shape.cpp12
1 files changed, 5 insertions, 7 deletions
diff --git a/src/sp-shape.cpp b/src/sp-shape.cpp
index 9d08fc58d..76fd37af1 100644
--- a/src/sp-shape.cpp
+++ b/src/sp-shape.cpp
@@ -234,7 +234,6 @@ static void
sp_shape_set(SPObject *object, unsigned int key, gchar const *value)
{
SPShape *shape = (SPShape *) object;
- bool path_effect_changed = false;
switch (key) {
case SP_ATTR_INKSCAPE_PATH_EFFECT:
@@ -256,10 +255,10 @@ sp_shape_set(SPObject *object, unsigned int key, gchar const *value)
shape->path_effect_ref->detach();
}
} else {
+ // Detach, which emits the changed signal.
shape->path_effect_ref->detach();
}
}
- path_effect_changed = true; // updated twice now when connected to changed signal??
break;
default:
if (((SPObjectClass *) parent_class)->set) {
@@ -267,9 +266,6 @@ sp_shape_set(SPObject *object, unsigned int key, gchar const *value)
}
break;
}
-
- if (path_effect_changed)
- sp_shape_update_patheffect ((SPShape *) object, false);
}
static Inkscape::XML::Node *
@@ -1138,6 +1134,9 @@ sp_shape_get_livepatheffectobject(SPShape *shape) {
void
sp_shape_update_patheffect (SPShape *shape, bool write)
{
+#ifdef SHAPE_VERBOSE
+ g_message("sp_shape_update_patheffect");
+#endif
g_return_if_fail (shape != NULL);
g_return_if_fail (SP_IS_SHAPE (shape));
@@ -1168,9 +1167,8 @@ lpeobject_ref_changed(SPObject *old_ref, SPObject *ref, SPShape *shape)
if ( IS_LIVEPATHEFFECT(ref) && ref != shape )
{
ref->connectModified(sigc::bind(sigc::ptr_fun(&lpeobject_ref_modified), shape));
+ lpeobject_ref_modified(ref, 0, shape);
}
-
- lpeobject_ref_modified(ref, 0, shape);
}
/**