From 968578da075b156f7e0a8c313aace282b6389956 Mon Sep 17 00:00:00 2001 From: Daniel Slomovits Date: Fri, 15 Dec 2023 19:37:38 -0500 Subject: [PATCH] Remove only the reverted diff entry rather than recompute the whole diff after revert (fixes #1745) --- Iceberg-TipUI/IceTipDiffPanel.class.st | 28 +++++++++++++++++++++++--- 1 file changed, 25 insertions(+), 3 deletions(-) diff --git a/Iceberg-TipUI/IceTipDiffPanel.class.st b/Iceberg-TipUI/IceTipDiffPanel.class.st index 6a999df1f2..5290375562 100644 --- a/Iceberg-TipUI/IceTipDiffPanel.class.st +++ b/Iceberg-TipUI/IceTipDiffPanel.class.st @@ -84,6 +84,29 @@ IceTipDiffPanel >> diffContentsLeft: leftString right: rightString [ rightText: rightString ] +{ #category : 'initialization' } +IceTipDiffPanel >> diffEntryRemoved: announcement [ + + | parent | + (parent := announcement entry parent) removeChild: announcement entry. + "Removing all changes to a class should remove the class node too, + unless the class definition has changed as well. Extension definitions + may appear as an 'addition' or 'removal', but can only exist when methods + of that class have changed. Repeat this process to check if the containing + package no longer has any changes. Cannot remove the root node as it has + no parent, but it's fine to just leave it there empty--though perhaps we should + close the browser instead in that case?" + [ + parent parent notNil and: [ + parent isEmpty and: [ + parent value isNoModification or: [ + parent value definition isExtensionDefinition ] ] ] ] whileTrue: [ + parent parent removeChild: parent. + parent := parent parent ]. + + self basicRefresh +] + { #category : 'accessing - ui' } IceTipDiffPanel >> diffPanel [ @@ -224,10 +247,9 @@ IceTipDiffPanel >> setModelBeforeInitialization: anObject [ IceTipDiffPanel >> subscribeToAnnouncements [ self announcer - when: IceTipDiffEntryRemoved - send: #refresh + when: IceTipDiffEntryRemoved + send: #diffEntryRemoved: to: self - ] { #category : 'specs' }