Explainer.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Tue, 10 May 2016 07:39:05 +0200
branchjv
changeset 3874 4f9db2d4c2b7
parent 3873 707275c1f86d
parent 3864 eaf361535167
child 3875 45c02b9a43a0
permissions -rw-r--r--
Merge
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
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
    23
!Explainer class methodsFor:'documentation'!
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    24
20
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    25
copyright
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    26
"
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    27
 COPYRIGHT (c) 1993 by Claus Gittinger
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
    28
              All Rights Reserved
20
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    29
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    30
 This software is furnished under a license and may be used
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    31
 only in accordance with the terms of that license and with the
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    32
 inclusion of the above copyright notice.   This software may not
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    33
 be provided or otherwise made available to, or used by, any
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    34
 other person.  No title to or ownership of the software is
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    35
 hereby transferred.
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    36
"
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    37
!
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    38
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    39
documentation
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    40
"
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
    41
    a very simple explainer - much more should be added...
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
    42
3608
873ba1855932 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3607
diff changeset
    43
    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
    44
    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
    45
    on some code construct in the new browser (then a short explanaition
873ba1855932 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3607
diff changeset
    46
    is shown in the lower info area).
263
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    47
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
    48
    Most of the texts returned here are heuristically motivated,
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
    49
    based on the experience with beginners and their frequently asked questions.
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
    50
263
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    51
    [author:]
3608
873ba1855932 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3607
diff changeset
    52
        Claus Gittinger
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    53
"
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    54
! !
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    55
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
    56
!Explainer class methodsFor:'explaining'!
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    57
2193
9416fc17ee62 pass the interval to the explainer
Claus Gittinger <cg@exept.de>
parents: 2191
diff changeset
    58
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
    59
    |expl literalValue literalsClass findInnerMost elementIndex codeOfCharacterBeforeCursor|
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    60
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    61
    literalValue := node value.
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
    62
    literalsClass := literalValue class.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
    63
    expl := (self asClassLink:literalsClass name "allBold") , '-constant'.
2954
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
    64
2316
f09794e008f8 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2315
diff changeset
    65
    (literalValue isInteger) ifTrue:[
3697
099dd080fd3e #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 3608
diff changeset
    66
        (literalValue ~~ 0 and:[literalValue ~~ 1]) ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    67
            expl := expl , ' ('.
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
    68
            #(2 10 16) with:#('binary: ' 'decimal: ' 'hex: ') do:[:base :baseExpl |
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    69
                |bStr|
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
    70
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    71
                base ~= (node token radix ? 10) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    72
                    bStr := base==10
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    73
                                ifTrue:[literalValue printString]
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
    74
                                ifFalse:[(literalValue printStringRadix:base) leftPaddedTo:2 with:$0]. "/ looks better: at least a size of 2
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
    75
                    "/ oops - someone looks at a largeInteger
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
    76
                    bStr := bStr contractAtEndTo:40.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    77
                    expl := expl , ' ' , baseExpl, bStr
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    78
                ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    79
            ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    80
            expl := expl , ' )'.
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
    81
        ].  
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    82
        ^ expl.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    83
    ].                
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    84
    (literalValue isCharacter) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    85
        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
    86
        ^ expl.
2316
f09794e008f8 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2315
diff changeset
    87
    ].
2954
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
    88
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
    89
    (node isLiteralArray and:[intervalIfKnown notNil]) ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    90
        "/ see which element we have to explain
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    91
        findInnerMost :=
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    92
            [:token |
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    93
                token value keysAndValuesDo:[:index :eachToken |
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
    94
                    |selectorOrName selectorExplanation|
2954
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
    95
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    96
                    ((eachToken start to:eachToken stop) intersect:intervalIfKnown) notEmpty ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    97
                        elementIndex := index.  "/ see below
2954
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
    98
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    99
                        eachToken value isArray ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   100
                            findInnerMost value:eachToken.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   101
                        ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   102
                        eachToken value isSymbol ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   103
                            selectorOrName := eachToken value.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   104
                            selectorOrName isUppercaseFirst ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   105
                                (Smalltalk includesKey:selectorOrName) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   106
                                    ^ expl, ' / ', (Explainer explainGlobal:selectorOrName inClass:cls short:short)
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   107
                                ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   108
                            ].
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   109
                            selectorExplanation := (Explainer explainSelector:selectorOrName inClass:cls short:short).
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   110
                            selectorExplanation isNil ifTrue:[^ expl].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   111
                            ^ expl, ' / ', selectorExplanation.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   112
                        ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   113
                    ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   114
                ]
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   115
             ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   116
        findInnerMost value:node token.
2954
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
   117
    ].
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
   118
2955
d52a51930921 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2954
diff changeset
   119
    (literalValue isArray or:[ literalValue isByteArray or:[ literalValue isString ]]) ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   120
        literalValue size == 0 ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   121
            ^ 'empty ' , expl
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   122
        ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   123
        elementIndex notNil ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   124
            ^ expl , (' (size=%1; element=%2)' bindWith:literalValue size with:elementIndex)
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   125
        ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   126
        literalValue isString ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   127
            elementIndex := intervalIfKnown start - node token start.
2955
d52a51930921 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2954
diff changeset
   128
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   129
            (elementIndex between:1 and:literalValue size) ifTrue:[
3601
1d377594ab06 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3549
diff changeset
   130
                codeOfCharacterBeforeCursor := (literalValue at:elementIndex) codePoint.
1d377594ab06 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3549
diff changeset
   131
                ^ expl , (' (size=%1; position=%2; codePoint=16r%3)' 
1d377594ab06 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3549
diff changeset
   132
                        bindWith:literalValue size 
1d377594ab06 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3549
diff changeset
   133
                        with:elementIndex
1d377594ab06 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3549
diff changeset
   134
                        with:codeOfCharacterBeforeCursor hexPrintString)
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   135
            ]
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   136
        ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   137
        ^ expl , (' (size=%1)' bindWith:literalValue size)
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   138
    ].
2191
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   139
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   140
    ^ expl
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   141
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   142
    "Modified (format): / 30-04-2016 / 16:00:05 / cg"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   143
!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   144
2193
9416fc17ee62 pass the interval to the explainer
Claus Gittinger <cg@exept.de>
parents: 2191
diff changeset
   145
explainMessageNode:node in:code forClass:cls short:short interval:intervalIfKnown
1771
9d6581314aed avoid to put nil in Set
Stefan Vogel <sv@exept.de>
parents: 1763
diff changeset
   146
    "answer a string which explains node"
9d6581314aed avoid to put nil in Set
Stefan Vogel <sv@exept.de>
parents: 1763
diff changeset
   147
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   148
    |receiver nm srchClass selector selectorString implClass
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   149
     boldSelectorString globalValue recClassSet
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   150
     implMethod implMethodComment info definer
1854
9dcdec831c46 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1771
diff changeset
   151
     instances classesOfInstVars implementingClasses canBeNil
3193
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
   152
     bestMatches hint|
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   153
3538
8dbc7dc8056b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3492
diff changeset
   154
    selector := node buildSelectorString.
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   155
    selectorString := selector printString contractTo:50.
3548
5b792260efe0 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3538
diff changeset
   156
    selector := selector asSymbolIfInterned.    "/ avoid creating new symbols.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   157
    selector isNil ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   158
        ^ '%1 is NOWHERE impemented.' bindWith:boldSelectorString
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   159
    ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   160
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   161
    selectorString := self asLink:selectorString to:(self actionToBrowseImplementorsOf:selector).
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   162
    boldSelectorString := selectorString "allBold".
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   163
    
1733
5a4d415c3bbc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1732
diff changeset
   164
    recClassSet := self guessPossibleImplementorClassesFor:(node receiver) in:code forClass:cls.
5a4d415c3bbc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1732
diff changeset
   165
    recClassSet size == 1 ifTrue:[
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   166
        srchClass := recClassSet first.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   167
        "take care - Set cannot store nil!!"
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   168
        implementingClasses := (recClassSet collect:[:cls | cls whichClassIncludesSelector:selector]) asArray.
1869
089f4ae37b06 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1854
diff changeset
   169
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   170
        (implementingClasses includes:nil) ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   171
            implementingClasses size > 1 ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   172
                ^ 'possibly not understood: %1 (%2 other implementors)'
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   173
                    bindWith:selector "allBold"
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   174
                    with:(implementingClasses size - 1)
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   175
            ].
1869
089f4ae37b06 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1854
diff changeset
   176
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   177
            (#('self'  'super' 'true' 'false' 'thisContext') includes:selector) ifTrue:[
3854
5142caa44ea1 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3853
diff changeset
   178
                ^ ('NOT understood here: %1 (missing period after previous statement?)' 
5142caa44ea1 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3853
diff changeset
   179
                        bindWith:selector allBold)
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   180
            ].
3193
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
   181
3854
5142caa44ea1 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3853
diff changeset
   182
            hint := ''.    
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   183
            (recClassSet contains:[:cls | cls isMeta not and:[cls theMetaclass canUnderstand:selector]]) ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   184
                hint := '. But class understands it - did you mean "rcvr class ',selector,'..." ?'.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   185
            ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   186
            bestMatches := Parser findBestSelectorsFor:selector in:srchClass.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   187
            bestMatches size > 0 ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   188
                ^ ('NOT understood here: %1 (best guess is: "%2" from %3)'
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   189
                    bindWith:selector allBold
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   190
                    with:(bestMatches first "allBold")
3854
5142caa44ea1 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3853
diff changeset
   191
                    with:(srchClass whichClassIncludesSelector:bestMatches first) name) , hint
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   192
            ].
3854
5142caa44ea1 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3853
diff changeset
   193
            ^ ('NOT understood here: %1' bindWith:selector allBold),hint
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   194
        ].
1733
5a4d415c3bbc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1732
diff changeset
   195
    ].
5a4d415c3bbc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1732
diff changeset
   196
