summaryrefslogtreecommitdiffstats
path: root/src/preferences.cpp
diff options
context:
space:
mode:
authorMartin Owens <doctormo@gmail.com>2014-04-20 00:36:33 +0000
committerMartin Owens <doctormo@gmail.com>2014-04-20 00:36:33 +0000
commit77b3c4eb00a8f297449deb5af29f566a12c03b2e (patch)
tree38283b135654eab44cd65272e0b8e4a1d2474d16 /src/preferences.cpp
parentMerge in outline bitmap image preference feature (diff)
downloadinkscape-77b3c4eb00a8f297449deb5af29f566a12c03b2e.tar.gz
inkscape-77b3c4eb00a8f297449deb5af29f566a12c03b2e.zip
Stop observer from crashing when it doesn't exist in preferences.xml
(bzr r13293)
Diffstat (limited to 'src/preferences.cpp')
-rw-r--r--src/preferences.cpp4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/preferences.cpp b/src/preferences.cpp
index 2fec3b307..d0c3783b5 100644
--- a/src/preferences.cpp
+++ b/src/preferences.cpp
@@ -581,6 +581,8 @@ XML::Node *Preferences::_findObserverNode(Glib::ustring const &pref_path, Glib::
// find the node corresponding to the "directory".
Inkscape::XML::Node *node = _getNode(node_key, create), *child;
+ if (!node) return node;
+
for (child = node->firstChild(); child; child = child->next()) {
// If there is a node with id corresponding to the attr key,
// this means that the last part of the path is actually a key (folder).
@@ -601,7 +603,7 @@ void Preferences::addObserver(Observer &o)
if ( _observer_map.find(&o) == _observer_map.end() ) {
Glib::ustring node_key, attr_key;
Inkscape::XML::Node *node;
- node = _findObserverNode(o.observed_path, node_key, attr_key, false);
+ node = _findObserverNode(o.observed_path, node_key, attr_key, true);
if (node) {
// set additional data
if (o._data) {