Explainer.st
author Claus Gittinger <cg@exept.de>
Tue, 03 Dec 2019 11:53:04 +0100
changeset 4604 531818d94f92
parent 4589 10ba6189f6b9
child 4627 1d2cd00b299f
permissions -rw-r--r--
#BUGFIX by cg class: Scanner changed: #nextNumber radix floats
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
     1
"
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1993 by Claus Gittinger
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
     3
              All Rights Reserved
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
     4
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    11
"
1081
6e6255672d68 allBehaviors vs. allClasses
Claus Gittinger <cg@exept.de>
parents: 913
diff changeset
    12
"{ Package: 'stx:libcomp' }"
6e6255672d68 allBehaviors vs. allClasses
Claus Gittinger <cg@exept.de>
parents: 913
diff changeset
    13
3548
5b792260efe0 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3538
diff changeset
    14
"{ NameSpace: Smalltalk }"
5b792260efe0 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3538
diff changeset
    15
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
    16
Parser subclass:#Explainer
3813
96f37f7b8297 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3810
diff changeset
    17
	instanceVariableNames:''
96f37f7b8297 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3810
diff changeset
    18
	classVariableNames:''
96f37f7b8297 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3810
diff changeset
    19
	poolDictionaries:''
96f37f7b8297 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3810
diff changeset
    20
	category:'System-Compiler'
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    21
!
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    22
3866
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
    23
Object variableSubclass:#ActionWithInfo
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
    24
	instanceVariableNames:'block info'
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
    25
	classVariableNames:''
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
    26
	poolDictionaries:''
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
    27
	privateIn:Explainer
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
    28
!
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
    29
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
    30
!Explainer class methodsFor:'documentation'!
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    31
20
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    32
copyright
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    33
"
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    34
 COPYRIGHT (c) 1993 by Claus Gittinger
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
    35
              All Rights Reserved
20
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    36
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    37
 This software is furnished under a license and may be used
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    38
 only in accordance with the terms of that license and with the
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    39
 inclusion of the above copyright notice.   This software may not
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    40
 be provided or otherwise made available to, or used by, any
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    41
 other person.  No title to or ownership of the software is
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    42
 hereby transferred.
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    43
"
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    44
!
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    45
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    46
documentation
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    47
"
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
    48
    a very simple explainer - much more should be added...
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
    49
3608
873ba1855932 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3607
diff changeset
    50
    This one is involved, when the 'explain' menu function is used in a
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    51
    codeView (popup or via CMD-E), or if the mouse button is clicked
3608
873ba1855932 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3607
diff changeset
    52
    on some code construct in the new browser (then a short explanaition
873ba1855932 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3607
diff changeset
    53
    is shown in the lower info area).
263
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    54
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
    55
    Most of the texts returned here are heuristically motivated,
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
    56
    based on the experience with beginners and their frequently asked questions.
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
    57
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
    58
    TODO:
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
    59
    this is in an experimental stage; the naive type inferer replicates code
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
    60
    found in DWIM support; it should use the code there.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
    61
    
263
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    62
    [author:]
3608
873ba1855932 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3607
diff changeset
    63
        Claus Gittinger
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    64
"
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    65
! !
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    66
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
    67
!Explainer class methodsFor:'explaining'!
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    68
2193
9416fc17ee62 pass the interval to the explainer
Claus Gittinger <cg@exept.de>
parents: 2191
diff changeset
    69
explainLiteralNode:node in:code forClass:cls short:short interval:intervalIfKnown
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
    70
    |expl literalValue literalsClass findInnerMost elementIndex codeOfCharacterBeforeCursor|
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    71
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    72
    literalValue := node value.
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
    73
    literalsClass := literalValue class.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
    74
    expl := (self asClassLink:literalsClass name "allBold") , '-constant'.
2954
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
    75
2316
f09794e008f8 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2315
diff changeset
    76
    (literalValue isInteger) ifTrue:[
3697
099dd080fd3e #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 3608
diff changeset
    77
        (literalValue ~~ 0 and:[literalValue ~~ 1]) ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    78
            expl := expl , ' ('.
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
    79
            #(2 10 16) with:#('binary: ' 'decimal: ' 'hex: ') do:[:base :baseExpl |
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    80
                |bStr|
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
    81
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    82
                base ~= (node token radix ? 10) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    83
                    bStr := base==10
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    84
                                ifTrue:[literalValue printString]
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
    85
                                ifFalse:[(literalValue printStringRadix:base) leftPaddedTo:2 with:$0]. "/ looks better: at least a size of 2
4465
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
    86
                    (base == 16 and:[literalValue < 10]) ifFalse:[
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
    87
                        "/ oops - maybe someone looks at a large largeInteger
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
    88
                        bStr := bStr contractAtEndTo:40.
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
    89
                        expl := expl , ' ' , baseExpl, bStr
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
    90
                    ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    91
                ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    92
            ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    93
            expl := expl , ' )'.
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
    94
        ].  
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    95
        ^ expl.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    96
    ].                
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    97
    (literalValue isCharacter) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    98
        expl := expl , ' ',literalValue storeString,' (code: ',literalValue codePoint printString,' hex: 16r',literalValue codePoint hexPrintString,')'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    99
        ^ expl.
2316
f09794e008f8 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2315
diff changeset
   100
    ].
2954
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
   101
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
   102
    (node isLiteralArray and:[intervalIfKnown notNil]) ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   103
        "/ see which element we have to explain
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   104
        findInnerMost :=
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   105
            [:token |
4499
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   106
                token value keysAndValuesDo:[:index :eachTokenOrValue |
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   107
                    |selectorOrName selectorExplanation|
2954
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
   108
4499
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   109
                    (eachTokenOrValue respondsTo:#start) ifTrue:[ "/ only works with RBTokens (i.e. not with JavaScript code)!!
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   110
                        ((eachTokenOrValue start to:eachTokenOrValue stop) intersect:intervalIfKnown) notEmpty ifTrue:[
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   111
                            elementIndex := index.  "/ see below
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   112
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   113
                            eachTokenOrValue value isArray ifTrue:[
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   114
                                findInnerMost value:eachTokenOrValue.
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   115
                            ].
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   116
                            eachTokenOrValue value isSymbol ifTrue:[
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   117
                                selectorOrName := eachTokenOrValue value.
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   118
                                selectorOrName isUppercaseFirst ifTrue:[
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   119
                                    (Smalltalk includesKey:selectorOrName) ifTrue:[
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   120
                                        ^ expl, ' / ', (Explainer explainGlobal:selectorOrName inClass:cls short:short)
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   121
                                    ].
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   122
                                ].
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   123
                                selectorExplanation := (Explainer explainSelector:selectorOrName inClass:cls short:short).
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   124
                                selectorExplanation isNil ifTrue:[^ expl].
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   125
                                ^ expl, ' / ', selectorExplanation.
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   126
                            ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   127
                        ].
4499
9375343c971b #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4465
diff changeset
   128
                    ]
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   129
                ]
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   130
             ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   131
        findInnerMost value:node token.
2954
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
   132
    ].
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
   133
4357
1f18f1094e72 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4287
diff changeset
   134
    (literalValue isArray 
1f18f1094e72 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4287
diff changeset
   135
      or:[ literalValue isByteArray 
1f18f1094e72 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4287
diff changeset
   136
      or:[ literalValue isString ]]
1f18f1094e72 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4287
diff changeset
   137
    ) ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   138
        literalValue size == 0 ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   139
            ^ 'empty ' , expl
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   140
        ].
4357
1f18f1094e72 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4287
diff changeset
   141
        (literalValue isString 
1f18f1094e72 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4287
diff changeset
   142
        and:[ node token isLiteralCString ]) ifTrue:[
1f18f1094e72 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4287
diff changeset
   143
            expl := expl,' (C-syntax)'.
1f18f1094e72 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4287
diff changeset
   144
        ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   145
        elementIndex notNil ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   146
            ^ expl , (' (size=%1; element=%2)' bindWith:literalValue size with:elementIndex)
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   147
        ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   148
        literalValue isString ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   149
            elementIndex := intervalIfKnown start - node token start.
2955
d52a51930921 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2954
diff changeset
   150
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   151
            (elementIndex between:1 and:literalValue size) ifTrue:[
3601
1d377594ab06 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3549
diff changeset
   152
                codeOfCharacterBeforeCursor := (literalValue at:elementIndex) codePoint.
1d377594ab06 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3549
diff changeset
   153
                ^ expl , (' (size=%1; position=%2; codePoint=16r%3)' 
1d377594ab06 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3549
diff changeset
   154
                        bindWith:literalValue size 
1d377594ab06 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3549
diff changeset
   155
                        with:elementIndex
1d377594ab06 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3549
diff changeset
   156
                        with:codeOfCharacterBeforeCursor hexPrintString)
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   157
            ]
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   158
        ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   159
        ^ expl , (' (size=%1)' bindWith:literalValue size)
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   160
    ].
2191
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   161
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   162
    ^ expl
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   163
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   164
    "Modified (format): / 30-04-2016 / 16:00:05 / cg"
4357
1f18f1094e72 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4287
diff changeset
   165
    "Modified: / 17-02-2019 / 12:52:23 / Claus Gittinger"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   166
!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   167
4382
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   168
explainMessageNode:node in:code forClass:aClassOrNil short:short interval:intervalIfKnown
1771
9d6581314aed avoid to put nil in Set
Stefan Vogel <sv@exept.de>
parents: 1763
diff changeset
   169
    "answer a string which explains node"
9d6581314aed avoid to put nil in Set
Stefan Vogel <sv@exept.de>
parents: 1763
diff changeset
   170
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   171
    |receiver nm srchClass selector selectorString implClass
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   172
     boldSelectorString globalValue recClassSet
4448
e0dbd918bc2e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4435
diff changeset
   173
     implMethod implMethodComment implMethodCommentLines info definer
1854
9dcdec831c46 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1771
diff changeset
   174
     instances classesOfInstVars implementingClasses canBeNil
3866
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   175
     bestMatches hint redefiningClasses|
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   176
3538
8dbc7dc8056b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3492
diff changeset
   177
    selector := node buildSelectorString.
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   178
    selectorString := selector printString contractTo:50.
3548
5b792260efe0 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3538
diff changeset
   179
    selector := selector asSymbolIfInterned.    "/ avoid creating new symbols.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   180
    selector isNil ifTrue:[
4370
80c9a296899b #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4367
diff changeset
   181
        ^ '%1 is NOWHERE impemented.' bindWith:selectorString
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   182
    ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   183
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   184
    selectorString := self asLink:selectorString to:(self actionToBrowseImplementorsOf:selector).
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   185
    boldSelectorString := selectorString "allBold".
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   186
    
4382
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   187
    recClassSet := self guessPossibleClassesFor:(node receiver) in:code forClass:aClassOrNil.
1733
5a4d415c3bbc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1732
diff changeset
   188
    recClassSet size == 1 ifTrue:[
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   189
        srchClass := recClassSet first.
4382
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   190
        
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   191
        "take care - Set cannot store nil!!"
4382
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   192
        implementingClasses := recClassSet 
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   193
                                    collect:[:eachImplClassOrNil | 
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   194
                                        eachImplClassOrNil whichClassIncludesSelector:selector]
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   195
                                    as:Array.
1869
089f4ae37b06 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1854
diff changeset
   196
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   197
        (implementingClasses includes:nil) ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   198
            implementingClasses size > 1 ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   199
                ^ 'possibly not understood: %1 (%2 other implementors)'
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   200
                    bindWith:selector "allBold"
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   201
                    with:(implementingClasses size - 1)
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   202
            ].
1869
089f4ae37b06 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1854
diff changeset
   203
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   204
            (#('self'  'super' 'true' 'false' 'thisContext') includes:selector) ifTrue:[
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   205
                ^ ('%1 is NOT understood here (missing period after previous statement?)' 
3854
5142caa44ea1 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3853
diff changeset
   206
                        bindWith:selector allBold)
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   207
            ].
3193
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
   208
3854
5142caa44ea1 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3853
diff changeset
   209
            hint := ''.    
4382
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   210
            (recClassSet contains:[:eachRecClassOrNil |
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   211
                              eachRecClassOrNil isMeta not 
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   212
                              and:[eachRecClassOrNil theMetaclass canUnderstand:selector]]
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   213
            ) ifTrue:[
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   214
                hint := '. But class understands it - did you mean "rcvr class ',selector,'..." ?'.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   215
            ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   216
            bestMatches := Parser findBestSelectorsFor:selector in:srchClass.
3927
adfb71f6e49e #OTHER by stefan
Stefan Vogel <sv@exept.de>
parents: 3918
diff changeset
   217
            bestMatches notEmptyOrNil ifTrue:[
3928
f7a113b37c13 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 3927
diff changeset
   218
                |guessedClass|
f7a113b37c13 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 3927
diff changeset
   219
                guessedClass := srchClass whichClassIncludesSelector:bestMatches first.
f7a113b37c13 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 3927
diff changeset
   220
                guessedClass notNil ifTrue:[
3927
adfb71f6e49e #OTHER by stefan
Stefan Vogel <sv@exept.de>
parents: 3918
diff changeset
   221
                    ^ ('%1 is NOT understood here (best guess is: "%2" from %3)'
adfb71f6e49e #OTHER by stefan
Stefan Vogel <sv@exept.de>
parents: 3918
diff changeset
   222
                        bindWith:selector allBold
adfb71f6e49e #OTHER by stefan
Stefan Vogel <sv@exept.de>
parents: 3918
diff changeset
   223
                        with:(bestMatches first "allBold")
3928
f7a113b37c13 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 3927
diff changeset
   224
                        with:guessedClass name) , hint.
3927
adfb71f6e49e #OTHER by stefan
Stefan Vogel <sv@exept.de>
parents: 3918
diff changeset
   225
                ].
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   226
            ].
3927
adfb71f6e49e #OTHER by stefan
Stefan Vogel <sv@exept.de>
parents: 3918
diff changeset
   227
            ^ ('%1 is NOT understood here' bindWith:selector allBold), hint
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   228
        ].
1733
5a4d415c3bbc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1732
diff changeset
   229
    ].
5a4d415c3bbc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1732
diff changeset
   230
