<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
</head>
<body>
<style type="text/css" style="display:none;"><!-- P {margin-top:0;margin-bottom:0;} --></style>
<div id="divtagdefaultwrapper" style="font-size:12pt;color:#000000;font-family:Calibri,Helvetica,sans-serif;" dir="ltr">
<p>I think this depends on your machine. :-) As I have already mentioned somewhere else on the list, for unknown reasons, I often have very slow access to my changes file. When the menu is opened, my image spends about 1000 ms in StandardFileStream >> #open:forWrite:,
 invoked by CompiledMethod >> #timeStamp as part of TheWorldMainDockingBar >> #listChangesOn:. It would be great if there was a way to keep the image and menus responsive even on systems with not-so-fast access to the file system. :-)</p>
<p><br>
</p>
<p>Best,</p>
<p>Christoph</p>
<div id="Signature">
<div id="divtagdefaultwrapper" dir="ltr" style="font-size: 12pt; color: rgb(0, 0, 0); font-family: Calibri, Helvetica, sans-serif, EmojiFont, "Apple Color Emoji", "Segoe UI Emoji", NotoColorEmoji, "Segoe UI Symbol", "Android Emoji", EmojiSymbols;">
<div name="divtagdefaultwrapper" style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:; margin:0">
<div>
<div class="_rp_T4" id="Item.MessagePartBody">
<div class="_rp_U4 ms-font-weight-regular ms-font-color-neutralDark rpHighlightAllClass rpHighlightBodyClass" id="Item.MessageUniqueBody" style="font-family:wf_segoe-ui_normal,"Segoe UI","Segoe WP",Tahoma,Arial,sans-serif,serif,EmojiFont">
<div dir="ltr">
<div id="divtagdefaultwrapper"><font face="Calibri,Helvetica,sans-serif,EmojiFont,Apple Color Emoji,Segoe UI Emoji,NotoColorEmoji,Segoe UI Symbol,Android Emoji,EmojiSymbols">
<div id="Signature">
<div style="margin:0px"><font style="font-family:Calibri,Arial,Helvetica,sans-serif,serif,EmojiFont">
<div><font size="3" color="black"><span style="font-size:12pt"><a href="http://www.hpi.de/" target="_blank" rel="noopener noreferrer" id="LPNoLP"><font size="2"><span id="LPlnk909538"><font color="#757B80"></font></span></font></a></span></font></div>
</font></div>
</div>
</font></div>
</div>
</div>
</div>
</div>
<div><font size="2" color="#808080"></font></div>
</div>
</div>
</div>
</div>
<hr style="display:inline-block;width:98%" tabindex="-1">
<div id="divRplyFwdMsg" dir="ltr"><font face="Calibri, sans-serif" style="font-size:11pt" color="#000000"><b>Von:</b> Squeak-dev <squeak-dev-bounces@lists.squeakfoundation.org> im Auftrag von Taeumel, Marcel<br>
<b>Gesendet:</b> Freitag, 7. Mai 2021 19:36:04<br>
<b>An:</b> squeak-dev<br>
<b>Betreff:</b> Re: [squeak-dev] The Trunk: Morphic-mt.1767.mcz</font>
<div> </div>
</div>
<div>
<div id="__MailbirdStyleContent" style="font-size: 10pt;font-family: Arial;color: #000000;text-align: left" dir="ltr">
<div><span style="font-size: 13.3333px">A rather big change set (81 changed methods, 474 changed methods) has about 150 ms lag in that menu. An empty change set has 5 ms lag. For comparison, the Extras-Menu has 15 ms lag.</span></div>
<div><span style="font-size: 13.3333px"><br>
</span></div>
<div><span style="font-size: 13.3333px">[self owner selectItem: self event: ActiveHand lastEvent.</span></div>
<div><span style="font-size: 13.3333px">ActiveWorld displayWorldSafely.</span></div>
<div><span style="font-size: 13.3333px">self deselect: ActiveHand lastEvent.</span></div>
<div><span style="font-size: 13.3333px">ActiveWorld displayWorldSafely] bench</span></div>
<div><span style="font-size: 13.3333px"><br>
</span></div>
<div><span style="font-size: 13.3333px">Best,</span></div>
<div><span style="font-size: 13.3333px">Marcel</span></div>
<div class="mb_sig"></div>
<blockquote class="history_container" type="cite" style="border-left-style:solid;border-width:1px; margin-top:20px; margin-left:0px;padding-left:10px;">
<p style="color: #AAAAAA; margin-top: 10px;">Am 06.05.2021 22:59:20 schrieb Thiede, Christoph <christoph.thiede@student.hpi.uni-potsdam.de>:</p>
<div style="font-family:Arial,Helvetica,sans-serif">
<div id="divtagdefaultwrapper" style="font-size: 12pt;color: #000000;font-family: Calibri,Helvetica,sans-serif" dir="ltr">
<p>> <span>So that the user can watch the list grow and repeatedly miss the click on the intended item because it moved away "just in time"?</span></p>
<p><span><br>
</span></p>
<p><span>This, of course, would only work if the list could only grow at its end. But I see your point ... I often have a similar situation with the thumbnails in the project menu (around 10 - 20 projects). Lazy loading might actually save me around 60 seconds
 per day. :D</span></p>