5a4d415c3bbc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1732
diff changeset
   197
    implementingClasses isNil ifTrue:[
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   198
        receiver := node receiver.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   199
        receiver isVariable ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   200
            nm := receiver name.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   201
            nm = 'self' ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   202
                srchClass := cls
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   203
            ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   204
            nm = 'super' ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   205
                srchClass := cls superclass
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   206
            ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   207
            definer := receiver whoDefines:nm.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   208
            definer isNil ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   209
                "/ not a local or argument
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   210
                (cls instanceVariableNames includes:nm) ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   211
                    "/ ok - an instVar; see what values we find...
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   212
                    instances := cls allSubInstances.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   213
                    classesOfInstVars := instances collect:[:eachInst | (eachInst instVarNamed:nm) class] as:Set.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   214
                    canBeNil := (classesOfInstVars remove:UndefinedObject ifAbsent:[]) notNil.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   215
                    "take care - Set cannot store nil!!"
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   216
                    implementingClasses := classesOfInstVars collect:[:cls | (cls whichClassIncludesSelector:selector) ? 0].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   217
                    implementingClasses remove:0 ifAbsent:[].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   218
                ] ifFalse:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   219
                    nm isUppercaseFirst ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   220
                        nm knownAsSymbol ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   221
                            globalValue := Smalltalk at:nm asSymbol.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   222
                            globalValue isClass ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   223
                                srchClass := globalValue class.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   224
                            ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   225
                        ]
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   226
                    ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   227
                ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   228
            ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   229
        ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   230
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   231
        receiver isLiteral ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   232
            srchClass := receiver value class
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   233
        ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   234
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   235
        srchClass notNil ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   236
            implClass := srchClass whichClassIncludesSelector:selector.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   237
            implClass isNil ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   238
                ^ '%1 is NOT understood here.' bindWith:boldSelectorString
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   239
            ].
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   240
            implementingClasses := { implClass }.
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   241
        ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   242
        implementingClasses isNil ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   243
            implementingClasses := Smalltalk allImplementorsOf:selector
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   244
        ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   245
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   246
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   247
    implementingClasses size == 1 ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   248
        |clsName|
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   249
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   250
        implClass := implementingClasses anElement.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   251
        implMethod := implClass compiledMethodAt:selector.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   252
        clsName := implClass name.
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   253
        clsName := self asLink:clsName to:(self actionToBrowseClass:implClass selector:selector).
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   254
        info := '%1 >> %2' bindWith:clsName "allBold" with:selectorString.
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   255
        info := self asLink:info to:(self actionToBrowseClass:implClass selector:selector).
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   256
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   257
        implMethodComment := self fetchCommentOfMethod:implMethod.
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   258
        implMethodComment notNil ifTrue:[
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   259
            info := info , ' ' , implMethodComment.
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   260
        ].
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   261
        ^ info
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   262
"/        (srchClass isNil and:[(cls includesBehavior:implClass) not]) ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   263
"/            "/ info := 'guess: ', info.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   264
"/            info := info , ' (guess)'.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   265
"/        ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   266
    ] ifFalse:[
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   267
        info := Explainer explainSelector:selector inClass:cls short:short.
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   268
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   269
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   270
"/    implementingClasses notEmptyOrNil ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   271
"/        implMethods := implementingClasses collect:[:implClass | implClass compiledMethodAt:selector].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   272
"/        implMethods size <= 8 ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   273
"/            implMethods size < 4 ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   274
"/                "/ show full comments
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   275
"/                comments := implMethods 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   276
"/                                collect:[:implMethod | implMethod comment]
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   277
"/                                thenSelect:[:comment | comment notEmptyOrNil].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   278
"/            ] ifFalse:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   279
"/                "/ show first lines one
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   280
"/                comments := implMethods 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   281
"/                                collect:[:implMethod | (self fetchCommentOfMethod:implMethod)]
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   282
"/                                thenSelect:[:comment | comment notEmptyOrNil].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   283
"/            ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   284
"/            comments := comments collect:[:each | each colorizeAllWith:(UserPreferences current commentColor) ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   285
"/            short ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   286
"/                comments := comments collect:[:implMethodComment | implMethodComment firstLine] as:Set.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   287
"/                comments size == 1 ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   288
"/                    ^ info , ' ' , (comments first).
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   289
"/                ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   290
"/                ^ info
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   291
"/            ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   292
"/            info := info,'\'withCRs.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   293
"/            comments 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   294
"/                with:implementingClasses 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   295
"/                do:[:eachComment :eachClass | 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   296
"/                    info := info,'\comment in ',eachClass name,':\',(eachComment asStringCollection asString) 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   297
"/                ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   298
"/        ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   299
"/    ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   300
    ^ info
1854
9dcdec831c46 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1771
diff changeset
   301
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   302
    "Modified: / 30-04-2016 / 17:08:11 / cg"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   303
!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   304
2193
9416fc17ee62 pass the interval to the explainer
Claus Gittinger <cg@exept.de>
parents: 2191
diff changeset
   305
explainMethodNode:node in:code forClass:cls short:short interval:intervalIfKnown
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   306
    |srchClass selector selectorString implClass
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   307
     "sendingMethods numSendingMethods sendingClasses" |
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   308
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   309
    selector := node selector.
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   310
    selector := selector asSymbolIfInterned.    "/ avoid creating new symbols.
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   311
    selectorString := selector printString contractTo:50.
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   312
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   313
    (srchClass := cls superclass) notNil ifTrue:[
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   314
        implClass := srchClass whichClassIncludesSelector:selector.
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   315
        implClass notNil ifTrue:[
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   316
            ^ '%1 overrides implementation in %2.'
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   317
              bindWith:(self asLink:selectorString "allBold" to:(self actionToOpenMethodFinderFor:selector))
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   318
              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
   319
        ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   320
    ].
2223
50b76baab48b changed: #explainMethodNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2214
diff changeset
   321
    (cls includesSelector:selector) ifFalse:[
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   322
        ^ '%1: a new method.' bindWith:selectorString "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   323
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   324
"/
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   325
"/        sendingMethods := SystemBrowser
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   326
"/                                allCallsOn:selector
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   327
"/                                in:(cls withAllSubclasses , cls allSubclasses)
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   328
"/                                ignoreCase:false
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   329
"/                                match:false.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   330
"/        sendingMethods := sendingMethods select:[:eachMethod | eachMethod mclass notNil].  "/ remove unbound ones
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   331
"/
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   332
"/        sendingClasses := (sendingMethods collect:[:eachMethod | eachMethod mclass]) asSet.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   333
"/        numSendingMethods := sendingMethods size.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   334
"/        numSendingMethods == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   335
"/            sendingClasses first == cls ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   336
"/                ^ '%1: sent locally from %2.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   337
"/                    bindWith:boldSelectorString
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   338
"/                    with:sendingMethods first selector "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   339
"/            ].
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   340
"/            ^ '%1: sent in hierarchy from %2 in %3.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   341
"/                bindWith:boldSelectorString
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   342
"/                with:sendingMethods first selector "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   343
"/                with:sendingClasses first name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   344
"/        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   345
"/        numSendingMethods == 2 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   346
"/            sendingClasses asIdentitySet size == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   347
"/                sendingClasses first == cls ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   348
"/                    ^ '%1: sent locally from %2 and %3.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   349
"/                        bindWith:boldSelectorString
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   350
"/                        with:sendingMethods first selector "allBold"
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   351
"/                        with:sendingMethods second selector "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   352
"/                ].
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   353
"/                ^ '%1: sent in hierarchy from %2 and %3 in %4.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   354
"/                    bindWith:boldSelectorString
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   355
"/                    with:sendingMethods first selector "allBold"
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   356
"/                    with:sendingMethods second selector "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   357
"/                    with:sendingClasses first name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   358
"/            ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   359
"/        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   360
"/        numSendingMethods == 0 ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   361
"/"/            ^ '%1: no sender found.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   362
"/"/                bindWith:boldSelectorString.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   363
"/            ^ nil
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   364
"/        ].
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   365
"/        ^ '%1: %2 sending methods in hierarchy.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   366
"/            bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   367
"/            with:numSendingMethods.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   368
"/
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   369
"/        "/ the following is too expensive...
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   370
"/"/        sendingMethods := SystemBrowser allCallsOn:selector in:Smalltalk allClasses.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   371
"/"/        numSendingMethods == 0 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   372
"/"/            ^ '%1: nowhere sent.' bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   373
"/"/        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   374
"/"/        numSendingMethods == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   375
"/"/            sendingMethods first mclass == cls ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   376
"/"/                ^ '%1: only sent from %2.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   377
"/"/                    bindWith:boldSelectorString
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   378
"/"/                    with:sendingMethods first selector "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   379
"/"/            ].
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   380
"/"/            ^ '%1: only sent from %2 in %3.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   381
"/"/                bindWith:boldSelectorString
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   382
"/"/                with:sendingMethods first selector "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   383
"/"/                with:sendingMethods first mclass name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   384
"/"/        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   385
"/"/        sendingClasses := (sendingMethods collect:[:eachMethod | eachMethod mclass]) asSet.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   386
"/"/        sendingClasses size == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   387
"/"/            sendingClasses first == cls ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   388
"/"/                ^ '%1: locally sent from %2 methods.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   389
"/"/                    bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   390
"/"/                    with:numSendingMethods
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   391
"/"/            ].
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   392
"/"/            ^ '%1 only sent from %2 methods in %3.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   393
"/"/                bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   394
"/"/                with:numSendingMethods
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   395
"/"/                with:sendingClasses first name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   396
"/"/        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   397
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   398
    ^ nil
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   399
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   400
    "Modified: / 09-10-2006 / 12:11:16 / cg"
1728
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
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   403
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
   404
    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
   405
!
9416fc17ee62 pass the interval to the explainer
Claus Gittinger <cg@exept.de>
parents: 2191
diff changeset
   406
9416fc17ee62 pass the interval to the explainer
Claus Gittinger <cg@exept.de>
parents: 2191
diff changeset
   407
explainNode:node in:code forClass:cls short:short interval:intervalIfKnown
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   408
    node isVariable ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   409
        ^ 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
   410
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   411
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   412
    node isLiteral ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   413
        ^ 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
   414
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   415
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   416
    node isMessage ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   417
        ^ 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
   418
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   419
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   420
    node isMethod ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   421
        ^ 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
   422
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   423
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   424
    ^ nil
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   425
!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   426
2193
9416fc17ee62 pass the interval to the explainer
Claus Gittinger <cg@exept.de>
parents: 2191
diff changeset
   427
explainVariableNode:node in:code forClass:cls short:short interval:intervalIfKnown
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   428
    |expl nm nmBold definingNode namePart argNode argClass argClassSet|
1728
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
    nm := node name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   431
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   432
    (#( 'self' 'super' 'thisContext' 'here') includes:nm) ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   433
        ^ Explainer explainPseudoVariable:nm in:cls short:short
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   434
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   435
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   436
    nm notNil ifTrue:[ nmBold := nm "allBold" ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   437
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   438
    definingNode := node whoDefines:nm.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   439
    definingNode notNil ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   440
        namePart := '''' , nmBold , ''''.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   441
        definingNode isMethod ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   442
            argNode := definingNode arguments detect:[:arg | arg name = nm] ifNone:nil.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   443
            argNode notNil ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   444
                expl := namePart , ' is a method argument.'.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   445
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   446
                argClassSet := self guessPossibleImplementorClassesFor:argNode in:code forClass:cls.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   447
                argClassSet size == 1 ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   448
                    argClass := argClassSet first.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
   449
                ].
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   450
            ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   451
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   452
        expl isNil ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   453
            definingNode isBlock ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   454
                (definingNode arguments contains:[:arg | arg name = nm]) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   455
                    expl := namePart , ' is a block argument.'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   456
                ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   457
            ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   458
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   459
        expl isNil ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   460
            | parentNode setOfTypes isLocal typesDescription|
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   461
            
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   462
            (parentNode := definingNode parent) notNil ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   463
                (isLocal := parentNode isMethod) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   464
                    expl := namePart , ' is a method temporary.'.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   465
                ] ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   466
                    (isLocal := parentNode isBlock) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   467
                       expl := namePart , ' is a block temporary.'.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   468
                    ]
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   469
                ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   470
                isLocal ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   471
                    setOfTypes := Set new.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   472
                    self addTypesAssignedToLocal:nm inTree:parentNode to:setOfTypes.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   473
                    typesDescription := self typeDescriptionFor:setOfTypes andSelector:nil.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   474
                    typesDescription notNil ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   475
                        expl := expl,' (',typesDescription,')'.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   476
                    ].    
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   477
                ].    
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   478
            ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   479
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   480
        expl isNil ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   481
            expl := namePart , ' is a temporary.'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   482
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   483
        (cls allInstanceVariableNames includes:nm) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   484
            expl := expl , ' (Instance Variable is hidden)'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   485
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   486
        ^ expl.
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   487
    ].
1938
8d0163055b68 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1926
diff changeset
   488
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   489
    ^ Explainer explain:node name in:code forClass:cls short:short
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   490
1938
8d0163055b68 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1926
diff changeset
   491
    "Modified: / 07-11-2006 / 12:22:09 / cg"
1728
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
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   494
fetchCommentOfMethod:mthd
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   495
    "retrieve the comment of a method (if possible and there is one; otherwise, return nil)"
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   496
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   497
    |windowGroup methodComment lines|
1909
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   498
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   499
    "/ with wait cursor, because it accesses sourcecode (via SCM)
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   500
    "/ however: this class is in libcomp (should be in libtool)
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   501
    "/ so check if WindowGroup (from libview) is present
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   502
    windowGroup := Smalltalk at:#WindowGroup.
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   503
    windowGroup isNil ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   504
        methodComment := mthd comment.
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   505
    ] ifFalse:[
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   506
        windowGroup activeGroup withWaitCursorDo:[
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   507
            methodComment := mthd comment.
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   508
        ].
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   509
    ].
3858
54188eb3549c #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3857
diff changeset
   510
    "/ Transcript showCR:methodComment.
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
   511
    
3047
3ca3ad7eb9b7 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 2988
diff changeset
   512
    methodComment isEmptyOrNil ifTrue:[^ nil].
1909
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   513
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   514
    lines := methodComment asStringCollection.
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   515
    methodComment := lines first.
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   516
    methodComment := methodComment withoutSeparators.
3156
b09c18add94f Changed usage of deprecated #copyWithoutLast: to #copyButLast:
Stefan Vogel <sv@exept.de>
parents: 3111
diff changeset
   517
    (methodComment endsWith:',') ifTrue:[ methodComment := methodComment copyButLast:1].
1909
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   518
    methodComment := methodComment withoutSeparators.
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   519
    (lines size > 1) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   520
        methodComment := methodComment , ' ...'
1909
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   521
    ].
3864
eaf361535167 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3861
diff changeset
   522
    ^ ('"' , methodComment , '"') withColor:(UserPreferences current commentColor).
1909
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   523
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   524
    "Created: / 14-09-2006 / 14:11:58 / cg"
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   525
    "Modified (comment): / 30-04-2016 / 16:17:18 / cg"
1909
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   526
!
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   527
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   528
guessPossibleImplementorClassesFor:node in:code forClass:cls
2191
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   529
    "given a node of some code of a method in cls,