5a4d415c3bbc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1732
diff changeset
   231
    implementingClasses isNil ifTrue:[
4382
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   232
        aClassOrNil notNil ifTrue:[  
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   233
            receiver := node receiver.
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   234
            receiver isVariable ifTrue:[
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   235
                nm := receiver name.
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   236
                nm = 'self' ifTrue:[
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   237
                    srchClass := aClassOrNil
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   238
                ].
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   239
                nm = 'super' ifTrue:[
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   240
                    srchClass := aClassOrNil superclass
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   241
                ].
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   242
                definer := receiver whoDefines:nm.
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   243
                definer isNil ifTrue:[
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   244
                    "/ not a local or argument
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   245
                    (aClassOrNil instanceVariableNames includes:nm) ifTrue:[
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   246
                        "/ ok - an instVar; see what values we find...
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   247
                        instances := aClassOrNil allSubInstances select:[:eachInst| eachInst isProtoObject not].
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   248
                        classesOfInstVars := instances collect:[:eachInst | (eachInst instVarNamed:nm) class] as:Set.
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   249
                        canBeNil := (classesOfInstVars remove:UndefinedObject ifAbsent:[]) notNil.
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   250
                        "take care - Set cannot store nil!!"
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   251
                        implementingClasses := classesOfInstVars collect:[:aClassOrNil | (aClassOrNil whichClassIncludesSelector:selector) ? 0].
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   252
                        implementingClasses remove:0 ifAbsent:[].
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   253
                    ] ifFalse:[
4586
adb8027024dd #DOCUMENTATION by stefan
Stefan Vogel <sv@exept.de>
parents: 4545
diff changeset
   254
                        (nm isUppercaseFirst and:[nm knownAsSymbol]) ifTrue:[
adb8027024dd #DOCUMENTATION by stefan
Stefan Vogel <sv@exept.de>
parents: 4545
diff changeset
   255
                            globalValue := Smalltalk at:nm asSymbol.
adb8027024dd #DOCUMENTATION by stefan
Stefan Vogel <sv@exept.de>
parents: 4545
diff changeset
   256
                            globalValue isClass ifTrue:[
adb8027024dd #DOCUMENTATION by stefan
Stefan Vogel <sv@exept.de>
parents: 4545
diff changeset
   257
                                srchClass := globalValue class.
adb8027024dd #DOCUMENTATION by stefan
Stefan Vogel <sv@exept.de>
parents: 4545
diff changeset
   258
                            ].
4382
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   259
                        ].
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   260
                    ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   261
                ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   262
            ].
4382
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   263
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   264
            receiver isLiteral ifTrue:[
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   265
                srchClass := receiver value class
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   266
            ].
4382
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   267
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   268
            srchClass notNil ifTrue:[
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   269
                implClass := srchClass whichClassIncludesSelector:selector.
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   270
                implClass isNil ifTrue:[
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   271
                    ^ '%1 is NOT understood here.' bindWith:boldSelectorString
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   272
                ].
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   273
                redefiningClasses := srchClass allSubclasses select:[:aClassOrNil | aClassOrNil implements:selector].
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   274
            ] ifFalse:[
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   275
                implementingClasses isNil ifTrue:[
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   276
                    implementingClasses := Smalltalk allImplementorsOf:selector
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   277
                ].
3866
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   278
            ].
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   279
        ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   280
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   281
3866
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   282
    implClass isNil ifTrue:[
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   283
        implementingClasses size == 1 ifTrue:[
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   284
            implClass := implementingClasses anElement.
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   285
        ]
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   286
    ].
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   287
    implClass notNil ifTrue:[ 
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   288
        |clsName action1 action2|
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   289
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   290
        implMethod := implClass compiledMethodAt:selector.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   291
        clsName := implClass name.
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   292
        clsName := self asLink:clsName to:(self actionToBrowseClass:implClass selector:selector).
4586
adb8027024dd #DOCUMENTATION by stefan
Stefan Vogel <sv@exept.de>
parents: 4545
diff changeset
   293
        "/ info := '%1 » %2' bindWith:clsName "allBold" with:selectorString.
4459
d21d7081d677 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4454
diff changeset
   294
        info := '%1 %2' bindWith:clsName with:(implMethod methodDefinitionTemplateForSelector:selector).
3866
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   295
        info := self asLink:info to:(action1 := self actionToBrowseClass:implClass selector:selector info:nil).
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   296
        
4370
80c9a296899b #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4367
diff changeset
   297
        redefiningClasses size ~~ 0 ifTrue:[
3866
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   298
            redefiningClasses size == 1 ifTrue:[
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   299
                |redefiner|
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   300
                redefiner := redefiningClasses first.
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   301
                info := info,(' (redefined in %1)'
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   302
                                bindWith:(self 
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   303
                                            asLink:redefiner name
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   304
                                            to:(action2 := self actionToBrowseClass:redefiner selector:selector))).
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   305
                action2 info:((redefiner compiledMethodAt:selector) source) 
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   306
            ] ifFalse:[    
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   307
                info := info,' (redefined in '
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   308
                             ,('%1 classes' 
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   309
                                    bindWith:(self 
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   310
                                              asLink:redefiningClasses size printString
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   311
                                              info:'Browse redefiners'
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   312
                                              to:(action2 := self actionToBrowseImplementorsOf:selector in:redefiningClasses)))
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   313
                             ,')'. 
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   314
                action2 info:'Browse redefiners'            
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   315
            ].
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   316
        ].
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   317
        
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   318
        implMethodComment := self fetchDescriptionOfMethod:"fetchCommentOfMethod:"implMethod.
4448
e0dbd918bc2e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4435
diff changeset
   319
        implMethodComment notEmptyOrNil ifTrue:[
e0dbd918bc2e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4435
diff changeset
   320
            implMethodCommentLines := implMethodComment asStringCollection.
e0dbd918bc2e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4435
diff changeset
   321
            implMethodCommentLines size > 1 ifTrue:[
e0dbd918bc2e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4435
diff changeset
   322
                implMethodCommentLines := implMethodCommentLines copyFrom:2.
e0dbd918bc2e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4435
diff changeset
   323
            ].
e0dbd918bc2e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4435
diff changeset
   324
            info := info , Character cr , (implMethodCommentLines asString).
3866
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
   325
            action1 info:implMethod source.
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   326
        ].
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   327
        ^ info
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   328
"/        (srchClass isNil and:[(cls includesBehavior:implClass) not]) ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   329
"/            "/ info := 'guess: ', info.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   330
"/            info := info , ' (guess)'.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   331
"/        ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   332
    ] ifFalse:[
4382
bf6211c20f71 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4381
diff changeset
   333
        info := Explainer explainSelector:selector inClass:aClassOrNil short:short.
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   334
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   335
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   336
"/    implementingClasses notEmptyOrNil ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   337
"/        implMethods := implementingClasses collect:[:implClass | implClass compiledMethodAt:selector].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   338
"/        implMethods size <= 8 ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   339
"/            implMethods size < 4 ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   340
"/                "/ show full comments
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   341
"/                comments := implMethods 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   342
"/                                collect:[:implMethod | implMethod comment]
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   343
"/                                thenSelect:[:comment | comment notEmptyOrNil].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   344
"/            ] ifFalse:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   345
"/                "/ show first lines one
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   346
"/                comments := implMethods 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   347
"/                                collect:[:implMethod | (self fetchCommentOfMethod:implMethod)]
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   348
"/                                thenSelect:[:comment | comment notEmptyOrNil].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   349
"/            ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   350
"/            comments := comments collect:[:each | each colorizeAllWith:(UserPreferences current commentColor) ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   351
"/            short ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   352
"/                comments := comments collect:[:implMethodComment | implMethodComment firstLine] as:Set.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   353
"/                comments size == 1 ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   354
"/                    ^ info , ' ' , (comments first).
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   355
"/                ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   356
"/                ^ info
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   357
"/            ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   358
"/            info := info,'\'withCRs.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   359
"/            comments 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   360
"/                with:implementingClasses 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   361
"/                do:[:eachComment :eachClass | 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   362
"/                    info := info,'\comment in ',eachClass name,':\',(eachComment asStringCollection asString) 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   363
"/                ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   364
"/        ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   365
"/    ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   366
    ^ info
1854
9dcdec831c46 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1771
diff changeset
   367
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   368
    "Modified: / 30-04-2016 / 17:08:11 / cg"
4459
d21d7081d677 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4454
diff changeset
   369
    "Modified: / 18-07-2019 / 07:51:21 / Claus Gittinger"
4586
adb8027024dd #DOCUMENTATION by stefan
Stefan Vogel <sv@exept.de>
parents: 4545
diff changeset
   370
    "Modified: / 24-10-2019 / 10:46:01 / Stefan Vogel"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   371
!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   372
2193
9416fc17ee62 pass the interval to the explainer
Claus Gittinger <cg@exept.de>
parents: 2191
diff changeset
   373
explainMethodNode:node in:code forClass:cls short:short interval:intervalIfKnown
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   374
    |srchClass selector selectorString implClass
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   375
     "sendingMethods numSendingMethods sendingClasses" |
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   376
4388
cdaf27eaa005 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4382
diff changeset
   377
    cls isNil ifTrue:[^ nil].
cdaf27eaa005 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4382
diff changeset
   378
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   379
    selector := node selector.
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   380
    selector := selector asSymbolIfInterned.    "/ avoid creating new symbols.
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   381
    selectorString := selector printString contractTo:50.
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   382
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   383
    (srchClass := cls superclass) notNil ifTrue:[
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   384
        implClass := srchClass whichClassIncludesSelector:selector.
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   385
        implClass notNil ifTrue:[
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   386
            ^ '%1 overrides implementation in %2.'
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   387
              bindWith:(self asLink:selectorString "allBold" to:(self actionToOpenMethodFinderFor:selector))
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   388
              with:(self asLink:implClass name "allBold" to:(self actionToBrowseClass:implClass selector:selector))
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   389
        ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   390
    ].
2223
50b76baab48b changed: #explainMethodNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2214
diff changeset
   391
    (cls includesSelector:selector) ifFalse:[
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   392
        ^ '%1: a new method.' bindWith:selectorString "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   393
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   394
"/
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   395
"/        sendingMethods := SystemBrowser
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   396
"/                                allCallsOn:selector
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   397
"/                                in:(cls withAllSubclasses , cls allSubclasses)
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   398
"/                                ignoreCase:false
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   399
"/                                match:false.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   400
"/        sendingMethods := sendingMethods select:[:eachMethod | eachMethod mclass notNil].  "/ remove unbound ones
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   401
"/
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   402
"/        sendingClasses := (sendingMethods collect:[:eachMethod | eachMethod mclass]) asSet.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   403
"/        numSendingMethods := sendingMethods size.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   404
"/        numSendingMethods == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   405
"/            sendingClasses first == cls ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   406
"/                ^ '%1: sent locally from %2.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   407
"/                    bindWith:boldSelectorString
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   408
"/                    with:sendingMethods first selector "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   409
"/            ].
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   410
"/            ^ '%1: sent in hierarchy from %2 in %3.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   411
"/                bindWith:boldSelectorString
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   412
"/                with:sendingMethods first selector "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   413
"/                with:sendingClasses first name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   414
"/        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   415
"/        numSendingMethods == 2 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   416
"/            sendingClasses asIdentitySet size == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   417
"/                sendingClasses first == cls ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   418
"/                    ^ '%1: sent locally from %2 and %3.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   419
"/                        bindWith:boldSelectorString
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   420
"/                        with:sendingMethods first selector "allBold"
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   421
"/                        with:sendingMethods second selector "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   422
"/                ].
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   423
"/                ^ '%1: sent in hierarchy from %2 and %3 in %4.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   424
"/                    bindWith:boldSelectorString
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   425
"/                    with:sendingMethods first selector "allBold"
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   426
"/                    with:sendingMethods second selector "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   427
"/                    with:sendingClasses first name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   428
"/            ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   429
"/        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   430
"/        numSendingMethods == 0 ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   431
"/"/            ^ '%1: no sender found.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   432
"/"/                bindWith:boldSelectorString.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   433
"/            ^ nil
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   434
"/        ].
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   435
"/        ^ '%1: %2 sending methods in hierarchy.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   436
"/            bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   437
"/            with:numSendingMethods.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   438
"/
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   439
"/        "/ the following is too expensive...
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   440
"/"/        sendingMethods := SystemBrowser allCallsOn:selector in:Smalltalk allClasses.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   441
"/"/        numSendingMethods == 0 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   442
"/"/            ^ '%1: nowhere sent.' bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   443
"/"/        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   444
"/"/        numSendingMethods == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   445
"/"/            sendingMethods first mclass == cls ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   446
"/"/                ^ '%1: only sent from %2.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   447
"/"/                    bindWith:boldSelectorString
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   448
"/"/                    with:sendingMethods first selector "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   449
"/"/            ].
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   450
"/"/            ^ '%1: only sent from %2 in %3.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   451
"/"/                bindWith:boldSelectorString
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   452
"/"/                with:sendingMethods first selector "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   453
"/"/                with:sendingMethods first mclass name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   454
"/"/        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   455
"/"/        sendingClasses := (sendingMethods collect:[:eachMethod | eachMethod mclass]) asSet.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   456
"/"/        sendingClasses size == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   457
"/"/            sendingClasses first == cls ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   458
"/"/                ^ '%1: locally sent from %2 methods.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   459
"/"/                    bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   460
"/"/                    with:numSendingMethods
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   461
"/"/            ].
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   462
"/"/            ^ '%1 only sent from %2 methods in %3.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   463
"/"/                bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   464
"/"/                with:numSendingMethods
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   465
"/"/                with:sendingClasses first name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   466
"/"/        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   467
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   468
    ^ nil
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   469
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   470
    "Modified: / 09-10-2006 / 12:11:16 / cg"
4388
cdaf27eaa005 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4382
diff changeset
   471
    "Modified: / 05-03-2019 / 03:30:22 / Claus Gittinger"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   472
!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   473
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   474
explainNode:node in:code forClass:cls short:short
2193
9416fc17ee62 pass the interval to the explainer
Claus Gittinger <cg@exept.de>
parents: 2191
diff changeset
   475
    self explainNode:node in:code forClass:cls short:short interval:nil
9416fc17ee62 pass the interval to the explainer
Claus Gittinger <cg@exept.de>
parents: 2191
diff changeset
   476
!
9416fc17ee62 pass the interval to the explainer
Claus Gittinger <cg@exept.de>
parents: 2191
diff changeset
   477
9416fc17ee62 pass the interval to the explainer
Claus Gittinger <cg@exept.de>
parents: 2191
diff changeset
   478
explainNode:node in:code forClass:cls short:short interval:intervalIfKnown
4210
a4e4e763773e #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4206
diff changeset
   479
    "parsetree based explanations"
a4e4e763773e #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4206
diff changeset
   480
    
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   481
    node isVariable ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   482
        ^ self explainVariableNode:node in:code forClass:cls short:short interval:intervalIfKnown.
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   483
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   484
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   485
    node isLiteral ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   486
        ^ self explainLiteralNode:node in:code forClass:cls short:short interval:intervalIfKnown
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   487
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   488
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   489
    node isMessage ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   490
        ^ self explainMessageNode:node in:code forClass:cls short:short interval:intervalIfKnown
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   491
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   492
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   493
    node isMethod ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   494
        ^ self explainMethodNode:node in:code forClass:cls short:short interval:intervalIfKnown
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   495
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   496
    ^ nil
4210
a4e4e763773e #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4206
diff changeset
   497
a4e4e763773e #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4206
diff changeset
   498
    "Modified (comment): / 27-11-2017 / 18:05:22 / cg"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   499
!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   500
4381
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   501
explainVariableNode:node in:code forClass:aClassOrNil short:short interval:intervalIfKnown
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   502
    |expl nm nmBold definingNode namePart argNode argClass argClassSet|
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   503
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   504
    nm := node name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   505
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   506
    (#( 'self' 'super' 'thisContext' 'here') includes:nm) ifTrue:[
4381
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   507
        ^ Explainer explainPseudoVariable:nm in:aClassOrNil short:short
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   508
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   509
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   510
    nm notNil ifTrue:[ nmBold := nm "allBold" ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   511
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   512
    definingNode := node whoDefines:nm.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   513
    definingNode notNil ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   514
        namePart := '''' , nmBold , ''''.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   515
        definingNode isMethod ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   516
            argNode := definingNode arguments detect:[:arg | arg name = nm] ifNone:nil.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   517
            argNode notNil ifTrue:[
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
   518
                expl := namePart , ': a method argument.'.
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   519
4381
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   520
                argClassSet := self guessPossibleClassesFor:argNode in:code forClass:aClassOrNil.
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   521
                argClassSet size == 1 ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   522
                    argClass := argClassSet first.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   523
                ].
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   524
            ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   525
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   526
        expl isNil ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   527
            definingNode isBlock ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   528
                (definingNode arguments contains:[:arg | arg name = nm]) ifTrue:[
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
   529
                    expl := namePart , ': a block argument.'
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   530
                ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   531
            ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   532
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   533
        expl isNil ifTrue:[
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   534
            | parentNode setOfTypes isLocal typesDescription |
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   535
            
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   536
            (parentNode := definingNode parent) notNil ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   537
                (isLocal := parentNode isMethod) ifTrue:[
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
   538
                    expl := namePart , ': a method temporary.'.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   539
                ] ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   540
                    (isLocal := parentNode isBlock) ifTrue:[
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
   541
                       expl := namePart , ': a block temporary.'.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   542
                    ]
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   543
                ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   544
                isLocal ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   545
                    setOfTypes := Set new.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   546
                    self addTypesAssignedToLocal:nm inTree:parentNode to:setOfTypes.
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   547
                    setOfTypes remove:UndefinedObject ifAbsent:[].
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   548
                    typesDescription := self typeDescriptionFor:setOfTypes andSelector:nil.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   549
                    typesDescription notNil ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   550
                        expl := expl,' (',typesDescription,')'.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   551
                    ].    
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   552
                ].    
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   553
            ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   554
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   555
        expl isNil ifTrue:[
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
   556
            expl := namePart , ': temporary.'
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   557
        ].
4381
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   558
        aClassOrNil notNil ifTrue:[
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   559
            (aClassOrNil allInstanceVariableNames includes:nm) ifTrue:[
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   560
                expl := expl , ' (instance variable is hidden)'
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   561
            ].
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   562
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   563
        ^ expl.
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   564
    ].
1938
8d0163055b68 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1926
diff changeset
   565
4381
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   566
    ^ Explainer explain:node name in:code forClass:aClassOrNil short:short
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   567
1938
8d0163055b68 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1926
diff changeset
   568
    "Modified: / 07-11-2006 / 12:22:09 / cg"
4381
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   569
    "Modified: / 05-03-2019 / 01:11:01 / Claus Gittinger"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   570
!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   571
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   572
fetchCommentOfMethod:mthd
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   573
    "retrieve the comment of a method 
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   574
     (if possible and there is one; otherwise, return nil)"
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   575
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   576
    |methodSource methodComment lines maxNumLines|
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   577
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   578
    self withWaitCursorDo:[
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   579
        SourceCodeManagerError handle:[:ex |
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   580
        ] do:[
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   581
            methodSource := mthd source.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   582
            methodComment := mthd comment
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
   583
        ].
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   584
    ].
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
   585
        
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   586
    methodComment isEmptyOrNil ifTrue:[^ nil].
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   587
    
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   588
    lines := methodComment asStringCollection.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   589
    maxNumLines := 1.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   590
true ifTrue:[
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   591
    methodComment := (lines copyToMax:maxNumLines) asString.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   592
    maxNumLines := 5.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   593
] ifFalse:[    
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   594
    methodComment := lines first.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   595
    methodComment := methodComment withoutSeparators.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   596
    (methodComment endsWith:',') ifTrue:[ methodComment := methodComment copyButLast:1].
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   597
    methodComment := methodComment withoutSeparators.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   598
].
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   599
    (lines size > maxNumLines) ifTrue:[
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   600
        methodComment := methodComment , '\...' withCRs
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   601
    ].
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   602
    ^ (methodComment) withColor:(UserPreferences current commentColor).
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   603
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   604
    "Created: / 14-09-2006 / 14:11:58 / cg"
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   605
    "Modified (comment): / 30-04-2016 / 16:17:18 / cg"
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   606
!
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   607
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   608
fetchDescriptionOfMethod:mthd
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   609
    "retrieve a desription of a method 
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   610
     (if possible and there is one; otherwise, return nil)"
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   611
3888
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   612
    |methodDecl methodSource methodComment lines maxNumLines firstIndent|
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   613
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   614
    self withWaitCursorDo:[
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   615
        SourceCodeManagerError handle:[:ex |
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   616
        ] do:[
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   617
            methodSource := mthd source.
3918
401939e91ddb #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3902
diff changeset
   618
            mthd selector isNil ifTrue:[
401939e91ddb #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3902
diff changeset
   619
                methodDecl := '??? (method removed from class)'.
401939e91ddb #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3902
diff changeset
   620
            ] ifFalse:[        
401939e91ddb #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3902
diff changeset
   621
                methodDecl := mthd methodDefinitionTemplate.
401939e91ddb #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3902
diff changeset
   622
            ].        
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   623
            methodComment := mthd comment.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   624
        ].
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   625
    ].
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   626
    methodComment isEmptyOrNil ifTrue:[
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   627
        ^ methodDecl
3888
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   628
    ].
3891
15ad4e20f7ea #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3889
diff changeset
   629
    lines := methodComment asStringCollection withoutLeadingAndTrailingBlankLines.
15ad4e20f7ea #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3889
diff changeset
   630
    lines isEmptyOrNil ifTrue:[
15ad4e20f7ea #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3889
diff changeset
   631
        ^ methodDecl
15ad4e20f7ea #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3889
diff changeset
   632
    ].
15ad4e20f7ea #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3889
diff changeset
   633
    
3888
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   634
    firstIndent := 0.
3889
e19003c34a9a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3888
diff changeset
   635
    lines size > 1 ifTrue:[
3888
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   636
        |line2|
3889
e19003c34a9a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3888
diff changeset
   637
        line2 := lines at:2.
3888
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   638
        line2 notEmpty ifTrue:[
4153
d5bd1f68b4bb #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4143
diff changeset
   639
            firstIndent := (line2 indexOfNonSeparator - 1) max:0.
3888
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   640
        ].    
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   641
    ].    
3889
e19003c34a9a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3888
diff changeset
   642
    lines := lines 
3888
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   643
                        collect:[:line | 
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   644
                            |l|
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   645
                            l := line withTabsExpanded.
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   646
                            l indexOfNonSeparator > firstIndent ifTrue:[
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   647
                                l := l copyFrom:firstIndent+1
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   648
                            ].
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   649
                            l
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   650
                        ].
3889
e19003c34a9a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3888
diff changeset
   651
    methodComment := lines asString.
3888
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   652
    
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   653
    ^ methodDecl , Character cr , 
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   654
        (methodComment withColor:(UserPreferences current commentColor)). 
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   655
    
3888
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   656
"/    methodComment isEmptyOrNil ifTrue:[^ nil].
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   657
"/    
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   658
"/    lines := methodComment asStringCollection.
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   659
"/    maxNumLines := 1.
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   660
"/true ifTrue:[
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   661
"/    methodComment := (lines copyToMax:maxNumLines) asString.
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   662
"/    maxNumLines := 5.
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   663
"/] ifFalse:[    
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   664
"/    methodComment := lines first.
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   665
"/    methodComment := methodComment withoutSeparators.
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   666
"/    (methodComment endsWith:',') ifTrue:[ methodComment := methodComment copyButLast:1].
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   667
"/    methodComment := methodComment withoutSeparators.
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   668
"/].
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   669
"/    (lines size > maxNumLines) ifTrue:[
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   670
"/        methodComment := methodComment , '\...' withCRs
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   671
"/    ].
e5c634278415 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3885
diff changeset
   672
"/    ^ (methodComment) withColor:(UserPreferences current commentColor).
1909
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   673
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   674
    "Created: / 14-09-2006 / 14:11:58 / cg"
4153
d5bd1f68b4bb #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4143
diff changeset
   675
    "Modified (format): / 20-06-2017 / 10:29:13 / cg"
1909
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   676
!
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   677
4381
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   678
guessPossibleClassesFor:node in:code forClass:aClassOrNil
2191
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   679
    "given a node of some code of a method in cls,
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   680
     return a collection of possible types of the node."
2191
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   681
2809
bbf42cc4d305 changed: #guessPossibleImplementorClassesFor:in:forClass:
Claus Gittinger <cg@exept.de>
parents: 2471
diff changeset
   682
    |nm globalValue definer instances classesOfInstVars ns|
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   683
4381
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   684
    node isLiteral ifTrue:[
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   685
        ^ Array with:(node value class)
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   686
    ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   687
    node isVariable ifTrue:[
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   688
        nm := node name.
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   689
4381
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   690
        (aClassOrNil isNil) ifTrue:[
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   691
            (nm isUppercaseFirst and:[ nm knownAsSymbol ]) ifTrue:[
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   692
                globalValue := Smalltalk at:nm asSymbol.
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   693
                globalValue isClass ifTrue:[
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   694
                    ^ Array with:globalValue class.
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   695
                ].
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   696
            ].
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   697
            ^ nil
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   698
        ].
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   699
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   700
        nm = #self ifTrue:[
4381
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   701
            ^ aClassOrNil withAllSubclasses
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   702
        ].
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   703
        nm = #here ifTrue:[
4381
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   704
            ^ aClassOrNil withAllSuperclasses
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   705
        ].
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   706
        nm = #super ifTrue:[
4381
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   707
            ^ aClassOrNil allSuperclasses
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   708
        ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   709
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   710
        definer := node whoDefines:nm.
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   711
        definer isNil ifTrue:[
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   712
            "/ not a local or argument
4381
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   713
            (aClassOrNil instanceVariableNames includes:nm) ifTrue:[
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   714
                "/ ok - an instVar; see what values we find...
4381
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   715
                instances := aClassOrNil allSubInstances select:[:eachInst | eachInst isProtoObject not].
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   716
                classesOfInstVars := instances collect:[:eachInst | (eachInst instVarNamed:nm) class] as:Set.
4589
10ba6189f6b9 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 4586
diff changeset
   717
                "/ should also look at all setters of this instvar, to see if there is sth. like
10ba6189f6b9 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 4586
diff changeset
   718
                "/ class new/new:
10ba6189f6b9 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 4586
diff changeset
   719
                "/ However, this will take too long, unless we implement some clever caching.
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   720
                ^ classesOfInstVars.
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   721
            ].
4381
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   722
            (aClassOrNil classVariableNames includes:nm) ifTrue:[
4589
10ba6189f6b9 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 4586
diff changeset
   723
                "/ should also look at all setters of this instvar, to see if there is sth. like
10ba6189f6b9 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 4586
diff changeset
   724
                "/ class new/new:
10ba6189f6b9 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 4586
diff changeset
   725
                "/ However, this will take too long, unless we implement some clever caching.
4381
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   726
                ^ Array with:(aClassOrNil classVarAt:nm asSymbol) class.
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   727
            ].
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   728
            nm isUppercaseFirst ifTrue:[
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   729
                nm knownAsSymbol ifTrue:[
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   730
                    globalValue := Smalltalk at:nm asSymbol.
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   731
                    globalValue isClass ifTrue:[
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   732
                        ^ Array with:globalValue class.
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   733
                    ].
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   734
                ].
4381
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   735
                ((ns := aClassOrNil topNameSpace) notNil and:[ns ~~ Smalltalk]) ifTrue:[
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   736
                    nm knownAsSymbol ifTrue:[
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   737
                        globalValue := ns at:nm asSymbol.
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   738
                        globalValue isClass ifTrue:[
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   739
                            ^ Array with:globalValue class.
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   740
                        ].
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   741
                    ].
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   742
                ]
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   743
            ].
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   744
        ].
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   745
        definer isMethod ifTrue:[
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   746
            |callers argNr setOfTypes|
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   747
            
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   748
            argNr := definer arguments findFirst:[:arg | arg name = nm]. 
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   749
            setOfTypes := IdentitySet new.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   750
            "/ see who calls this message; are there any calls with an obvious type?
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   751
            callers := SystemBrowser allCallsOn:definer selector.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   752
            callers do:[:eachCaller |
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   753
                |tree|
3940
6b4ea1b3c1a8 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3928
diff changeset
   754
                (tree := eachCaller parseTree) notNil ifTrue:[
6b4ea1b3c1a8 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3928
diff changeset
   755
                    tree allMessageNodesDo:[:msg |
6b4ea1b3c1a8 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3928
diff changeset
   756
                        |argExpr|
6b4ea1b3c1a8 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3928
diff changeset
   757
6b4ea1b3c1a8 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3928
diff changeset
   758
                        msg selector = definer selector ifTrue:[
6b4ea1b3c1a8 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3928
diff changeset
   759
                            argExpr := (msg arguments at:argNr).
6b4ea1b3c1a8 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3928
diff changeset
   760
                            self addTypeOfExpressionNode:argExpr forAssignmentTo:nil to:setOfTypes.
6b4ea1b3c1a8 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3928
diff changeset
   761
                        ].                
6b4ea1b3c1a8 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3928
diff changeset
   762
                    ].
6b4ea1b3c1a8 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3928
diff changeset
   763
                ].                
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   764
            ].                
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   765
            setOfTypes notEmpty ifTrue:[
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   766
                ^ setOfTypes.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   767
            ].    
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   768
        ].    
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   769
        ^ nil
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   770
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   771
2191
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   772
"/    node isMessage ifTrue:[
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   773
"/        recClassSet := self guessPossibleImplementorClassesFor:(node receiver) in:code forClass:cls.
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   774
"/        recClassSet isNil ifTrue:[ ^ nil ].
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   775
"/        recClassSet isEmpty ifTrue:[ ^ nil ].
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   776
"/
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   777
"/        implSet := recClassSet collect:[:recClass | recClass whichClassIncludesSelector:node selector].
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   778
"/        "/ toDo: for each implementor, parse its method for possible return types.
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   779
"/        ^ rsltClassSet.
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   780
"/    ].
1731
f10b69e9c3a1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1729
diff changeset
   781
    ^ nil
2809
bbf42cc4d305 changed: #guessPossibleImplementorClassesFor:in:forClass:
Claus Gittinger <cg@exept.de>
parents: 2471
diff changeset
   782
bbf42cc4d305 changed: #guessPossibleImplementorClassesFor:in:forClass:
Claus Gittinger <cg@exept.de>
parents: 2471
diff changeset
   783
    "Modified: / 07-02-2012 / 22:19:53 / cg"
4381
0ba145fd0686 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4378
diff changeset
   784
    "Modified: / 05-03-2019 / 01:09:49 / Claus Gittinger"
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   785
!
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   786
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   787
withWaitCursorDo:aBlock
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   788
    "with wait cursor;
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   789
     however: this class is in libcomp (should be in libtool)
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   790
     so check if WindowGroup (from libview) is present"
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   791
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   792
    |windowGroup wg|
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   793
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   794
    windowGroup := Smalltalk at:#WindowGroup.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   795
    windowGroup notNil ifTrue:[
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   796
        (wg := windowGroup activeGroup) notNil ifTrue:[
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   797
            ^ wg withWaitCursorDo:aBlock.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   798
        ].
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   799
    ].
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
   800
    ^ aBlock value.
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   801
! !
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   802
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   803
!Explainer class methodsFor:'explaining-naive'!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   804
4465
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   805
colorForValue:val
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   806
    val == true ifTrue:[
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   807
        ^ Color darkGreen.
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   808
    ].
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   809
    val == false ifTrue:[
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   810
        ^ Color darkRed
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   811
    ].
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   812
    val == nil ifTrue:[
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   813
        ^ Color darkGrey
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   814
    ].    
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   815
    ^ nil
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   816
!
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   817
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   818
explain:someText in:source forClass:aClassOrNil
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   819
    "Given a source and a substring of it, return a string containing
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   820
     an explanation.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   821
     This is just a q&d implementation - to be correct, it should use the parser,
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   822
     and explain from the parsetree (instead of doing string matches).
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   823
     This leads to some wrong explanations, for example if some string is
839
021af12ebd18 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 835
diff changeset
   824
     used as selector within a string, or if a variable is named like a
021af12ebd18 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 835
diff changeset
   825
     message selector. I.e. the explanation should be context sensitive.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   826
     Also, there could be much more detailed explanations."
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   827
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   828
    ^ self explain:someText in:source forClass:aClassOrNil short:false
2037
003d9b5a2788 explain shared pool variables
Claus Gittinger <cg@exept.de>
parents: 2031
diff changeset
   829
003d9b5a2788 explain shared pool variables
Claus Gittinger <cg@exept.de>
parents: 2031
diff changeset
   830
    "Modified: / 07-06-2007 / 11:34:05 / cg"
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   831
    "Modified (format): / 04-03-2019 / 10:09:46 / Claus Gittinger"
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   832
!
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   833
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   834
explain:someText in:source forClass:aClassOrNil short:shortText
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   835
    "Given a source and a substring of it, return a string containing
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   836
     an explanation.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   837
     This is just a q&d implementation - to be correct, it should use the parser,
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   838
     and explain from the parsetree (instead of doing string matches).
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   839
     This leads to some wrong explanations, for example if some string is
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   840
     used as selector within a string, or if a variable is named like a
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   841
     message selector. I.e. the explanation should be context sensitive.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   842
     Also, there could be much more detailed explanations."
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   843
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   844
    |explainer variables c string explanation tmp1
4187
a315b2137a68 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4177
diff changeset
   845
     spc sym sel stringText cls clsName val valString color|
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   846
675
a2f41004c24d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 509
diff changeset
   847
    string := someText string withoutSeparators.
2314
0c590d9937bd changed: #explain:in:forClass:short:
Claus Gittinger <cg@exept.de>
parents: 2292
diff changeset
   848
    string isEmpty ifTrue:[ ^ nil ].
0c590d9937bd changed: #explain:in:forClass:short:
Claus Gittinger <cg@exept.de>
parents: 2292
diff changeset
   849
2214
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
   850
    stringText := string allBold.
2414
4da315c5bcf4 changed: #explain:in:forClass:short:
Claus Gittinger <cg@exept.de>
parents: 2316
diff changeset
   851
    "/ stringText := '''' , stringText , ''''.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   852
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   853
    "
4465
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   854
     ask instance for variable names
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   855
    "
3070
aceab5843775 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3059
diff changeset
   856
    ParseError catch:[
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   857
        explainer := self parseMethod:source in:aClassOrNil ignoreErrors:true ignoreWarnings:true.
1357
3936e1d64491 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1352
diff changeset
   858
    ].
3320
d7f6dce69619 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3319
diff changeset
   859
    "/ bad leftover from a stupid return value from ancient times
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   860
    explainer == #Error ifTrue:[ explainer := nil ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   861
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   862
    (explainer notNil) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   863
        "look for variables"
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   864
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   865
        variables := explainer methodVars.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   866
        (variables notNil and:[variables includes:string]) ifTrue:[
4465
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   867
            ^ '%1: a method variable' bindWith:stringText
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   868
        ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   869
        variables := explainer methodArgs.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   870
        (variables notNil and:[variables includes:string]) ifTrue:[
4465
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   871
            ^ '%1: a method argument' bindWith:stringText
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   872
        ]
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   873
    ].
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   874
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   875
    explainer isNil ifTrue:[
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   876
        explainer := self for:(ReadStream on:source) in:aClassOrNil
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   877
    ].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   878
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   879
    aClassOrNil notNil ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   880
        "instvars/class instVars"
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   881
        c := aClassOrNil whichClassDefinesInstVar:string.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   882
        c notNil ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   883
            c isMeta ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   884
                clsName := c theNonMetaclass name.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   885
                shortText ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   886
                    clsName := self asClassLink:clsName.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   887
                ].
4465
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   888
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   889
                val := aClassOrNil theNonMetaclass instVarNamed:string.
4435
10a6786b7d87 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4434
diff changeset
   890
                valString := self safeValueStringFor:val.
4465
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   891
                (color := self colorForValue:val) notNil ifTrue:[
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   892
                    stringText := stringText withColor:color.
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   893
                    valString := valString withColor:color. 
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   894
                ].
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   895
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   896
                shortText ifTrue:[
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   897
                    ^ '%1 (%2): class instVar in %3' bindWith:stringText with:valString with:clsName
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   898
                ] ifFalse:[
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   899
                    ^ '%1 (%2): class instance variable inherited from %3' bindWith:stringText with:valString with:clsName
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   900
                ].
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   901
            ].
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   902
            ^ self explainInstanceVariable:string inClass:c short:shortText.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   903
        ].
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   904
    ].
4465
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   905
2986
cb591c4fc915 class: Explainer
Stefan Vogel <sv@exept.de>
parents: 2955
diff changeset
   906
    string isWideString ifFalse:[
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   907
        aClassOrNil notNil ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   908
            "classvars"
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   909
            c := explainer inWhichClassIsClassVar:string.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   910
            c notNil ifTrue:[
4465
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   911
                clsName := c name.
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   912
                shortText ifTrue:[
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   913
                    clsName := self asClassLink:clsName.
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   914
                ].
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   915
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   916
                val := c theNonMetaclass classVarAt:string. "/ Smalltalk at:(clsName , ':' , string) asSymbol.
4435
10a6786b7d87 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4434
diff changeset
   917
                valString := self safeValueStringFor:val.
4465
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   918
                (color := self colorForValue:val) notNil ifTrue:[
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   919
                    stringText := stringText withColor:color.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   920
                    valString := valString withColor:color. 
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   921
                ].
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   922
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   923
                shortText ifTrue:[
4465
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   924
                    ^ '%1 (%2): classVar in %3' bindWith:stringText with:valString with:clsName
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   925
                ] ifFalse:[
4465
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   926
                    ^ '%1 (%2): class variable in %3' bindWith:stringText with:valString with:clsName
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   927
                ].
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   928
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   929
        ].
4465
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   930
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   931
        aClassOrNil notNil ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   932
            "private classes"
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   933
            c := aClassOrNil theNonMetaclass.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   934
            c privateClasses do:[:pClass |
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   935
                (pClass name = string
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   936
                 or:[pClass nameWithoutPrefix = string]) ifTrue:[
4465
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   937
                    stringText := pClass name.
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   938
                    shortText ifTrue:[
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   939
                        stringText := self asClassLink:stringText
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   940
                    ].
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   941
                    clsName := c name.   "/ owning class
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   942
                    shortText ifTrue:[
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   943
                        clsName := self asClassLink:clsName.
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   944
                    ].
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   945
                    stringText := '%1: private class in %2' bindWith:stringText with:clsName.
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   946
                    shortText ifFalse:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   947
                        stringText := (stringText , '\\It is only visible locally.') withCRs
3407
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   948
                    ].
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   949
                    ^ stringText withCRs
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   950
                ].
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   951
            ].
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   952
        ].
4465
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
   953
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   954
        aClassOrNil notNil ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   955
            aClassOrNil theNonMetaclass sharedPoolNames do:[:eachPoolName |
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   956
                |sharedPool sharedPoolSym poolName|
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   957
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   958
                sharedPoolSym := string asSymbolIfInterned.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   959
                sharedPoolSym notNil ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   960
                    sharedPool := Smalltalk classNamed:eachPoolName.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   961
                    sharedPool notNil ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   962
                        sharedPool isSharedPool ifFalse:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   963
                            ^ 'oops - not a shared pool: ',eachPoolName
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   964
                        ].
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   965
                        (sharedPool includesKey:sharedPoolSym) ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   966
                            poolName := sharedPool name.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   967
                            poolName := self asClassLink:eachPoolName.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   968
                            stringText := stringText , ': a pool variable in ',poolName.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   969
                            val := sharedPool at:sharedPoolSym.
4435
10a6786b7d87 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4434
diff changeset
   970
                            valString := self safeValueStringFor:val.
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   971
                            ^ stringText , ' (' , valString , ').'
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   972
                        ].
3407
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   973
                    ].
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   974
                ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   975
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   976
        ].
