X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=src%2Fconn-avoid-ref.cpp;h=22ddb54250c2a46c2f99ffe63bf1bb888bdad37c;hb=91db03f244c420daa37e0b5b8a8359ddc2dd626b;hp=d90eca49b1ac20c5e1007517557295736e4bf043;hpb=6129af7cc5b723223e9617614c931936e5190421;p=inkscape.git diff --git a/src/conn-avoid-ref.cpp b/src/conn-avoid-ref.cpp index d90eca49b..22ddb5425 100644 --- a/src/conn-avoid-ref.cpp +++ b/src/conn-avoid-ref.cpp @@ -74,14 +74,24 @@ void SPAvoidRef::handleSettingChange(void) if (desktop == NULL) { return; } + if (sp_desktop_document(desktop) != item->document) { + // We don't want to go any further if the active desktop's document + // isn't the same as the document that this item is part of. This + // case can happen if a new document is loaded from the file chooser + // or via the recent file menu. In this case, we can end up here + // as a rersult of a sp_document_ensure_up_to_date performed on a + // document not yet attached to the active desktop. + return; + } - Router *router = item->document->router; - if (new_setting == setting) { // Don't need to make any changes return; } + setting = new_setting; + Router *router = item->document->router; + _transformed_connection.disconnect(); if (new_setting) { _transformed_connection = item->connectTransformed( @@ -110,7 +120,6 @@ void SPAvoidRef::handleSettingChange(void) router->delShape(shapeRef); shapeRef = NULL; } - setting = new_setting; }