2292
e5ccd3d7a805 changed: #guessPossibleImplementorClassesFor:in:forClass:
Stefan Vogel <sv@exept.de>
parents: 2288
diff changeset
   530
     return a collection of possible receiver classes."
2191
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   531
2809
bbf42cc4d305 changed: #guessPossibleImplementorClassesFor:in:forClass:
Claus Gittinger <cg@exept.de>
parents: 2471
diff changeset
   532
    |nm globalValue definer instances classesOfInstVars ns|
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   533
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   534
    node isVariable ifTrue:[
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   535
        nm := node name.
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   536
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   537
        nm = #self ifTrue:[
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   538
            ^ cls withAllSubclasses
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   539
        ].
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   540
        nm = #here ifTrue:[
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   541
            ^ cls withAllSuperclasses
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   542
        ].
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   543
        nm = #super ifTrue:[
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   544
            ^ cls allSuperclasses
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   545
        ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   546
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   547
        definer := node whoDefines:nm.
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   548
        definer isNil ifTrue:[
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   549
            "/ not a local or argument
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   550
            (cls instanceVariableNames includes:nm) ifTrue:[
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   551
                "/ ok - an instVar; see what values we find...
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   552
                instances := cls allSubInstances.
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   553
                classesOfInstVars := instances collect:[:eachInst | (eachInst instVarNamed:nm) class] as:Set.
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   554
                ^ classesOfInstVars.
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   555
            ].
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   556
            (cls classVariableNames includes:nm) ifTrue:[
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   557
                ^ Array with:(cls classVarAt:nm asSymbol) class.
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   558
            ].
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   559
            nm isUppercaseFirst ifTrue:[
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   560
                nm knownAsSymbol ifTrue:[
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   561
                    globalValue := Smalltalk at:nm asSymbol.
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   562
                    globalValue isClass ifTrue:[
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   563
                        ^ Array with:globalValue class.
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   564
                    ].
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   565
                ].
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   566
                ((ns := cls topNameSpace) notNil and:[ns ~~ Smalltalk]) ifTrue:[
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   567
                    nm knownAsSymbol ifTrue:[
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   568
                        globalValue := ns at:nm asSymbol.
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   569
                        globalValue isClass ifTrue:[
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   570
                            ^ Array with:globalValue class.
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   571
                        ].
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   572
                    ].
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   573
                ]
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   574
            ].
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   575
        ].
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   576
        ^ nil
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   577
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   578
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   579
    node isLiteral ifTrue:[
3549
c427fab999ae class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3548
diff changeset
   580
        ^ Array with:(node value class)
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   581
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   582
2191
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   583
"/    node isMessage ifTrue:[
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   584
"/        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
   585
"/        recClassSet isNil ifTrue:[ ^ nil ].
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   586
"/        recClassSet isEmpty ifTrue:[ ^ nil ].
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   587
"/
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   588
"/        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
   589
"/        "/ 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
   590
"/        ^ rsltClassSet.
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   591
"/    ].
1731
f10b69e9c3a1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1729
diff changeset
   592
    ^ nil
2809
bbf42cc4d305 changed: #guessPossibleImplementorClassesFor:in:forClass:
Claus Gittinger <cg@exept.de>
parents: 2471
diff changeset
   593
bbf42cc4d305 changed: #guessPossibleImplementorClassesFor:in:forClass:
Claus Gittinger <cg@exept.de>
parents: 2471
diff changeset
   594
    "Modified: / 07-02-2012 / 22:19:53 / cg"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   595
! !
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   596
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   597
!Explainer class methodsFor:'explaining-naive'!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   598
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   599
explain:someText in:source forClass:aClass
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   600
    "Given a source and a substring of it, return a string containing
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   601
     an explanation.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   602
     This is just a q&d implementation - to be correct, it should use the parser,
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   603
     and explain from the parsetree (instead of doing string matches).
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   604
     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
   605
     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
   606
     message selector. I.e. the explanation should be context sensitive.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   607
     Also, there could be much more detailed explanations."
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   608
2037
003d9b5a2788 explain shared pool variables
Claus Gittinger <cg@exept.de>
parents: 2031
diff changeset
   609
    ^ self explain:someText in:source forClass:aClass short:false
003d9b5a2788 explain shared pool variables
Claus Gittinger <cg@exept.de>
parents: 2031
diff changeset
   610
003d9b5a2788 explain shared pool variables
Claus Gittinger <cg@exept.de>
parents: 2031
diff changeset
   611
    "Modified: / 07-06-2007 / 11:34:05 / cg"
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   612
!
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   613
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   614
explain:someText in:source forClass:aClass short:shortText
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   615
    "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
   616
     an explanation.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   617
     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
   618
     and explain from the parsetree (instead of doing string matches).
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   619
     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
   620
     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
   621
     message selector. I.e. the explanation should be context sensitive.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   622
     Also, there could be much more detailed explanations."
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   623
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   624
    |explainer variables c string explanation tmp1
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   625
     spc sym sel stringText cls clsName val valString|
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   626
675
a2f41004c24d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 509
diff changeset
   627
    string := someText string withoutSeparators.
2314
0c590d9937bd changed: #explain:in:forClass:short:
Claus Gittinger <cg@exept.de>
parents: 2292
diff changeset
   628
    string isEmpty ifTrue:[ ^ nil ].
0c590d9937bd changed: #explain:in:forClass:short:
Claus Gittinger <cg@exept.de>
parents: 2292
diff changeset
   629
2214
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
   630
    stringText := string allBold.
2414
4da315c5bcf4 changed: #explain:in:forClass:short:
Claus Gittinger <cg@exept.de>
parents: 2316
diff changeset
   631
    "/ stringText := '''' , stringText , ''''.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   632
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   633
    "
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   634
     ask parser for variable names
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   635
    "
3070
aceab5843775 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3059
diff changeset
   636
    ParseError catch:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   637
        explainer := self parseMethod:source in:aClass ignoreErrors:true ignoreWarnings:true.
1357
3936e1d64491 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1352
diff changeset
   638
    ].
3320
d7f6dce69619 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3319
diff changeset
   639
    "/ bad leftover from a stupid return value from ancient times
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   640
    explainer == #Error ifTrue:[ explainer := nil ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   641
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   642
    (explainer notNil) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   643
        "look for variables"
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   644
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   645
        variables := explainer methodVars.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   646
        (variables notNil and:[variables includes:string]) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   647
            ^ stringText , ' a method variable.'
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   648
        ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   649
        variables := explainer methodArgs.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   650
        (variables notNil and:[variables includes:string]) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   651
            ^ stringText , ' a method argument.'
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   652
        ]
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   653
    ].
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   654
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   655
    explainer isNil ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   656
        explainer := self for:(ReadStream on:source) in:aClass
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   657
    ].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   658
2988
f3cd958d9fd2 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 2986
diff changeset
   659
    "instvars/class instVars"
84
claus
parents: 58
diff changeset
   660
    c := aClass whichClassDefinesInstVar:string.
claus
parents: 58
diff changeset
   661
    c notNil ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   662
        c isMeta ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   663
            clsName := c theNonMetaclass name.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   664
            shortText ifTrue:[
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   665
                clsName := self asLink:clsName to:(self actionToBrowseClass:c).
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   666
                stringText := stringText , ': a class instVar in ' , clsName
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   667
            ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   668
                stringText := stringText, ': a class instance variable inherited from ' , clsName
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   669
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   670
            val := aClass theNonMetaclass instVarNamed:string.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   671
            valString := self valueStringFor:val.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   672
            ^ stringText , ' (' , valString , ').'
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   673
        ].
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   674
        ^ self explainInstanceVariable:string inClass:c short:shortText.
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   675
    ].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   676
2986
cb591c4fc915 class: Explainer
Stefan Vogel <sv@exept.de>
parents: 2955
diff changeset
   677
    string isWideString ifFalse:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   678
        "classvars"
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   679
        c := explainer inWhichClassIsClassVar:string.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   680
        c notNil ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   681
            clsName := c name.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   682
            shortText ifTrue:[
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   683
                clsName := self asLink:clsName to:(self actionToBrowseClass:c).
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   684
                stringText := stringText , ': a classVar in ' , clsName
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   685
            ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   686
                stringText := stringText , ': a class variable in ' , clsName
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   687
            ].
2315
45f09cea2063 changed: #explain:in:forClass:short:
Claus Gittinger <cg@exept.de>
parents: 2314
diff changeset
   688
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   689
            val := c theNonMetaclass classVarAt:string. "/ Smalltalk at:(clsName , ':' , string) asSymbol.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   690
            valString := self valueStringFor:val.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   691
            ^ stringText , ' (' , valString , ').'
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   692
        ].