2037
003d9b5a2788 explain shared pool variables
Claus Gittinger <cg@exept.de>
parents: 2031
diff changeset
   977
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   978
        aClassOrNil notNil ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   979
            "namespace & global variables"
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   980
            (spc := aClassOrNil nameSpace) notNil ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   981
                sym := (spc name , '::' , string) asSymbolIfInterned.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   982
                sym notNil ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   983
                    (cls := Smalltalk at:sym) isBehavior ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   984
                        stringText := self asClassLink:sym.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   985
                        string :=  stringText , ': '.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   986
                        cls name = sym ifFalse:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   987
                            string :=  string , 'refers to ',cls name,', '
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   988
                        ].
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   989
                        cls isSharedPool ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   990
                            string := string , 'a sharedPool'.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   991
                        ] ifFalse:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   992
                            string := string , 'a class'.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   993
                        ].
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   994
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   995
                        string :=  string , ' in the ''' , spc name , ''' nameSpace'.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   996
                        string := string , ' {', (cls category ? '* no category *') ,'}'.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   997
                        shortText ifFalse:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   998
                            string := (string
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
   999
                                 , '\\It is only visible within this nameSpace.'
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1000
                                 , '\Access from the outside is possible'
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1001
                                 , '\by the special name ''' , spc name , '::' , string , '''.') withCRs
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1002
                        ].
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1003
                        ^ string withCRs
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1004
                    ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1005
                ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1006
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1007
        ].
422
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
  1008
3866
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  1009
        "/ string knownAsSymbol ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1010
            "globals & symbols"
839
021af12ebd18 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 835
diff changeset
  1011
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1012
            explanation := self explainKnownSymbol:string inClass:aClassOrNil short:shortText.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1013
            explanation notNil ifTrue:[ 
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1014
                string isBinarySelector ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1015
                    "/ some are both known as syntax AND as selector (for example: #| )
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1016
                    tmp1 := self explainSyntax:string short:shortText.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1017
                    tmp1 notNil ifTrue:[ 
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1018
                        ^ tmp1 , '\\also:\\' withCRs , explanation
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1019
                    ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1020
                ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1021
                ^ explanation
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1022
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1023
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1024
            "/ try with added colon ...
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1025
            sel := string , ':'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1026
            Symbol allInstancesDo:[:sym |
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1027
                (sym startsWith:sel) ifTrue:[
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1028
                    explanation := self explainKnownSymbol:sym inClass:aClassOrNil short:shortText.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1029
                    explanation notNil ifTrue:[ ^ explanation].
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1030
                ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1031
            ].
3866
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  1032
        "/ ].
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
  1033
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1034
        "try for some obvious things"
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1035
        explanation := self explainPseudoVariable:string in:aClassOrNil short:true.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1036
        explanation notNil ifTrue:[ ^ explanation].
2315
45f09cea2063 changed: #explain:in:forClass:short:
Claus Gittinger <cg@exept.de>
parents: 2314
diff changeset
  1037
    ].
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
  1038
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
  1039
    "try syntax ..."
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
  1040
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1041
    explanation := self explainSyntax:string short:shortText.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1042
    explanation notNil ifTrue:[ ^ explanation].
20
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
  1043
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1044
    shortText ifTrue:[
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1045
        |selector|
4465
48abe3471357 #UI_ENHANCEMENT by exept
Claus Gittinger <cg@exept.de>
parents: 4459
diff changeset
  1046
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1047
        (selector := SystemBrowser extractSelectorFrom:string) notNil ifTrue:[
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1048
            selector ~= string string ifTrue:[
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1049
                ^ self explain:selector in:source forClass:aClassOrNil short:shortText    
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1050
            ].    
4177
43a98615134a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4175
diff changeset
  1051
        ]. 
43a98615134a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4175
diff changeset
  1052
        someText size == 1 ifTrue:[
43a98615134a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4175
diff changeset
  1053
            ^ 'no explanation; character encoding: %1 (0x%2)'
43a98615134a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4175
diff changeset
  1054
                    bindWith:someText first codePoint
43a98615134a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4175
diff changeset
  1055
                    with:(someText first codePoint hexPrintString:4)
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1056
        ].    
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1057
        ^ 'no explanation'
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1058
    ].
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1059
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1060
    explainer isNil ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1061
        ^ 'parse error - no explanation'
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
  1062
    ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1063
    ^ 'Sorry, I cannot explain this (could not figure out what this is).
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1064
Please try again with an individual token selected.'
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
  1065
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
  1066
    "Created: / 03-12-1995 / 12:47:37 / cg"
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
  1067
    "Modified: / 16-04-1997 / 12:46:11 / stefan"
4187
a315b2137a68 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4177
diff changeset
  1068
    "Modified: / 23-08-2017 / 12:44:12 / cg"
4435
10a6786b7d87 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4434
diff changeset
  1069
    "Modified: / 08-06-2019 / 14:04:00 / Claus Gittinger"
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
  1070
!
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
  1071
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1072
explainGlobal:string inClass:aClassOrNil short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1073
    "return an explanation or nil"
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1074
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1075
    ^ self explainGlobalOrPoolVariable:string inClass:aClassOrNil short:shortText
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1076
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1077
    "Modified: / 14-10-2010 / 11:33:17 / cg"
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1078
    "Modified (comment): / 28-02-2012 / 10:45:58 / cg"
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1079
    "Modified (format): / 04-03-2019 / 10:09:52 / Claus Gittinger"
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1080
!
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1081
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1082
explainGlobalOrPoolVariable:varName inClass:aClassOrNil short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1083
    "return an explanation or nil"
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1084
4367
edd71d52065f #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4357
diff changeset
  1085
    |template shortTemplate bindings
3972
f87c3c8f747a #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 3940
diff changeset
  1086
     sym explanation val pool valText doc|
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1087
3878
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  1088
    "if not even known as key, it's definitely not a global"
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  1089
    sym := varName asSymbolIfInterned.
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1090
    sym isNil ifTrue:[^ nil].
3879
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1091
       
4367
edd71d52065f #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4357
diff changeset
  1092
    template := shortTemplate := nil.
3879
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1093
    bindings := Dictionary new.
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1094
    
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1095
    "a pool variable?"
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1096
    aClassOrNil notNil ifTrue:[
4454
4e682b3abdae #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4448
diff changeset
  1097
        |nonMeta|
4e682b3abdae #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4448
diff changeset
  1098
4e682b3abdae #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4448
diff changeset
  1099
        nonMeta := aClassOrNil theNonMetaclass.
4e682b3abdae #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4448
diff changeset
  1100
        nonMeta sharedPoolNames do:[:eachPoolName |
4e682b3abdae #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4448
diff changeset
  1101
            pool := nonMeta nameSpace isNameSpace
4e682b3abdae #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4448
diff changeset
  1102
                    ifTrue:[nonMeta nameSpace at:eachPoolName]
4e682b3abdae #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4448
diff changeset
  1103
                    ifFalse:[nonMeta topNameSpace at:eachPoolName].
4367
edd71d52065f #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4357
diff changeset
  1104
            pool isNil ifTrue:[
edd71d52065f #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4357
diff changeset
  1105
                pool := Smalltalk at:eachPoolName.
edd71d52065f #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4357
diff changeset
  1106
            ].    
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1107
            pool isNil ifTrue:[
3878
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  1108
                "/ oops - on the fly we encountered a non existing pool...
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1109
            ] ifFalse:[
3878
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  1110
                (pool classVarNames includes:varName) ifTrue:[
3879
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1111
                    template := '%(varName): pool variable in "%(poolName)"'.
4367
edd71d52065f #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4357
diff changeset
  1112
                    shortTemplate := '%1 in pool "%2"' bindWith:varName with:eachPoolName.   
3879
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1113
                    bindings at:'poolName' put:eachPoolName.                    
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1114
                    val := pool classVarAt:sym.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1115
                ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1116
            ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1117
        ].
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1118
    ].
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1119
3879
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1120
    bindings at:'varName' put:varName allBold.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1121
3879
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1122
    template isNil ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1123
        "try globals"
3879
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1124
        (Smalltalk includesKey:sym) ifFalse:[
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1125
            ^ '%(varName): an undefined variable.' bindWithArguments:bindings.
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1126
        ].    
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1127
        template := '%(varName): global'.
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1128
        val := Smalltalk at:sym.
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1129
    ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1130
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
  1131
    val isBehavior ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1132
        "/ a class
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1133
        val name = sym ifFalse:[
3879
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1134
            "/ an alias (such as OperatingSystem, Screen etc.)
4040
59634354b0c5 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4032
diff changeset
  1135
            template := template,'. Refers to %(realName)'.
3879
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1136
            bindings at:'realName' put:val name.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1137
        ].
1979
847742bcb22d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1943
diff changeset
  1138
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1139
        (val isRealNameSpace) ifTrue:[
3879
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1140
            template := template,', a namespace.'.
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1141
            ^ template bindWithArguments:bindings.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1142
        ].
3879
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1143
        
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1144
        "/ a real class
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1145
        bindings at:'category' put:(val category ? 'uncategorized').
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1146
        shortText ifTrue:[
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1147
            template := template , ',' , (val isLoaded ifTrue:[' a'] ifFalse:[' an autoloaded']).
3879
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1148
            template := template , (val isSharedPool ifTrue:[' pool'] ifFalse:[' class']).
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1149
            template := template , ' in %(package) {%(category)}.'.
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1150
            bindings at:'package' put:val package.
4040
59634354b0c5 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4032
diff changeset
  1151
            bindings at:'varName' put:(self asClassLink:varName "val name").
3879
a8813df85e98 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3878
diff changeset
  1152
            ^ template bindWithArguments:bindings
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1153
        ].
1330
100f022924b6 oops - care for namespaces
ca
parents: 1317
diff changeset
  1154
3878
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  1155
        val name = varName ifTrue:[
3322
c4dfa6cff14b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3321
diff changeset
  1156
            false ifTrue:[
c4dfa6cff14b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3321
diff changeset
  1157
                "/ TODO: generate a short documentation string (comment plus interface)
c4dfa6cff14b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3321
diff changeset
  1158
                "/ and return { #html->htmlText . #text->regularText}
3972
f87c3c8f747a #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 3940
diff changeset
  1159
                "/ so caller can extract what he wants to see...
3322
c4dfa6cff14b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3321
diff changeset
  1160
                ^ (HTMLDocGenerator htmlDocOf:val).
c4dfa6cff14b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3321
diff changeset
  1161
            ].
3972
f87c3c8f747a #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 3940
diff changeset
  1162
            explanation := varName , ' is '.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1163
            explanation := explanation , (val isLoaded ifTrue:['a'] ifFalse:['an autoloaded']).
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1164
            explanation := explanation , (val isSharedPool ifTrue:[' sharedPool'] ifFalse:[' class']).
3972
f87c3c8f747a #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 3940
diff changeset
  1165
            explanation := explanation , ' categorized as "' , val category , '"'.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1166
            explanation := explanation , '\' withCRs , 'in the "' , val package , '" package.'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1167
            (doc := val commentOrDocumentationString) notEmptyOrNil ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1168
                doc := doc asStringCollection.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1169
                doc size > 25 ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1170
                    doc := doc copyTo:25.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1171
                    doc add:''; add:'   ... <more documentation cut off>'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1172
                ].
3864
eaf361535167 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3861
diff changeset
  1173
                doc := doc asString withColor:(UserPreferences current commentColor).
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1174
                explanation := explanation,'\\' withCRs,val name,'''s documentation:\'withCRs, doc
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1175
            ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1176
            ^ explanation.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1177
        ].
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
  1178
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1179
        explanation := explanation , '
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1180
3878
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  1181
' , varName , ' is bound to the class ' , val name ,
3972
f87c3c8f747a #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 3940
diff changeset
  1182