<p><span><br>
</span></p>
<p><span>> </span><span style="font-size: 12pt">How big was the changeset that produced those lags?</span><span></span></p>
<div><br>
</div>
<div>Very small, maybe a dozen of changes.</div>
<div><br>
</div>
<div>Best,</div>
<div>Christoph</div>
<p></p>
<div id="Signature">
<div id="divtagdefaultwrapper" dir="ltr" style="font-size: 12pt;color: rgb(0, 0, 0);font-family: Calibri, Helvetica, sans-serif, EmojiFont, "Apple Color Emoji", "Segoe UI Emoji", NotoColorEmoji, "Segoe UI Symbol", "Android Emoji", EmojiSymbols">
<div name="divtagdefaultwrapper" style="font-family: Calibri,Arial,Helvetica,sans-serif;font-size: ;margin: 0">
<div><span style="font-size: 10pt;color: #808080"></span></div>
</div>
</div>
</div>
</div>
<hr style="display:inline-block;width:98%" tabindex="-1">
<div id="divRplyFwdMsg" dir="ltr"><span style="font-family: Calibri, sans-serif;color: #000000"><b>Von:</b> Squeak-dev <squeak-dev-bounces@lists.squeakfoundation.org> im Auftrag von Taeumel, Marcel<br>
<b>Gesendet:</b> Donnerstag, 6. Mai 2021 20:26:33<br>
<b>An:</b> squeak-dev<br>
<b>Betreff:</b> Re: [squeak-dev] The Trunk: Morphic-mt.1767.mcz</span>
<div> </div>
</div>
<div>
<div id="__MailbirdStyleContent" style="font-size: 10pt;font-family: Arial;color: #000000;text-align: left" dir="ltr">
> <span style="font-family: Calibri, Helvetica, sans-serif, EmojiFont, "Apple Color Emoji", "Segoe UI Emoji", NotoColorEmoji, "Segoe UI Symbol", "Android Emoji", EmojiSymbols;font-size: 16px">Could we add lazy menu loading (i.e., adding some items to the menu
 *after* it has been opened) to our future wish-list? :-)</span>
<div><span style="font-family: Calibri, Helvetica, sans-serif, EmojiFont, "Apple Color Emoji", "Segoe UI Emoji", NotoColorEmoji, "Segoe UI Symbol", "Android Emoji", EmojiSymbols;font-size: 16px"><br>
</span></div>
<div><span style="font-family: Calibri, Helvetica, sans-serif, EmojiFont, Apple Color Emoji, Segoe UI Emoji, NotoColorEmoji, Segoe UI Symbol, Android Emoji, EmojiSymbols"><span style="font-size: 16px">So that the user can watch the list grow and repeatedly
 miss the click on the intended item because it moved away "just in time"? Maybe that's not a good. :-)</span></span></div>