1693
b6ac1ae4e625 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1674
diff changeset
   693
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   694
        "private classes"
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   695
        c := aClass theNonMetaclass.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   696
        c privateClasses do:[:pClass |
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   697
            (pClass name = string
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   698
             or:[pClass nameWithoutPrefix = string]) ifTrue:[
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   699
                stringText := self asLink:stringText to:(self actionToBrowseClass:pClass).
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   700
                stringText := stringText , ': a private class in ''' , c name , '''.'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   701
                shortText ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   702
                    stringText := (stringText , '\\It is only visible locally.') withCRs
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   703
                ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   704
                ^ stringText withCRs
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   705
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   706
        ].
422
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   707
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   708
        aClass theNonMetaclass sharedPoolNames do:[:eachPoolName |
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   709
            |sharedPool sharedPoolSym poolName|
2037
003d9b5a2788 explain shared pool variables
Claus Gittinger <cg@exept.de>
parents: 2031
diff changeset
   710
3407
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   711
            sharedPoolSym := string asSymbolIfInterned.
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   712
            sharedPoolSym notNil ifTrue:[
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   713
                sharedPool := Smalltalk classNamed:eachPoolName.
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   714
                sharedPool notNil ifTrue:[
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   715
                    sharedPool isSharedPool ifFalse:[
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   716
                        ^ 'oops - not a shared pool: ',eachPoolName
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   717
                    ].
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   718
                    (sharedPool includesKey:sharedPoolSym) ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   719
                        poolName := sharedPool name.
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   720
                        poolName := self asLink:poolName to:(self actionToBrowseClass:sharedPool).
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   721
                        stringText := stringText , ': a pool variable in ',poolName.
3407
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   722
                        val := sharedPool at:sharedPoolSym.
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   723
                        valString := self valueStringFor:val.
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   724
                        ^ stringText , ' (' , valString , ').'
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   725
                    ].
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   726
                ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   727
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   728
        ].
2037
003d9b5a2788 explain shared pool variables
Claus Gittinger <cg@exept.de>
parents: 2031
diff changeset
   729
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   730
        "namespace & global variables"
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   731
        (spc := aClass nameSpace) notNil ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   732
            sym := (spc name , '::' , string) asSymbolIfInterned.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   733
            sym notNil ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   734
                (cls := Smalltalk at:sym) isBehavior ifTrue:[
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   735
                    stringText := self asLink:stringText to:(self actionToBrowseClass:cls).
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   736
                    string :=  stringText , ': '.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   737
                    cls name = sym ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   738
                        string :=  string , 'refers to ',cls name,', '
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   739
                    ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   740
                    cls isSharedPool ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   741
                        string := string , 'a sharedPool'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   742
                    ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   743
                        string := string , 'a class'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   744
                    ].
3049
a2d17670f62a class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3047
diff changeset
   745
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   746
                    string :=  string , ' in the ''' , spc name , ''' nameSpace'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   747
                    string := string , ' {', cls category ,'}'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   748
                    shortText ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   749
                        string := (string
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   750
                             , '\\It is only visible within this nameSpace.'
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   751
                             , '\Access from the outside is possible'
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   752
                             , '\by the special name ''' , spc name , '::' , string , '''.') withCRs
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   753
                    ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   754
                    ^ string withCRs
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   755
                ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   756
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   757
        ].
422
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   758
2315
45f09cea2063 changed: #explain:in:forClass:short:
Claus Gittinger <cg@exept.de>
parents: 2314
diff changeset
   759
    "/    string knownAsSymbol ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   760
            "globals & symbols"
839
021af12ebd18 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 835
diff changeset
   761
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   762
            explanation := self explainKnownSymbol:string inClass:aClass short:shortText.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   763
            explanation notNil ifTrue:[ 
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   764
                string isBinarySelector ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   765
                    "/ some are both known as syntax AND as selector (for example: #| )
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   766
                    tmp1 := self explainSyntax:string short:shortText.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   767
                    tmp1 notNil ifTrue:[ 
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   768
                        ^ tmp1 , '\\also:\\' withCRs , explanation
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   769
                    ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   770
                ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   771
                ^ explanation
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   772
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   773
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   774
            "/ try with added colon ...
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   775
            sel := string , ':'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   776
            Symbol allInstancesDo:[:sym |
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   777
                (sym startsWith:sel) ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   778
                    explanation := self explainKnownSymbol:sym inClass:aClass short:shortText.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   779
                    explanation notNil ifTrue:[ ^ explanation].
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   780
                ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   781
            ].
2315
45f09cea2063 changed: #explain:in:forClass:short:
Claus Gittinger <cg@exept.de>
parents: 2314
diff changeset
   782
    "/    ].
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   783
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   784
        "try for some obvious things"
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   785
        explanation := self explainPseudoVariable:string in:aClass short:true.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   786
        explanation notNil ifTrue:[ ^ explanation].
2315
45f09cea2063 changed: #explain:in:forClass:short:
Claus Gittinger <cg@exept.de>
parents: 2314
diff changeset
   787
    ].
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   788
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   789
    "try syntax ..."
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   790
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   791
    explanation := self explainSyntax:string short:shortText.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   792
    explanation notNil ifTrue:[ ^ explanation].
20
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
   793
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   794
    shortText ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   795
        ^ 'no explanation'
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   796
    ].
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   797
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   798
    explainer isNil ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   799
        ^ 'parse error - no explanation'
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   800
    ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   801
    ^ 'Sorry, I cannot explain this (could not figure out what this is).
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   802
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
   803
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   804
    "Created: / 03-12-1995 / 12:47:37 / cg"
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   805
    "Modified: / 16-04-1997 / 12:46:11 / stefan"
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   806
    "Modified: / 30-04-2016 / 15:00:28 / cg"
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   807
!
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   808
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   809
explainGlobal:string inClass:aClass short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   810
    "return an explanation or nil"
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   811
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   812
    ^ self explainGlobalOrPoolVariable:string inClass:aClass short:shortText
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   813
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   814
    "Modified: / 14-10-2010 / 11:33:17 / cg"
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   815
    "Modified (comment): / 28-02-2012 / 10:45:58 / cg"
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   816
!
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   817
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   818
explainGlobalOrPoolVariable:string inClass:aClass short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   819
    "return an explanation or nil"
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   820
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   821
    |sym stringText explanation val classCategory what pool valText doc|
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   822
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   823
    "if not even known as key, its definitely not a global"
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   824
    sym := string asSymbolIfInterned.
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
   825
    sym isNil ifTrue:[^ nil].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   826
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   827
    "a pool variable?"
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   828
    aClass notNil ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   829
        aClass theNonMetaclass sharedPoolNames do:[:eachPoolName |
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   830
            pool := Smalltalk at:eachPoolName.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   831
            pool isNil ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   832
            ] ifFalse:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   833
                (pool classVarNames includes:string) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   834
                    what := 'a pool variable in "%1".' bindWith:eachPoolName.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   835
                    val := pool classVarAt:sym.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   836
                ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   837
            ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   838
        ].
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   839
    ].
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   840
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   841
    stringText := string allBold.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   842
    "/ stringText := '''' , stringText , ''''.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   843
    stringText := stringText , ': '.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   844
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   845
    what isNil ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   846
        "try globals"
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   847
        (Smalltalk includesKey:sym) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   848
            what := 'a global variable.'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   849
            val := Smalltalk at:sym.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   850
        ] ifFalse:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   851
           (aClass theNonMetaclass sharedPoolNames includes:string) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   852
                pool := Smalltalk at:sym ifAbsent:nil.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   853
                pool isNil ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   854
                    ^ stringText,'a missing pool'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   855
                ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   856
            ] ifFalse:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   857
                ^ nil
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   858
            ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   859
        ].
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   860
    ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   861
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   862
    explanation := stringText , what.
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   863
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   864
    val isBehavior ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   865
        "/ a class
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   866
        val name = sym ifFalse:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   867
            stringText := stringText , ' a global; refers to ',val name,', '.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   868
        ].
1979
847742bcb22d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1943
diff changeset
   869
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   870
        (val isRealNameSpace) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   871
            ^ stringText , 'a namespace.'
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   872
        ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   873
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   874
        classCategory := val category ? 'uncategorized'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   875
        shortText ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   876
            stringText := stringText , (val isLoaded ifTrue:['a'] ifFalse:['an autoloaded']).
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   877
            stringText := stringText , (val isSharedPool ifTrue:[' sharedPool'] ifFalse:[' class']).
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   878
            stringText emphasisFrom:1 to:string size add:(#actionBlock -> [ val browse ]).
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   879
            ^ stringText , ' in ',val package,' {' , classCategory , '}.'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   880
        ].
1330
100f022924b6 oops - care for namespaces
ca
parents: 1317
diff changeset
   881
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   882
        val name = string ifTrue:[
3322
c4dfa6cff14b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3321
diff changeset
   883
            false ifTrue:[
c4dfa6cff14b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3321
diff changeset
   884
                "/ TODO: generate a short documentation string (comment plus interface)
c4dfa6cff14b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3321
diff changeset
   885
                "/ and return { #html->htmlText . #text->regularText}
c4dfa6cff14b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3321
diff changeset
   886
                "/ so caller can extrat what he wants to see...
3841
a22f33410bdf Reduced dependencies
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3839
diff changeset
   887
                ^ ((Smalltalk at:#HTMLDocGenerator) htmlDocOf:val).
3322
c4dfa6cff14b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3321
diff changeset
   888
            ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   889
            explanation := explanation , '\' withCRs , string , ' is '.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   890
            explanation := explanation , (val isLoaded ifTrue:['a'] ifFalse:['an autoloaded']).
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   891
            explanation := explanation , (val isSharedPool ifTrue:[' sharedPool'] ifFalse:[' class']).
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   892
            explanation := explanation , ' categorized as "' , classCategory , '"'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   893
            explanation := explanation , '\' withCRs , 'in the "' , val package , '" package.'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   894
            (doc := val commentOrDocumentationString) notEmptyOrNil ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   895
                doc := doc asStringCollection.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   896
                doc size > 25 ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   897
                    doc := doc copyTo:25.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   898
                    doc add:''; add:'   ... <more documentation cut off>'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   899
                ].
3864
eaf361535167 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3861
diff changeset
   900
                doc := doc asString withColor:(UserPreferences current commentColor).
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   901
                explanation := explanation,'\\' withCRs,val name,'''s documentation:\'withCRs, doc
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   902
            ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   903
            ^ explanation.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   904
        ].
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   905
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   906
        explanation := explanation , '
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   907
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   908
' , string , ' is bound to the class ' , val name ,
3049
a2d17670f62a class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3047
diff changeset
   909
' in the "' , classCategory , '" category.'.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   910
        ^ explanation.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   911
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   912
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   913
    valText := self valueStringFor:val.
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   914
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   915
    shortText ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   916
        ^ stringText,' a global (',valText,')'.
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   917
    ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   918
    explanation := explanation , '
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   919
2466
75b29e4a34c0 changed: #explainGlobalOrPoolVariable:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2427
diff changeset
   920
Its current value is "%1".' bindWith:valText.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   921
    ^ explanation.
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   922
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   923
    "Created: / 14-10-2010 / 11:33:04 / cg"
2815
a04d0047c512 changed:
Claus Gittinger <cg@exept.de>
parents: 2809
diff changeset
   924
    "Modified: / 14-02-2012 / 15:31:28 / cg"
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   925
    "Modified (comment): / 28-02-2012 / 10:45:48 / cg"
3841
a22f33410bdf Reduced dependencies
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3839
diff changeset
   926
    "Modified: / 05-05-2016 / 00:25:40 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   927
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   928
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   929
explainHereIn:aClass
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   930
    "return an explanation"
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   931
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   932
    <resource: #obsolete>
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   933
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   934
    ^ self explainHereIn:aClass short:false
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   935
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   936
    "Modified (comment): / 28-02-2012 / 10:47:29 / cg"
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   937
!
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   938
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   939
explainHereIn:aClass short:shortText
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   940
    "return an explanation"
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   941
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   942
    |className|
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   943
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   944
    className := aClass name.
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   945
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   946
    shortText ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   947
        ^ '"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
   948
    ].
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   949
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   950
    ^ '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
   951
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   952
However, when sending a message to "here", the search for methods
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   953
implementing this message will start in the defining class (' , className , '),
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   954
instead of the receiver''s class (' , className , ' or subclass).
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   955
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
   956
that the local method is called.'
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   957
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   958
    "Created: / 28-02-2012 / 10:44:55 / cg"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   959
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   960
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   961
explainInstanceVariable:instVarName inClass:aClass short:shortText
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
   962
    |varNameInText classNameInText template stringText setOfTypes typesDescription|
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   963
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
   964
    varNameInText := instVarName allBold.
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
   965
    classNameInText := aClass name.
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
   966
    
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   967
    shortText ifTrue:[
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
   968
        template := '%1: an instVar in %2'.
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   969
        varNameInText := self asLink:varNameInText to:(self actionToBrowseInstvarRefsTo:instVarName inClass:aClass).
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
   970
        classNameInText := self asLink:classNameInText to:(self actionToBrowseClass:aClass).
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   971
    ] ifFalse:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   972
        template := '%1: an instance variable in %2'
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   973
    ].
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
   974
    stringText := template bindWith:varNameInText with:classNameInText.
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   975
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   976
    "/ look for instances
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   977
    setOfTypes := IdentitySet new.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   978
    self addTypesOfInstvar:instVarName inClass:aClass fromExistingInstancesTo:setOfTypes.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   979
    "/ look for assignments
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   980
    aClass withAllSubclassesDo:[:cls | self addTypesAssignedToInstvar:instVarName inClass:cls to:setOfTypes].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   981
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   982
    typesDescription := self typeDescriptionFor:setOfTypes andSelector:nil.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   983
    typesDescription notNil ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   984
        stringText := stringText,' (',typesDescription,')'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
   985
    ].
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   986
    ^ stringText
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   987
!
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
   988
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   989
explainKnownSymbol:string inClass:aClass
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   990
    "return an explanation or nil"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   991
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   992
    ^ self explainKnownSymbol:string inClass:aClass short:false
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   993
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   994
    "Modified (comment): / 28-02-2012 / 10:45:40 / cg"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   995
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   996
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   997
explainKnownSymbol:string inClass:aClass short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   998
    "return an explanation or nil"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   999
2471
2d80a20bde1c changed:
Claus Gittinger <cg@exept.de>
parents: 2470
diff changeset
  1000
    |sym expl|
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1001
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1002
    sym := string asSymbolIfInterned.
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1003
    sym isNil ifTrue:[^ nil].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1004
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1005
    "try globals and pools"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1006
    (Smalltalk includesKey:sym) ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1007
        expl := self explainGlobalOrPoolVariable:string inClass:aClass short:shortText.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1008
        expl notNil ifTrue:[^ expl].
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1009
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1010
2471
2d80a20bde1c changed:
Claus Gittinger <cg@exept.de>
parents: 2470
diff changeset
  1011
    expl := self explainSelector:string inClass:aClass short:shortText.
2d80a20bde1c changed:
Claus Gittinger <cg@exept.de>
parents: 2470
diff changeset
  1012
    expl notNil ifTrue:[^ expl].