' in the "' , val category , '" category.'.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1183
        ^ explanation.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1184
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1185
4435
10a6786b7d87 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4434
diff changeset
  1186
    valText := self safeValueStringFor:val.
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1187
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
  1188
    shortText ifTrue:[
4367
edd71d52065f #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4357
diff changeset
  1189
        ^ (shortTemplate ? '%1: a global (%2)') 
3881
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1190
            bindWith:varName 
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1191
            with:(self asLink:valText to:(self actionToBrowseClass:val class selector:nil))
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
  1192
    ].
3881
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1193
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1194
    explanation := explanation , '
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
  1195
2466
75b29e4a34c0 changed: #explainGlobalOrPoolVariable:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2427
diff changeset
  1196
Its current value is "%1".' bindWith:valText.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1197
    ^ explanation.
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
  1198
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1199
    "Created: / 14-10-2010 / 11:33:04 / cg"
4040
59634354b0c5 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4032
diff changeset
  1200
    "Modified: / 16-11-2016 / 13:08:07 / cg"
4454
4e682b3abdae #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4448
diff changeset
  1201
    "Modified: / 30-06-2019 / 03:46:10 / Claus Gittinger"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1202
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1203
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1204
explainHereIn:aClassOrNil short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1205
    "return an explanation"
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1206
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1207
    |className|
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1208
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1209
    aClassOrNil isNil ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1210
        shortText ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1211
            ^ '"here" - message lookup always starts in the method''s class (always call local method).'
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1212
        ].
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1213
        ^ 'like "self", "','here'allBold,'" refers to the object which received the message.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1214
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1215
However, when sending a message to "here", the search for methods
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1216
implementing this message will start in the defining class,
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1217
instead of the receiver''s class.
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1218
Thus, using "here", redefined methods will NOT be reached with a here-send and it is ensured,
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1219
that the local method is called.'
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1220
    ].
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1221
    
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1222
    className := aClassOrNil name.
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1223
    shortText ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1224
        ^ '"here" - message lookup always starts in "%1" (always call local method).' bindWith:className
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1225
    ].
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1226
    ^ 'like "self", "','here'allBold,'" refers to the object which received the message.
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1227
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1228
However, when sending a message to "here", the search for methods
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1229
implementing this message will start in the defining class (' , className , '),
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1230
instead of the receiver''s class (' , className , ' or subclass).
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1231
Thus, using "here", redefined methods will NOT be reached with a here-send and it is ensured,
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1232
that the local method is called.'
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1233
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1234
    "Created: / 28-02-2012 / 10:44:55 / cg"
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1235
    "Modified: / 04-03-2019 / 10:14:00 / Claus Gittinger"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1236
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1237
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1238
explainInstanceVariable:instVarName inClass:aClass short:shortText
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1239
    |varNameInText classNameInText template stringText setOfTypes typesDescription|
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1240
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1241
    aClass isNil ifTrue:[^ nil].
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1242
    
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1243
    varNameInText := instVarName allBold.
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1244
    classNameInText := aClass name.
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1245
    
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1246
    shortText ifTrue:[
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1247
        template := '%1: instVar in %2'.
3878
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  1248
        varNameInText := self 
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  1249
                            asLink:varNameInText 
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  1250
                            info:('Click to browse references to %1' bindWith:instVarName)
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  1251
                            to:(self actionToBrowseInstvarRefsTo:instVarName inClass:aClass).
3866
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  1252
        classNameInText := self asClassLink:classNameInText.
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1253
    ] ifFalse:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1254
        template := '%1: an instance variable in %2'
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1255
    ].
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1256
    stringText := template bindWith:varNameInText with:classNameInText.
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1257
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1258
    "/ look for instances
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1259
    setOfTypes := IdentitySet new.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1260
    self addTypesOfInstvar:instVarName inClass:aClass fromExistingInstancesTo:setOfTypes.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1261
    "/ look for assignments
3878
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  1262
    aClass withAllSubclassesDo:[:cls | 
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  1263
        self addTypesAssignedToInstvar:instVarName inClass:cls to:setOfTypes
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  1264
    ].
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  1265
    
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  1266
    "/ generate a list of up-to 3 links
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1267
    typesDescription := self typeDescriptionFor:setOfTypes andSelector:nil.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1268
    typesDescription notNil ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1269
        stringText := stringText,' (',typesDescription,')'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1270
    ].
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1271
    ^ stringText
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1272
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1273
    "Modified: / 04-03-2019 / 10:14:32 / Claus Gittinger"
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1274
!
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1275
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1276
explainKnownSymbol:string inClass:aClass
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1277
    "return an explanation or nil"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1278
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1279
    ^ self explainKnownSymbol:string inClass:aClass short:false
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1280
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1281
    "Modified (comment): / 28-02-2012 / 10:45:40 / cg"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1282
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1283
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1284
explainKnownSymbol:string inClass:aClassOrNil short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1285
    "return an explanation or nil"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1286
