diff --git a/src/Spec2-Adapters-Morphic/SpMorphicTextAdapter.class.st b/src/Spec2-Adapters-Morphic/SpMorphicTextAdapter.class.st index 1a873a34..ea146944 100644 --- a/src/Spec2-Adapters-Morphic/SpMorphicTextAdapter.class.st +++ b/src/Spec2-Adapters-Morphic/SpMorphicTextAdapter.class.st @@ -17,6 +17,12 @@ SpMorphicTextAdapter >> accept: aString notifying: aNotifyier [ notifying: aNotifyier ] +{ #category : 'widget API' } +SpMorphicTextAdapter >> addExtraActionsTo: actionGroup [ + + "override to add extra actions between user defined and edition" +] + { #category : 'initialization' } SpMorphicTextAdapter >> addFocusRotationKeyBindings [ "Text areas needs to be able to process tab. Cancel the binding." @@ -91,9 +97,10 @@ SpMorphicTextAdapter >> codePaneMenu: aMenu shifted: shifted [ self presenter internalActions ifNotNil: [ :group | actionGroup add: group beRoot ]. + self addExtraActionsTo: actionGroup. self presenter actions ifNotNil: [ :group | actionGroup add: group beRoot ]. - self presenter hasEditionContextMenu ifTrue: [ + self presenter hasEditionContextMenu ifTrue: [ actionGroup add: self presenter editionCommandsGroup beRoot ]. menuPresenter := self presenter newMenu. diff --git a/src/Spec2-Code-Commands/SpCodeDebugItCommand.class.st b/src/Spec2-Code-Commands/SpCodeDebugItCommand.class.st index f93d142f..e843d45a 100644 --- a/src/Spec2-Code-Commands/SpCodeDebugItCommand.class.st +++ b/src/Spec2-Code-Commands/SpCodeDebugItCommand.class.st @@ -31,9 +31,7 @@ SpCodeDebugItCommand class >> defaultName [ { #category : 'default' } SpCodeDebugItCommand class >> defaultShortcutKey [ - ^ $d shift command mac - | $d shift control win - | $d shift control unix + ^ $d shift actionModifier ] { #category : 'private' } diff --git a/src/Spec2-Code-Commands/SpCodeDoItCommand.class.st b/src/Spec2-Code-Commands/SpCodeDoItCommand.class.st index f9d141fe..fba5b5a5 100644 --- a/src/Spec2-Code-Commands/SpCodeDoItCommand.class.st +++ b/src/Spec2-Code-Commands/SpCodeDoItCommand.class.st @@ -31,9 +31,7 @@ SpCodeDoItCommand class >> defaultName [ { #category : 'default' } SpCodeDoItCommand class >> defaultShortcutKey [ - ^ $d command mac - | $d control win - | $d control unix + ^ $d actionModifier ] { #category : 'accessing' } diff --git a/src/Spec2-Code-Commands/SpCodeInspectItCommand.class.st b/src/Spec2-Code-Commands/SpCodeInspectItCommand.class.st index f3bd1a10..ae0f6674 100644 --- a/src/Spec2-Code-Commands/SpCodeInspectItCommand.class.st +++ b/src/Spec2-Code-Commands/SpCodeInspectItCommand.class.st @@ -31,9 +31,7 @@ SpCodeInspectItCommand class >> defaultName [ { #category : 'default' } SpCodeInspectItCommand class >> defaultShortcutKey [ - ^ $i command mac - | $i control win - | $i control unix + ^ $i actionModifier ] { #category : 'documentation' } diff --git a/src/Spec2-Code-Commands/SpCodePrintItCommand.class.st b/src/Spec2-Code-Commands/SpCodePrintItCommand.class.st index 860e0bc4..434272df 100644 --- a/src/Spec2-Code-Commands/SpCodePrintItCommand.class.st +++ b/src/Spec2-Code-Commands/SpCodePrintItCommand.class.st @@ -31,9 +31,7 @@ SpCodePrintItCommand class >> defaultName [ { #category : 'default' } SpCodePrintItCommand class >> defaultShortcutKey [ - ^ $p command mac - | $p control win - | $p control unix + ^ $p actionModifier ] { #category : 'execution' } diff --git a/src/Spec2-Code-Morphic/SpMorphicCodeAdapter.class.st b/src/Spec2-Code-Morphic/SpMorphicCodeAdapter.class.st index 4c5c2cf2..93a1467e 100644 --- a/src/Spec2-Code-Morphic/SpMorphicCodeAdapter.class.st +++ b/src/Spec2-Code-Morphic/SpMorphicCodeAdapter.class.st @@ -5,6 +5,14 @@ Class { #package : 'Spec2-Code-Morphic' } +{ #category : 'widget API' } +SpMorphicCodeAdapter >> addExtraActionsTo: group [ + + self presenter isOverrideContextMenu ifTrue: [ ^ self ]. + + group add: self presenter rootCommandsGroup beRoot +] + { #category : 'widget API' } SpMorphicCodeAdapter >> behavior [ diff --git a/src/Spec2-Code/SpCodePresenter.class.st b/src/Spec2-Code/SpCodePresenter.class.st index f6865c75..f4df6b0f 100644 --- a/src/Spec2-Code/SpCodePresenter.class.st +++ b/src/Spec2-Code/SpCodePresenter.class.st @@ -434,7 +434,7 @@ SpCodePresenter >> hasEditionContextMenu [ "Answer if edition context menu is active. Edition context menu is available by default, but it can be disabled by calling `SpTextPresenter>>#withoutEditionContextMenu` or `SpCodePresenter>>#overridingContextMenu`" - ^ super hasEditionContextMenu and: [ overrideContextMenu not ] + ^ super hasEditionContextMenu and: [ self isOverrideContextMenu not ] ] { #category : 'testing' } @@ -539,6 +539,12 @@ SpCodePresenter >> interactionModel: anInteractionModel [ self basicInteractionModel: anInteractionModel ] +{ #category : 'private - testing' } +SpCodePresenter >> isOverrideContextMenu [ + + ^ overrideContextMenu +] + { #category : 'private - bindings' } SpCodePresenter >> isScripting [ diff --git a/src/Spec2-Commands/SpBrowseInstancesCommand.class.st b/src/Spec2-Commands/SpBrowseInstancesCommand.class.st index d3b880b0..7dcb08f5 100644 --- a/src/Spec2-Commands/SpBrowseInstancesCommand.class.st +++ b/src/Spec2-Commands/SpBrowseInstancesCommand.class.st @@ -23,5 +23,5 @@ SpBrowseInstancesCommand class >> shortName [ { #category : 'executing' } SpBrowseInstancesCommand >> execute [ - self target instanceSide inspectAllInstances + self target instanceSide allInstances inspect ] diff --git a/src/Spec2-Commands/SpBrowseSubInstancesCommand.class.st b/src/Spec2-Commands/SpBrowseSubInstancesCommand.class.st index 316e2ce6..b70ecd77 100644 --- a/src/Spec2-Commands/SpBrowseSubInstancesCommand.class.st +++ b/src/Spec2-Commands/SpBrowseSubInstancesCommand.class.st @@ -23,5 +23,5 @@ SpBrowseSubInstancesCommand class >> shortName [ { #category : 'executing' } SpBrowseSubInstancesCommand >> execute [ - self target instanceSide inspectSubInstances + self target instanceSide allSubInstances inspect ] diff --git a/src/Spec2-ListView/SpListViewPresenter.class.st b/src/Spec2-ListView/SpListViewPresenter.class.st index 5823dd83..4d4a4787 100644 --- a/src/Spec2-ListView/SpListViewPresenter.class.st +++ b/src/Spec2-ListView/SpListViewPresenter.class.st @@ -143,8 +143,10 @@ SpListViewPresenter class >> exampleWithIconsAndMorph [ It shows also the fact you can put any presenter inside, giving a huge power to your lists." + | application | + application := SpApplication new useBackend: #Gtk. ^ self new - application: (SpApplication new useBackend: #Gtk); + application: application; items: self environment allClasses; setup: [ :aPresenter | | presenter morph | @@ -157,7 +159,7 @@ SpListViewPresenter class >> exampleWithIconsAndMorph [ morph: ((morph := SimpleButtonMorph new) color: Color blue; target: [ - self inform: 'Clicked: ', morph label ]; + application inform: 'Clicked: ', morph label ]; actionSelector: #value; yourself); yourself);