2d80a20bde1c changed:
Claus Gittinger <cg@exept.de>
parents: 2470
diff changeset
  1013
    ^ self explainGlobalOrPoolVariable:string inClass:aClass short:shortText.
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1014
2471
2d80a20bde1c changed:
Claus Gittinger <cg@exept.de>
parents: 2470
diff changeset
  1015
    "Modified: / 18-01-2011 / 19:13:07 / cg"
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1016
    "Modified (comment): / 28-02-2012 / 10:46:06 / cg"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1017
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1018
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1019
explainPseudoVariable:string in:aClass
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1020
    "return an explanation for the pseudoVariables self, super etc."
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1021
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1022
    <resource: #obsolete>
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1023
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1024
    ^ self explainPseudoVariable:string in:aClass short:false
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1025
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1026
    "Modified (format): / 28-02-2012 / 10:47:17 / cg"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1027
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1028
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1029
explainPseudoVariable:string in:aClass short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1030
    "return an explanation for the pseudoVariables self, super etc."
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1031
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1032
    (string = 'self') ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1033
        ^ self explainSelfIn:aClass short:shortText
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1034
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1035
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1036
    (string = 'super') ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1037
        ^ self explainSuperIn:aClass short:shortText
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1038
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1039
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1040
    (string = 'here') ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1041
        ^ self explainHereIn:aClass short:shortText
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1042
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1043
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1044
    (string = 'thisContext') ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1045
        shortText ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1046
            ^ '''thisContext'' - the current stack frame as an object.'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1047
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1048
        ^ '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
  1049
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1050
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
  1051
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
  1052
receivers/selectors can be accessed via thisContext.'
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1053
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1054
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1055
    (string = 'true') ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1056
        shortText ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1057
            ^ '''true'' - the truth and nothing but the truth.'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1058
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1059
        ^ '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
  1060
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1061
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
  1062
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1063
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1064
    (string = 'false') ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1065
        shortText ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1066
            ^ '''false'' - obvisously not true.'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1067
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1068
        ^ '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
  1069
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1070
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
  1071
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1072
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1073
    (string = 'nil') ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1074
        shortText ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1075
            ^ '''nil'' - undefined, unknown, void or dont care.'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1076
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1077
        ^ '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
  1078
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1079
Nil is used for unitialized variables (among other uses).
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1080
Nil is the one and only instance of class UndefinedObject.'
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1081
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1082
    ^ nil
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1083
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1084
    "Modified (comment): / 28-02-2012 / 10:46:18 / cg"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1085
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1086
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1087
explainSelector:string inClass:aClass short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1088
    "return an explanation or nil"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1089
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1090
    |selector listOfImplementingClasses listOfImplementingClassNames listOfSimilarSelectors
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1091
     firstImplementingClassOfSimilar count tmp commonSuperClass s s2
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1092
     firstImplementingClass 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1093
     firstImplementingClassName secondImplementingClassName thirdImplementingClassName
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1094
     classProvidingComment
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1095
     cm msg t check|
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1096
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1097
    selector := string asSymbolIfInterned.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1098
    selector isNil ifTrue:[^ nil].
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1099
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1100
    "/ look who implements it    
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1101
    listOfImplementingClassNames := Set new.
3174
e3e1c0bde329 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3156
diff changeset
  1102
    listOfImplementingClasses := Set new.
e3e1c0bde329 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3156
diff changeset
  1103
    listOfSimilarSelectors := Set new.
2288
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1104
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1105
    check :=
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1106
        [:sel :mthd :cls |
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1107
            sel == selector ifTrue:[
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1108
                listOfImplementingClasses add:cls.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1109
                listOfImplementingClassNames add:(cls name).
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1110
                firstImplementingClass isNil ifTrue:[
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1111
                    firstImplementingClass := cls.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1112
                    firstImplementingClassName := cls name.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1113
                ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1114
            ] ifFalse:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1115
                (sel startsWith:selector) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1116
                    listOfSimilarSelectors add:sel.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1117
                    firstImplementingClassOfSimilar isNil ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1118
                        firstImplementingClassOfSimilar := cls
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1119
                    ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1120
                ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1121
            ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1122
        ].
2288
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1123
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1124
    Smalltalk allClassesDo:[:c|
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1125
        c methodDictionary keysAndValuesDo:[:sel :mthd |
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1126
            check value:sel value:mthd value:c
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1127
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1128
        c class methodDictionary keysAndValuesDo:[:sel :mthd |
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1129
            check value:sel value:mthd value:c class
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1130
        ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1131
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1132
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1133
    (aClass canUnderstand:selector) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1134
        s2 := ('Instances of ''' , aClass name , ''' respond to #') , selector "allBold" , '.'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1135
        shortText ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1136
            s2 := '\\' , s2
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1137
                  , '\- inherited from ' withCRs
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1138
                  , (aClass whichClassIncludesSelector:selector) name "allBold".
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1139
        ].
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1140
        firstImplementingClass := (aClass whichClassIncludesSelector:selector)
835
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
  1141
    ] ifFalse:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1142
        s2 := ''.
835
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
  1143
    ].
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
  1144
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1145
    count := listOfImplementingClassNames size.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1146
    (count ~~ 0) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1147
        "
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1148
         for up-to 4 implementing classes,
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1149
         list them
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1150
        "
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1151
        listOfImplementingClassNames := listOfImplementingClassNames asOrderedCollection sort.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1152
        shortText ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1153
            tmp := ' is implemented in '.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1154
        ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1155
            tmp := ' is a selector implemented in '.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1156
        ].
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  1157
        s := string allBold.
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  1158
        count > 1 ifTrue:[
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  1159
            s := self asLink:s to:(self actionToOpenMethodFinderFor:selector).
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1160
        ] ifFalse:[    
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  1161
            s := self asLink:s to:(self actionToBrowseImplementorsOf:selector).
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1162
        ].
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1163
        
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1164
        shortText ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1165
            |typesDescription|
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1166
            
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1167
            msg := s , tmp.
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1168
            typesDescription := self typeDescriptionFor:listOfImplementingClasses andSelector:selector wordBetween:'and'.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1169
            typesDescription notNil ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1170
                msg := msg,typesDescription
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1171
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1172
        ] ifFalse:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1173
            (count == 1) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1174
                t := firstImplementingClassName.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1175
                firstImplementingClass isMeta ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1176
                    t := 'the ' , t
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1177
                ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1178
                msg := s , tmp , t , '.'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1179
                shortText ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1180
                    msg := msg , s2.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1181
                ]
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1182
            ] ifFalse:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1183
                firstImplementingClassName := listOfImplementingClassNames at:1.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1184
                secondImplementingClassName := listOfImplementingClassNames at:2.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1185
                (count == 2) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1186
                    msg := s,tmp,firstImplementingClassName,' and ',secondImplementingClassName,'.'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1187
                    shortText ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1188
                        msg := msg , s2.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1189
                    ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1190
                ] ifFalse:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1191
                    thirdImplementingClassName := listOfImplementingClassNames at:3.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1192
                    (count == 3) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1193
                        msg := s,tmp,firstImplementingClassName,',',secondImplementingClassName,' and ',thirdImplementingClassName,'.'.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1194
                        shortText ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1195
                            msg := msg , s2.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1196
                        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1197
                    ] ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1198
                        false "shortText" ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1199
                            msg := s , tmp , count printString , ' classes'.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1200
                            commonSuperClass := Class commonSuperclassOf:listOfImplementingClassNames.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1201
                            commonSuperClass notNil ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1202
                                (commonSuperClass == Object
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1203
                                and:[commonSuperClass includesSelector:selector]) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1204
                                    msg := msg , ' (including ' , 'Object' "allBold", ')'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1205
                                ] ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1206
                                    (commonSuperClass ~= Object) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1207
                                        msg := msg , ' (under ' , commonSuperClass name, ')'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1208
                                    ]
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1209
                                ].
3492
1867a7dfc26f class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3464
diff changeset
  1210
                            ].
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1211
                            msg := msg , '.'.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1212
                            ^ msg
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1213
                        ].
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1214
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1215
                        "
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1216
                         if there are more, look for a common
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1217
                         superclass and show it ...
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1218
                        "
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1219
                        commonSuperClass := (Behavior commonSuperclassOf:listOfImplementingClasses) ? Object.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1220
                        (commonSuperClass ~~ Object
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1221
                        and:[commonSuperClass ~~ Behavior
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1222
                        and:[commonSuperClass ~~ Class
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1223
                        and:[commonSuperClass ~~ ClassDescription]]]) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1224
                            (listOfImplementingClasses includes:commonSuperClass) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1225
                                msg := s . tmp , count printString , commonSuperClass name
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1226
                                         , ' and redefined in ' , (count - 1) printString
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1227
                                         , ' subclasses'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1228
                                         , s2.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1229
                                firstImplementingClass := commonSuperClass
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1230
                            ] ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1231
                                msg := s , tmp, count printString , ' subclasses of ' , commonSuperClass name , s2
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1232
                            ]
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1233
                        ] ifFalse:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1234
                            (commonSuperClass == Object
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1235
                            and:[commonSuperClass includesSelector:selector]) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1236
                                shortText ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1237
                                    msg := s , tmp , count printString , ' classes (incl. Object)'.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1238
                                ] ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1239
                                    msg := s , tmp , count printString , ' classes.
3804
f1ad0e2b65f8 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3801
diff changeset
  1240
 
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1241
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
  1242
since there is an implementation in Object.' , s2.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1243
                                ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1244
                                firstImplementingClass := Object
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1245
                            ] ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1246
                                ((commonSuperClass == Behavior
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1247
                                 or:[commonSuperClass == Class
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1248
                                 or:[commonSuperClass == ClassDescription]])
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1249
                                and:[commonSuperClass includesSelector:selector]) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1250
                                    shortText ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1251
                                        msg := s , tmp , count printString , ' classes (incl. all classes)'.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1252
                                    ] ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1253
                                        msg := s , tmp , count printString , ' classes.
913
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
  1254
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1255
All classes seem to respond to that message,
913
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
  1256
since there is an implementation in ' , commonSuperClass name , '.' , s2.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1257
                                    ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1258
                                    firstImplementingClass := commonSuperClass
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1259
                                ] ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1260
                                    "
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1261
                                     otherwise just give the number.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1262
                                    "
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1263
                                    msg := s , tmp , count printString , ' classes.' , s2
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1264
                                ]
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1265
                            ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1266
                        ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1267
                    ]
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1268
                ].
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1269
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1270
        ].
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1271
        "/ look for a comment...
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1272
        count == 1 ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1273
            classProvidingComment := firstImplementingClass.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1274
        ] ifFalse:[
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1275
            commonSuperClass isNil ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1276
                commonSuperClass := Behavior commonSuperclassOf:listOfImplementingClasses.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1277
            ] .
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1278
            (listOfImplementingClasses includes:commonSuperClass) ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1279
                (commonSuperClass implements:selector) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1280
                    classProvidingComment := commonSuperClass
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1281
                ] ifFalse:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1282
                    classProvidingComment := firstImplementingClass.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1283
                ].
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1284
            ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1285
        ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1286
        classProvidingComment notNil ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1287
            cm := self fetchCommentOfMethod:(classProvidingComment compiledMethodAt:selector).
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1288
        ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1289
        cm isNil ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1290
            "/ should: find the class with most subclasses from the list
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1291
            (listOfImplementingClasses includes:Collection) ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1292
                classProvidingComment := Collection
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1293
            ] ifFalse:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1294
                (listOfImplementingClasses includes:Stream) ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1295
                    classProvidingComment := Stream
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1296
                ] ifFalse:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1297
                    classProvidingComment := listOfImplementingClasses detect:[:cls | (self fetchCommentOfMethod:(cls compiledMethodAt:selector)) notNil] ifNone:nil.
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1298
                ]
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1299
            ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1300
            classProvidingComment notNil ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1301
                cm := self fetchCommentOfMethod:(classProvidingComment compiledMethodAt:selector).
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1302
                cm notNil ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1303
                    cm := (' %1 says: ' bindWith:classProvidingComment name),cm
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1304
                ].
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1305
            ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1306
        ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1307
        cm notNil ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1308
            msg := msg,(msg last isSeparator ifTrue:[''] ifFalse:[' ']),cm
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1309
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1310
        ^ msg
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1311
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1312
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1313
    "/ none implements it (type?);
3174
e3e1c0bde329 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3156
diff changeset
  1314
    count := listOfSimilarSelectors size.
2288
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1315
    (count ~~ 0) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1316
        listOfSimilarSelectors := listOfSimilarSelectors asOrderedCollection sort.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1317
        shortText ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1318
            tmp := ' is implemented in '.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1319
        ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1320
            tmp := ' is a selector implemented in '.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1321
        ].
2288
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1322
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1323
        (count == 1) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1324
            msg := listOfSimilarSelectors first allBold , tmp , firstImplementingClassOfSimilar name , '.'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1325
            shortText ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1326
                msg := msg , s2.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1327
            ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1328
        ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1329
            msg := 'similar selectors: %1, %2' bindWith:listOfSimilarSelectors first allBold with:listOfSimilarSelectors second allBold.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1330
            count > 2 ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1331
                msg := msg,'...'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1332
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1333
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1334
        ^ msg
2288
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1335
    ].
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1336
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1337
    ^ nil
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
  1338
1909
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
  1339
    "Modified: / 17-06-1996 / 17:09:30 / stefan"
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
  1340
    "Created: / 23-03-1999 / 13:29:33 / cg"
3804
f1ad0e2b65f8 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 3801
diff changeset
  1341
    "Modified: / 01-05-2016 / 15:42:24 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1342
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1343
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1344
explainSelfIn:aClass short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1345
    "return an explanation"
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1346
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1347
    |sub subNames selfString className nSubClasses|
1198
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
  1348
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
  1349
    selfString := '''' , 'self' "allBold" , ''''.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1350
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1351
    sub := aClass allSubclasses.
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1352
    nSubClasses := sub size.
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1353
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1354
    aClass isMeta ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1355
        className := aClass theNonMetaclass name.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1356
        subNames := sub collect:[:c | c theNonMetaclass name].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1357
        nSubClasses == 0 ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1358
            shortText ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1359
                ^ selfString , ' - the ''' , className , '''-class.'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1360
            ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1361
            ^ selfString , 'refers to the object which received the message.
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1362
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1363
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
  1364
        ].
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1365
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1366
        shortText ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1367
            nSubClasses == 1 ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1368
                ^ selfString , ' - the ''' , className , '''- or ''' , subNames first , '''-class.'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1369
            ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1370
            ^ selfString , ' - the ''' , className , '''-class or one of its subclasses.'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1371
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1372
        nSubClasses <= 5 ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1373
            ^ selfString , ' refers to the object which received the message.
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1374
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1375
In this case, it will be the ' , className , '-class
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1376
or one of its subclasses:
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1377
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1378
' , subNames asStringCollection asString
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1379
        ].
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1380
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1381
        ^ selfString , ' refers to the object which received the message.
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1382
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1383
In this case, it will be the ' , className , '-class
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1384
or one of its ' , nSubClasses printString , ' subclasses.'
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1385
    ].
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1386
1256
cc3fa02585ec *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
  1387
    subNames := aClass allSubclasses collect:[:c | c theNonMetaclass name].
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1388
    className := aClass name.
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1389
    nSubClasses == 0 ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1390
        shortText ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1391
            ^ selfString , ' - an instance of ''' , className , '''.'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1392
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1393
        ^ selfString , 'refers to the object which received the message.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1394
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1395
In this case, it will be an instance of ' , className , '.'
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1396
    ].
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1397
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1398
    shortText ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1399
        nSubClasses == 1 ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1400
            ^ selfString , ' - an instance of ''' , className , ''' or ''' , subNames first , '''.'
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1401
        ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1402
        ^ selfString , ' - an instance of ''' , className , ''' or one of its subclasses.'
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1403
    ].
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1404
    nSubClasses <= 5 ifTrue:[
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1405
        ^ selfString , ' refers to the object which received the message.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1406
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1407
In this case, it will be an instance of ' , className , '
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1408
or one of its subclasses:
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1409
1256
cc3fa02585ec *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
  1410
' , subNames asStringCollection asString
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1411
    ].
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1412
1198
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
  1413
    ^ selfString , ' refers to the object which received the message.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1414
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1415
In this case, it will be an instance of ' , className , '
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1416
or one of its ' , nSubClasses printString , ' subclasses.'
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
  1417
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
  1418
    "Modified: / 09-10-2006 / 12:11:44 / cg"
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1419
    "Modified (comment): / 28-02-2012 / 10:47:06 / cg"
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1420
!
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1421
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1422
explainSuperIn:aClass short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1423
    "return an explanation"
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1424
1352
e9e91394ca1a Remove unused method variables
Stefan Vogel <sv@exept.de>
parents: 1331
diff changeset
  1425
    |superName|
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1426
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1427
    superName := aClass superclass name.
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1428
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1429
    shortText ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1430
        ^ '"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
  1431
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1432
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1433
    ^ 'like "self", "','super'allBold,'" refers to the object which received the message.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1434
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1435
However, when sending a message to "super", the search for methods
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1436
implementing this message will start in the superclass (' , superName , '),
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1437
instead of the receiver''s class (' , aClass name , ' or subclass).
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1438
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
  1439
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1440
    "Modified (comment): / 28-02-2012 / 10:47:03 / cg"
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1441
!
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
  1442
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1443
explainSyntax:string
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1444
    "try syntax ...; return explanation or nil"
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1445
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1446
    ^ self explainSyntax:string short:false
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1447
!
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1448
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1449
explainSyntax:string short:shortText
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1450
    "try syntax ...; return explanation or nil.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1451
     This is meant for beginners..."
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1452
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1453
    ((string = ':=') or:[string = '_']) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1454
        shortText ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1455
            string = '_' ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1456
                ^ '"_" - old style for assignment. Consider changing to ":=".'
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1457
            ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1458
            ^ '":=" - assign to variable on the left (syntax).'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1459
        ].
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1460
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1461
        ^ '<variable> := <expression>
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1462
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1463
":=" and "_" (which is left-arrow in some fonts) mean assignment.
3464
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1464
The variable is bound to (i.e. points to) the value of <expression>.
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1465
The "_" form is historic and should not be used with new code.'
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1466
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1467
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1468
    (string = '^') ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1469
        shortText ifTrue:[
3607
58a91ac8dfb5 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3601
diff changeset
  1470
            ^ '"^" - return value from method (syntax)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1471
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1472
        ^ '^ <expression>
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1473
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1474
A return statement evaluates <expression> and returns its value from the method.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1475
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
  1476
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1477
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1478
    (string = ';') ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1479
        shortText ifTrue:[
3607
58a91ac8dfb5 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3601
diff changeset
  1480
            ^ '";" - a cascade expression (syntax)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1481
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1482
        ^ '<expression> ; selector1 ; .... ; selectorN
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1483
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1484
a cascade expression; evaluate expression, and send messages
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1485
<selector1> ... <selectorN> to the first expression''s receiver.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1486
Returns the value of the last send. The cascade sends may also have arguments.'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1487
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1488
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1489
    (string = '|') ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1490
        shortText ifTrue:[
3607
58a91ac8dfb5 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3601
diff changeset
  1491
            ^ '"|" - local variables (syntax)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1492
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1493
        ^ '| locals |  or: [:arg | statements]
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1494
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1495
"|" is used to mark a local variable declaration or separates arguments
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1496
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
  1497
these arg nams must be prefixed by a colon character.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1498
"|" is also a selector understood by Booleans.'
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1499
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1500
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1501
    (string startsWith:'$' ) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1502
        shortText ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1503
            ^ '"$x" - ',(self asClassLink:'Character'),' literal (syntax)'.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1504
        ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1505
        ^ 'is a Character literal constant.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1506
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1507
Character objects represent indivdual text cheracters in Unicode encoding.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1508
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
  1509
Smalltalk/X supports unicode and uses this encoding internally for all characters
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1510
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
  1511
    ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1512
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1513
    (string startsWith:'#' ) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1514
        (string startsWith:'#(' ) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1515
            shortText ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1516
                ^ '"#(..)" - ',(self asClassLink:'Array'),' literal (syntax)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1517
            ].
3607
58a91ac8dfb5 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3601
diff changeset
  1518
            ^ 'is a constant Array (literal).
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1519
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1520
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
  1521
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
  1522
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
  1523
other array constants or byte-arrays.
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1524
(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
  1525
 element in an Array-constant).'
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1526
        ].
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1527
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1528
        (string startsWith:'#[') ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1529
            shortText ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1530
                ^ '"#[..]" - ',(self asClassLink:'ByteArray'),' literal (syntax)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1531
            ].
3607
58a91ac8dfb5 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3601
diff changeset
  1532
            ^ 'is a constant ByteArray (literal).
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1533
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1534
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
  1535
0 .. 255.
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1536
(notice, that not all Smalltalk implementations support constant ByteArrays).'
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1537
        ].
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1538
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1539
        (string startsWith:'#''') ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1540
            shortText ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1541
                ^ '"#''..''" - ',(self asClassLink:'Symbol'),' literal (syntax)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1542
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1543
            ^ 'is a constant symbol containing non-alphanumeric characters.
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1544
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1545
Symbols are unique strings, meaning that there exists
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1546
exactly one instance of a given symbol. Therefore symbols can
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1547
be compared using == (identity compare) in addition to = (contents compare).
3194
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1548
Beside this, Symbols behave mostly like Strings but are immutable.'
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1549
        ].
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1550
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1551
        shortText ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1552
            ^ '"#.." - ',(self asClassLink:'Symbol'),' literal (syntax)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1553
        ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1554
        ^ 'is a constant symbol.
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1555
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1556
Symbols are unique strings, meaning that there exists
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1557
exactly one instance of a given symbol. Therefore symbols can
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1558
be compared using == (identity compare) in addition to = (contents compare).
3194
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1559
Beside this, Symbols behave mostly like Strings but are immutable.'
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1560
    ].
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1561
    ((string startsWith:'(') or:[string endsWith:')']) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1562
        shortText ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1563
            ^ ''.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1564
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1565
        ^ '( <expression> )
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1566
3194
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1567
expression grouping. Without them, expressions are evaluated left to right,
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1568
with unary messages preceeding binary messages, preceeding keyword mesages.'
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1569
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1570
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1571
    ((string startsWith:'[') or:[string endsWith:']']) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1572
        shortText ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1573
            ^ '"[..]" - a ',(self asClassLink:'Block'),' (aka lambda/closure for experts)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1574
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1575
        ^ '[:arg1 .. :argN | statements]
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1576
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1577
defines a block.
3194
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1578
Blocks represent pieces of executable code. The definition of a block does
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1579
not evaluate it, instead a reference to the blocks computation is created.
3194
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1580
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
  1581
(it can be even evaluated multiple times).
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1582
Blocks are often passed as arguments to Booleans (i.e. "bool ifTrue:[...]"),
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1583
other blocks (i.e. "[...] whileTrue: [...]"]) or collections (i.e. "coll do:[...]").
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1584
Blocks are also often used as callbacks from UI components or as exception handlers.'
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1585
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1586
2286
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1587
    ((string startsWith:'{') or:[string endsWith:'}']) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1588
        shortText ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1589
            ^ '"{..}" ',(self asClassLink:'Array'),' instantiation (syntax)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1590
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1591
        ^ '{ <expr1>. .. <exprN> }
2286
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1592
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1593
This is syntactic sugar for "Array with:<expr1> .. with:<exprN>".
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1594
2286
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1595
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
  1596
The expressions are separated by a period statement separator.
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1597
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
  1598
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
  1599
compilation time) and which is shared.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1600
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
  1601
