summaryrefslogtreecommitdiffstats
path: root/src/attribute-rel-util.cpp
diff options
context:
space:
mode:
authorsu_v <suv-sf@users.sourceforge.net>2012-11-10 06:07:17 +0000
committer~suv <suv-sf@users.sourceforge.net>2012-11-10 06:07:17 +0000
commit6fadc1a815eca2b0a85038ae95d9dd7dbe8a8ae7 (patch)
tree951c9b05d57c8ffe745561865253055ae2e8f566 /src/attribute-rel-util.cpp
parentmerge from trunk (r11858) (diff)
parentWin32. Updating the trunk again for devlibs r36. (diff)
downloadinkscape-6fadc1a815eca2b0a85038ae95d9dd7dbe8a8ae7.tar.gz
inkscape-6fadc1a815eca2b0a85038ae95d9dd7dbe8a8ae7.zip
merge from trunk (r11865)
(bzr r11668.1.39)
Diffstat (limited to 'src/attribute-rel-util.cpp')
-rw-r--r--src/attribute-rel-util.cpp9
1 files changed, 8 insertions, 1 deletions
diff --git a/src/attribute-rel-util.cpp b/src/attribute-rel-util.cpp
index cf94c0c1e..38327b413 100644
--- a/src/attribute-rel-util.cpp
+++ b/src/attribute-rel-util.cpp
@@ -76,7 +76,14 @@ void sp_attribute_clean_recursive(Node *repr, unsigned int flags) {
}
for(Node *child=repr->firstChild() ; child ; child = child->next()) {
- sp_attribute_clean_recursive( child, flags );
+
+ // Don't remove default css values if element is in <defs> or is a <symbol>
+ Glib::ustring element = child->name();
+ unsigned int flags_temp = flags;
+ if( element.compare( "svg:defs" ) == 0 || element.compare( "svg:symbol" ) == 0 ) {
+ flags_temp &= ~(SP_ATTR_CLEAN_DEFAULT_WARN|SP_ATTR_CLEAN_DEFAULT_REMOVE);
+ }
+ sp_attribute_clean_recursive( child, flags_temp );
}
}