<div><span style="font-family: Calibri, Helvetica, sans-serif, EmojiFont, Apple Color Emoji, Segoe UI Emoji, NotoColorEmoji, Segoe UI Symbol, Android Emoji, EmojiSymbols"><span style="font-size: 16px"><br>
</span></span></div>
<div><span style="font-family: Calibri, Helvetica, sans-serif, EmojiFont, Apple Color Emoji, Segoe UI Emoji, NotoColorEmoji, Segoe UI Symbol, Android Emoji, EmojiSymbols"><span style="font-size: 16px">How big was the changeset that produced those lags?</span></span></div>
<div><span style="font-family: Calibri, Helvetica, sans-serif, EmojiFont, Apple Color Emoji, Segoe UI Emoji, NotoColorEmoji, Segoe UI Symbol, Android Emoji, EmojiSymbols"><span style="font-size: 16px"><br>
</span></span></div>
<div><span style="font-family: Calibri, Helvetica, sans-serif, EmojiFont, Apple Color Emoji, Segoe UI Emoji, NotoColorEmoji, Segoe UI Symbol, Android Emoji, EmojiSymbols"><span style="font-size: 16px">Best,</span></span></div>
<div><span style="font-family: Calibri, Helvetica, sans-serif, EmojiFont, Apple Color Emoji, Segoe UI Emoji, NotoColorEmoji, Segoe UI Symbol, Android Emoji, EmojiSymbols"><span style="font-size: 16px">Marcel</span></span></div>
<div class="mb_sig"></div>
<blockquote class="history_container" type="cite" style="border-left-style: solid;border-width: 1px;margin-top: 20px;margin-left: 0px;padding-left: 10px;min-width: 500px">
<p style="color: #AAAAAA; margin-top: 10px;">Am 01.05.2021 19:31:52 schrieb Thiede, Christoph <christoph.thiede@student.hpi.uni-potsdam.de>:</p>
<div style="font-family:Arial,Helvetica,sans-serif">
<div id="divtagdefaultwrapper" style="font-size: 12pt;color: #000000;font-family: Calibri,Helvetica,sans-serif" dir="ltr">
<div id="divtagdefaultwrapper" style="font-size: 12pt;color: rgb(0, 0, 0);font-family: Calibri, Helvetica, sans-serif, EmojiFont, "Apple Color Emoji", "Segoe UI Emoji", NotoColorEmoji, "Segoe UI Symbol", "Android Emoji", EmojiSymbols" dir="ltr">
<p>Hi Marcel,</p>
<p><br>
</p>
<p>thanks again. Here are some -- new and recycled :-) -- ideas:</p>
<p><br>
</p>
<p></p>
<ul style="margin-bottom: 0px; margin-top: 0px;">
<li>IMO the <span>ChangeSetBrowser does not really add value here. It is only a subset of a regular SimpleChangeSorter, isn't it?</span></li><li><span>I noticed multiple lags when opening the new menu because the change list is compiled dynamically. Could we add lazy menu loading (i.e., adding some items to the menu *after* it has been opened) to our future wish-list? :-)</span></li><li>Despite the new options, I use the change sorter options most frequently. To make them easier to find (and to guarantee their visibility, considering very large changesets ...), I would still prefer to find the tool section at the beginning but not the
 end of the menu.</li></ul>