makes your program somewhat dialect specific.'
2286
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1602
    ].
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1603
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1604
    (string = ':') ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1605
        shortText ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1606
            ^ ''.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1607
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1608
        ^ 'colons have different meaning depending on context:
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1609
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1610
1) they separate keyword-parts in symbols and keyword-messages as in:
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1611
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1612
    #at:put:                     a constant keyword symbol
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1613
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1614
    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
  1615
                                 passing index and value as arguments.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1616
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1617
2) within block-argument declarations as in:
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1618
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1619
    [:arg1 :arg2 | statements]
834
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1620
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1621
3) within an identifier, they separate the nameSpace part from
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1622
   the name part; as in:
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1623
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1624
    Smalltalk::Array    - the Array class in the Smalltalk nameSpace.
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1625
    Foo::Array          - the Array class in the Foo nameSpace.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1626
'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1627
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1628
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1629
    (string = '.') ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1630
        ^ 'statement. "<- period here"
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1631
statement
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1632
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1633
within a method or block, individual statements are separated by periods.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1634
'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1635
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1636
3464
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1637
    (string withoutSeparators startsWith:'"') ifTrue:[
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1638
        (string withoutSeparators startsWith:'"/') ifTrue:[
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1639
            shortText ifTrue:[
3607
58a91ac8dfb5 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3601
diff changeset
  1640
                ^ 'an end-of-line comment (syntax)'.
3464
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1641
            ].
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1642
            ^ '"/ comment
3193
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1643
EOL (end-of-line) comment
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1644
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1645
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
  1646
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
  1647
'
3464
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1648
        ].
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1649
        (string withoutSeparators startsWith:'"<<') ifTrue:[
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1650
            shortText ifTrue:[
3607
58a91ac8dfb5 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3601
diff changeset
  1651
                ^ 'a token delimited comment (syntax)'.
3464
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1652
            ].
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1653
            ^ '"<<TOKEN
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1654
...
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1655
TOKEN
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1656
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1657
Token delimited comment
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1658
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1659
anything up to a line which contains the token alone is a comment and ignored (but not inside a string).
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1660
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
  1661
'
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1662
        ].
e54c1b7cb5ee class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3407
diff changeset
  1663
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1664
        shortText ifTrue:[
3607
58a91ac8dfb5 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3601
diff changeset
  1665
            ^ 'a comment (syntax)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1666
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1667
        ^ '" comment ... "
3193
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1668
comment
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1669
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1670
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
  1671
'
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1672
    ].
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1673
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1674
    "/ is it a symbol without hash-character ?
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1675
    "/
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1676
"/    string knownAsSymbol ifTrue:[
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1677
"/        ^ 'is nothing, but #' , string , ' is known as a symbol.
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1678
"/
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1679
"/Symbols are unique strings, meaning that there exists
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1680
"/exactly one instance of a given symbol. Therefore symbols can
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1681
"/be compared using == (identity compare) in addition to = (contents compare).
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1682
"/Beside this, Symbols behave mostly like Strings.'
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1683
"/    ].
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1684
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1685
    ^ nil
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1686
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1687
    "Modified: / 27-07-2013 / 10:08:57 / cg"
2214
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1688
!
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1689
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1690
typeDescriptionFor:setOfTypes andSelector:selectorOrNil
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1691
    "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
  1692
    
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1693
    ^ self typeDescriptionFor:setOfTypes andSelector:selectorOrNil wordBetween:'or'
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1694
!
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1695
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1696
typeDescriptionFor:setOfTypes andSelector:selectorOrNil wordBetween:wordbetween
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1697
    "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
  1698
    
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1699
    |types numTypes
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1700
     type1 type2 type3
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  1701
     nm1 nm2 nm3 link|
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1702
     
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1703
    "/ reduce...
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1704
    self compressSetOfTypes:setOfTypes.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1705
    setOfTypes isEmpty ifTrue:[^ nil].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1706
    
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1707
    types := setOfTypes asOrderedCollection.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1708
    types sortBySelector:#name.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1709
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1710
    "/ now make this a nice string
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1711
    numTypes := types size.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1712
    type1 := types first.
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  1713
    nm1 := self asLink:type1 name to:(self actionToBrowseClass:type1 selector:selectorOrNil).
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1714
    numTypes == 1 ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1715
        ^ nm1
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1716
    ].
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1717
    
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1718
    type2 := types second.
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  1719
    nm2 := self asLink:type2 name to:(self actionToBrowseClass:type2 selector:selectorOrNil).
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1720
    numTypes == 2 ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1721
        ^ nm1,' ',wordbetween,' ',nm2
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1722
    ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1723
    type3 := types third.
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  1724
    nm3 := self asLink:type3 name to:(self actionToBrowseClass:type3 selector:selectorOrNil).
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1725
    numTypes == 3 ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1726
         ^ nm1,', ',nm2,' ',wordbetween,' ',nm3
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1727
    ].
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  1728
    link := self actionToBrowseClasses:types.
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  1729
"/    selectorOrNil notNil ifTrue:[
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  1730
"/        link := self actionToOpenMethodFinderFor:selectorOrNil. 
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  1731
"/    ].
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  1732
    ^ self asLink:('%1 classes' bindWith:numTypes) to:link.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1733
