From 6ffb880e2b6895598032c609065ba928ef4ca6c2 Mon Sep 17 00:00:00 2001 From: Joana Bergsiek Date: Tue, 13 Feb 2024 15:54:58 +0100 Subject: [PATCH 1/8] Adjusts icon link --- packages/Sandblocks-Morphs/SBIcon.class.st | 2 +- packages/Sandblocks-Smalltalk/SBExample.extension.st | 7 +++++++ 2 files changed, 8 insertions(+), 1 deletion(-) create mode 100644 packages/Sandblocks-Smalltalk/SBExample.extension.st diff --git a/packages/Sandblocks-Morphs/SBIcon.class.st b/packages/Sandblocks-Morphs/SBIcon.class.st index c7ffb4ef..68633a6a 100644 --- a/packages/Sandblocks-Morphs/SBIcon.class.st +++ b/packages/Sandblocks-Morphs/SBIcon.class.st @@ -1,7 +1,7 @@ " A PHTIcon displays an icon. Create it with one of the many class methods. -The current icon list is imported from FontAwesome. See https://fontawesome.com/icons for a full list. Names are changed, e.g. instead of 'align-center' write 'iconAlignCenter'. +The current icon list is imported from FontAwesome. See https://fontawesome.com/search?m=free&o=r for a full list. Names are changed, e.g. instead of 'align-center' write 'iconAlignCenter'. Internally, it holds a reference to the requested SVGMorph (SVGCache) as well as a cached form of the rendered result of that SVG at the required size (FormCache). " diff --git a/packages/Sandblocks-Smalltalk/SBExample.extension.st b/packages/Sandblocks-Smalltalk/SBExample.extension.st new file mode 100644 index 00000000..586634e6 --- /dev/null +++ b/packages/Sandblocks-Smalltalk/SBExample.extension.st @@ -0,0 +1,7 @@ +Extension { #name : #SBExample } + +{ #category : #'*Sandblocks-Smalltalk' } +SBExample >> isExample [ + + ^ true +] From f8009cdabc134aebecf7a99e61fcc80113f789ce Mon Sep 17 00:00:00 2001 From: Joana Bergsiek Date: Tue, 13 Feb 2024 15:59:40 +0100 Subject: [PATCH 2/8] Adds a SBTrace to know the execution order of watch values, which are directly saved as watch values when reported and not just in the watch views --- .../Sandblocks-Babylonian/Object.extension.st | 8 ++ .../Sandblocks-Babylonian/SBExample.class.st | 122 ++++++++++-------- .../SBExample.extension.st | 7 + .../SBExampleValueDisplay.class.st | 4 +- .../SBExampleWatch.class.st | 28 ++-- .../Sandblocks-Babylonian/SBTrace.class.st | 73 +++++++++++ .../SBWatchValue.class.st | 36 +++++- packages/Sandblocks-Core/SBWatch.class.st | 8 +- .../SBExampleWatchView.class.st | 4 +- .../Sandblocks-Watch/SBWatchView.class.st | 17 +-- 10 files changed, 221 insertions(+), 86 deletions(-) create mode 100644 packages/Sandblocks-Babylonian/SBExample.extension.st create mode 100644 packages/Sandblocks-Babylonian/SBTrace.class.st diff --git a/packages/Sandblocks-Babylonian/Object.extension.st b/packages/Sandblocks-Babylonian/Object.extension.st index 45b2b7f7..20481b1c 100644 --- a/packages/Sandblocks-Babylonian/Object.extension.st +++ b/packages/Sandblocks-Babylonian/Object.extension.st @@ -1,5 +1,13 @@ Extension { #name : #Object } +{ #category : #'*Sandblocks-Babylonian' } +Object >> asSBWatchValue [ + + ^ SBWatchValue + value: self sbSnapshot + identityHash: self identityHash +] + { #category : #'*Sandblocks-Babylonian' } Object class >> exampleBlock [ diff --git a/packages/Sandblocks-Babylonian/SBExample.class.st b/packages/Sandblocks-Babylonian/SBExample.class.st index 1f0478d3..74f7d641 100644 --- a/packages/Sandblocks-Babylonian/SBExample.class.st +++ b/packages/Sandblocks-Babylonian/SBExample.class.st @@ -12,7 +12,8 @@ Class { 'active', 'errorDecorator', 'returnValue', - 'reportedError' + 'reportedError', + 'traceSize' ], #category : #'Sandblocks-Babylonian' } @@ -86,13 +87,13 @@ SBExample class >> self: aBlock args: aCollection label: aString assert: anAsser ] -{ #category : #'as yet unclassified' } +{ #category : #accessing } SBExample >> active [ ^ active ] -{ #category : #'as yet unclassified' } +{ #category : #actions } SBExample >> addAssertion [ @@ -100,32 +101,32 @@ SBExample >> addAssertion [ self addAssertion: self newNullBlock ] -{ #category : #'as yet unclassified' } +{ #category : #layout } SBExample >> addAssertion: aBlock [ self addMorphBack: (SBStringMorph new contents: 'assert:'). ^ self addMorphBack: aBlock ] -{ #category : #'as yet unclassified' } +{ #category : #accessing } SBExample >> argumentsBlock [ ^ self submorphs sixth ] -{ #category : #'as yet unclassified' } +{ #category : #callbacks } SBExample >> artefactSaved: aMethod [ (aMethod isMethod and: [self active]) ifTrue: [self run] ] -{ #category : #'as yet unclassified' } +{ #category : #accessing } SBExample >> assertionBlock [ ^ self submorphCount > 7 ifTrue: [self submorphs ninth] ifFalse: [nil] ] -{ #category : #'as yet unclassified' } +{ #category : #'event handling' } SBExample >> click: anEvent [ super click: anEvent. @@ -140,7 +141,7 @@ SBExample >> click: anEvent [ "currentProcess debug: error signalerContext title: error asString full: true."] ] -{ #category : #'as yet unclassified' } +{ #category : #accessing } SBExample >> collectTypeInfo [ | arguments receiver selector | @@ -161,19 +162,19 @@ SBExample >> collectTypeInfo [ do: []]] ] -{ #category : #'as yet unclassified' } +{ #category : #accessing } SBExample >> currentMethodMap [ ^ (self sandblockEditor methods select: #exists) collect: [:method | method compiledMethod sandblocksFastHash -> method] as: Dictionary ] -{ #category : #'as yet unclassified' } +{ #category : #accessing } SBExample >> currentSelf [ ^ currentSelf ] -{ #category : #'as yet unclassified' } +{ #category : #actions } SBExample >> debug [ @@ -190,19 +191,19 @@ SBExample >> debug [ self sandblockEditor errors focusErrors ] -{ #category : #'as yet unclassified' } +{ #category : #'event handling' } SBExample >> doubleClick: anEvent [ self toggleRunning ] -{ #category : #'as yet unclassified' } +{ #category : #'colors and color policies' } SBExample >> drawnColor [ ^ self colorPolicy toolColorFor: self ] -{ #category : #'as yet unclassified' } +{ #category : #evaluate } SBExample >> evaluate [ | arguments | @@ -211,13 +212,13 @@ SBExample >> evaluate [ ^ currentSelf perform: self containingArtefact selector asSymbol withArguments: arguments ] -{ #category : #'as yet unclassified' } +{ #category : #evaluate } SBExample >> evaluateArguments [ ^ self argumentsBlock childSandblocks collect: [:block | Compiler evaluate: block sourceString] ] -{ #category : #'as yet unclassified' } +{ #category : #evaluate } SBExample >> evaluateIn: aBlock [ | arguments | @@ -226,13 +227,13 @@ SBExample >> evaluateIn: aBlock [ ^ aBlock value: [currentSelf perform: self containingArtefact selector asSymbol withArguments: arguments] ] -{ #category : #'as yet unclassified' } +{ #category : #evaluate } SBExample >> evaluateSelf [ ^ Compiler evaluate: self selfBlock veryDeepCopy sourceString ] -{ #category : #'as yet unclassified' } +{ #category : #execution } SBExample >> execute [ | newSelf arguments | @@ -241,7 +242,7 @@ SBExample >> execute [ ^ newSelf perform: self containingArtefact selector asSymbol withArguments: arguments ] -{ #category : #'as yet unclassified' } +{ #category : #execution } SBExample >> executeForBlock: aBlock ifFound: aClosure [ [ | newSelf arguments | @@ -259,13 +260,14 @@ SBExample >> executeForBlock: aBlock ifFound: aClosure [ do: [:err | SBWatch report: err for: 477523582] ] -{ #category : #'as yet unclassified' } +{ #category : #initialization } SBExample >> initialize [ super initialize. active := false. processRunning := false. + traceSize := 0. self layoutInset: 8; @@ -277,7 +279,7 @@ SBExample >> initialize [ cellGap: 4 * self scalingFactor ] -{ #category : #'as yet unclassified' } +{ #category : #initialization } SBExample >> intoWorld: aWorld [ super intoWorld: aWorld. @@ -285,31 +287,25 @@ SBExample >> intoWorld: aWorld [ "self startRunning" ] -{ #category : #'as yet unclassified' } +{ #category : #accessing } SBExample >> isCurrent [ ^ currentProcess == Processor activeProcess ] -{ #category : #'as yet unclassified' } -SBExample >> isExample [ - - ^ true -] - -{ #category : #'as yet unclassified' } +{ #category : #'*Sandblocks-Babylonian' } SBExample >> isMorphExample [ ^ false ] -{ #category : #'as yet unclassified' } +{ #category : #accessing } SBExample >> label [ ^ nameInput contents ] -{ #category : #'as yet unclassified' } +{ #category : #accessing } SBExample >> lastError: anError [ lastError := anError. @@ -337,7 +333,7 @@ SBExample >> lastError: anError [ errorIndicator := nil] ] -{ #category : #'as yet unclassified' } +{ #category : #layout } SBExample >> layoutCommands [ ^ SBAlgebraCommand container @@ -346,32 +342,38 @@ SBExample >> layoutCommands [ SBAlgebraCommand group data: {a layoutCommands. SBAlgebraCommand gap. b layoutCommands. SBAlgebraCommand softLineOrGap}]), {self lastSubmorph layoutCommands} ] -{ #category : #'as yet unclassified' } +{ #category : #accessing } SBExample >> nameBlock [ ^ self submorphs second ] -{ #category : #'as yet unclassified' } +{ #category : #initialization } SBExample >> outOfWorld: aWorld [ currentProcess ifNotNil: #terminate. super outOfWorld: aWorld ] -{ #category : #'as yet unclassified' } +{ #category : #printing } SBExample >> printOn: aStream [ aStream nextPutAll: 'example' ] -{ #category : #'as yet unclassified' } +{ #category : #testing } SBExample >> providesExecutionEnvironment [ ^ true ] -{ #category : #'as yet unclassified' } +{ #category : #accessing } +SBExample >> registerWatchValue [ + + traceSize := traceSize + 1 +] + +{ #category : #execution } SBExample >> run [ self runSetup. @@ -390,7 +392,7 @@ SBExample >> run [ currentProcess := nil. processRunning := false. Project current addDeferredUIMessage: [ - returnValue reportValues: {returned} sized: SBMorphResizer newThumbmail. + returnValue reportValues: {returned asSBWatchValue} sized: SBMorphResizer newThumbmail. returnValue updateDisplay. self sendFinishNotification] ] forkAt: Processor userBackgroundPriority. @@ -398,7 +400,7 @@ SBExample >> run [ ^ currentProcess ] -{ #category : #'as yet unclassified' } +{ #category : #actions } SBExample >> runOnlyThis [ @@ -406,7 +408,7 @@ SBExample >> runOnlyThis [ self startRunning ] -{ #category : #'as yet unclassified' } +{ #category : #execution } SBExample >> runSetup [ self containingArtefact valid ifFalse: [^ self]. @@ -415,14 +417,16 @@ SBExample >> runSetup [ errorDecorator ifNotNil: #detach. errorDecorator := nil. + traceSize := 0. returnValue clear. ] -{ #category : #'as yet unclassified' } +{ #category : #execution } SBExample >> runSynchUpdatingOnlyValuesOf: aCollectionOfSBWatches [ | returned | aCollectionOfSBWatches do: [:aWatch | aWatch resetOnlyValuesFor: self]. + traceSize := 0. SBExecutionEnvironment value: self. [returned := self evaluate] on: Error do: [:e | self scheduleLastError: e]. self scheduleLastError: nil. @@ -430,13 +434,13 @@ SBExample >> runSynchUpdatingOnlyValuesOf: aCollectionOfSBWatches [ ] -{ #category : #'as yet unclassified' } +{ #category : #execution } SBExample >> scheduleLastError: anError [ Project current addDeferredUIMessage: [self lastError: anError] ] -{ #category : #'as yet unclassified' } +{ #category : #initialization } SBExample >> self: aBlock args: aCollectionBlock label: aString [ self @@ -454,34 +458,34 @@ SBExample >> self: aBlock args: aCollectionBlock label: aString [ updateIcon ] -{ #category : #'as yet unclassified' } +{ #category : #initialization } SBExample >> self: aBlock args: aCollectionBlock label: aString assert: anAssertBlock [ self self: aBlock args: aCollectionBlock label: aString. self addAssertion: anAssertBlock ] -{ #category : #'as yet unclassified' } +{ #category : #accessing } SBExample >> selfBlock [ ^ self submorphs fourth ] -{ #category : #'as yet unclassified' } +{ #category : #execution } SBExample >> sendFinishNotification [ self sandblockEditor allMorphsDo: [:morph | (morph isSandblock and: [morph listensToExamples]) ifTrue: [morph exampleFinished: self]] ] -{ #category : #'as yet unclassified' } +{ #category : #execution } SBExample >> sendStartNotification [ self sandblockEditor allBlocksDo: [:morph | morph listensToExamples ifTrue: [morph exampleStarting: self]] ] -{ #category : #'as yet unclassified' } +{ #category : #actions } SBExample >> showReachability [ @@ -494,7 +498,7 @@ SBExample >> showReachability [ self sandblockEditor colorPolicy: policy ] -{ #category : #'as yet unclassified' } +{ #category : #execution } SBExample >> startRunning [ active ifTrue: [^ self]. @@ -504,13 +508,13 @@ SBExample >> startRunning [ self run ] -{ #category : #'as yet unclassified' } +{ #category : #'stepping and presenter' } SBExample >> stepTime [ ^ 2000 ] -{ #category : #'as yet unclassified' } +{ #category : #execution } SBExample >> stopRunning [ active ifFalse: [^ false]. @@ -524,7 +528,7 @@ SBExample >> stopRunning [ (morph isSandblock and: [morph listensToExamples]) ifTrue: [morph exampleStopped: self]] ] -{ #category : #'as yet unclassified' } +{ #category : #actions } SBExample >> toggleRunning [ @@ -533,14 +537,20 @@ SBExample >> toggleRunning [ ifTrue: [self stopRunning] ] -{ #category : #'as yet unclassified' } +{ #category : #accessing } +SBExample >> traceSize [ + + ^ traceSize +] + +{ #category : #layout } SBExample >> updateIcon [ icon changeIconName: (self active ifTrue: [#iconPause] ifFalse: [#iconPlay]) ] -{ #category : #'as yet unclassified' } +{ #category : #copying } SBExample >> veryDeepCopyWith: aCopier [ | copy oldError | @@ -553,7 +563,7 @@ SBExample >> veryDeepCopyWith: aCopier [ ^ copy ] -{ #category : #'as yet unclassified' } +{ #category : #printing } SBExample >> writeSourceOn: aStream [ aStream nextPut: $(. diff --git a/packages/Sandblocks-Babylonian/SBExample.extension.st b/packages/Sandblocks-Babylonian/SBExample.extension.st new file mode 100644 index 00000000..07686946 --- /dev/null +++ b/packages/Sandblocks-Babylonian/SBExample.extension.st @@ -0,0 +1,7 @@ +Extension { #name : #SBExample } + +{ #category : #'*Sandblocks-Babylonian' } +SBExample >> isMorphExample [ + + ^ false +] diff --git a/packages/Sandblocks-Babylonian/SBExampleValueDisplay.class.st b/packages/Sandblocks-Babylonian/SBExampleValueDisplay.class.st index e192da9e..e3508187 100644 --- a/packages/Sandblocks-Babylonian/SBExampleValueDisplay.class.st +++ b/packages/Sandblocks-Babylonian/SBExampleValueDisplay.class.st @@ -131,9 +131,9 @@ SBExampleValueDisplay >> newChangeVizButton [ ] { #category : #'event handling' } -SBExampleValueDisplay >> reportValues: aCollectionOfObjects name: aString sized: aSBMorphResizer [ +SBExampleValueDisplay >> reportValues: aCollectionOfWatchValues name: aString sized: aSBMorphResizer [ - display reportValues: aCollectionOfObjects sized: aSBMorphResizer. + display reportValues: aCollectionOfWatchValues sized: aSBMorphResizer. label contents: aString. label visible: aString notEmpty. hadValue := true diff --git a/packages/Sandblocks-Babylonian/SBExampleWatch.class.st b/packages/Sandblocks-Babylonian/SBExampleWatch.class.st index 4127f8b7..3b364996 100644 --- a/packages/Sandblocks-Babylonian/SBExampleWatch.class.st +++ b/packages/Sandblocks-Babylonian/SBExampleWatch.class.st @@ -77,14 +77,13 @@ SBExampleWatch class >> report: aValue for: aSymbol [ { #category : #'event handling' } SBExampleWatch class >> report: aValue for: aSymbol modifying: aBlock [ - | reg watchers example | + | watchers example | example := SBExecutionEnvironment value ifNil: [^ aValue]. - reg := self registry. - watchers := reg select: [:watcher | watcher notNil + watchers := self registry select: [:watcher | watcher notNil and: [watcher identifier = aSymbol] and: [watcher isActive]]. - watchers do: [:watcher | watcher reportValue: aValue for: example]. + watchers do: [:watcher | watcher reportValue: aValue asSBWatchValue for: example]. ^ aValue ] @@ -252,9 +251,9 @@ SBExampleWatch >> exampleToDisplay: anExampleToDisplayDict [ ] { #category : #accessing } -SBExampleWatch >> exampleToValues: anExampleToCollectionOfObjectsDict [ +SBExampleWatch >> exampleToValues: anExampleToCollectionOfWatchValuesDict [ - exampleToValues := anExampleToCollectionOfObjectsDict + exampleToValues := anExampleToCollectionOfWatchValuesDict ] { #category : #accessing } @@ -389,7 +388,9 @@ SBExampleWatch >> modifiedValuesFor: anExample [ ^ exampleToValues at: anExample ifPresent: [:aCollection | aCollection - collect: [:anObject | self modifyExpression evaluateWithArguments: {anObject}]] + collect: [:aWatchValue | |modifiedResult | + modifiedResult := self modifyExpression evaluateWithArguments: {aWatchValue watchedValue}. + aWatchValue shallowCopy watchedValue: modifiedResult.]] ifAbsent: [{}] ] @@ -445,19 +446,24 @@ SBExampleWatch >> replaceWithWatchedExpression [ ] { #category : #actions } -SBExampleWatch >> reportValue: anObject for: anExample [ +SBExampleWatch >> reportValue: aWatchValue for: anExample [ exampleToValues at: anExample - ifPresent: [:values | values add: anObject] + ifPresent: [:values | + anExample registerWatchValue. + values add: (aWatchValue + tracePosition: anExample traceSize; + occuringWatchId: self identifier + yourself)] ] { #category : #actions } -SBExampleWatch >> reportValues: aCollectionOfObjects for: anExample [ +SBExampleWatch >> reportValues: aCollectionOfWatchValues for: anExample [ exampleToValues at: anExample - ifPresent: [:values | values addAll: aCollectionOfObjects] + ifPresent: [:values | values addAll: aCollectionOfWatchValues] ] { #category : #'event handling' } diff --git a/packages/Sandblocks-Babylonian/SBTrace.class.st b/packages/Sandblocks-Babylonian/SBTrace.class.st new file mode 100644 index 00000000..0a7e728d --- /dev/null +++ b/packages/Sandblocks-Babylonian/SBTrace.class.st @@ -0,0 +1,73 @@ +Class { + #name : #SBTrace, + #superclass : #Morph, + #category : #'Sandblocks-Babylonian' +} + +{ #category : #'as yet unclassified' } +SBTrace class >> newForExample: anExample watches: aCollectionOfWatches [ + + ^ self new visualizeFor: anExample withWatches: aCollectionOfWatches + +] + +{ #category : #visualization } +SBTrace >> addSectionFor: aWatchValue [ + + self addMorphBack: ( + self placeHolderMorph + addMorphBack: (TextMorph new contents: (aWatchValue expressionString asText + addAttribute: (TextColor color: Color gray); + yourself)); + addMorphBack: aWatchValue asValueMorph; + yourself) + +] + +{ #category : #initialization } +SBTrace >> initialize [ + + super initialize. + + self changeTableLayout; + color: Color white; + listDirection: #topToBottom; + cellPositioning: #topRight; + layoutInset: 0@3; + cellInset: 0@2; + hResizing: #shrinkWrap; + vResizing: #shrinkWrap +] + +{ #category : #visualization } +SBTrace >> placeHolderMorph [ + + ^ Morph new + changeTableLayout; + color: Color white; + layoutInset: 3@0; + cellInset: 2@0; + listDirection: #leftToRight; + cellPositioning: #bottomRight; + hResizing: #shrinkWrap; + vResizing: #shrinkWrap +] + +{ #category : #visualization } +SBTrace >> sortedWatchValuesFor: anExample givenWatches: aCollectionOfWatches [ + + | allValues | + allValues := SortedCollection sortBlock: [:a :b | a tracePosition <= b tracePosition]. + aCollectionOfWatches do: [:aWatch | + aWatch exampleToDisplay at: anExample + ifPresent: [:aSBWatchView | allValues addAll: aSBWatchView display watchValues ] + ifAbsent: [{}]]. + ^ allValues +] + +{ #category : #visualization } +SBTrace >> visualizeFor: anExample withWatches: aCollectionOfWatches [ + + (self sortedWatchValuesFor: anExample givenWatches: aCollectionOfWatches) + do: [:aWatchValue | self addSectionFor: aWatchValue] +] diff --git a/packages/Sandblocks-Babylonian/SBWatchValue.class.st b/packages/Sandblocks-Babylonian/SBWatchValue.class.st index 635516f3..22af2819 100644 --- a/packages/Sandblocks-Babylonian/SBWatchValue.class.st +++ b/packages/Sandblocks-Babylonian/SBWatchValue.class.st @@ -4,7 +4,9 @@ Class { #instVars : [ 'watchedValue', 'watchedValueIdentityHash', - 'morphResizer' + 'morphResizer', + 'tracePosition', + 'occuringWatchId' ], #category : #'Sandblocks-Babylonian' } @@ -51,6 +53,12 @@ SBWatchValue >> explore [ self watchedValue explore ] +{ #category : #accessing } +SBWatchValue >> expressionString [ + + ^ self occuringWatch expression sourceString +] + { #category : #'initialize-release' } SBWatchValue >> initialize [ @@ -59,6 +67,7 @@ SBWatchValue >> initialize [ watchedValue := 0. watchedValueIdentityHash := 0 identityHash. morphResizer := SBMorphResizer newIdentity. + tracePosition := 0. ] { #category : #accessing } @@ -74,6 +83,19 @@ SBWatchValue >> morphResizer: aSBMorphResizer [ ] +{ #category : #accessing } +SBWatchValue >> occuringWatch [ + + ^ SBExampleWatch registry detect: [:aWatch | + aWatch notNil and: [aWatch identifier = occuringWatchId]] +] + +{ #category : #accessing } +SBWatchValue >> occuringWatchId: aNumber [ + + occuringWatchId := aNumber +] + { #category : #printing } SBWatchValue >> printOn: aStream [ @@ -82,6 +104,18 @@ SBWatchValue >> printOn: aStream [ self watchedValue printOn: aStream. ] +{ #category : #accessing } +SBWatchValue >> tracePosition [ + + ^ tracePosition +] + +{ #category : #accessing } +SBWatchValue >> tracePosition: aNumber [ + + tracePosition := aNumber +] + { #category : #accessing } SBWatchValue >> watchedValue [ diff --git a/packages/Sandblocks-Core/SBWatch.class.st b/packages/Sandblocks-Core/SBWatch.class.st index 177de001..cadbf1b6 100644 --- a/packages/Sandblocks-Core/SBWatch.class.st +++ b/packages/Sandblocks-Core/SBWatch.class.st @@ -33,7 +33,7 @@ SBWatch class >> report: aValue for: identifier [ | reg watchers | reg := self registry. watchers := reg select: [:watcher | watcher notNil and: [watcher identifier = identifier]]. - watchers do: [:watcher | watcher reportValue: aValue]. + watchers do: [:watcher | watcher reportValue: aValue asSBWatchValue]. ^ aValue ] @@ -219,10 +219,10 @@ SBWatch >> printOn: aStream [ ] { #category : #'as yet unclassified' } -SBWatch >> reportValue: anObject [ +SBWatch >> reportValue: aWatchValue [ - display reportValue: anObject. - self logOutput ifTrue: [Transcript showln: anObject] + display reportValue: aWatchValue. + self logOutput ifTrue: [Transcript showln: aWatchValue watchedValue] ] { #category : #actions } diff --git a/packages/Sandblocks-Watch/SBExampleWatchView.class.st b/packages/Sandblocks-Watch/SBExampleWatchView.class.st index 0405649f..c0f2279c 100644 --- a/packages/Sandblocks-Watch/SBExampleWatchView.class.st +++ b/packages/Sandblocks-Watch/SBExampleWatchView.class.st @@ -29,9 +29,9 @@ SBExampleWatchView >> initialize [ ] { #category : #accessing } -SBExampleWatchView >> reportValues: aCollectionOfObjects sized: aMorphResizer [ +SBExampleWatchView >> reportValues: aCollectionOfWatchValues sized: aMorphResizer [ - aCollectionOfObjects do: [:anObject | self addValue: anObject sized: aMorphResizer]. + aCollectionOfWatchValues do: [:anObject | self addValue: anObject sized: aMorphResizer]. updateScheduled := true ] diff --git a/packages/Sandblocks-Watch/SBWatchView.class.st b/packages/Sandblocks-Watch/SBWatchView.class.st index d86e8fae..47fe9b0b 100644 --- a/packages/Sandblocks-Watch/SBWatchView.class.st +++ b/packages/Sandblocks-Watch/SBWatchView.class.st @@ -25,13 +25,10 @@ SBWatchView class >> saving: anInteger [ ] { #category : #accessing } -SBWatchView >> addValue: anObject sized: aSBMorphResizer [ +SBWatchView >> addValue: aWatchValue sized: aSBMorphResizer [ (watchValues size >= numSavedValues and: [numSavedValues > 0]) ifTrue: [watchValues removeFirst]. - ^ watchValues addLast: (SBWatchValue - value: anObject sbSnapshot - identityHash: anObject identityHash - sized: aSBMorphResizer) + ^ watchValues addLast: (aWatchValue morphResizer: aSBMorphResizer) ] { #category : #'insert/delete' } @@ -269,17 +266,17 @@ SBWatchView >> printOn: aStream [ ] { #category : #actions } -SBWatchView >> reportValue: anObject [ +SBWatchView >> reportValue: aWatchValue [ - self reportValues: {anObject} sized: SBMorphResizer newIdentity + self reportValues: {aWatchValue} sized: SBMorphResizer newIdentity ] { #category : #actions } -SBWatchView >> reportValues: aCollectionOfObjects sized: aMorphResizer [ +SBWatchView >> reportValues: aCollectionOfWatchValues sized: aMorphResizer [ self fallbackResizer: aMorphResizer. - aCollectionOfObjects do: [:anObject | self addValue: anObject sized: aMorphResizer]. - self count: self count contents + aCollectionOfObjects size. + aCollectionOfWatchValues do: [:anObject | self addValue: anObject sized: aMorphResizer]. + self count: self count contents + aCollectionOfWatchValues size. updateScheduled ifFalse: [ updateScheduled := true. From e1b8aad23b18093a306de55abd4ef0faf2a6f418 Mon Sep 17 00:00:00 2001 From: Joana Bergsiek Date: Tue, 13 Feb 2024 16:00:54 +0100 Subject: [PATCH 3/8] Adds new trace views for exploriants which can be toggled --- .../Sandblocks-Babylonian/SBCluster.class.st | 27 +++++++-- .../SBExampleCluster.class.st | 5 +- .../SBExampleGridsView.class.st | 12 +++- .../SBExampleTrace.class.st | 47 +++++++++++++++ .../SBGridResultsView.class.st | 2 +- .../SBPermutationGridsView.class.st | 12 +++- .../SBPermutationTraces.class.st | 50 ++++++++++++++++ .../SBResultsView.class.st | 2 +- .../SBSwitchableResultsView.class.st | 57 +++++++++++++++++++ 9 files changed, 202 insertions(+), 12 deletions(-) create mode 100644 packages/Sandblocks-Babylonian/SBExampleTrace.class.st create mode 100644 packages/Sandblocks-Babylonian/SBPermutationTraces.class.st create mode 100644 packages/Sandblocks-Babylonian/SBSwitchableResultsView.class.st diff --git a/packages/Sandblocks-Babylonian/SBCluster.class.st b/packages/Sandblocks-Babylonian/SBCluster.class.st index 7da66902..292f2d3b 100644 --- a/packages/Sandblocks-Babylonian/SBCluster.class.st +++ b/packages/Sandblocks-Babylonian/SBCluster.class.st @@ -109,6 +109,17 @@ SBCluster >> newTopRowFrom: aCollectionOfMorphs [ (self wrapInCell: aMorph owner flexVertically: true flexHorizontally: false) borderWidth: 0]) ] +{ #category : #visualisation } +SBCluster >> sortedWatchValuesFor: anExample givenWatches: aCollectionOfWatches [ + + | allValues | + allValues := SortedCollection sortBlock: [:a :b | a chronologicalPosition <= b chronologicalPosition]. + aCollectionOfWatches exampleToDisplay at: anExample + ifPresent: [:aSBWatchView | allValues addAll: aSBWatchView watchValues ] + ifAbsent: [{}]. + ^ allValues +] + { #category : #visualisation } SBCluster >> visualize [ @@ -117,9 +128,7 @@ SBCluster >> visualize [ matrix := self buildDisplayMatrix. (matrix rowCount < 2 or: [matrix columnCount < 2]) - ifTrue:[ - self addMorph: (SBOwnTextMorph new contents: 'No watches to display'). - ^ self]. + ifTrue:[self visualizeNothingToDisplay. ^ self]. self addAllMorphsBack: { self newTopRowFrom: (matrix atRow: 1) allButFirst. "ignore placeholder morph" @@ -133,6 +142,13 @@ SBCluster >> visualize [ collect: [:aMorph | self wrapInCell: aMorph])}} ] +{ #category : #visualisation } +SBCluster >> visualizeNothingToDisplay [ + + self addMorph: (SBOwnTextMorph new contents: 'No watches to display') + +] + { #category : #helper } SBCluster >> wrapInCell: aMorph [ @@ -151,12 +167,13 @@ SBCluster >> wrapInCell: aMorph flexVertically: aVBoolean flexHorizontally: aHBo (((aMorph fullBounds extent <= cell extent) or: [aVBoolean and: (aMorph fullBounds width <= cell width)]) - or: [aHBoolean and: (aMorph fullBounds height <= cell height)]) + or: [aHBoolean and: (aMorph fullBounds height <= cell height)] + or: [aVBoolean and: aHBoolean]) ifTrue: [cell addMorph: aMorph. ^ cell]. targetExtent := cell extent - (cell borderWidth@cell borderWidth). aVBoolean ifTrue: [targetExtent setX: targetExtent x setY: aMorph fullBounds height]. - aHBoolean ifTrue: [targetExtent setX: aMorph fullBounds width setY: targetExtent height]. + aHBoolean ifTrue: [targetExtent setX: aMorph fullBounds width setY: targetExtent y]. self flag: #todo. "Another way besides turning into an image to keep interactions.-jb" cell addMorph: (ImageMorph new diff --git a/packages/Sandblocks-Babylonian/SBExampleCluster.class.st b/packages/Sandblocks-Babylonian/SBExampleCluster.class.st index c84dbaca..bee77678 100644 --- a/packages/Sandblocks-Babylonian/SBExampleCluster.class.st +++ b/packages/Sandblocks-Babylonian/SBExampleCluster.class.st @@ -71,7 +71,10 @@ SBExampleCluster >> extractedTopHeadingsFrom: aSBMultiverse [ ^ (aSBMultiverse universes collect: [:aUniverse | self newContainerMorph - listDirection: #leftToRight; + listDirection: #bottomToTop; + cellPositioning: #topLeft; + cellGap: 3; + cellInset: 3; addAllMorphsBack: { SBButton newApplyPermutationFor: aUniverse activePermutation. SBPermutationLabel newDisplaying: aUniverse activePermutation}]) diff --git a/packages/Sandblocks-Babylonian/SBExampleGridsView.class.st b/packages/Sandblocks-Babylonian/SBExampleGridsView.class.st index 7b5c20ab..c30ab483 100644 --- a/packages/Sandblocks-Babylonian/SBExampleGridsView.class.st +++ b/packages/Sandblocks-Babylonian/SBExampleGridsView.class.st @@ -1,6 +1,6 @@ Class { #name : #SBExampleGridsView, - #superclass : #SBGridResultsView, + #superclass : #SBSwitchableResultsView, #category : #'Sandblocks-Babylonian' } @@ -21,7 +21,7 @@ SBExampleGridsView >> buildExampleFor: aNumber [ self containerRow listDirection: #topToBottom; addAllMorphsBack: { SBOwnTextMorph new contents: 'example: ', (self multiverse activeExamples at: aNumber) label. - SBExampleCluster + self currentClusterClass newForSize: morphResizer multiverse: self multiverse displaying: aNumber}. @@ -30,6 +30,14 @@ SBExampleGridsView >> buildExampleFor: aNumber [ self updateContainerWidth. ] +{ #category : #accessing } +SBExampleGridsView >> currentClusterClass [ + + ^ isDisplayingTrace + ifTrue: [SBExampleTrace] + ifFalse: [SBExampleCluster] +] + { #category : #updating } SBExampleGridsView >> gridSize [ diff --git a/packages/Sandblocks-Babylonian/SBExampleTrace.class.st b/packages/Sandblocks-Babylonian/SBExampleTrace.class.st new file mode 100644 index 00000000..c1ffd5e9 --- /dev/null +++ b/packages/Sandblocks-Babylonian/SBExampleTrace.class.st @@ -0,0 +1,47 @@ +Class { + #name : #SBExampleTrace, + #superclass : #SBExampleCluster, + #category : #'Sandblocks-Babylonian' +} + +{ #category : #visualisation } +SBExampleTrace >> buildDisplayMatrix [ + + | matrix displayedExample | + matrix := Matrix + rows: 2 + columns: self multiverse universes size. + displayedExample := self multiverse watches first examples at: self displayedIndex. + + matrix atRow: 1 put: (self extractedTopHeadingsFrom: self multiverse). + self multiverse universes withIndexDo: [:aUniverse :column | + matrix + at: 2 + at: column + put: (SBTrace newForExample: displayedExample watches: aUniverse watches)]. + + ^ matrix +] + +{ #category : #visualisation } +SBExampleTrace >> visualize [ + + | matrix | + self submorphs copy do: #delete. + self multiverse watches ifEmpty: [self visualizeNothingToDisplay. ^ self]. + + matrix := self buildDisplayMatrix. + self addAllMorphsBack: {self newContainerMorph + listDirection: #leftToRight; + cellPositioning: #topLeft; + cellInset: 0; + addAllMorphsBack:( + (matrix atRow: 2) withIndexCollect: [:aTrace :i | + self wrapInCell: (aTrace addMorphFront:( + self newContainerMorph + wrapCentering: #center; + hResizing: #spaceFill; + addMorphBack: (matrix at: 1 at: i))) + flexVertically: true + flexHorizontally: true ])} +] diff --git a/packages/Sandblocks-Babylonian/SBGridResultsView.class.st b/packages/Sandblocks-Babylonian/SBGridResultsView.class.st index 13bb11d2..1c288d1b 100644 --- a/packages/Sandblocks-Babylonian/SBGridResultsView.class.st +++ b/packages/Sandblocks-Babylonian/SBGridResultsView.class.st @@ -50,7 +50,7 @@ SBGridResultsView >> newGridContainer [ SBGridResultsView >> updateContainerWidth [ gridContainer width: - self gridSize safeSquareRoot ceiling + (self gridSize safeSquareRoot ceiling + 1) * (gridContainer lastSubmorph fullBounds width + (2 * gridContainer cellInset) + (2 * gridContainer cellGap) diff --git a/packages/Sandblocks-Babylonian/SBPermutationGridsView.class.st b/packages/Sandblocks-Babylonian/SBPermutationGridsView.class.st index 61ec95bf..b2016248 100644 --- a/packages/Sandblocks-Babylonian/SBPermutationGridsView.class.st +++ b/packages/Sandblocks-Babylonian/SBPermutationGridsView.class.st @@ -1,6 +1,6 @@ Class { #name : #SBPermutationGridsView, - #superclass : #SBGridResultsView, + #superclass : #SBSwitchableResultsView, #category : #'Sandblocks-Babylonian' } @@ -19,7 +19,7 @@ SBPermutationGridsView >> buildPermutationFor: aSBUniverse [ addAllMorphsBack: { SBPermutationLabel newDisplaying: aSBUniverse activePermutation. SBButton newApplyPermutationFor: aSBUniverse activePermutation. - (SBPermutationCluster + (self currentClusterClass newForSize: morphResizer havingWatches: aSBUniverse watches)}. LineMorph from: 0@0 to: 0@50 color: Color black width: 2}). @@ -27,6 +27,14 @@ SBPermutationGridsView >> buildPermutationFor: aSBUniverse [ self updateContainerWidth. ] +{ #category : #building } +SBPermutationGridsView >> currentClusterClass [ + + ^ isDisplayingTrace + ifTrue: [SBPermutationTraces] + ifFalse: [SBPermutationCluster] +] + { #category : #updating } SBPermutationGridsView >> gridSize [ diff --git a/packages/Sandblocks-Babylonian/SBPermutationTraces.class.st b/packages/Sandblocks-Babylonian/SBPermutationTraces.class.st new file mode 100644 index 00000000..e98ba985 --- /dev/null +++ b/packages/Sandblocks-Babylonian/SBPermutationTraces.class.st @@ -0,0 +1,50 @@ +Class { + #name : #SBPermutationTraces, + #superclass : #SBPermutationCluster, + #category : #'Sandblocks-Babylonian' +} + +{ #category : #converting } +SBPermutationTraces >> buildDisplayMatrix [ + + | matrix | + self hasNothingToDisplay ifTrue: [^ Matrix new]. + matrix := Matrix + rows: 2 + columns: self watches first examples size. + + matrix atRow: 1 put: (self extractedTopHeadingsFrom: self watches). + matrix atRow: 2 put: (self watches first examples collect: [:anExample | + SBTrace newForExample: anExample watches: self watches]). + + ^ matrix +] + +{ #category : #converting } +SBPermutationTraces >> hasNothingToDisplay [ + + ^ self watches isEmpty or: [self watches first examples isEmpty] +] + +{ #category : #converting } +SBPermutationTraces >> visualize [ + + | matrix | + self submorphs copy do: #delete. + self hasNothingToDisplay ifTrue: [self visualizeNothingToDisplay. ^ self]. + + matrix := self buildDisplayMatrix. + self addAllMorphsBack: {self newContainerMorph + listDirection: #leftToRight; + cellPositioning: #topLeft; + cellInset: 0; + addAllMorphsBack:( + (matrix atRow: 2) withIndexCollect: [:aTrace :i | + self wrapInCell: (aTrace addMorphFront:( + self newContainerMorph + wrapCentering: #center; + hResizing: #spaceFill; + addMorphBack: (matrix at: 1 at: i))) + flexVertically: true + flexHorizontally: true ])} +] diff --git a/packages/Sandblocks-Babylonian/SBResultsView.class.st b/packages/Sandblocks-Babylonian/SBResultsView.class.st index a1238e79..73dc8ef3 100644 --- a/packages/Sandblocks-Babylonian/SBResultsView.class.st +++ b/packages/Sandblocks-Babylonian/SBResultsView.class.st @@ -18,7 +18,7 @@ SBResultsView >> initialize [ super initialize. - morphResizer := SBMorphResizer newThumbmail. + morphResizer := SBMorphResizer newMedium. ] { #category : #actions } diff --git a/packages/Sandblocks-Babylonian/SBSwitchableResultsView.class.st b/packages/Sandblocks-Babylonian/SBSwitchableResultsView.class.st new file mode 100644 index 00000000..dbbc4f4b --- /dev/null +++ b/packages/Sandblocks-Babylonian/SBSwitchableResultsView.class.st @@ -0,0 +1,57 @@ +" +Offer to switch between trace based and a grid based view +" +Class { + #name : #SBSwitchableResultsView, + #superclass : #SBGridResultsView, + #instVars : [ + 'isDisplayingTrace' + ], + #category : #'Sandblocks-Babylonian' +} + +{ #category : #accessing } +SBSwitchableResultsView >> buttons [ + + ^ super buttons, {self toggleViewButton} +] + +{ #category : #accessing } +SBSwitchableResultsView >> currentClusterClass [ + + ^ self subclassResponsibility +] + +{ #category : #accessing } +SBSwitchableResultsView >> initialize [ + + super initialize. + + isDisplayingTrace := false. +] + +{ #category : #building } +SBSwitchableResultsView >> toggleIcon [ + + ^ isDisplayingTrace + ifTrue: [SBIcon iconToggleOn] + ifFalse: [SBIcon iconToggleOff] +] + +{ #category : #accessing } +SBSwitchableResultsView >> toggleView [ + + isDisplayingTrace := isDisplayingTrace not. + + self visualize +] + +{ #category : #building } +SBSwitchableResultsView >> toggleViewButton [ + + ^ SBButton new + icon: self toggleIcon + label: 'Group By Watches <> In Execution Order' + do: [self toggleView]; + cornerStyle: #squared +] From 74c6f6e102ada27a483d3d9f5afc927126ba46cc Mon Sep 17 00:00:00 2001 From: Joana Bergsiek Date: Tue, 13 Feb 2024 16:07:10 +0100 Subject: [PATCH 4/8] Delete the isExample --- packages/Sandblocks-Smalltalk/SBExample.extension.st | 7 ------- 1 file changed, 7 deletions(-) delete mode 100644 packages/Sandblocks-Smalltalk/SBExample.extension.st diff --git a/packages/Sandblocks-Smalltalk/SBExample.extension.st b/packages/Sandblocks-Smalltalk/SBExample.extension.st deleted file mode 100644 index 586634e6..00000000 --- a/packages/Sandblocks-Smalltalk/SBExample.extension.st +++ /dev/null @@ -1,7 +0,0 @@ -Extension { #name : #SBExample } - -{ #category : #'*Sandblocks-Smalltalk' } -SBExample >> isExample [ - - ^ true -] From 4aa50023e69788bcd42af18b027b36bd388df904 Mon Sep 17 00:00:00 2001 From: Joana Bergsiek Date: Tue, 13 Feb 2024 16:08:57 +0100 Subject: [PATCH 5/8] Recategorizes isExample --- packages/Sandblocks-Babylonian/SBExample.class.st | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/packages/Sandblocks-Babylonian/SBExample.class.st b/packages/Sandblocks-Babylonian/SBExample.class.st index 74f7d641..d81e5e5d 100644 --- a/packages/Sandblocks-Babylonian/SBExample.class.st +++ b/packages/Sandblocks-Babylonian/SBExample.class.st @@ -293,6 +293,12 @@ SBExample >> isCurrent [ ^ currentProcess == Processor activeProcess ] +{ #category : #'as yet unclassified' } +SBExample >> isExample [ + + ^ true +] + { #category : #'*Sandblocks-Babylonian' } SBExample >> isMorphExample [ From 2fb0145d1348baae945b10371124a3679e85355f Mon Sep 17 00:00:00 2001 From: Joana Bergsiek Date: Tue, 13 Feb 2024 16:12:17 +0100 Subject: [PATCH 6/8] Recategorisation --- packages/Sandblocks-Babylonian/SBExample.class.st | 2 +- packages/Sandblocks-Babylonian/SBExample.extension.st | 7 ------- 2 files changed, 1 insertion(+), 8 deletions(-) delete mode 100644 packages/Sandblocks-Babylonian/SBExample.extension.st diff --git a/packages/Sandblocks-Babylonian/SBExample.class.st b/packages/Sandblocks-Babylonian/SBExample.class.st index d81e5e5d..e8be6d13 100644 --- a/packages/Sandblocks-Babylonian/SBExample.class.st +++ b/packages/Sandblocks-Babylonian/SBExample.class.st @@ -299,7 +299,7 @@ SBExample >> isExample [ ^ true ] -{ #category : #'*Sandblocks-Babylonian' } +{ #category : #'as yet unclassified' } SBExample >> isMorphExample [ ^ false diff --git a/packages/Sandblocks-Babylonian/SBExample.extension.st b/packages/Sandblocks-Babylonian/SBExample.extension.st deleted file mode 100644 index 07686946..00000000 --- a/packages/Sandblocks-Babylonian/SBExample.extension.st +++ /dev/null @@ -1,7 +0,0 @@ -Extension { #name : #SBExample } - -{ #category : #'*Sandblocks-Babylonian' } -SBExample >> isMorphExample [ - - ^ false -] From 12b28c68c505012c2d7c1c91906b8ec868cc81a1 Mon Sep 17 00:00:00 2001 From: Joana Bergsiek Date: Tue, 13 Feb 2024 16:19:32 +0100 Subject: [PATCH 7/8] Revert SBIcon class comment --- packages/Sandblocks-Morphs/SBIcon.class.st | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/Sandblocks-Morphs/SBIcon.class.st b/packages/Sandblocks-Morphs/SBIcon.class.st index 68633a6a..c7ffb4ef 100644 --- a/packages/Sandblocks-Morphs/SBIcon.class.st +++ b/packages/Sandblocks-Morphs/SBIcon.class.st @@ -1,7 +1,7 @@ " A PHTIcon displays an icon. Create it with one of the many class methods. -The current icon list is imported from FontAwesome. See https://fontawesome.com/search?m=free&o=r for a full list. Names are changed, e.g. instead of 'align-center' write 'iconAlignCenter'. +The current icon list is imported from FontAwesome. See https://fontawesome.com/icons for a full list. Names are changed, e.g. instead of 'align-center' write 'iconAlignCenter'. Internally, it holds a reference to the requested SVGMorph (SVGCache) as well as a cached form of the rendered result of that SVG at the required size (FormCache). " From 81ada3e2dc04e78be925e352e12197e51d4ab086 Mon Sep 17 00:00:00 2001 From: Joana Bergsiek Date: Wed, 14 Feb 2024 16:41:27 +0100 Subject: [PATCH 8/8] Adds resizing option for grid views --- .../SBExampleGridsView.class.st | 2 +- .../SBExampleTrace.class.st | 5 ++- .../Sandblocks-Babylonian/SBLiveView.class.st | 2 +- .../SBPermutationGridsView.class.st | 2 +- .../SBPermutationTraces.class.st | 5 ++- .../SBResultsView.class.st | 11 ----- .../SBSwitchableResultsView.class.st | 42 ++++++++++++++++++- .../Sandblocks-Babylonian/SBTrace.class.st | 17 ++++---- 8 files changed, 61 insertions(+), 25 deletions(-) diff --git a/packages/Sandblocks-Babylonian/SBExampleGridsView.class.st b/packages/Sandblocks-Babylonian/SBExampleGridsView.class.st index c30ab483..4b8ba62b 100644 --- a/packages/Sandblocks-Babylonian/SBExampleGridsView.class.st +++ b/packages/Sandblocks-Babylonian/SBExampleGridsView.class.st @@ -22,7 +22,7 @@ SBExampleGridsView >> buildExampleFor: aNumber [ addAllMorphsBack: { SBOwnTextMorph new contents: 'example: ', (self multiverse activeExamples at: aNumber) label. self currentClusterClass - newForSize: morphResizer + newForSize: self selectedResizer multiverse: self multiverse displaying: aNumber}. LineMorph from: 0@0 to: 0@50 color: Color black width: 2}). diff --git a/packages/Sandblocks-Babylonian/SBExampleTrace.class.st b/packages/Sandblocks-Babylonian/SBExampleTrace.class.st index c1ffd5e9..222aa956 100644 --- a/packages/Sandblocks-Babylonian/SBExampleTrace.class.st +++ b/packages/Sandblocks-Babylonian/SBExampleTrace.class.st @@ -18,7 +18,10 @@ SBExampleTrace >> buildDisplayMatrix [ matrix at: 2 at: column - put: (SBTrace newForExample: displayedExample watches: aUniverse watches)]. + put: (SBTrace + newForSize: self morphResizer + example: displayedExample + watches: aUniverse watches)]. ^ matrix ] diff --git a/packages/Sandblocks-Babylonian/SBLiveView.class.st b/packages/Sandblocks-Babylonian/SBLiveView.class.st index 6c772eca..d599ca09 100644 --- a/packages/Sandblocks-Babylonian/SBLiveView.class.st +++ b/packages/Sandblocks-Babylonian/SBLiveView.class.st @@ -66,7 +66,7 @@ SBLiveView >> buildSetUpRow [ { #category : #building } SBLiveView >> buttons [ - ^ {self updateButton. self rebuildButton. self resolveButton} + ^ super buttons, {self resolveButton} ] { #category : #actions } diff --git a/packages/Sandblocks-Babylonian/SBPermutationGridsView.class.st b/packages/Sandblocks-Babylonian/SBPermutationGridsView.class.st index b2016248..232118d8 100644 --- a/packages/Sandblocks-Babylonian/SBPermutationGridsView.class.st +++ b/packages/Sandblocks-Babylonian/SBPermutationGridsView.class.st @@ -20,7 +20,7 @@ SBPermutationGridsView >> buildPermutationFor: aSBUniverse [ SBPermutationLabel newDisplaying: aSBUniverse activePermutation. SBButton newApplyPermutationFor: aSBUniverse activePermutation. (self currentClusterClass - newForSize: morphResizer + newForSize: self selectedResizer havingWatches: aSBUniverse watches)}. LineMorph from: 0@0 to: 0@50 color: Color black width: 2}). diff --git a/packages/Sandblocks-Babylonian/SBPermutationTraces.class.st b/packages/Sandblocks-Babylonian/SBPermutationTraces.class.st index e98ba985..ee3bf67d 100644 --- a/packages/Sandblocks-Babylonian/SBPermutationTraces.class.st +++ b/packages/Sandblocks-Babylonian/SBPermutationTraces.class.st @@ -15,7 +15,10 @@ SBPermutationTraces >> buildDisplayMatrix [ matrix atRow: 1 put: (self extractedTopHeadingsFrom: self watches). matrix atRow: 2 put: (self watches first examples collect: [:anExample | - SBTrace newForExample: anExample watches: self watches]). + SBTrace + newForSize: self morphResizer + example: anExample + watches: self watches]). ^ matrix ] diff --git a/packages/Sandblocks-Babylonian/SBResultsView.class.st b/packages/Sandblocks-Babylonian/SBResultsView.class.st index 73dc8ef3..c1f33bfd 100644 --- a/packages/Sandblocks-Babylonian/SBResultsView.class.st +++ b/packages/Sandblocks-Babylonian/SBResultsView.class.st @@ -1,9 +1,6 @@ Class { #name : #SBResultsView, #superclass : #SBExploriantsView, - #instVars : [ - 'morphResizer' - ], #category : #'Sandblocks-Babylonian' } @@ -13,14 +10,6 @@ SBResultsView >> buildAllPossibleResults [ self subclassResponsibility ] -{ #category : #initialization } -SBResultsView >> initialize [ - - super initialize. - - morphResizer := SBMorphResizer newMedium. -] - { #category : #actions } SBResultsView >> visualize [ diff --git a/packages/Sandblocks-Babylonian/SBSwitchableResultsView.class.st b/packages/Sandblocks-Babylonian/SBSwitchableResultsView.class.st index dbbc4f4b..569bf136 100644 --- a/packages/Sandblocks-Babylonian/SBSwitchableResultsView.class.st +++ b/packages/Sandblocks-Babylonian/SBSwitchableResultsView.class.st @@ -5,11 +5,33 @@ Class { #name : #SBSwitchableResultsView, #superclass : #SBGridResultsView, #instVars : [ - 'isDisplayingTrace' + 'isDisplayingTrace', + 'dimensionOptions' ], #category : #'Sandblocks-Babylonian' } +{ #category : #actions } +SBSwitchableResultsView >> applyResizer [ + + self visualize. + self multiverse sandblockEditor markSaved: SBExploriants uniqueInstance +] + +{ #category : #building } +SBSwitchableResultsView >> buildDimensionOptions [ + + | options | + options := SBMorphResizer standardOptions. + + ^ SBComboBox new + prefix: 'Morph Dimensions: '; + labels: (options collect: #label); + values: options; + object: options third; + when: #selectionChanged send: #applyResizer to: self +] + { #category : #accessing } SBSwitchableResultsView >> buttons [ @@ -28,6 +50,13 @@ SBSwitchableResultsView >> initialize [ super initialize. isDisplayingTrace := false. + dimensionOptions := self buildDimensionOptions +] + +{ #category : #accessing } +SBSwitchableResultsView >> selectedResizer [ + + ^ dimensionOptions object ] { #category : #building } @@ -55,3 +84,14 @@ SBSwitchableResultsView >> toggleViewButton [ do: [self toggleView]; cornerStyle: #squared ] + +{ #category : #actions } +SBSwitchableResultsView >> visualize [ + + self clean. + + self block addMorph: dimensionOptions. + self buildButtonRow. + + self buildAllPossibleResults +] diff --git a/packages/Sandblocks-Babylonian/SBTrace.class.st b/packages/Sandblocks-Babylonian/SBTrace.class.st index 0a7e728d..a835d348 100644 --- a/packages/Sandblocks-Babylonian/SBTrace.class.st +++ b/packages/Sandblocks-Babylonian/SBTrace.class.st @@ -4,22 +4,23 @@ Class { #category : #'Sandblocks-Babylonian' } -{ #category : #'as yet unclassified' } -SBTrace class >> newForExample: anExample watches: aCollectionOfWatches [ +{ #category : #'initialize-release' } +SBTrace class >> newForSize: aMorphResizer example: anExample watches: aCollectionOfWatches [ - ^ self new visualizeFor: anExample withWatches: aCollectionOfWatches - + ^ self new visualizeFor: anExample withWatches: aCollectionOfWatches resizer: aMorphResizer + ] { #category : #visualization } -SBTrace >> addSectionFor: aWatchValue [ +SBTrace >> addSectionFor: aWatchValue resizer: aMorphResizer [ self addMorphBack: ( self placeHolderMorph addMorphBack: (TextMorph new contents: (aWatchValue expressionString asText addAttribute: (TextColor color: Color gray); yourself)); - addMorphBack: aWatchValue asValueMorph; + addMorphBack: ([aWatchValue morphResizer: aMorphResizer. + aWatchValue asValueMorph] value); yourself) ] @@ -66,8 +67,8 @@ SBTrace >> sortedWatchValuesFor: anExample givenWatches: aCollectionOfWatches [ ] { #category : #visualization } -SBTrace >> visualizeFor: anExample withWatches: aCollectionOfWatches [ +SBTrace >> visualizeFor: anExample withWatches: aCollectionOfWatches resizer: aMorphResizer [ (self sortedWatchValuesFor: anExample givenWatches: aCollectionOfWatches) - do: [:aWatchValue | self addSectionFor: aWatchValue] + do: [:aWatchValue | self addSectionFor: aWatchValue resizer: aMorphResizer] ]