<div><br>
</div>
<div>What do you think? :-)</div>
<p></p>
<div id="Signature">
<div id="divtagdefaultwrapper" dir="ltr" style="font-size: 12pt;color: rgb(0, 0, 0);font-family: Calibri, Helvetica, sans-serif, EmojiFont, "Apple Color Emoji", "Segoe UI Emoji", NotoColorEmoji, "Segoe UI Symbol", "Android Emoji", EmojiSymbols">
<div name="divtagdefaultwrapper" style="font-family: Calibri,Arial,Helvetica,sans-serif;font-size: ;margin: 0">
<div>
<div class="_rp_T4" id="Item.MessagePartBody">
<div class="_rp_U4 ms-font-weight-regular ms-font-color-neutralDark rpHighlightAllClass rpHighlightBodyClass" id="Item.MessageUniqueBody" style="font-family:wf_segoe-ui_normal,"Segoe UI","Segoe WP",Tahoma,Arial,sans-serif,serif,EmojiFont">
<div dir="ltr">
<div id="divtagdefaultwrapper"><span style="font-family: Calibri,Helvetica,sans-serif,EmojiFont,Apple Color Emoji,Segoe UI Emoji,NotoColorEmoji,Segoe UI Symbol,Android Emoji,EmojiSymbols">
<div id="Signature">
<div style="margin:0px"><span style="">
<div><span style="font-size: 12pt;color: black"><span style="font-size: 12pt"><a href="http://www.hpi.de/" target="_blank" rel="noopener noreferrer" id="LPNoLP"><font size="2"><span id="LPlnk909538"><font color="#757B80"></font></span></font></a></span></span></div>
</span></div>
</div>
</span></div>
</div>
</div>
</div>
</div>
<div><span style="font-size: 10pt;color: #808080"></span></div>
</div>
</div>
</div>
<div id="divtagdefaultwrapper" style="font-size: 12pt;color: rgb(0, 0, 0);font-family: Calibri, Helvetica, sans-serif, EmojiFont, "Apple Color Emoji", "Segoe UI Emoji", NotoColorEmoji, "Segoe UI Symbol", "Android Emoji", EmojiSymbols" dir="ltr">
<br>
</div>
Best,</div>
<div id="divtagdefaultwrapper" style="font-size: 12pt;color: rgb(0, 0, 0);font-family: Calibri, Helvetica, sans-serif, EmojiFont, "Apple Color Emoji", "Segoe UI Emoji", NotoColorEmoji, "Segoe UI Symbol", "Android Emoji", EmojiSymbols" dir="ltr">
Christoph<br>
<br>
<div style="color: rgb(0, 0, 0);">
<div>
<hr tabindex="-1" style="display:inline-block; width:98%">
<div id="x_divRplyFwdMsg" dir="ltr"><span style="font-family: Calibri, sans-serif;color: #000000"><b>Von:</b> Squeak-dev <squeak-dev-bounces@lists.squeakfoundation.org> im Auftrag von commits@source.squeak.org <commits@source.squeak.org><br>
<b>Gesendet:</b> Freitag, 30. April 2021 10:11 Uhr<br>
<b>An:</b> squeak-dev@lists.squeakfoundation.org; packages@lists.squeakfoundation.org<br>
<b>Betreff:</b> [squeak-dev] The Trunk: Morphic-mt.1767.mcz</span>
<div> </div>
</div>
</div>
<span style="font-size: 10pt"><span style="font-size: 10pt">
<div class="PlainText">Marcel Taeumel uploaded a new version of Morphic to project The Trunk:<br>
<a href="http://source.squeak.org/trunk/Morphic-mt.1767.mcz">http://source.squeak.org/trunk/Morphic-mt.1767.mcz</a><br>
<br>
==================== Summary ====================<br>
<br>
Name: Morphic-mt.1767<br>
Author: mt<br>
Time: 30 April 2021, 10:11:09.230936 am<br>
UUID: ebeb7f55-0ca6-a04c-8b5c-87008f09c697<br>
Ancestors: Morphic-mt.1766<br>
<br>
Now that I recently discovered the various ways to browse changes ... make the (rather new) changes menu in the docking bar feel more complete.<br>
<br>
Note that I have no real clue on the actual uses of browsing single change sets or sets of changed methods. Maybe you can help me with some experience reports so that we might remove one or the other menu item again.<br>
<br>
=============== Diff against Morphic-mt.1766 ===============<br>
<br>
Item was added:<br>
+ ----- Method: TheWorldMainDockingBar>>browseChangeSet (in category 'submenu - changes') -----<br>
+ browseChangeSet<br>
+ <br>
+        ChangeSetBrowser openOnCurrent.!<br>
<br>
Item was added:<br>
+ ----- Method: TheWorldMainDockingBar>>browseChangedMethods (in category 'submenu - changes') -----<br>
+ browseChangedMethods<br>
+ <br>
+        ChangedMessageSet openFor: ChangeSet current.!<br>
<br>
Item was added:<br>
+ ----- Method: TheWorldMainDockingBar>>browseChangesDual (in category 'submenu - changes') -----<br>
+ browseChangesDual<br>
+ <br>
+        DualChangeSorter open.!<br>
<br>
Item was changed:<br>
  ----- Method: TheWorldMainDockingBar>>listChangesOn: (in category 'submenu - changes') -----<br>
  listChangesOn: menu<br>
  <br>
         | latestMethodChanges latestClassChanges|<br>
         latestMethodChanges := (Array streamContents: [:s |<br>
                 ChangeSet current changedMethodsDo: [:method :changeType :dateAndTime :category |<br>
                         s nextPut: { dateAndTime. method. changeType. category }]])<br>
                         sorted: [:a :b | a first >= b first].<br>
  <br>
         1 to: (10 min: latestMethodChanges size) do: [:index | | spec method |<br>
                 spec := latestMethodChanges at: index.<br>
                 method := spec second.<br>
                 menu addItem: [:item |<br>
                         item<br>
                                 contents: ('{1} {2} \{{3}\} \{{4}\}' format: {method methodClass. method selector. spec fourth. method methodClass category}) ;<br>
                                 target: ToolSet;<br>
                                 balloonText: spec third asString;<br>
                                 icon: ((#(remove addedThenRemoved) includes: spec third) ifTrue: [MenuIcons smallDeleteIcon] ifFalse: [<br>
                                         spec third = #add ifTrue: [MenuIcons smallNewIcon] ifFalse: [MenuIcons blankIcon]]);<br>
                                 selector: (method isInstalled ifTrue: [#browseMethod:] ifFalse: [#browseMethodVersion:]);<br>
                                 arguments: {method}]].<br>
                                 <br>
         latestClassChanges := (Array streamContents: [:s |<br>
                 ChangeSet current changedClassesDo: [:class :changeTypes :dateAndTime :category |<br>
                         "We are not interested in classes whose method's did only change."<br>
                         changeTypes ifNotEmpty: [s nextPut: { dateAndTime. class. changeTypes. category }]]])<br>
                         sorted: [:a :b | a first >= b first].<br>
  <br>
         latestClassChanges ifNotEmpty: [menu addLine].<br>
         1 to: (10 min: latestClassChanges size) do: [:index | | spec class |<br>
                 spec := latestClassChanges at: index.<br>
                 class := spec second.<br>
                 menu addItem: [:item |<br>
                         item<br>
                                 contents: ('{1} \{{2}\}' format: {class name. spec fourth }) ;<br>
                                 target: ToolSet;<br>
                                 balloonText: (spec third sorted joinSeparatedBy: Character space);<br>
                                 icon: ((spec third includesAnyOf: #(remove addedThenRemoved))<br>
                                         ifTrue: [MenuIcons smallDeleteIcon]<br>
                                         ifFalse: [<br>
                                                 (spec third includes: #add)<br>
                                                         ifTrue: [MenuIcons smallNewIcon]<br>
                                                         ifFalse: [MenuIcons blankIcon]]);<br>
                                 selector: ((spec third includes: #remove) ifTrue: [#inspect:] ifFalse: [#browseClass:]);<br>
                                 arguments: {class}]].<br>
+        <br>
+        menu defaultTarget: self.<br>
+        menu addTranslatedList: #(<br>
+                -<br>
+                ('Browse current change set'            browseChangeSet)<br>
+                ('Browse changed methods'               browseChangedMethods)<br>
+                -<br>
+                ('Simple Change Sorter'                         browseChanges)<br>
+                ('Dual Change Sorter'                                   browseChangesDual)).<br>
+ <br>
+ <br>
+ !<br>
-                                <br>
-        menu addLine; addItem: [:item |<br>
-                item<br>
-                        contents: 'Browse current change set...' translated;<br>
-                        target: self;<br>
-                        selector: #browseChanges].!<br>
<br>
Item was changed:<br>
+ (PackageInfo named: 'Morphic') postscript: 'TheWorldMainDockingBar updateInstances..'!<br>
- (PackageInfo named: 'Morphic') postscript: 'TheWorldMainDockingBar updateInstances.'!<br>
<br>
<br>
</div>
</span></span></div>
</div>
</div>
</div>
</blockquote>
</div>
</div>
</div>
</blockquote>
</div>
</div>
</body>
</html>