!
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1734
2214
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1735
valueStringFor:aValue
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1736
    |valString|
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1737
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1738
    "/ only show the value, if it is really short...
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1739
    (aValue isBoolean
3708
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  1740
        or:[aValue isNil
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  1741
        or:[aValue isString
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  1742
        or:[aValue isNumber
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  1743
        or:[aValue isPoint
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  1744
        or:[aValue isCharacter
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  1745
    ]]]]]) ifTrue:[
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  1746
        ^ aValue storeString.
2226
d628e2ef289e changed: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2225
diff changeset
  1747
    ].
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1748
2226
d628e2ef289e changed: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2225
diff changeset
  1749
    (aValue isColor) ifTrue:[
3708
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  1750
        ^ 'Color: ',('   ' emphasizeAllWith:(#backgroundColor->aValue)).
2226
d628e2ef289e changed: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2225
diff changeset
  1751
    ].
d628e2ef289e changed: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2225
diff changeset
  1752
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1753
    ((aValue isKindOf:GUID)
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1754
     or:[aValue isUUID]) ifTrue:[
3708
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  1755
        valString := aValue printString.
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1756
    ].
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1757
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1758
    (valString isEmptyOrNil
2899
8b8701a65441 Avoid #isKindOf: where possible
Stefan Vogel <sv@exept.de>
parents: 2828
diff changeset
  1759
     or:[ valString size > 50
8b8701a65441 Avoid #isKindOf: where possible
Stefan Vogel <sv@exept.de>
parents: 2828
diff changeset
  1760
     or:[ valString includes:Character cr ]]) ifTrue:[
3708
2f157664dec3 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 3697
diff changeset
  1761
        valString := aValue classNameWithArticle.
2214
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1762
    ].
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1763
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1764
    ^ valString
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1765
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1766
    "Modified: / 14-10-2010 / 11:57:52 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1767
! !
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1768
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1769
!Explainer class methodsFor:'naive type inferer'!
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1770
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1771
addTypeOfExpressionNode:expr forAssignmentTo:varName to:setOfTypes
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1772
    "pick up low hanging type information.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1773
     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
  1774
     and info in the browser."
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1775
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1776
    |val valClass|
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1777
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1778
    "/ only look for wellknown types on the right side.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1779
    expr isLiteral ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1780
        val := expr value.
3801
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  1781
        valClass := val class.
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1782
        val isImmutable ifTrue:[
3801
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  1783
            valClass := [ valClass mutableClass ] on:Error do:[ valClass ].
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1784
        ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1785
        self rememberType:valClass in:setOfTypes.
3826
770a639a57a0 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3824
diff changeset
  1786
        ^ setOfTypes.
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1787
    ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1788
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1789
    expr isMessage ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1790
        self addTypeOfMessageNode:expr forAssignmentTo:varName to:setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1791
        ^ setOfTypes.
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1792
    ].
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  1793
3826
770a639a57a0 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3824
diff changeset
  1794
    ^ setOfTypes
770a639a57a0 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3824
diff changeset
  1795
    
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1796
    "Created: / 30-04-2016 / 15:28:59 / cg"
3801
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  1797
    "Modified: / 30-04-2016 / 20:17:35 / cg"
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1798
!
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1799
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1800
addTypeOfMessageNode:expr forAssignmentTo:varName to:setOfTypes
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1801
    "pick up low hanging type information.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1802
     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
  1803
     and info in the browser."
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1804
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1805
    |valClass msgSelector msgReceiver|
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1806
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1807
    msgSelector := expr selector.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1808
    msgReceiver := expr receiver.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1809
        
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1810
    msgSelector == #? ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1811
        self addTypeOfExpressionNode:(expr arg1) forAssignmentTo:varName to:setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1812
        ^ setOfTypes
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1813
    ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1814
    
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1815
    "/ really really only very low hanging fruit...
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1816
    "/ ignore #/ here, because of filename
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1817
    ( #(+ - *) includes:msgSelector ) ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1818
        "/ ignore foo := foo OP expr
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1819
        "/ ignore foo := expr OP foo
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1820
        (msgReceiver isVariable and:[msgReceiver name = varName]) ifFalse:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1821
            (expr arg1 isVariable and:[expr arg1 name = varName]) ifFalse:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1822
                self rememberType:Number in:setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1823
            ]
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1824
        ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1825
        ^ setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1826
    ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1827
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1828
    ( #(// size hash identityHash) includes:msgSelector ) ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1829
        self rememberType:Integer in:setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1830
        ^ setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1831
    ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1832
    
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1833
    ( #(next next:) includes:msgSelector ) ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1834
        |rcvrTypes|
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1835
        
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1836
        rcvrTypes := self addTypeOfExpressionNode:msgReceiver forAssignmentTo:nil to:Set new.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1837
        rcvrTypes notEmpty ifTrue:[
3857
8e460e8c7322 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3855
diff changeset
  1838
self breakPoint:#cg.
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1839
            self rememberType:Character in:setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1840
        ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1841
        ^ setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1842
    ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1843
    
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1844
    ( msgSelector startsWith:'as') ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1845
        valClass := Smalltalk classNamed:(msgSelector copyFrom:3).
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1846
        valClass notNil ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1847
            self rememberType:valClass in:setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1848
            ^ setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1849
        ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1850
    ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1851
    
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1852
    ( #(copy shallowCopy) includes:msgSelector ) ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1853
        msgReceiver isLiteral ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1854
            self addTypeOfExpressionNode:msgReceiver forAssignmentTo:varName to:setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1855
        ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1856
        ^ setOfTypes
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1857
    ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1858
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1859
    msgReceiver isGlobal ifTrue:[
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1860
        |instCreatorMessages globalValue implMethod|
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1861
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1862
        instCreatorMessages := #(new new: basicNew basicNew:).
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1863
        
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1864
        globalValue := msgReceiver value.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1865
        globalValue isBehavior ifTrue:[
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1866
            ( instCreatorMessages includes:msgSelector ) ifTrue:[
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1867
                self rememberType:globalValue in:setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1868
                ^ setOfTypes.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1869
            ].
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1870
            implMethod := globalValue class lookupMethodFor:msgSelector.
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1871
            "/ 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
  1872
            "/ assume it is returning it.
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1873
            implMethod isNil ifTrue:[
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1874
                "/ will not be understood
3857
8e460e8c7322 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3855
diff changeset
  1875
self breakPoint:#cg.
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1876
                ^ setOfTypes.
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1877
            ].    
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1878
            (implMethod messagesSentToSelf includesAny:instCreatorMessages) ifTrue:[
3857
8e460e8c7322 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3855
diff changeset
  1879
self breakPoint:#cg.
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1880
                self rememberType:globalValue in:setOfTypes.
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1881
                ^ setOfTypes.
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1882
            ].    
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1883
            "/ 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
  1884
            ((implMethod category ? '') startsWith:'instance creation') ifTrue:[
3857
8e460e8c7322 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3855
diff changeset
  1885
self breakPoint:#cg.
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1886
                self rememberType:globalValue in:setOfTypes.
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1887
                ^ setOfTypes.
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1888
            ].    
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1889
        ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1890
        self breakPoint:#cg.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1891
        ^ setOfTypes
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1892
    ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1893
    
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1894
self breakPoint:#cg.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1895
    ^ setOfTypes
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1896
!
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1897
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1898
addTypesAssignedToInstvar:instVarName inClass:aClass method:aMethod to:setOfTypes
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1899
    "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
  1900
     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
  1901
     and info in the browser."
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1902
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1903
    | code |
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1904
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1905
    code := aMethod source.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1906
    (code notNil) ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1907
        self addTypesAssignedToInstvar:instVarName inClass:aClass source:code to:setOfTypes
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1908
    ]
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1909
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1910
    "Created: / 30-04-2016 / 15:07:33 / cg"
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1911
!
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1912
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1913
addTypesAssignedToInstvar:instVarName inClass:aClass source:code to:setOfTypes
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1914
    "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
  1915
     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
  1916
     and info in the browser."
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1917
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1918
    |tree|
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1919
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1920
    "/ quick check (avoids expensive parse)
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1921
    (code includesString:instVarName) ifFalse:[ ^ self ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1922
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1923
    tree := Parser parse:code class:aClass.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1924
    (tree isNil or:[tree == #Error]) ifTrue:[ ^ self ]. "/ unparsable
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1925
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1926
    self addTypesAssignedToInstvar:instVarName inTree:tree to:setOfTypes.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1927
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1928
    "Created: / 30-04-2016 / 15:09:18 / cg"
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1929
!
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1930
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1931
addTypesAssignedToInstvar:instVarName inClass:aClass to:setOfTypes
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1932
    "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
  1933
     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
  1934
     and info in the browser."
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1935
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1936
    aClass methodDictionary do:[:m |
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1937
        self addTypesAssignedToInstvar:instVarName inClass:aClass method:m to:setOfTypes
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1938
    ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1939
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1940
    "Created: / 30-04-2016 / 14:52:56 / cg"
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1941
!
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1942
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1943
addTypesAssignedToInstvar:instVarName inTree:tree to:setOfTypes
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1944
    "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
  1945
     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
  1946
     and info in the browser."
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1947
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1948
    |visitor|
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1949
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1950
    visitor := PluggableParseNodeVisitor new. 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1951
    visitor 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1952
        actionForNodeClass:AssignmentNode 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1953
        put:[:node |
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1954
            (node variable isInstanceVariableNamed:instVarName) ifTrue:[
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1955
                self addTypeOfExpressionNode:(node expression) forAssignmentTo:instVarName to:setOfTypes
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1956
            ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1957
            true "/ yes - visit subnodes
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1958
        ].        
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1959
    visitor visit:tree.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1960
!
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1961
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1962
addTypesAssignedToLocal:localName inTree:tree to:setOfTypes
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  1963
    "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
  1964
     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
  1965
     and info in the browser."
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1966
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1967
    |visitor|
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1968
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1969
    "/ hack, allowing to deal with both types of AST (sigh)
3841
a22f33410bdf Reduced dependencies
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3839
diff changeset
  1970
    (tree isKindOf:(Smalltalk at:#RBProgramNode)) ifTrue:[
a22f33410bdf Reduced dependencies
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3839
diff changeset
  1971
        visitor := (Smalltalk at:#RBPluggableProgramNodeVisitor) new.
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1972
        visitor 
3841
a22f33410bdf Reduced dependencies
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3839
diff changeset
  1973
            actionForNodeClass:(Smalltalk at:#RBAssignmentNode)
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1974
            put:[:node |
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1975
                |leftSide|
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  1976
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1977
                leftSide := node variable.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1978
                (leftSide isTemporary and:[ leftSide name = localName ]) ifTrue:[
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  1979
                    self addTypeOfExpressionNode:(node value) forAssignmentTo:localName to:setOfTypes
3810
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1980
                ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1981
                true "/ yes - visit subnodes
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1982
            ].        
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1983
        visitor visitNode:tree.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1984
    ] ifFalse:[    
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1985
        visitor := PluggableParseNodeVisitor new. 
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1986
        visitor 
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1987
            actionForNodeClass:AssignmentNode 
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1988
            put:[:node |
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1989
                |leftSide expr|
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1990
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1991
                leftSide := node variable.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1992
                (leftSide isLocalVariable and:[ leftSide name = localName ]) ifTrue:[
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1993
                    expr := node expression.
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1994
                    self addTypeOfExpressionNode:expr forAssignmentTo:localName to:setOfTypes
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1995
                ].
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1996
                true "/ yes - visit subnodes
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1997
            ].        
adc9cf5d82af #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3809
diff changeset
  1998
        visitor visit:tree.
3841
a22f33410bdf Reduced dependencies
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3839
diff changeset
  1999
    ].
a22f33410bdf Reduced dependencies
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3839
diff changeset
  2000
a22f33410bdf Reduced dependencies
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3839
diff changeset
  2001
    "Modified (format): / 05-05-2016 / 00:19:03 / Jan Vrany <jan.vrany@fit.cvut.cz>"
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2002
!
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2003
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2004
addTypesOfInstvar:instVarName inClass:aClass fromExistingInstancesTo:setOfTypes
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2005
    "look for existing instances and see that type is there"
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2006
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2007
    |instIndex|
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2008
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2009
    instIndex := aClass instVarIndexFor:instVarName.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2010
    aClass allSubInstancesDo:[:i |
3801
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2011
        |val varClass|
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2012
3801
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2013
        val := (i instVarAt:instIndex).
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2014
        val notNil ifTrue:[
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2015
            varClass := val class.
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2016
            self rememberType:varClass in:setOfTypes.
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2017
        ].
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2018
    ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2019
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2020
    "Created: / 30-04-2016 / 14:56:11 / cg"
3801
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2021
    "Modified: / 30-04-2016 / 20:05:03 / cg"
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2022
!
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2023
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2024
compressSetOfTypes:setOfTypes
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2025
    |toAdd toRemove|
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2026
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2027
    "/ reduce by eliminating common superclasses...
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2028
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2029
    toAdd := Set new.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2030
    toRemove := Set new.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2031
    setOfTypes do:[:type1 |
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2032
        setOfTypes do:[:type2 |
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2033
            |common|
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2034
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2035
            type1 superclass == type2 ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2036
                toRemove add:type1.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2037
            ] ifFalse:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2038
                type2 superclass == type1 ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2039
                    toRemove add:type2.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2040
                ] ifFalse:[    
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2041
                    common := type1 commonSuperclass:type2.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2042
                    common ~~ Object ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2043
                        toRemove add:type1.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2044
                        toRemove add:type2.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2045
                        toAdd add:common.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2046
                    ].    
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2047
                ].                        
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2048
            ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2049
        ]
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2050
    ]. 
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2051
    setOfTypes removeAll:toRemove.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2052
    setOfTypes addAll:toRemove.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2053
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2054
    "/ hack
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2055
    setOfTypes size == 2 ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2056
        ((setOfTypes includes:True) and:[setOfTypes includes:False]) ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2057
            setOfTypes removeAll; add:Boolean.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2058
            ^ self.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2059
        ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2060
        ((setOfTypes includes:SmallInteger) and:[setOfTypes includes:LargeInteger]) ifTrue:[
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2061
            setOfTypes removeAll; add:Integer.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2062
            ^ self.
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2063
        ]
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2064
    ].
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2065
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2066
    "Created: / 30-04-2016 / 15:37:38 / cg"
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2067
!
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2068
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2069
rememberType:aClass in:setOfTypes
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2070
    setOfTypes add:aClass
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2071
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2072
    "Created: / 30-04-2016 / 15:35:44 / cg"
3801
58d649c2286a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3798
diff changeset
  2073
    "Modified: / 30-04-2016 / 20:05:09 / cg"
3798
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2074
! !
faa62aacc8f2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3795
diff changeset
  2075
3838
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2076
!Explainer class methodsFor:'utilities'!
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2077
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2078
actionToBrowseClass:class
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2079
    ^ self actionToBrowseClass:class selector:nil.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2080
!
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2081
3838
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2082
actionToBrowseClass:class selector:selectorOrNil
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2083
    ^ [
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2084
        self thisOrNewBrowserInto:[:browser :openHow |
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2085
            browser
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2086
                spawnFullBrowserInClass:class selector:selectorOrNil in:openHow
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2087
"/                    spawnMethodBrowserFor:{class compiledMethodAt:selectorOrNil}
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2088
"/                    in:openHow 
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2089
"/                    label:nil
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2090
        ]
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2091
    ]. 
3838
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2092
!
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2093
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2094
actionToBrowseClasses:classes 
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2095
    ^ [
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2096
        self thisOrNewBrowserInto:[:browser :openHow |
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2097
            browser
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2098
                spawnClassBrowserFor:classes in:openHow
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2099
        ]
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2100
    ]
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2101
    "/ ^ [Tools::NewSystemBrowser browseClasses:classes]
3838
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2102
!
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2103
3855
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2104
actionToBrowseImplementorsOf:selector
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2105
    ^ [
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2106
        self thisOrNewBrowserInto:[:browser :openHow |
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2107
            browser
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2108
                spawnMethodImplementorsBrowserFor:{ selector }
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2109
                in:openHow
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2110
        ]
68413d2ee7c2 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3854
diff changeset
  2111
    ]
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2112
!
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2113
3853
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2114
actionToBrowseInstvarRefsTo:instVarName inClass:class
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2115
    ^ [(Tools::NewSystemBrowser basicNew)
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2116
            browseVarRefsToAny:{ instVarName }
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2117
            classes:{ class }
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2118
            variables:#instVarNames access:#readOrWrite all:true
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2119
            title:'references to ',instVarName
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2120
            in:#newBrowser
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2121
      ]
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2122
!
9e7bf7eb2a3b #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3843
diff changeset
  2123
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2124
actionToBrowseMethod:mthd
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2125
    ^ self actionToBrowseClass:(mthd mclass) selector:(mthd selector).
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2126
!
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2127
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2128
actionToOpenMethodFinderFor:selector 
3838
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2129
    MethodFinderWindow notNil ifTrue:[
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2130
        ^ [MethodFinderWindow openOnSelectorPattern:selector].
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2131
    ].
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2132
    ^ self actionToBrowseImplementorsOf:selector
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2133
!
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2134
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2135
asClassLink:nameOfClass
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2136
    "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
  2137
    
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2138
    |cls|
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2139
    
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2140
    cls := Smalltalk classNamed:nameOfClass string asUppercaseFirst.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2141
    cls isNil ifTrue:[^ nameOfClass].
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2142
3861
214e93764392 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 3860
diff changeset
  2143
    ^ self asLink:nameOfClass to:(self actionToBrowseClass:cls) 
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2144
!
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2145
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2146
asLink:aString to:action
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2147
    ^ (aString actionForAll:action)
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2148
        withColor:(Color blue)
3842
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2149
!
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2150
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2151
infoStringForMethods:aCollectionOfMethods withPrefix:prefix
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2152
    "get a nice user readable list for some methods.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2153
     Up to 3 are named, otherwise the count is presented.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2154
     The prefix can be sth like ' other', ' sender', ' implementor',
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2155
     Or it can be an empty string.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2156
     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
  2157
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2158
    |nMethodNames sortedByName methodNames|
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2159
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2160
    aCollectionOfMethods isEmpty ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2161
        ^ 'No %1' bindWith:prefix.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2162
    ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2163
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2164
    methodNames := aCollectionOfMethods asOrderedCollection 
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2165
                    collect:[:each | each whoString].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2166
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2167
    nMethodNames := methodNames size.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2168
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2169
    nMethodNames <= 3 ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2170
        nMethodNames == 1 ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2171
            ^ '%2' "'1 %1class: %2'" bindWith:prefix with:(methodNames first allBold).
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2172
        ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2173
        sortedByName := methodNames sort.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2174
        nMethodNames == 2 ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2175
            ^ '%2 and %3' "'2 %1classes: %2 and %3'" bindWith:prefix
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2176
                        with:(sortedByName first allBold)
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2177
                        with:(sortedByName second allBold).
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2178
        ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2179
        nMethodNames == 3 ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2180
            ^ '%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
  2181
                        with:(sortedByName first allBold)
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2182
                        with:(sortedByName second allBold)
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2183
                        with:(sortedByName third allBold).
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2184
        ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2185
        nMethodNames == 4 ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2186
            ^ '%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
  2187
                        with:(sortedByName first allBold)
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2188
                        with:(sortedByName second allBold)
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2189
                        with:(sortedByName third allBold)
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2190
                        with:(sortedByName fourth allBold).
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2191
        ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2192
    ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2193
    ^ '%1 %2methods' bindWith:nMethodNames printString allBold with:prefix.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2194
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2195
    "
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2196
     Time millisecondsToRun:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2197
         self infoStringForMethods:(SystemBrowser allCallsOn:#'at:put:') withPrefix:''
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2198
     ].   
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2199
     Time millisecondsToRun:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2200
         self infoStringForMethods:(SystemBrowser allCallsOn:#'actionToBrowseClasses:') withPrefix:''
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2201
     ].
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2202
    "
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
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2205
methodSendersInfoFor:selector inEnvironment:environment
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2206
    "get something about the senders of a message.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2207
     to be shown in the info line at the bottom.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2208
     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
  2209
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2210
    |senders|
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2211
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2212
    senders := SystemBrowser
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2213
                findSendersOf:selector
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2214
                in:(environment allClasses)
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2215
                ignoreCase:false
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2216
                match:false.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2217
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2218
    senders notEmpty ifTrue:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2219
        ^ 'Sent from ' , senders size printString, ' methods.'.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2220
    ] ifFalse:[
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2221
        ^ 'No senders.'.
4baaec079753 #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3839
diff changeset
  2222
    ].
3859
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2223
!
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2224
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2225
thisOrNewBrowserInto:aTwoArgBlock
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2226
    "if I am invoked by a browser, 
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2227
     invoke the twoArgBlock withit and an #newBuffer arg.
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2228
     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
  2229
     with a #newBrowser arg."
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2230
     
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2231
    |windowGroupClass browserClass wg app|
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2232
    
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2233
    "/ stupid: I am in libcomp; should be in libtool
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2234
    windowGroupClass := Smalltalk at:#WindowGroup.
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2235
    windowGroupClass isNil ifTrue:[^ self].
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2236
    browserClass := Smalltalk at:#'Tools::NewSystemBrowser'.
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2237
    browserClass isNil ifTrue:[^ self].
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2238
    
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2239
    ((wg := windowGroupClass activeGroup) notNil
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2240
        and:[ (app := wg application) isKindOf:browserClass ]
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2241
    ) ifTrue:[
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2242
        ^ aTwoArgBlock value:app value:#newBuffer
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2243
    ].        
7efa40ce52c6 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 3858
diff changeset
  2244
    ^ aTwoArgBlock value:(browserClass basicNew) value:#newBrowser
3838
22b2bf23304a #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 3827
diff changeset
  2245
! !
3826
770a639a57a0 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3824
diff changeset
  2246
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
  2247
!Explainer class methodsFor:'documentation'!
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
  2248
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
  2249
version
3697
099dd080fd3e #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 3608
diff changeset
  2250
    ^ '$Header$'
2214
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  2251
!
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  2252
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  2253
version_CVS
3697
099dd080fd3e #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 3608
diff changeset
  2254
    ^ '$Header$'
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
  2255
! !
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
  2256