2471
2d80a20bde1c changed:
Claus Gittinger <cg@exept.de>
parents: 2470
diff changeset
  1287
    |sym expl|
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1288
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1289
    sym := string asSymbolIfInterned.
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1290
    sym isNil ifTrue:[^ nil].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1291
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1292
    "try globals and pools"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1293
    (Smalltalk includesKey:sym) ifTrue:[
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1294
        expl := self explainGlobalOrPoolVariable:string inClass:aClassOrNil short:shortText.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1295
        expl notNil ifTrue:[^ expl].
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1296
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1297
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1298
    expl := self explainSelector:string inClass:aClassOrNil short:shortText.
2471
2d80a20bde1c changed:
Claus Gittinger <cg@exept.de>
parents: 2470
diff changeset
  1299
    expl notNil ifTrue:[^ expl].
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1300
    ^ self explainGlobalOrPoolVariable:string inClass:aClassOrNil short:shortText.
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1301
2471
2d80a20bde1c changed:
Claus Gittinger <cg@exept.de>
parents: 2470
diff changeset
  1302
    "Modified: / 18-01-2011 / 19:13:07 / cg"
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1303
    "Modified (comment): / 28-02-2012 / 10:46:06 / cg"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1304
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1305
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1306
explainPseudoVariable:string in:aClass
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1307
    "return an explanation for the pseudoVariables self, super etc."
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1308
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1309
    <resource: #obsolete>
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1310
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1311
    ^ self explainPseudoVariable:string in:aClass short:false
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1312
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1313
    "Modified (format): / 28-02-2012 / 10:47:17 / cg"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1314
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1315
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1316
explainPseudoVariable:string in:aClassOrNil short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1317
    "return an explanation for the pseudoVariables self, super etc."
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1318
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1319
    (string = 'self') ifTrue:[
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1320
        ^ self explainSelfIn:aClassOrNil short:shortText
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1321
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1322
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1323
    (string = 'super') ifTrue:[
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1324
        ^ self explainSuperIn:aClassOrNil short:shortText
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1325
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1326
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1327
    (string = 'here') ifTrue:[
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1328
        ^ self explainHereIn:aClassOrNil short:shortText
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1329
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1330
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1331
    (string = 'thisContext') ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1332
        shortText ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1333
            ^ '''thisContext'' - the current stack frame as an object.'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1334
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1335
        ^ 'thisContext is a pseudo variable (i.e. it is built in).
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1336
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1337
ThisContext always refers to the context object for the currently executed method or
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1338
block (an instance of Context or BlockContext respectively). The calling chain and calling
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1339
receivers/selectors can be accessed via thisContext.'
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1340
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1341
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1342
    (string = 'true') ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1343
        shortText ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1344
            ^ '''true'' - the truth and nothing but the truth.'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1345
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1346
        ^ 'true is a pseudo variable (i.e. it is built in).
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1347
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1348
True represents logical truth. It is the one and only instance of class True.'
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1349
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1350
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1351
    (string = 'false') ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1352
        shortText ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1353
            ^ '''false'' - obvisously not true.'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1354
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1355
        ^ 'false is a pseudo variable (i.e. it is built in).
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1356
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1357
False represents logical falseness. It is the one and only instance of class False.'
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1358
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1359
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1360
    (string = 'nil') ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1361
        shortText ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1362
            ^ '''nil'' - undefined, unknown, void or dont care.'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1363
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1364
        ^ 'nil is a pseudo variable (i.e. it is built in).
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1365
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1366
Nil is used for unitialized variables (among other uses).
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1367
Nil is the one and only instance of class UndefinedObject.'
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1368
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1369
    ^ nil
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1370
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1371
    "Modified (comment): / 28-02-2012 / 10:46:18 / cg"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1372
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1373
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1374
explainSelector:string inClass:aClassOrNil short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1375
    "return an explanation or nil"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1376
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1377
    |selector listOfImplementingClasses listOfImplementingClassNames listOfSimilarSelectors
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1378
     firstImplementingClassOfSimilar count tmp commonSuperClass s s2
4143
821161064375 #DOCUMENTATION by mawalch
mawalch
parents: 4110
diff changeset
  1379
     firstImplementingClass
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1380
     firstImplementingClassName secondImplementingClassName thirdImplementingClassName
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1381
     classProvidingComment
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1382
     cm msg t check|
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1383
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1384
    selector := string asSymbolIfInterned.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1385
    selector isNil ifTrue:[^ nil].
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1386
4143
821161064375 #DOCUMENTATION by mawalch
mawalch
parents: 4110
diff changeset
  1387
    "/ look who implements it
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1388
    listOfImplementingClassNames := Set new.
3174
e3e1c0bde329 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3156
diff changeset
  1389
    listOfImplementingClasses := Set new.
e3e1c0bde329 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3156
diff changeset
  1390
    listOfSimilarSelectors := Set new.
2288
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1391
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1392
    check :=
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1393
        [:sel :mthd :cls |
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1394
            sel == selector ifTrue:[
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1395
                listOfImplementingClasses add:cls.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1396
                listOfImplementingClassNames add:(cls name).
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1397
                firstImplementingClass isNil ifTrue:[
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1398
                    firstImplementingClass := cls.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1399
                    firstImplementingClassName := cls name.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1400
                ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1401
            ] ifFalse:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1402
                (sel startsWith:selector) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1403
                    listOfSimilarSelectors add:sel.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1404
                    firstImplementingClassOfSimilar isNil ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1405
                        firstImplementingClassOfSimilar := cls
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1406
                    ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1407
                ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1408
            ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1409
        ].
2288
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1410
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1411
    Smalltalk allClassesDo:[:c|
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1412
        c methodDictionary keysAndValuesDo:[:sel :mthd |
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1413
            check value:sel value:mthd value:c
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1414
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1415
        c class methodDictionary keysAndValuesDo:[:sel :mthd |
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1416
            check value:sel value:mthd value:c class
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1417
        ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1418
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1419
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1420
    (aClassOrNil notNil and:[aClassOrNil canUnderstand:selector]) ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1421
        s2 := ('Instances of ''' , aClassOrNil name , ''' respond to #') , selector "allBold" , '.'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1422
        shortText ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1423
            s2 := '\\' , s2
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1424
                  , '\- inherited from ' withCRs
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1425
                  , (aClassOrNil whichClassIncludesSelector:selector) name "allBold".
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1426
        ].
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1427
        firstImplementingClass := (aClassOrNil whichClassIncludesSelector:selector)
835
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
  1428
    ] ifFalse:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1429
        s2 := ''.
835
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
  1430
    ].
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
  1431
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1432
    count := listOfImplementingClassNames size.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1433
    (count ~~ 0) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1434
        "
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1435
         for up-to 4 implementing classes,
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1436
         list them
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1437
        "
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1438
        listOfImplementingClassNames := listOfImplementingClassNames asOrderedCollection sort.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1439
        shortText ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1440
            tmp := ' is implemented in '.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1441
        ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1442
            tmp := ' is a selector implemented in '.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1443
        ].
3881
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1444
        "/ s := string allBold.
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  1445
        count > 1 ifTrue:[
3881
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1446
            s := self asLink:selector to:(self actionToOpenMethodFinderFor:selector).
4143
821161064375 #DOCUMENTATION by mawalch
mawalch
parents: 4110
diff changeset
  1447
        ] ifFalse:[
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  1448
            s := self asLink:selector to:(self actionToBrowseClass:listOfImplementingClasses first selector:selector).
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1449
        ].
4143
821161064375 #DOCUMENTATION by mawalch
mawalch
parents: 4110
diff changeset
  1450
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1451
        shortText ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1452
            |typesDescription|
4143
821161064375 #DOCUMENTATION by mawalch
mawalch
parents: 4110
diff changeset
  1453
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1454
            msg := s , tmp.
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1455
            typesDescription := self typeDescriptionFor:listOfImplementingClasses andSelector:selector wordBetween:'and'.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1456
            typesDescription notNil ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1457
                msg := msg,typesDescription
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1458
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1459
        ] ifFalse:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1460
            (count == 1) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1461
                t := firstImplementingClassName.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1462
                firstImplementingClass isMeta ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1463
                    t := 'the ' , t
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1464
                ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1465
                msg := s , tmp , t , '.'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1466
                shortText ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1467
                    msg := msg , s2.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1468
                ]
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1469
            ] ifFalse:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1470
                firstImplementingClassName := listOfImplementingClassNames at:1.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1471
                secondImplementingClassName := listOfImplementingClassNames at:2.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1472
                (count == 2) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1473
                    msg := s,tmp,firstImplementingClassName,' and ',secondImplementingClassName,'.'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1474
                    shortText ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1475
                        msg := msg , s2.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1476
                    ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1477
                ] ifFalse:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1478
                    thirdImplementingClassName := listOfImplementingClassNames at:3.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1479
                    (count == 3) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1480
                        msg := s,tmp,firstImplementingClassName,',',secondImplementingClassName,' and ',thirdImplementingClassName,'.'.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1481
                        shortText ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1482
                            msg := msg , s2.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1483
                        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1484
                    ] ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1485
                        false "shortText" ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1486
                            msg := s , tmp , count printString , ' classes'.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1487
                            commonSuperClass := Class commonSuperclassOf:listOfImplementingClassNames.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1488
                            commonSuperClass notNil ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1489
                                (commonSuperClass == Object
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1490
                                and:[commonSuperClass includesSelector:selector]) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1491
                                    msg := msg , ' (including ' , 'Object' "allBold", ')'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1492
                                ] ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1493
                                    (commonSuperClass ~= Object) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1494
                                        msg := msg , ' (under ' , commonSuperClass name, ')'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1495
                                    ]
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1496
                                ].
3492
1867a7dfc26f class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3464
diff changeset
  1497
                            ].
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1498
                            msg := msg , '.'.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1499
                            ^ msg
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1500
                        ].
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1501
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1502
                        "
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1503
                         if there are more, look for a common
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1504
                         superclass and show it ...
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1505
                        "
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1506
                        commonSuperClass := (Behavior commonSuperclassOf:listOfImplementingClasses) ? Object.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1507
                        (commonSuperClass ~~ Object
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1508
                        and:[commonSuperClass ~~ Behavior
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1509
                        and:[commonSuperClass ~~ Class
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1510
                        and:[commonSuperClass ~~ ClassDescription]]]) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1511
                            (listOfImplementingClasses includes:commonSuperClass) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1512
                                msg := s . tmp , count printString , commonSuperClass name
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1513
                                         , ' and redefined in ' , (count - 1) printString
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1514
                                         , ' subclasses'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1515
                                         , s2.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1516
                                firstImplementingClass := commonSuperClass
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1517
                            ] ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1518
                                msg := s , tmp, count printString , ' subclasses of ' , commonSuperClass name , s2
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1519
                            ]
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1520
                        ] ifFalse:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1521
                            (commonSuperClass == Object
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1522
                            and:[commonSuperClass includesSelector:selector]) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1523
                                shortText ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1524
                                    msg := s , tmp , count printString , ' classes (incl. Object)'.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1525
                                ] ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1526
                                    msg := s , tmp , count printString , ' classes.
4143
821161064375 #DOCUMENTATION by mawalch
mawalch
parents: 4110
diff changeset
  1527
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1528
All objects seem to respond to that message,
911
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
  1529
since there is an implementation in Object.' , s2.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1530
                                ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1531
                                firstImplementingClass := Object
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1532
                            ] ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1533
                                ((commonSuperClass == Behavior
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1534
                                 or:[commonSuperClass == Class
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1535
                                 or:[commonSuperClass == ClassDescription]])
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1536
                                and:[commonSuperClass includesSelector:selector]) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1537
                                    shortText ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1538
                                        msg := s , tmp , count printString , ' classes (incl. all classes)'.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1539
                                    ] ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1540
                                        msg := s , tmp , count printString , ' classes.
913
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
  1541
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1542
All classes seem to respond to that message,
913
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
  1543
since there is an implementation in ' , commonSuperClass name , '.' , s2.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1544
                                    ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1545
                                    firstImplementingClass := commonSuperClass
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1546
                                ] ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1547
                                    "
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1548
                                     otherwise just give the number.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1549
                                    "
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1550
                                    msg := s , tmp , count printString , ' classes.' , s2
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1551
                                ]
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1552
                            ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1553
                        ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1554
                    ]
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1555
                ].
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1556
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1557
        ].
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1558
        "/ look for a comment...
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1559
        count == 1 ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1560
            classProvidingComment := firstImplementingClass.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1561
        ] ifFalse:[
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1562
            commonSuperClass isNil ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1563
                commonSuperClass := Behavior commonSuperclassOf:listOfImplementingClasses.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1564
            ] .
4100
2cb9290bd5dc #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4060
diff changeset
  1565
4143
821161064375 #DOCUMENTATION by mawalch
mawalch
parents: 4110
diff changeset
  1566
            ((listOfImplementingClasses includes:commonSuperClass)
4100
2cb9290bd5dc #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4060
diff changeset
  1567
              and:[ (commonSuperClass implements:selector) ]
2cb9290bd5dc #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4060
diff changeset
  1568
            ) ifTrue:[
2cb9290bd5dc #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4060
diff changeset
  1569
                classProvidingComment := commonSuperClass
2cb9290bd5dc #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4060
diff changeset
  1570
            ] ifFalse:[
4143
821161064375 #DOCUMENTATION by mawalch
mawalch
parents: 4110
diff changeset
  1571
                "/ avoid some obvious misleading paths...
821161064375 #DOCUMENTATION by mawalch
mawalch
parents: 4110
diff changeset
  1572
                classProvidingComment := { Number . Collection . Stream . View }
4100
2cb9290bd5dc #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4060
diff changeset
  1573
                                            detect:[:cls | (listOfImplementingClasses includes:cls)
2cb9290bd5dc #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4060
diff changeset
  1574
                                                           or:[cls canUnderstand:selector]  ]
2cb9290bd5dc #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4060
diff changeset
  1575
                                            ifNone:nil.
2cb9290bd5dc #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4060
diff changeset
  1576
                classProvidingComment notNil ifTrue:[
2cb9290bd5dc #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4060
diff changeset
  1577
                    classProvidingComment := classProvidingComment whichClassImplements:selector.
4143
821161064375 #DOCUMENTATION by mawalch
mawalch
parents: 4110
diff changeset
  1578
                ] ifFalse:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1579
                    classProvidingComment := firstImplementingClass.
4143
821161064375 #DOCUMENTATION by mawalch
mawalch
parents: 4110
diff changeset
  1580
                    [
4100
2cb9290bd5dc #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4060
diff changeset
  1581
                        classProvidingComment superclass notNil
2cb9290bd5dc #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4060
diff changeset
  1582
                        and:[ classProvidingComment superclass implements:selector ]
2cb9290bd5dc #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4060
diff changeset
  1583
                    ] whileTrue:[
2cb9290bd5dc #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4060
diff changeset
  1584
                        classProvidingComment := classProvidingComment superclass
2cb9290bd5dc #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4060
diff changeset
  1585
                    ].
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1586
                ].
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1587
            ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1588
        ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1589
        classProvidingComment notNil ifTrue:[
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  1590
            cm := self fetchDescriptionOfMethod:"fetchCommentOfMethod:"(classProvidingComment compiledMethodAt:selector).
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1591
        ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1592
        cm isNil ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1593
            "/ should: find the class with most subclasses from the list
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1594
            (listOfImplementingClasses includes:Collection) ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1595
                classProvidingComment := Collection
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1596
            ] ifFalse:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1597
                (listOfImplementingClasses includes:Stream) ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1598
                    classProvidingComment := Stream
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1599
                ] ifFalse:[
4143
821161064375 #DOCUMENTATION by mawalch
mawalch
parents: 4110
diff changeset
  1600
                    classProvidingComment := listOfImplementingClasses
821161064375 #DOCUMENTATION by mawalch
mawalch
parents: 4110
diff changeset
  1601
                            detect:[:cls |
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1602
                                |mthd|
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1603
                                (mthd := cls compiledMethodAt:selector) notNil
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  1604
                                and:[ (self fetchCommentOfMethod:mthd) notNil]]
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1605
                            ifNone:nil.
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1606
                ]
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1607
            ].
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1608
            cm isNil ifTrue:[
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1609
                classProvidingComment notNil ifTrue:[
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  1610
                    cm := self fetchDescriptionOfMethod:(classProvidingComment compiledMethodAt:selector).
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1611
                ]
4143
821161064375 #DOCUMENTATION by mawalch
mawalch
parents: 4110
diff changeset
  1612
            ].
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1613
        ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1614
        cm notNil ifTrue:[
4273
08a8c063cc93 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4269
diff changeset
  1615
            cm := ('%1 says:\' withCRs bindWith:(self asClassLink:classProvidingComment name)),cm.
4143
821161064375 #DOCUMENTATION by mawalch
mawalch
parents: 4110
diff changeset
  1616
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1617
            "/ msg := msg,(msg last isSeparator ifTrue:[''] ifFalse:[' ']),cm
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1618
            msg := msg,(Character cr),cm
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1619
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1620
        ^ msg
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1621
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1622
3881
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1623
    "/ none implements it (typo?);
3174
e3e1c0bde329 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3156
diff changeset
  1624
    count := listOfSimilarSelectors size.
2288
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1625
    (count ~~ 0) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1626
        listOfSimilarSelectors := listOfSimilarSelectors asOrderedCollection sort.
2288
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1627
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1628
        (count == 1) ifTrue:[
3881
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1629
            |sel selLink clsLink implementors|
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1630
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1631
            sel := listOfSimilarSelectors first.
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1632
            selLink := self asLink:sel to:(self actionToOpenMethodFinderFor:sel).
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1633
            "/ clsLink := self asLink:firstImplementingClassOfSimilar name to:(self actionToBrowseClass:firstImplementingClassOfSimilar selector:sel).
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1634
            implementors := Smalltalk allImplementorsOf:sel.
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1635
            clsLink := self typeDescriptionFor:implementors andSelector:sel.
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1636
            msg := selLink , ' is implemented in ' , clsLink , '.'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1637
            shortText ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1638
                msg := msg , s2.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1639
            ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1640
        ] ifFalse:[
3881
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1641
            |sel1 sel2|
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1642
            sel1 := listOfSimilarSelectors first.
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1643
            sel2 := listOfSimilarSelectors second.
4143
821161064375 #DOCUMENTATION by mawalch
mawalch
parents: 4110
diff changeset
  1644
            msg := 'similar selectors: %1, %2'
821161064375 #DOCUMENTATION by mawalch
mawalch
parents: 4110
diff changeset
  1645
                        bindWith:(self asLink:sel1 to:(self actionToOpenMethodFinderFor:sel1))
3881
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1646
                        with:(self asLink:sel2 to:(self actionToOpenMethodFinderFor:sel1)).
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1647
            count > 2 ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1648
                msg := msg,'...'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1649
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1650
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1651
        ^ msg
2288
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1652
    ].
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1653
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1654
    ^ nil
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
  1655
1909
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
  1656
    "Modified: / 17-06-1996 / 17:09:30 / stefan"
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
  1657
    "Created: / 23-03-1999 / 13:29:33 / cg"
3804
f1ad0e2b65f8 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3801
diff changeset
  1658
    "Modified: / 01-05-2016 / 15:42:24 / cg"
4143
821161064375 #DOCUMENTATION by mawalch
mawalch
parents: 4110
diff changeset
  1659
    "Modified: / 22-05-2017 / 11:35:31 / mawalch"
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1660
    "Modified: / 04-03-2019 / 10:16:07 / Claus Gittinger"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1661
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1662
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1663
explainSelfIn:aClassOrNil short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1664
    "return an explanation"
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1665
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1666
    |subClasses subNames selfString className nSubClasses 
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1667
     classLink classLink2 subclassesLink|
1198
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
  1668
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
  1669
    selfString := '''' , 'self' "allBold" , ''''.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1670
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1671
    aClassOrNil isNil ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1672
        ^ selfString , 'refers to the object which received the message.'
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1673
    ].
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1674
    
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1675
    subClasses := aClassOrNil allSubclasses.
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1676
    nSubClasses := subClasses size.
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1677
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1678
    aClassOrNil isMeta ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1679
        className := aClassOrNil theNonMetaclass name.
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1680
        subNames := subClasses collect:[:c | c theNonMetaclass name].
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1681
        shortText ifTrue:[
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1682
            classLink := (self asClassLink:className).
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1683
            nSubClasses == 0 ifTrue:[
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1684
                ^ selfString , (' - the %1 class.' bindWith:classLink)
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1685
            ].
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1686
            nSubClasses == 1 ifTrue:[
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1687
                classLink2 := self asClassLink:subNames first.
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1688
                ^ selfString , (' - the %1- or %2 class.' bindWith:classLink with:classLink2)
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1689
            ].
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1690
            subclassesLink := self 
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1691
                        asLink:('%1 subclasses' bindWith:nSubClasses)  
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1692
                        info:('Click to browse subclasses')    
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1693
                        to:(self actionToBrowseClasses:subClasses). 
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1694
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1695
            ^ selfString , (' - the %1 class or one of its %2.' bindWith:classLink with:subclassesLink)
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1696
        ].
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1697
        
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1698
        nSubClasses == 0 ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1699
            ^ selfString , 'refers to the object which received the message.
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1700
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1701
In this case, it will be the ' , className , '-class itself.'
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1702
        ].
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1703
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1704
        nSubClasses <= 5 ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1705
            ^ selfString , ' refers to the object which received the message.
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1706
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1707
In this case, it will be the ' , className , '-class
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1708
or one of its subclasses:
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1709
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1710
' , subNames asStringCollection asString
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1711
        ].
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1712
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1713
        ^ selfString , ' refers to the object which received the message.
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1714
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1715
In this case, it will be the ' , className , '-class
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1716
or one of its ' , nSubClasses printString , ' subclasses.'
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1717
    ].
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1718
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1719
    subClasses := aClassOrNil allSubclasses.
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1720
    subNames := subClasses collect:[:c | c theNonMetaclass name].
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1721
    className := aClassOrNil name.
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1722
    shortText ifTrue:[
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1723
        classLink := self asClassLink:className.
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1724
        nSubClasses == 0 ifTrue:[
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1725
            ^ selfString , (' - an instance of %1.' bindWith:classLink)
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1726
        ].
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1727
        nSubClasses == 1 ifTrue:[
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1728
            classLink2 := self asClassLink:subNames first.
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1729
            ^ selfString , (' - an instance of %1 or %2.' bindWith:classLink with:classLink2)
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1730
        ].
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1731
        subclassesLink := self 
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1732
                    asLink:('%1 subclasses' bindWith:nSubClasses)  
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1733
                    info:('Click to browse subclasses')    
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1734
                    to:(self actionToBrowseClasses:subClasses). 
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1735
        ^ selfString , (' - an instance of %1 or one of its %2.' bindWith:classLink with:subclassesLink)
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1736
    ].
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1737
    
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1738
    nSubClasses == 0 ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1739
        ^ selfString , 'refers to the object which received the message.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1740
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1741
In this case, it will be an instance of ' , className , '.'
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1742
    ].
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1743
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1744
    nSubClasses <= 5 ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1745
        ^ selfString , ' refers to the object which received the message.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1746
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1747
In this case, it will be an instance of ' , className , '
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1748
or one of its subclasses:
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1749
1256
cc3fa02585ec *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
  1750
' , subNames asStringCollection asString
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1751
    ].
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1752
1198
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
  1753
    ^ selfString , ' refers to the object which received the message.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1754
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1755
In this case, it will be an instance of ' , className , '
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1756
or one of its ' , nSubClasses printString , ' subclasses.'
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
  1757
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
  1758
    "Modified: / 09-10-2006 / 12:11:44 / cg"
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1759
    "Modified (comment): / 28-02-2012 / 10:47:06 / cg"
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1760
!
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1761
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1762
explainSuperIn:aClassOrNil short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1763
    "return an explanation"
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1764
1352
e9e91394ca1a Remove unused method variables
Stefan Vogel <sv@exept.de>
parents: 1331
diff changeset
  1765
    |superName|
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1766
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1767
    aClassOrNil isNil ifTrue:[
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1768
        ^ '"super" - message lookup starts in superclass (call redefined method).'
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1769
    ].
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1770
    
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1771
    superName := aClassOrNil superclass name.
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1772
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1773
    shortText ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1774
        ^ '"super" - message lookup starts in superclass "%1" (call redefined method).' bindWith:(self asClassLink:superName)
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1775
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1776
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1777
    ^ 'like "self", "','super'allBold,'" refers to the object which received the message.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1778
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1779
However, when sending a message to "super", the search for methods
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1780
implementing this message will start in the superclass (' , superName , '),
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1781
instead of the receiver''s class (' , aClassOrNil name , ' or subclass).
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1782
Thus, using "super", a redefined method can call the original (redefined) method of its superclass.'
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1783
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1784
    "Modified (comment): / 28-02-2012 / 10:47:03 / cg"
4378
1558b65aad41 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4376
diff changeset
  1785
    "Modified: / 04-03-2019 / 10:17:44 / Claus Gittinger"
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1786
!
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
  1787
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1788
explainSyntax:string
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1789
    "try syntax ...; return explanation or nil"
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1790
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1791
    ^ self explainSyntax:string short:false
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1792
!
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1793
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1794
explainSyntax:string short:shortText
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1795
    "try syntax ...; return explanation or nil.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1796
     This is meant for beginners..."
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1797
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1798
    |fullMsg stringWithoutSeparators|
3881
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1799
    
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1800
    ((string = ':=') or:[string = '_']) ifTrue:[
3881
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1801
        fullMsg := '<variable> := <expression>
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1802
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1803
":=" and "_" (which is left-arrow in some fonts) mean assignment.
3464
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1804
The variable is bound to (i.e. points to) the value of <expression>.
3881
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1805
The "_" form is historic and should not be used with new code.'.
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1806
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1807
        shortText ifTrue:[
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1808
            string = '_' ifTrue:[
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1809
                ^ (self 
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1810
                    asLink:'"_"' 
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1811
                    info:fullMsg 
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1812
                    to:nil),' - old style for assignment. Consider changing to ":=".'
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1813
            ].
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1814
            ^ (self 
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1815
                asLink:'":="' 
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1816
                info:fullMsg 
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1817
                to:nil),' - assign to variable on the left (syntax).'
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1818
        ].
38b3c05b700a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3879
diff changeset
  1819
        ^ fullMsg
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1820
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1821
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1822
    (string = '^') ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1823
        shortText ifTrue:[
3607
58a91ac8dfb5 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3601
diff changeset
  1824
            ^ '"^" - return value from method (syntax)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1825
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1826
        ^ '^ <expression>
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1827
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1828
A return statement evaluates <expression> and returns its value from the method.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1829
A return inside a block exits the method where the block is defined (not only the block).'
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1830
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1831
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1832
    (string = ';') ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1833
        shortText ifTrue:[
3607
58a91ac8dfb5 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3601
diff changeset
  1834
            ^ '";" - a cascade expression (syntax)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1835
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1836
        ^ '<expression> ; selector1 ; .... ; selectorN
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1837
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1838
a cascade expression; evaluate expression, and send messages
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1839
<selector1> ... <selectorN> to the first expression''s receiver.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1840
Returns the value of the last send. The cascade sends may also have arguments.'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1841
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1842
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1843
    (string = '|') ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1844
        shortText ifTrue:[
3607
58a91ac8dfb5 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3601
diff changeset
  1845
            ^ '"|" - local variables (syntax)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1846
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1847
        ^ '| locals |  or: [:arg | statements]
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1848
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1849
"|" is used to mark a local variable declaration or separates arguments
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1850
from the statements in a block. Notice, that in a block-argument declaration
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1851
these arg nams must be prefixed by a colon character.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1852
"|" is also a selector understood by Booleans.'
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1853
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1854
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1855
    (string startsWith:'$' ) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1856
        shortText ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1857
            ^ '"$x" - ',(self asClassLink:'Character'),' literal (syntax)'.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1858
        ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1859
        ^ 'is a Character literal constant.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1860
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1861
Character objects represent indivdual text cheracters in Unicode encoding.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1862
For example, $a is the character "a" with an encoding of 97 "hex: 16r61".
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1863
Smalltalk/X supports unicode and uses this encoding internally for all characters
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1864
and strings. Notice, that not all Smalltalk implementations allow non-ascii (i.e. codes > 255).'
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1865
    ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1866
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1867
    (string startsWith:'#' ) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1868
        (string startsWith:'#(' ) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1869
            shortText ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1870
                ^ '"#(..)" - ',(self asClassLink:'Array'),' literal (syntax)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1871
            ].
3607
58a91ac8dfb5 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3601
diff changeset
  1872
            ^ 'is a constant Array (literal).
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1873
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1874
The array-object is created at compilation time and a reference to this is
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1875
used at execution time (thus, the same object is referred to every time).
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1876
The elements of a constant Array must be numbers, strings, symbols, nil, true or false,
3194
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1877
other array constants or byte-arrays.
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1878
(notice, that not all Smalltalk implementations allow true, false and nil as
3194
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1879
 element in an Array-constant).'
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1880
        ].
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1881
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1882
        (string startsWith:'#[') ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1883
            shortText ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1884
                ^ '"#[..]" - ',(self asClassLink:'ByteArray'),' literal (syntax)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1885
            ].
3607
58a91ac8dfb5 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3601
diff changeset
  1886
            ^ 'is a constant ByteArray (literal).
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1887
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1888
The elements of a constant ByteArray must be Integer constants in the range
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1889
0 .. 255.
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1890
(notice, that not all Smalltalk implementations support constant ByteArrays).'
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1891
        ].
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1892
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1893
        (string startsWith:'#''') ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1894
            shortText ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1895
                ^ '"#''..''" - ',(self asClassLink:'Symbol'),' literal (syntax)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1896
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1897
            ^ 'is a constant symbol containing non-alphanumeric characters.
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1898
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1899
Symbols are unique strings, meaning that there exists
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1900
exactly one instance of a given symbol. Therefore symbols can
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1901
be compared using == (identity compare) in addition to = (contents compare).
3194
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1902
Beside this, Symbols behave mostly like Strings but are immutable.'
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1903
        ].
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1904
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1905
        shortText ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1906
            ^ '"#.." - ',(self asClassLink:'Symbol'),' literal (syntax)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1907
        ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1908
        ^ 'is a constant symbol.
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1909
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1910
Symbols are unique strings, meaning that there exists
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1911
exactly one instance of a given symbol. Therefore symbols can
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1912
be compared using == (identity compare) in addition to = (contents compare).
3194
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1913
Beside this, Symbols behave mostly like Strings but are immutable.'
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1914
    ].
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1915
    ((string startsWith:'(') or:[string endsWith:')']) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1916
        shortText ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1917
            ^ ''.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1918
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1919
        ^ '( <expression> )
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1920
3194
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1921
expression grouping. Without them, expressions are evaluated left to right,
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1922
with unary messages preceeding binary messages, preceeding keyword mesages.'
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1923
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1924
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1925
    ((string startsWith:'[') or:[string endsWith:']']) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1926
        shortText ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1927
            ^ '"[..]" - a ',(self asClassLink:'Block'),' (aka lambda/closure for experts)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1928
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1929
        ^ '[:arg1 .. :argN | statements]
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1930
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1931
defines a block.
3194
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1932
Blocks represent pieces of executable code. The definition of a block does
4390
f79d16609aff #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4388
diff changeset
  1933
not evaluate it, instead a reference to the block''s computation is created.
3194
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1934
The block can be evaluated later, by sending it a value/value: message
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1935
(it can be even evaluated multiple times).
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1936
Blocks are often passed as arguments to Booleans (i.e. "bool ifTrue:[...]"),
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1937
other blocks (i.e. "[...] whileTrue: [...]"]) or collections (i.e. "coll do:[...]").
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1938
Blocks are also often used as callbacks from UI components or as exception handlers.'
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1939
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1940
2286
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1941
    ((string startsWith:'{') or:[string endsWith:'}']) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1942
        shortText ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1943
            ^ '"{..}" ',(self asClassLink:'Array'),' instantiation (syntax)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1944
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1945
        ^ '{ <expr1>. .. <exprN> }
2286
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1946
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1947
This is syntactic sugar for "Array with:<expr1> .. with:<exprN>".
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1948
2286
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1949
A new array is created with N elements initialized from the N expressions.
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1950
The expressions are separated by a period statement separator.
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1951
The expressions are evaluated at execution time, and a new array is always created
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1952
when executed (as opposed to an array literal, which is computed only once at
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1953
compilation time) and which is shared.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1954
Notice that this construct is not supported by all Smalltalk dialects, so its use
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1955
makes your program somewhat dialect specific.'
2286
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1956
    ].
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1957
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1958
    (string = ':') ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1959
        shortText ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1960
            ^ ''.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1961
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1962
        ^ 'colons have different meaning depending on context:
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1963
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1964
1) they separate keyword-parts in symbols and keyword-messages as in:
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1965
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1966
    #at:put:                     a constant keyword symbol
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1967
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1968
    rec at:index put:value       sends the #at:put: message to rec,
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1969
                                 passing index and value as arguments.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1970
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1971
2) within block-argument declarations as in:
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1972
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1973
    [:arg1 :arg2 | statements]
834
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1974
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1975
3) within an identifier, they separate the nameSpace part from
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1976
   the name part; as in:
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1977
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1978
    Smalltalk::Array    - the Array class in the Smalltalk nameSpace.
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1979
    Foo::Array          - the Array class in the Foo nameSpace.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1980
'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1981
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1982
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1983
    (string = '.') ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1984
        ^ 'statement. "<- period here"
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1985
statement
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1986
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1987
within a method or block, individual statements are separated by periods.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1988
'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1989
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1990
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1991
    stringWithoutSeparators := string withoutSeparators.
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1992
    
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1993
    (stringWithoutSeparators startsWith:'"') ifTrue:[
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  1994
        (stringWithoutSeparators startsWith:'"/') ifTrue:[
3464
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1995
            shortText ifTrue:[
3607
58a91ac8dfb5 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3601
diff changeset
  1996
                ^ 'an end-of-line comment (syntax)'.
3464
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1997
            ].
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1998
            ^ '"/ comment
3193
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1999
EOL (end-of-line) comment
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  2000
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  2001
anything up to the end of line is a comment and ignored (but not inside a string).
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  2002
Notice that EOL-comments are only supported by Smalltalk/X (i.e. non-portable).
3193
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  2003
'
3464
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  2004
        ].
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  2005
        (stringWithoutSeparators startsWith:'"<<') ifTrue:[
3464
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  2006
            shortText ifTrue:[
4175
43bb9f108a3a #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4153
diff changeset
  2007
                ^ 'a token delimited comment; up to line starting with the token after ''<<''.'.
3464
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  2008
            ].
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  2009
            ^ '"<<TOKEN
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  2010
...
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  2011
TOKEN
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  2012
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  2013
Token delimited comment
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  2014
4175
43bb9f108a3a #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4153
diff changeset
  2015
anything up to a line which starts with the token is a comment and ignored (but not inside a string).
3464
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  2016
Notice that Token-comments are only supported by Smalltalk/X (i.e. non-portable).
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  2017
'
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  2018
        ].
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  2019
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  2020
        shortText ifTrue:[
3607
58a91ac8dfb5 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3601
diff changeset
  2021
            ^ 'a comment (syntax)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  2022
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  2023
        ^ '" comment ... "
3193
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  2024
comment
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  2025
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  2026
anything between double quotes is a comment and ignored (but not inside a string).
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  2027
'
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  2028
    ].
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  2029
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  2030
    "/ is it a symbol without hash-character ?
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  2031
    "/
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  2032
"/    string knownAsSymbol ifTrue:[
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  2033
"/        ^ 'is nothing, but #' , string , ' is known as a symbol.
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  2034
"/
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  2035
"/Symbols are unique strings, meaning that there exists
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  2036
"/exactly one instance of a given symbol. Therefore symbols can
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  2037
"/be compared using == (identity compare) in addition to = (contents compare).
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  2038
"/Beside this, Symbols behave mostly like Strings.'
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  2039
"/    ].
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  2040
3883
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  2041
    ((stringWithoutSeparators startsWith:'<') and:[stringWithoutSeparators endsWith:'>']) ifTrue:[
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  2042
        shortText ifTrue:[
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  2043
            (stringWithoutSeparators includesString:'resource:') ifTrue:[
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  2044
                ^ 'a ',(self 
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  2045
                    asLink:'resource annotation' 
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  2046
                    info:fullMsg 
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  2047
                    to:(self actionToBrowseClass:Annotation)),' (syntax)'
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  2048
            ].    
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  2049
            ^ 'an ',(self 
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  2050
                asLink:'annotation / pragma' 
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  2051
                info:fullMsg 
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  2052
                to:(self actionToBrowseClass:Annotation)),' (syntax)'
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  2053
        ].
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  2054
    ].
29ce8a8b315e #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3881
diff changeset
  2055
    
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  2056
    ^ nil
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  2057
4175
43bb9f108a3a #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4153
diff changeset
  2058
    "Modified: / 28-07-2017 / 10:32:11 / cg"
4390
f79d16609aff #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4388
diff changeset
  2059
    "Modified: / 13-03-2019 / 10:25:48 / Claus Gittinger"
2214
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  2060
!
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  2061
4435
10a6786b7d87 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4434
diff changeset
  2062
safeValueStringFor:aValue
10a6786b7d87 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4434
diff changeset
  2063
    Error handle:[:ex |
10a6786b7d87 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4434
diff changeset
  2064
        ^ 'Error in storeString: ',ex description
10a6786b7d87 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4434
diff changeset
  2065
    ] do:[
10a6786b7d87 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4434
diff changeset
  2066
        ^ self valueStringFor:aValue
10a6786b7d87 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4434
diff changeset
  2067
    ]
10a6786b7d87 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4434
diff changeset
  2068
10a6786b7d87 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4434
diff changeset
  2069
    "Created: / 08-06-2019 / 14:03:38 / Claus Gittinger"
10a6786b7d87 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4434
diff changeset
  2070
!
10a6786b7d87 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4434
diff changeset
  2071
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2072
typeDescriptionFor:setOfTypes andSelector:selectorOrNil
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2073
    "up to 3 types are shown by name; more are simply counted"
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2074
    
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2075
    ^ self typeDescriptionFor:setOfTypes andSelector:selectorOrNil wordBetween:'or'
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2076
!
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2077
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2078
typeDescriptionFor:setOfTypes andSelector:selectorOrNil wordBetween:wordbetween
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2079
    "up to 3 types are shown by name; more are simply counted"
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2080
    
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2081
    |types numTypes
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2082
     type1 type2 type3
4206
fd7ee568c201 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4197
diff changeset
  2083
     nm1 nm2 nm3 link stringForType|
fd7ee568c201 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4197
diff changeset
  2084
fd7ee568c201 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4197
diff changeset
  2085
    stringForType := 
fd7ee568c201 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4197
diff changeset
  2086
        [:class |
fd7ee568c201 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4197
diff changeset
  2087
            class == UndefinedObject ifTrue:['nil']
fd7ee568c201 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4197
diff changeset
  2088
            ifFalse:[ class == True ifTrue:['true']
fd7ee568c201 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4197
diff changeset
  2089
            ifFalse:[ class == False ifTrue:['false']
fd7ee568c201 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4197
diff changeset
  2090
            ifFalse:[ class == VoidObject ifTrue:['Void']
fd7ee568c201 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4197
diff changeset
  2091
            ifFalse:[ class name ]]]]
fd7ee568c201 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4197
diff changeset
  2092
        ].
fd7ee568c201 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4197
diff changeset
  2093
        
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2094
    "/ reduce...
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2095
    self compressSetOfTypes:setOfTypes.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2096
    setOfTypes isEmpty ifTrue:[^ nil].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2097
    
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2098
    types := setOfTypes asOrderedCollection.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2099
    types sortBySelector:#name.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2100
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2101
    "/ now make this a nice string
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2102
    numTypes := types size.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2103
    type1 := types first.
4206
fd7ee568c201 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4197
diff changeset
  2104
    
fd7ee568c201 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4197
diff changeset
  2105
    nm1 := self asLink:(stringForType value:type1) to:(self actionToBrowseClass:type1 selector:selectorOrNil).
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2106
    numTypes == 1 ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2107
        ^ nm1
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2108
    ].
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2109
    
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2110
    type2 := types second.
4206
fd7ee568c201 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4197
diff changeset
  2111
    nm2 := self asLink:(stringForType value:type2) to:(self actionToBrowseClass:type2 selector:selectorOrNil).
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2112
    numTypes == 2 ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2113
        ^ nm1,' ',wordbetween,' ',nm2
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2114
    ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2115
    type3 := types third.
4206
fd7ee568c201 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4197
diff changeset
  2116
    nm3 := self asLink:(stringForType value:type3) to:(self actionToBrowseClass:type3 selector:selectorOrNil).
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2117
    numTypes == 3 ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2118
         ^ nm1,', ',nm2,' ',wordbetween,' ',nm3
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2119
    ].
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2120
    link := self actionToBrowseClasses:types.
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2121
"/    selectorOrNil notNil ifTrue:[
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2122
"/        link := self actionToOpenMethodFinderFor:selectorOrNil. 
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2123
"/    ].
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2124
    ^ self asLink:('%1 classes' bindWith:numTypes) to:link.
