X-Git-Url: http://git.vanrenterghem.biz/git.ikiwiki.info.git/blobdiff_plain/9583d6978a703ecca340ca39eaad1b7741efaee4..3b316c6f93e04350e89e0cf73d923ba82f0190b3:/doc/bugs/discussion_removal.mdwn?ds=inline diff --git a/doc/bugs/discussion_removal.mdwn b/doc/bugs/discussion_removal.mdwn index 70bc2f5c0..9e08361a3 100644 --- a/doc/bugs/discussion_removal.mdwn +++ b/doc/bugs/discussion_removal.mdwn @@ -7,4 +7,27 @@ link to it in the action bar. Looks to me like loadindex is populating %destsources with information that the old discussion page exists, which isn't invalidated when ikiwiki discovers that the page is gone. This leaves dangling links whenever *any* -page is deleted, not just a discussion page. --Ethan \ No newline at end of file +page is deleted, not just a discussion page. --Ethan + +Here's a patch that trawls through %destsources deleting pages when they +are found to be deleted. It's a little inelegant, but it's simple and it +works. --Ethan + +
+diff -urX ignorepats ikiwiki/IkiWiki/Render.pm ikidev/IkiWiki/Render.pm
+--- ikiwiki/IkiWiki/Render.pm	2007-07-25 15:58:24.501068000 -0700
++++ ikidev/IkiWiki/Render.pm	2007-07-25 20:08:32.966449000 -0700
+@@ -320,6 +320,11 @@
+ 			prune($config{destdir}."/".$_)
+ 				foreach @{$oldrenderedfiles{$page}};
+ 			delete $pagesources{$page};
++			foreach (keys %destsources){
++				if ($destsources{$_} == $page) {
++					delete $destsources{$_};
++				}
++			}
+ 		}
+ 	}
+ 
+
+