4206
fd7ee568c201 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4197
diff changeset
  2125
fd7ee568c201 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4197
diff changeset
  2126
    "Modified (format): / 11-11-2017 / 12:30:09 / cg"
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2127
!
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2128
2214
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  2129
valueStringFor:aValue
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  2130
    |valString|
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  2131
4287
66641d57216d #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4273
diff changeset
  2132
    aValue isProtoObject ifTrue:[
66641d57216d #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4273
diff changeset
  2133
        ^ aValue printString
66641d57216d #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4273
diff changeset
  2134
    ].
66641d57216d #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4273
diff changeset
  2135
    
2214
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  2136
    "/ only show the value, if it is really short...
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  2137
    (aValue isBoolean
3708
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  2138
        or:[aValue isNil
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  2139
        or:[aValue isString
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  2140
        or:[aValue isNumber
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  2141
        or:[aValue isPoint
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  2142
        or:[aValue isCharacter
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  2143
    ]]]]]) ifTrue:[
4435
10a6786b7d87 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4434
diff changeset
  2144
        ^ aValue storeString.
2226
d628e2ef289e changed: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2225
diff changeset
  2145
    ].
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  2146
2226
d628e2ef289e changed: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2225
diff changeset
  2147
    (aValue isColor) ifTrue:[
3708
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  2148
        ^ 'Color: ',('   ' emphasizeAllWith:(#backgroundColor->aValue)).
2226
d628e2ef289e changed: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2225
diff changeset
  2149
    ].
d628e2ef289e changed: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2225
diff changeset
  2150
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  2151
    ((aValue isKindOf:GUID)
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  2152
     or:[aValue isUUID]) ifTrue:[
3708
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  2153
        valString := aValue printString.
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  2154
    ].
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  2155
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  2156
    (valString isEmptyOrNil
2899
8b8701a65441 Avoid #isKindOf: where possible
Stefan Vogel <sv@exept.de>
parents: 2828
diff changeset
  2157
     or:[ valString size > 50
8b8701a65441 Avoid #isKindOf: where possible
Stefan Vogel <sv@exept.de>
parents: 2828
diff changeset
  2158
     or:[ valString includes:Character cr ]]) ifTrue:[
3708
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  2159
        valString := aValue classNameWithArticle.
2214
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  2160
    ].
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  2161
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  2162
    ^ valString
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  2163
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  2164
    "Modified: / 14-10-2010 / 11:57:52 / cg"
4435
10a6786b7d87 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4434
diff changeset
  2165
    "Modified: / 08-06-2019 / 14:02:57 / Claus Gittinger"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  2166
! !
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  2167
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2168
!Explainer class methodsFor:'naive type inferer'!
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2169
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2170
addTypeOfExpressionNode:expr forAssignmentTo:varName to:setOfTypes
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2171
    "pick up low hanging type information.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2172
     This is far from being complete, but often gives a hint good enough for code completion
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2173
     and info in the browser."
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2174
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2175
    |val valClass|
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2176
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2177
    "/ only look for wellknown types on the right side.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2178
    expr isLiteral ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2179
        val := expr value.
3801
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2180
        valClass := val class.
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2181
        val isImmutable ifTrue:[
3801
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2182
            valClass := [ valClass mutableClass ] on:Error do:[ valClass ].
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2183
        ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2184
        self rememberType:valClass in:setOfTypes.
3826
770a639a57a0 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3824
diff changeset
  2185
        ^ setOfTypes.
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2186
    ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2187
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2188
    expr isMessage ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2189
        self addTypeOfMessageNode:expr forAssignmentTo:varName to:setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2190
        ^ setOfTypes.
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2191
    ].
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2192
3826
770a639a57a0 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3824
diff changeset
  2193
    ^ setOfTypes
770a639a57a0 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3824
diff changeset
  2194
    
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2195
    "Created: / 30-04-2016 / 15:28:59 / cg"
3801
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2196
    "Modified: / 30-04-2016 / 20:17:35 / cg"
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2197
!
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2198
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2199
addTypeOfMessageNode:expr forAssignmentTo:varName to:setOfTypes
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2200
    "pick up low hanging type information.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2201
     This is far from being complete, but often gives a hint good enough for code completion
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2202
     and info in the browser."
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2203
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2204
    |valClass msgSelector msgReceiver|
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2205
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2206
    msgSelector := expr selector.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2207
    msgReceiver := expr receiver.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2208
        
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2209
    msgSelector == #? ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2210
        self addTypeOfExpressionNode:(expr arg1) forAssignmentTo:varName to:setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2211
        ^ setOfTypes
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2212
    ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2213
    
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2214
    "/ really really only very low hanging fruit...
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2215
    "/ ignore #/ here, because of filename
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2216
    ( #(+ - *) includes:msgSelector ) ifTrue:[
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2217
        true "(msgReceiver isLiteralNumber or:[expr arg1 isLiteralNumber])" ifTrue:[
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2218
            self rememberType:Number in:setOfTypes.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2219
            ^ setOfTypes.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2220
        ].    
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2221
"/        "/ ignore foo := foo OP expr
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2222
"/        "/ ignore foo := expr OP foo
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2223
"/        (msgReceiver isVariable and:[msgReceiver name = varName]) ifFalse:[
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2224
"/            (expr arg1 isVariable and:[expr arg1 name = varName]) ifFalse:[
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2225
"/                self rememberType:Number in:setOfTypes.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2226
"/            ]
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2227
"/        ].
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2228
        ^ setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2229
    ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2230
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2231
    ( #(// size hash identityHash) includes:msgSelector ) ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2232
        self rememberType:Integer in:setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2233
        ^ setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2234
    ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2235
    
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2236
    ( #(next next:) includes:msgSelector ) ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2237
        |rcvrTypes|
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2238
        
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2239
        rcvrTypes := self addTypeOfExpressionNode:msgReceiver forAssignmentTo:nil to:Set new.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2240
        rcvrTypes notEmpty ifTrue:[
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2241
            self breakPoint:#cg.
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2242
            self rememberType:Character in:setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2243
        ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2244
        ^ setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2245
    ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2246
    
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2247
    ( msgSelector startsWith:'as') ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2248
        valClass := Smalltalk classNamed:(msgSelector copyFrom:3).
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2249
        valClass notNil ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2250
            self rememberType:valClass in:setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2251
            ^ setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2252
        ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2253
    ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2254
    
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2255
    ( #(copy shallowCopy) includes:msgSelector ) ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2256
        msgReceiver isLiteral ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2257
            self addTypeOfExpressionNode:msgReceiver forAssignmentTo:varName to:setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2258
        ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2259
        ^ setOfTypes
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2260
    ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2261
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2262
    msgReceiver isGlobal ifTrue:[
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2263
        |instCreatorMessages globalValue implMethod|
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2264
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2265
        instCreatorMessages := #(new new: basicNew basicNew:).
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2266
        
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2267
        globalValue := msgReceiver value.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2268
        globalValue isBehavior ifTrue:[
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2269
            ( instCreatorMessages includes:msgSelector ) ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2270
                self rememberType:globalValue in:setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2271
                ^ setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2272
            ].
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2273
            implMethod := globalValue class lookupMethodFor:msgSelector.
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2274
            "/ mhmh - fuzzy; if the implementing message sends any of the above to itself...
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2275
            "/ assume it is returning it.
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2276
            implMethod isNil ifTrue:[
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2277
                "/ will not be understood
3857
8e460e8c7322 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3855
diff changeset
  2278
self breakPoint:#cg.
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2279
                ^ setOfTypes.
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2280
            ].    
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2281
            (implMethod messagesSentToSelf includesAny:instCreatorMessages) ifTrue:[
3857
8e460e8c7322 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3855
diff changeset
  2282
self breakPoint:#cg.
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2283
                self rememberType:globalValue in:setOfTypes.
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2284
                ^ setOfTypes.
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2285
            ].    
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2286
            "/ very fuzzy - if the implementing method is in the "instance creation" category...
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2287
            ((implMethod category ? '') startsWith:'instance creation') ifTrue:[
3857
8e460e8c7322 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3855
diff changeset
  2288
self breakPoint:#cg.
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2289
                self rememberType:globalValue in:setOfTypes.
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2290
                ^ setOfTypes.
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2291
            ].    
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2292
        ].
4197
3ea2e07f886c #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 4187
diff changeset
  2293
        "/ self breakPoint:#cg.
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2294
        ^ setOfTypes
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2295
    ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2296
    
4197
3ea2e07f886c #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 4187
diff changeset
  2297
    "/ self breakPoint:#cg.
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2298
    ^ setOfTypes
4197
3ea2e07f886c #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 4187
diff changeset
  2299
3ea2e07f886c #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 4187
diff changeset
  2300
    "Modified: / 10-10-2017 / 16:57:09 / cg"
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2301
!
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2302
4545
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2303
addTypesAssignedToInstvar:instVarName inClass:aClass method:methodOrNil source:code to:setOfTypes
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2304
    "look to asssignments to an instance variable, and pick up low hanging class information.
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2305
     This is far from being complete, but often gives a hint good enough for code completion
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2306
     and info in the browser."
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2307
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2308
    |tree parserClass lang parser|
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2309
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2310
    "/ quick check (avoids expensive parse)
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2311
    (code includesString:instVarName) ifFalse:[ ^ self ].
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2312
    parserClass := Parser.
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2313
    (methodOrNil notNil
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2314
      and:[(lang := methodOrNil programmingLanguage) notNil]) ifTrue:[
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2315
        parserClass := lang parserClass.
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2316
    ].
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2317
    parser := parserClass parseMethod:code in:aClass.
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2318
    tree := parser tree.
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2319
    "/ tree := parserClass parseMethod:code in:aClass.
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2320
    (tree isNil or:[tree == #Error]) ifTrue:[ ^ self ]. "/ unparsable
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2321
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2322
    self addTypesAssignedToInstvar:instVarName inTree:tree to:setOfTypes using:(parserClass parseNodeVisitorClass new).
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2323
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2324
    "Created: / 30-04-2016 / 15:09:18 / cg"
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2325
!
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2326
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2327
addTypesAssignedToInstvar:instVarName inClass:aClass method:aMethod to:setOfTypes
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2328
    "look to asssignments to an instance variable, and pick up low hanging class information.
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2329
     This is far from being complete, but often gives a hint good enough for code completion
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2330
     and info in the browser."
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2331
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2332
    | code |
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2333
3902
e9c6e1b34b65 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3891
diff changeset
  2334
    SourceCodeManagerError handle:[:ex |
e9c6e1b34b65 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3891
diff changeset
  2335
    ] do:[    
e9c6e1b34b65 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3891
diff changeset
  2336
        code := aMethod source.
e9c6e1b34b65 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3891
diff changeset
  2337
    ].
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2338
    (code notNil) ifTrue:[
4545
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2339
        self addTypesAssignedToInstvar:instVarName inClass:aClass method:aMethod source:code to:setOfTypes
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2340
    ]
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2341
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2342
    "Created: / 30-04-2016 / 15:07:33 / cg"
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2343
!
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2344
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2345
addTypesAssignedToInstvar:instVarName inClass:aClass to:setOfTypes
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2346
    "look to asssignments to an instance variable, and pick up low hanging class information.
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2347
     This is far from being complete, but often gives a hint good enough for code completion
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2348
     and info in the browser."
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2349
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2350
    aClass methodDictionary do:[:m |
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2351
        self addTypesAssignedToInstvar:instVarName inClass:aClass method:m to:setOfTypes
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2352
    ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2353
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2354
    "Created: / 30-04-2016 / 14:52:56 / cg"
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2355
!
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2356
4545
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2357
addTypesAssignedToInstvar:instVarName inTree:tree to:setOfTypes using:visitor
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2358
    "look to asssignments to an instance variable, and pick up low hanging class information.
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2359
     This is far from being complete, but often gives a hint good enough for code completion
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2360
     and info in the browser."
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2361
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2362
    visitor 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2363
        actionForNodeClass:AssignmentNode 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2364
        put:[:node |
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2365
            (node variable isInstanceVariableNamed:instVarName) ifTrue:[
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2366
                self addTypeOfExpressionNode:(node expression) forAssignmentTo:instVarName to:setOfTypes
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2367
            ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2368
            true "/ yes - visit subnodes
4545
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2369
        ].
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2370
    visitor 
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2371
        actionForNodeClass:JavaScriptParser::JavaScriptAssignmentNode
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2372
        put:[:node |
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2373
            (node variable isInstanceVariableNamed:instVarName) ifTrue:[
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2374
                self addTypeOfExpressionNode:(node expression) forAssignmentTo:instVarName to:setOfTypes
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2375
            ].
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2376
            true "/ yes - visit subnodes
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2377
        ].
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2378
    visitor visit:tree.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2379
!
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2380
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2381
addTypesAssignedToLocal:localName inTree:tree to:setOfTypes
4545
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2382
    <resource: #todo>
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2383
    "look to asssignments to a local variable, and pick up low hanging class information.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2384
     This is far from being complete, but often gives a hint good enough for code completion
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2385
     and info in the browser."
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2386
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2387
    |visitor|
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2388
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2389
    "/ hack, allowing to deal with both types of AST (sigh)
4545
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2390
    "/ ugly; TODO: unify RB-framework with STX's parser framework.
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2391
    #TODO. 
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2392
    (tree isKindOf:RBProgramNode) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2393
        visitor := RBPluggableProgramNodeVisitor new.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2394
        visitor 
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2395
            actionForNodeClass:RBAssignmentNode 
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2396
            put:[:node |
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2397
                |leftSide|
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2398
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2399
                leftSide := node variable.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2400
                (leftSide isTemporary and:[ leftSide name = localName ]) ifTrue:[
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2401
                    self addTypeOfExpressionNode:(node value) forAssignmentTo:localName to:setOfTypes
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2402
                ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2403
                true "/ yes - visit subnodes
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2404
            ].        
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2405
        visitor visitNode:tree.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2406
    ] ifFalse:[    
4545
4f5f760213d5 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 4499
diff changeset
  2407
        visitor := ParseNodeVisitor new. 
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2408
        visitor 
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2409
            actionForNodeClass:AssignmentNode 
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2410
            put:[:node |
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2411
                |leftSide expr|
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2412
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2413
                leftSide := node variable.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2414
                (leftSide isLocalVariable and:[ leftSide name = localName ]) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2415
                    expr := node expression.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2416
                    self addTypeOfExpressionNode:expr forAssignmentTo:localName to:setOfTypes
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2417
                ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2418
                true "/ yes - visit subnodes
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2419
            ].        
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2420
        visitor visit:tree.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  2421
    ].    
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2422
!
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2423
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2424
addTypesOfInstvar:instVarName inClass:aClass fromExistingInstancesTo:setOfTypes
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2425
    "look for existing instances and see that type is there"
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2426
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2427
    |instIndex|
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2428
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2429
    instIndex := aClass instVarIndexFor:instVarName.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2430
    aClass allSubInstancesDo:[:i |
3801
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2431
        |val varClass|
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2432
3801
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2433
        val := (i instVarAt:instIndex).
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2434
        val notNil ifTrue:[
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2435
            varClass := val class.
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2436
            self rememberType:varClass in:setOfTypes.
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2437
        ].
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2438
    ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2439
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2440
    "Created: / 30-04-2016 / 14:56:11 / cg"
3801
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2441
    "Modified: / 30-04-2016 / 20:05:03 / cg"
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2442
!
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2443
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2444
compressSetOfTypes:setOfTypes
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2445
    |toAdd toRemove|
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2446
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2447
    "/ reduce by eliminating common superclasses...
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2448
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2449
    toAdd := Set new.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2450
    toRemove := Set new.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2451
    setOfTypes do:[:type1 |
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2452
        setOfTypes do:[:type2 |
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2453
            |common|
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2454
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2455
            type1 superclass == type2 ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2456
                toRemove add:type1.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2457
            ] ifFalse:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2458
                type2 superclass == type1 ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2459
                    toRemove add:type2.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2460
                ] ifFalse:[    
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2461
                    common := type1 commonSuperclass:type2.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2462
                    common ~~ Object ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2463
                        toRemove add:type1.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2464
                        toRemove add:type2.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2465
                        toAdd add:common.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2466
                    ].    
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2467
                ].                        
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2468
            ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2469
        ]
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2470
    ]. 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2471
    setOfTypes removeAll:toRemove.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2472
    setOfTypes addAll:toRemove.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2473
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2474
    "/ hack
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2475
    setOfTypes size == 2 ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2476
        ((setOfTypes includes:True) and:[setOfTypes includes:False]) ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2477
            setOfTypes removeAll; add:Boolean.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2478
            ^ self.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2479
        ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2480
        ((setOfTypes includes:SmallInteger) and:[setOfTypes includes:LargeInteger]) ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2481
            setOfTypes removeAll; add:Integer.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2482
            ^ self.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2483
        ]
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2484
    ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2485
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2486
    "Created: / 30-04-2016 / 15:37:38 / cg"
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2487
!
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2488
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2489
rememberType:aClass in:setOfTypes
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2490
    setOfTypes add:aClass
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2491
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2492
    "Created: / 30-04-2016 / 15:35:44 / cg"
3801
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2493
    "Modified: / 30-04-2016 / 20:05:09 / cg"
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2494
! !
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2495
3838
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2496
!Explainer class methodsFor:'utilities'!
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2497
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2498
actionToBrowseClass:class
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2499
    ^ self actionToBrowseClass:class selector:nil.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2500
!
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2501
3838
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2502
actionToBrowseClass:class selector:selectorOrNil
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2503
    ^ self actionToBrowseClass:class selector:selectorOrNil info:nil
3866
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2504
!
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2505
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2506
actionToBrowseClass:class selector:selectorOrNil info:info
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2507
    self assert:class isBehavior.
3866
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2508
    ^ ActionWithInfo
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2509
        block:
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2510
            [
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2511
                self thisOrNewBrowserInto:[:browser :openHow |
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2512
                    browser
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2513
                        spawnFullBrowserInClass:class selector:selectorOrNil in:openHow
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2514
                ]
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2515
            ]
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2516
        info:info
3838
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2517
!
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2518
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2519
actionToBrowseClasses:classes 
3868
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2520
    ^ ActionWithInfo
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2521
        block:[
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2522
            "/ Tools::NewSystemBrowser browseClasses:classes
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2523
            self thisOrNewBrowserInto:[:browser :openHow |
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2524
                browser spawnClassBrowserFor:classes in:openHow
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2525
            ]
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2526
        ]
3868
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2527
        info:nil
3838
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2528
!
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2529
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2530
actionToBrowseImplementorsOf:selector
4032
58a37f863591 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3972
diff changeset
  2531
    ^ self actionToBrowseImplementorsOf:selector in:[Smalltalk allClasses]
3866
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2532
!
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2533
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2534
actionToBrowseImplementorsOf:selector in:classes
3868
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2535
    ^ ActionWithInfo
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2536
        block:[
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2537
            self thisOrNewBrowserInto:[:browser :openHow |
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2538
                browser
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2539
                    spawnMethodImplementorsBrowserFor:{ selector }
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2540
                    match:false
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2541
                    in:openHow
4032
58a37f863591 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3972
diff changeset
  2542
                    classes:classes value
3868
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2543
                    label:('Implementors of %1' bindWith:selector)
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2544
            ]
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2545
        ]
4032
58a37f863591 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3972
diff changeset
  2546
        info:('Click to browse implementors')
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2547
!
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2548
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2549
actionToBrowseInstvarRefsTo:instVarName inClass:class
3868
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2550
    ^ ActionWithInfo
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2551
        block:[
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2552
            self thisOrNewBrowserInto:[:browser :openHow |
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2553
                browser   
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2554
                    browseVarRefsToAny:{ instVarName }
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2555
                    classes:{ class }
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2556
                    variables:#instVarNames access:#readOrWrite all:true
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2557
                    title:'references to ',instVarName
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2558
                    in:openHow
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2559
            ]
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2560
        ]
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2561
        info:nil
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2562
!
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2563
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2564
actionToBrowseMethod:mthd
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2565
    self assert:mthd isMethod.
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2566
    ^ self actionToBrowseClass:(mthd mclass) selector:(mthd selector).
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2567
!
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2568
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2569
actionToOpenMethodFinderFor:selector 
3838
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2570
    MethodFinderWindow notNil ifTrue:[
3868
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2571
        ^ ActionWithInfo
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2572
            block:[ 
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2573
                MethodFinderWindow openOnSelectorPattern:selector
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2574
            ]
7be5e57bd1dd #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3867
diff changeset
  2575
            info:nil.
3838
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2576
    ].
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2577
    ^ self actionToBrowseImplementorsOf:selector
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2578
!
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2579
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2580
asClassLink:nameOfClass
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2581
    "return text with a hyperlink to browse a class by that name"
3838
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2582
    
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2583
    |cls|
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2584
    
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2585
    cls := Smalltalk classNamed:nameOfClass string asUppercaseFirst.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2586
    cls isNil ifTrue:[^ nameOfClass].
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2587
3866
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2588
    ^ self 
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2589
        asLink:nameOfClass  
3878
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  2590
        info:('Click to browse %1' bindWith:nameOfClass)    
3866
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2591
        to:(self actionToBrowseClass:cls) 
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2592
!
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2593
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2594
asLink:aString info:info to:actionOrNil
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2595
    actionOrNil isNil ifTrue:[^ aString].
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2596
    ^ aString asActionLinkTo:(ActionWithInfo block:actionOrNil info:info)
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2597
!
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2598
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2599
asLink:aString to:actionOrNil
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2600
    actionOrNil isNil ifTrue:[^ aString].
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2601
    ^ aString asActionLinkTo:actionOrNil
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2602
!
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2603
3872
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2604
infoStringForClasses:aCollectionOfClasses withPrefix:prefix
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2605
    "get a nice user readable list for some classes.
4399
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2606
     Up to 4 are listed by name, otherwise the count is presented.
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2607
     The prefix can be sth like 'other ', 'sub', 'super',
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2608
     'implementing ' etc. 
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2609
     Or it can be an empty string.
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2610
     The returned string is meant to be shown in the info line at the bottom."
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2611
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2612
    |nClassNames sortedByName classNames 
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2613
     commonSuperClass link1 link2 link3 link4|
3872
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2614
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2615
    aCollectionOfClasses isEmpty ifTrue:[
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2616
        ^ 'No %1classes' bindWith:prefix.
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2617
    ].
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2618
4032
58a37f863591 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3972
diff changeset
  2619
    classNames := aCollectionOfClasses asIdentitySet asOrderedCollection 
58a37f863591 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3972
diff changeset
  2620
                        collect:[:each | each theNonMetaclass name].
3872
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2621
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2622
    nClassNames := classNames size.
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2623
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2624
    nClassNames <= 4 ifTrue:[
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2625
        sortedByName := classNames sort.
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2626
        link1 := self asClassLink:sortedByName first.
3872
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2627
        nClassNames == 1 ifTrue:[
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2628
            ^ '%2' "'1 %1class: %2'" bindWith:prefix with:link1.
3872
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2629
        ].
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2630
        link2 := self asClassLink:classNames second.
3872
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2631
        nClassNames == 2 ifTrue:[
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2632
            ^ '%2 and %3' "'2 %1classes: %2 and %3'" bindWith:prefix
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2633
                        with:link1
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2634
                        with:link2.
3872
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2635
        ].
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2636
        link3 := self asClassLink:classNames third.
3872
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2637
        nClassNames == 3 ifTrue:[
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2638
            ^ '%2, %3 and %4' "'3 %1classes: %2, %3 and %4'" bindWith:prefix
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2639
                        with:link1
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2640
                        with:link2
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2641
                        with:link3.
3872
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2642
        ].
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2643
        link4 := self asClassLink:classNames fourth.
3872
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2644
        nClassNames == 4 ifTrue:[
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2645
            ^ '%2, %3, %4 and %5' "'4 %1classes: %2, %3, %4 and %5'" bindWith:prefix
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2646
                        with:link1
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2647
                        with:link2
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2648
                        with:link3
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2649
                        with:link4.
3872
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2650
        ].
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2651
    ].
4399
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2652
    commonSuperClass := Class commonSuperclassOf:aCollectionOfClasses.
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2653
    (aCollectionOfClasses includes:commonSuperClass) ifTrue:[
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2654
        ^ self
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2655
            asLink:('%1 and %2 additional %3classes' 
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2656
                        bindWith:commonSuperClass theNonMetaclass name
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2657
                        with:(nClassNames - 1)
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2658
                        with:prefix)
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2659
            info:'Browse classes' 
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2660
            to:(self actionToBrowseClasses:aCollectionOfClasses)        
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2661
    ].    
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2662
    
3885
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2663
    ^ self
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2664
        asLink:('%1 %2classes' bindWith:nClassNames printString with:prefix)
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2665
        info:'Browse classes' 
8bcccd9a6fdd #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3883
diff changeset
  2666
        to:(self actionToBrowseClasses:aCollectionOfClasses)        
3872
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2667
4399
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2668
    "
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2669
     self infoStringForClasses:{ Array } withPrefix:'sub'
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2670
     self infoStringForClasses:{ Array . Point } withPrefix:'sub'
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2671
     self infoStringForClasses:{ Array . Point . Integer . Float} withPrefix:'sub'
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2672
     self infoStringForClasses:{ Array . Point . Integer . Float . Fraction} withPrefix:'sub'
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2673
     self infoStringForClasses:{ Number . Integer . Float . Fraction . SmallInteger} withPrefix:'sub'
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2674
    "
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2675
3872
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2676
    "Modified: / 27-07-2006 / 10:09:02 / cg"
4399
4b80ef759ebe #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2677
    "Modified: / 27-03-2019 / 10:42:24 / Claus Gittinger"
3872
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2678
!
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2679
3866
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2680
infoStringForClasses:aCollectionOfClasses withPrefix:prefix actionGenerator:actionGeneratorOrNil
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2681
    "get a nice user readable list for some classes.
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2682
     Up to 4 are named, otherwise the count is presented.
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2683
     The prefix can be sth like ' other', ' sub', ' super',
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2684
     ' implementing' etc. Or it can be an empty string.
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2685
     To be shown in the info line at the bottom."
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2686
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2687
    |nClassNames classes sortedByName classNames
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2688
     link1 link2 link3 link4 actionGenerator|
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2689
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2690
    aCollectionOfClasses isEmpty ifTrue:[
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2691
        ^ 'No %1classes' bindWith:prefix.
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2692
    ].
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2693
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2694
    actionGenerator := actionGeneratorOrNil isNil
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2695
                        ifTrue:[ [:classes | self actionToBrowseClasses:classes] ]
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2696
                        ifFalse:[ actionGeneratorOrNil ].
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2697
                        
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2698
    classes := aCollectionOfClasses asIdentitySet asOrderedCollection. 
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2699
    classNames := classes collect:[:each | each theNonMetaclass name].
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2700
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2701
    nClassNames := classNames size.
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2702
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2703
    nClassNames <= 4 ifTrue:[
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2704
        sortedByName := classNames sortWith:classes.
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2705
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2706
        link1 := self asLink:classNames first "allBold"
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2707
                      info:('Browse %1' bindWith:classNames first)
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2708
                      to:(actionGenerator value:{classes first}).
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2709
        nClassNames == 1 ifTrue:[
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2710
            ^ '%2' "'1 %1class: %2'" 
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2711
                bindWith:prefix 
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2712
                with:link1.
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2713
        ].
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2714
        link2 := self asLink:classNames second "allBold" to:(actionGenerator value:{classes second}).
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2715
        nClassNames == 2 ifTrue:[
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2716
            ^ '%2 and %3' "'2 %1classes: %2 and %3'" 
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2717
                bindWith:prefix
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2718
                with:link1
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2719
                with:link2.
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2720
        ].
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2721
        link3 := self asLink:classNames third "allBold" to:(actionGenerator value:{classes third}).
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2722
        nClassNames == 3 ifTrue:[
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2723
            ^ '%2, %3 and %4' "'3 %1classes: %2, %3 and %4'" 
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2724
                bindWith:prefix
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2725
                with:link1
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2726
                with:link2
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2727
                with:link3.
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2728
        ].
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2729
        link4 := self asLink:classNames fourth "allBold" to:(actionGenerator value:{classes fourth}).
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2730
        nClassNames == 4 ifTrue:[
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2731
            ^ '%2, %3, %4 and %5' "'4 %1classes: %2, %3, %4 and %5'" 
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2732
                bindWith:prefix
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2733
                with:link1
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2734
                with:link2
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2735
                with:link3
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2736
                with:link4.
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2737
        ].
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2738
    ].
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2739
    ^ self 
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2740
        asLink:('%1 %2classes' bindWith:(nClassNames printString "allBold") with:prefix)
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2741
        to:(actionGenerator value:classes)    
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2742
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2743
    "Modified: / 27-07-2006 / 10:09:02 / cg"
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2744
!
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2745
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2746
infoStringForMethods:aCollectionOfMethods withPrefix:prefix
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2747
    "get a nice user readable list for some methods.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2748
     Up to 3 are named, otherwise the count is presented.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2749
     The prefix can be sth like ' other', ' sender', ' implementor',
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2750
     Or it can be an empty string.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2751
     Result is meant to be shown in the info line at the bottom of a browser."
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2752
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2753
    |nMethodNames sortedByName methodNames|
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2754
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2755
    aCollectionOfMethods isEmpty ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2756
        ^ 'No %1' bindWith:prefix.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2757
    ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2758
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2759
    methodNames := aCollectionOfMethods asOrderedCollection 
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2760
                    collect:[:each | each whoString].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2761
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2762
    nMethodNames := methodNames size.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2763
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2764
    nMethodNames <= 3 ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2765
        nMethodNames == 1 ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2766
            ^ '%2' "'1 %1class: %2'" bindWith:prefix with:(methodNames first allBold).
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2767
        ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2768
        sortedByName := methodNames sort.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2769
        nMethodNames == 2 ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2770
            ^ '%2 and %3' "'2 %1classes: %2 and %3'" bindWith:prefix
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2771
                        with:(sortedByName first allBold)
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2772
                        with:(sortedByName second allBold).
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2773
        ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2774
        nMethodNames == 3 ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2775
            ^ '%2, %3 and %4' "'3 %1classes: %2, %3 and %4'" bindWith:prefix
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2776
                        with:(sortedByName first allBold)
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2777
                        with:(sortedByName second allBold)
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2778
                        with:(sortedByName third allBold).
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2779
        ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2780
        nMethodNames == 4 ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2781
            ^ '%2, %3, %4 and %5' "'4 %1classes: %2, %3, %4 and %5'" bindWith:prefix
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2782
                        with:(sortedByName first allBold)
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2783
                        with:(sortedByName second allBold)
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2784
                        with:(sortedByName third allBold)
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2785
                        with:(sortedByName fourth allBold).
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2786
        ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2787
    ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2788
    ^ '%1 %2methods' bindWith:nMethodNames printString allBold with:prefix.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2789
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2790
    "
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2791
     Time millisecondsToRun:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2792
         self infoStringForMethods:(SystemBrowser allCallsOn:#'at:put:') withPrefix:''
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2793
     ].   
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2794
     Time millisecondsToRun:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2795
         self infoStringForMethods:(SystemBrowser allCallsOn:#'actionToBrowseClasses:') withPrefix:''
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2796
     ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2797
    "
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2798
!
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2799
3872
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2800
methodImplementorsInfoFor:aMethod inEnvironment:environment
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2801
    "get something about the implementors of aMethod
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2802
     to be shown in the info line at the bottom"
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2803
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2804
    |implementors msg senders msg2|
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2805
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2806
    implementors := SystemBrowser
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2807
        findImplementorsOf:aMethod selector
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2808
        in:(environment allClasses)
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2809
        ignoreCase:false.
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2810
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2811
    implementors notEmpty ifTrue:[
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2812
        msg := 'Only implemented here.'.
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2813
        implementors remove:aMethod ifAbsent:nil.
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2814
        implementors notEmpty ifTrue:[
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2815
            implementors := implementors collect:[:mthd | mthd mclass ? mthd getMclass].
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2816
            implementors notEmpty ifTrue:[
4032
58a37f863591 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3972
diff changeset
  2817
                msg := 'Also ',(self asLink:'implemented' to:(self actionToBrowseImplementorsOf:aMethod selector)),' in '.
3872
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2818
                msg := msg , (self infoStringForClasses:implementors withPrefix:'other ').
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2819
                msg := msg , '.'.
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2820
            ]
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2821
        ].
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2822
    ].
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2823
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2824
false ifTrue:[  "/ too slow
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2825
    senders := SystemBrowser
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2826
        findSendersOf:aMethod selector
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2827
        in:(environment allClasses)
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2828
        ignoreCase:false.
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2829
    senders notEmpty ifTrue:[
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2830
        msg2 := 'Sent from ' , senders size printString, ' methods.'.
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2831
    ] ifFalse:[
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2832
        msg2 := 'No senders.'.
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2833
    ].
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2834
    msg := msg , '/' , msg2
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2835
].
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2836
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2837
    ^ msg
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2838
!
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2839
3871
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2840
methodInheritanceInfoFor:aMethod
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2841
    |methodsSuperclass inheritedClass msg methodsClass sel mthd selectorString|
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2842
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2843
    methodsClass := aMethod mclass.
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2844
    methodsClass isNil ifTrue:[^ nil].
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2845
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2846
    methodsSuperclass := methodsClass superclass.
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2847
    methodsSuperclass isNil ifTrue:[^ nil].
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2848
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2849
    sel := aMethod selector.
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2850
    inheritedClass := methodsSuperclass whichClassIncludesSelector:sel.
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2851
    inheritedClass notNil ifTrue:[
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2852
        mthd := inheritedClass compiledMethodAt:sel.
4110
e3ae7a6cc004 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4100
diff changeset
  2853
        (mthd sendsSelector:#'subclassResponsibility') ifTrue:[
3871
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2854
            msg := '%1 overrides subclassResponsibility in %2'.
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2855
        ] ifFalse:[
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2856
            msg := '%1 overrides implementation in %2'.
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2857
        ].
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2858
        selectorString := sel contractTo:30.
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2859
        ^ msg 
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2860
            bindWith:(self 
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2861
                        asLink:selectorString "allBold" 
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2862
                        info:('Browse all implementors of %1' bindWith:selectorString)
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2863
                        to:(self actionToOpenMethodFinderFor:sel)) 
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2864
            with:(self 
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2865
                    asLink:inheritedClass name "allBold" 
4586
adb8027024dd #DOCUMENTATION by stefan
Stefan Vogel <sv@exept.de>
parents: 4545
diff changeset
  2866
                    info:('Browse %1 » %2' bindWith:inheritedClass name with:sel)
3871
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2867
                    to:(self actionToBrowseClass:inheritedClass selector:sel)).
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2868
    ].
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2869
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2870
    ^ msg
4110
e3ae7a6cc004 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4100
diff changeset
  2871
e3ae7a6cc004 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4100
diff changeset
  2872
    "Modified: / 05-02-2017 / 01:24:25 / cg"
3871
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2873
!
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2874
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2875
methodRedefinitionInfoFor:aMethod
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2876
    "return a user readable string telling in how many subclasses
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2877
     a method is redefined.
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2878
     To be shown in the info line of a browser"
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2879
     
4060
25c54b8b50c6 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4059
diff changeset
  2880
    |redefiningClasses msg methodsClass|
25c54b8b50c6 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4059
diff changeset
  2881
25c54b8b50c6 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4059
diff changeset
  2882
    methodsClass := aMethod mclass.
25c54b8b50c6 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4059
diff changeset
  2883
    methodsClass isNil ifTrue:[^ nil].
25c54b8b50c6 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4059
diff changeset
  2884
25c54b8b50c6 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4059
diff changeset
  2885
    redefiningClasses := methodsClass allSubclasses select:[:eachClass | eachClass includesSelector:aMethod selector].
25c54b8b50c6 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4059
diff changeset
  2886
    redefiningClasses size ~~ 0 ifTrue:[
3871
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2887
        msg := 'redefined in '.
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2888
        msg := msg , (self 
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2889
                        infoStringForClasses:redefiningClasses 
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2890
                        withPrefix:'sub'
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2891
                        actionGenerator:[:classes | 
3878
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  2892
                            classes size == 1 ifTrue:[
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  2893
                                |cls|
4060
25c54b8b50c6 #BUGFIX by stefan
Stefan Vogel <sv@exept.de>
parents: 4059
diff changeset
  2894
3878
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  2895
                                cls := classes first.
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  2896
                                self 
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  2897
                                    actionToBrowseClass:cls 
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  2898
                                    selector:aMethod selector 
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  2899
                                    info:('Browse implementation in %1' bindWith:cls name)
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  2900
                            ] ifFalse:[
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  2901
                                self
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  2902
                                    actionToBrowseImplementorsOf:aMethod selector 
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  2903
                                    in:classes
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  2904
                            ].    
bcfd350f5d05 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3872
diff changeset
  2905
                        ]).
3871
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2906
        msg := msg , '.'.
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2907
    ].
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2908
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2909
    ^ msg
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2910
!
3c8741b74ab9 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3868
diff changeset
  2911
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2912
methodSendersInfoFor:selector inEnvironment:environment
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2913
    "get something about the senders of a message.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2914
     to be shown in the info line at the bottom.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2915
     This may be slow; so think about doing it in background..."
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2916
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2917
    |senders|
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2918
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2919
    senders := SystemBrowser
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2920
                findSendersOf:selector
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2921
                in:(environment allClasses)
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2922
                ignoreCase:false
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2923
                match:false.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2924
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2925
    senders notEmpty ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2926
        ^ 'Sent from ' , senders size printString, ' methods.'.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2927
    ] ifFalse:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2928
        ^ 'No senders.'.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2929
    ].
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2930
!
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2931
3872
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2932
methodSpecialInfoFor:aMethod
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2933
    "handles special cases - such as documentation methods"
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2934
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2935
    |cls sel|
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2936
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2937
    (cls := aMethod mclass) isNil ifTrue:[^ nil].
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2938
    (sel := aMethod selector) isNil ifTrue:[^ nil].
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2939
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2940
    cls isMeta ifTrue:[
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2941
        (AbstractSourceCodeManager isVersionMethodSelector:sel) ifTrue:[
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2942
            ^ 'The version method is required for the source code repository - do not modify.'.
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2943
        ].
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2944
        sel == #documentation ifTrue:[
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2945
            ^ 'ST/X stores documentation in this method (not in comment slots)'.
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2946
        ].
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2947
    ].
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2948
    ^ nil
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2949
!
446f75051730 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3871
diff changeset
  2950
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2951
thisOrNewBrowserInto:aTwoArgBlock
4269
fb59cef471ec #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4268
diff changeset
  2952
    "I am inviked when user clicks on a link in the info line.
fb59cef471ec #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4268
diff changeset
  2953
     if I am invoked by a browser, 
4268
79d5c1eaa723 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4210
diff changeset
  2954
     invoke the twoArgBlock with it and a #newBuffer arg.
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2955
     Otherwise, create a new (invisible) browser and pass it to the block
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2956
     with a #newBrowser arg."
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2957
     
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2958
    |windowGroupClass browserClass wg app|
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2959
    
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2960
    "/ stupid: I am in libcomp; should be in libtool
4269
fb59cef471ec #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4268
diff changeset
  2961
    "/ access by name, so we do not introduce new prerequisites on the package
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2962
    windowGroupClass := Smalltalk at:#WindowGroup.
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2963
    windowGroupClass isNil ifTrue:[^ self].
4269
fb59cef471ec #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4268
diff changeset
  2964
    browserClass := Smalltalk at:#'SystemBrowser'.
fb59cef471ec #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4268
diff changeset
  2965
    browserClass isNil ifTrue:[^ self].
fb59cef471ec #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4268
diff changeset
  2966
    browserClass := browserClass default.
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2967
    browserClass isNil ifTrue:[^ self].
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2968
    
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2969
    ((wg := windowGroupClass activeGroup) notNil
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2970
        and:[ (app := wg application) isKindOf:browserClass ]
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2971
    ) ifTrue:[
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2972
        ^ aTwoArgBlock value:app value:#newBuffer
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2973
    ].        
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2974
    ^ aTwoArgBlock value:(browserClass basicNew) value:#newBrowser
4268
79d5c1eaa723 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4210
diff changeset
  2975
4269
fb59cef471ec #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4268
diff changeset
  2976
    "Modified (comment): / 24-05-2018 / 15:01:01 / Claus Gittinger"
3838
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2977
! !
3826
770a639a57a0 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3824
diff changeset
  2978
3866
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2979
!Explainer::ActionWithInfo class methodsFor:'instance creation'!
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2980
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2981
block:aBlock info:info
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2982
    ^ self new block:aBlock info:info
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2983
! !
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2984
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2985
!Explainer::ActionWithInfo methodsFor:'accessing'!
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2986
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2987
block:blockArg info:infoArg 
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2988
    block := blockArg.
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2989
    info := infoArg.
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2990
!
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2991
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2992
info:something
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2993
    info := something.
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2994
! !
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2995
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2996
!Explainer::ActionWithInfo methodsFor:'evaluation'!
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2997
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2998
info
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  2999
    ^ info
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  3000
!
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  3001
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  3002
value
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  3003
    ^ block value
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  3004
!
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  3005
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  3006
value:arg
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  3007
    ^ block value:arg
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  3008
! !
3f2dd51c8a76 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3864
diff changeset
  3009
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
  3010
!Explainer class methodsFor:'documentation'!
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
  3011
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
  3012
version
3697
099dd080fd3e #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 3608
diff changeset
  3013
    ^ '$Header$'
2214
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  3014
!
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  3015
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  3016
version_CVS
3697
099dd080fd3e #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 3608
diff changeset
  3017
    ^ '$Header$'
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
  3018
! !
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
  3019