Explainer.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Thu, 08 May 2014 13:09:23 +0200
changeset 3432 8665f2cf6dd1
parent 3407 ced75e88cf6a
child 3464 e54c1b7cb5ee
permissions -rw-r--r--
Added BreakpointQuery
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
49
02660b790c3e *** empty log message ***
claus
parents: 24
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
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
    14
Parser subclass:#Explainer
263
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    15
	instanceVariableNames:''
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    16
	classVariableNames:''
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    17
	poolDictionaries:''
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    18
	category:'System-Compiler'
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    19
!
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    20
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
    21
!Explainer class methodsFor:'documentation'!
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    22
20
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    23
copyright
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    24
"
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    25
 COPYRIGHT (c) 1993 by Claus Gittinger
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
    26
	      All Rights Reserved
20
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    27
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    28
 This software is furnished under a license and may be used
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    29
 only in accordance with the terms of that license and with the
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    30
 inclusion of the above copyright notice.   This software may not
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    31
 be provided or otherwise made available to, or used by, any
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    32
 other person.  No title to or ownership of the software is
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    33
 hereby transferred.
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    34
"
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    35
!
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    36
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    37
documentation
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    38
"
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
    39
    a very simple explainer - much more should be added...
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
    40
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
    41
    This one is involved, when the 'explain' function is used in a
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    42
    codeView (popup or via CMD-E), or if the mouse button is clicked
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    43
    on some code construct in the new browser.
263
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    44
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
    45
    Most of the texts returned here are heuristically motivated,
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
    46
    based on the experience with beginners and their frequently asked questions.
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
    47
263
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    48
    [author:]
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
    49
	Claus Gittinger
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    50
"
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    51
! !
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    52
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
    53
!Explainer class methodsFor:'explaining'!
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    54
2193
9416fc17ee62 pass the interval to the explainer
Claus Gittinger <cg@exept.de>
parents: 2191
diff changeset
    55
explainLiteralNode:node in:code forClass:cls short:short interval:intervalIfKnown
2954
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
    56
    |expl literalValue findInnerMost elementIndex|
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    57
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    58
    literalValue := node value.
2955
d52a51930921 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2954
diff changeset
    59
    expl := literalValue class name "allBold" , '-constant'.
2954
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
    60
2316
f09794e008f8 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2315
diff changeset
    61
    (literalValue isInteger) ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    62
        (literalValue ~= 0 and:[literalValue ~= 1]) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    63
            expl := expl , ' ('.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    64
            #(2 10 16) with:#('binary: ' 'decimal: ' 'hex: ')do:[:base :baseExpl |
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    65
                |bStr|
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
    66
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    67
                base ~= (node token radix ? 10) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    68
                    bStr := base==10
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    69
                                ifTrue:[literalValue printString]
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    70
                                ifFalse:[literalValue radixPrintStringRadix:base].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    71
                    expl := expl , ' ' , baseExpl, bStr
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    72
                ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    73
            ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    74
            expl := expl , ' )'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    75
        ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    76
        ^ expl.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    77
    ].                
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    78
    (literalValue isCharacter) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    79
        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
    80
        ^ expl.
2316
f09794e008f8 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2315
diff changeset
    81
    ].
2954
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
    82
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
    83
    (node isLiteralArray and:[intervalIfKnown notNil]) ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    84
        "/ see which element we have to explain
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    85
        findInnerMost :=
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    86
            [:token |
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    87
                token value keysAndValuesDo:[:index :eachToken |
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    88
                    |selectorOrName|
2954
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
    89
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    90
                    ((eachToken start to:eachToken stop) intersect:intervalIfKnown) notEmpty ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    91
                        elementIndex := index.  "/ see below
2954
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
    92
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    93
                        eachToken value isArray ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    94
                            findInnerMost value:eachToken.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    95
                        ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    96
                        eachToken value isSymbol ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    97
                            selectorOrName := eachToken value.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    98
                            selectorOrName isUppercaseFirst ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
    99
                                (Smalltalk includesKey:selectorOrName) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   100
                                    ^ expl, ' / ', (Explainer explainGlobal:selectorOrName inClass:cls short:short)
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
                            ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   103
                            ^ expl, ' / ', (Explainer explainSelector:selectorOrName inClass:cls short:short)
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   104
                        ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   105
                    ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   106
                ]
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
        findInnerMost value:node token.
2954
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
   109
    ].
0943337cfb73 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2940
diff changeset
   110
2955
d52a51930921 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2954
diff changeset
   111
    (literalValue isArray or:[ literalValue isByteArray or:[ literalValue isString ]]) ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   112
        literalValue size == 0 ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   113
            ^ 'empty ' , expl
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
        elementIndex notNil ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   116
            ^ expl , (' (size=%1; element=%2)' bindWith:literalValue size with:elementIndex)
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   117
        ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   118
        literalValue isString ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   119
            elementIndex := intervalIfKnown start - node token start.
2955
d52a51930921 changed: #explainLiteralNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2954
diff changeset
   120
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   121
            (elementIndex between:1 and:literalValue size) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   122
                ^ expl , (' (size=%1; position=%2)' bindWith:literalValue size with:elementIndex)
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   123
            ]
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   124
        ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   125
        ^ expl , (' (size=%1)' bindWith:literalValue size)
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   126
    ].
2191
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   127
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   128
    ^ expl
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   129
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   130
    "Modified: / 09-10-2006 / 12:09:43 / cg"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   131
!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   132
2193
9416fc17ee62 pass the interval to the explainer
Claus Gittinger <cg@exept.de>
parents: 2191
diff changeset
   133
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
   134
    "answer a string which explains node"
9d6581314aed avoid to put nil in Set
Stefan Vogel <sv@exept.de>
parents: 1763
diff changeset
   135
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   136
    |receiver nm srchClass selector selectorString implClass
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   137
     boldSelectorString globalValue recClassSet
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   138
     implMethod implMethodComment info implMethods comments definer
1854
9dcdec831c46 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1771
diff changeset
   139
     instances classesOfInstVars implementingClasses canBeNil
3193
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
   140
     bestMatches hint|
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   141
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   142
    selector := node selector.
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   143
    selectorString := selector printString contractTo:30.
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   144
    boldSelectorString := selectorString "allBold".
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   145
1733
5a4d415c3bbc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1732
diff changeset
   146
    recClassSet := self guessPossibleImplementorClassesFor:(node receiver) in:code forClass:cls.
5a4d415c3bbc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1732
diff changeset
   147
    recClassSet size == 1 ifTrue:[
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   148
        srchClass := recClassSet first.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   149
        "take care - Set cannot store nil!!"
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   150
        implementingClasses := (recClassSet collect:[:cls | cls whichClassIncludesSelector:selector]) asArray.
1869
089f4ae37b06 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1854
diff changeset
   151
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   152
        (implementingClasses includes:nil) ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   153
            implementingClasses size > 1 ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   154
                ^ 'possibly not understood: %1 (%2 other implementors)'
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   155
                    bindWith:selector "allBold"
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   156
                    with:(implementingClasses size - 1)
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   157
            ].
1869
089f4ae37b06 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1854
diff changeset
   158
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   159
            (#('self'  'super' 'true' 'false' 'thisContext') includes:selector) ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   160
                ^ ('NOT understood here: %1 (missing period after previous statement?)' bindWith:selector allBold),hint
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   161
            ].
3193
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
   162
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   163
            (recClassSet contains:[:cls | cls isMeta not and:[cls theMetaclass canUnderstand:selector]]) ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   164
                hint := '. But class understands it - did you mean "rcvr class ',selector,'..." ?'.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   165
            ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   166
            bestMatches := Parser findBestSelectorsFor:selector in:srchClass.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   167
            bestMatches size > 0 ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   168
                ^ ('NOT understood here: %1 (best guess is: "%2" from %3)'
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   169
                    bindWith:selector allBold
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   170
                    with:(bestMatches first "allBold")
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   171
                    with:(srchClass whichClassIncludesSelector:bestMatches first) name) , hint
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   172
            ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   173
            ^ ('NOT understood here: %1' bindWith:selector allBold),hint
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   174
        ].
1733
5a4d415c3bbc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1732
diff changeset
   175
    ].
5a4d415c3bbc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1732
diff changeset
   176
5a4d415c3bbc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1732
diff changeset
   177
    implementingClasses isNil ifTrue:[
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   178
        receiver := node receiver.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   179
        receiver isVariable ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   180
            nm := receiver name.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   181
            nm = 'self' ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   182
                srchClass := cls
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   183
            ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   184
            nm = 'super' ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   185
                srchClass := cls superclass
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   186
            ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   187
            definer := receiver whoDefines:nm.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   188
            definer isNil ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   189
                "/ not a local or argument
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   190
                (cls instanceVariableNames includes:nm) ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   191
                    "/ ok - an instVar; see what values we find...
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   192
                    instances := cls allSubInstances.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   193
                    classesOfInstVars := instances collect:[:eachInst | (eachInst instVarNamed:nm) class] as:Set.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   194
                    canBeNil := (classesOfInstVars remove:UndefinedObject ifAbsent:[]) notNil.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   195
                    "take care - Set cannot store nil!!"
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   196
                    implementingClasses := classesOfInstVars collect:[:cls | (cls whichClassIncludesSelector:selector) ? 0].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   197
                    implementingClasses remove:0 ifAbsent:[].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   198
                ] ifFalse:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   199
                    nm isUppercaseFirst ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   200
                        nm knownAsSymbol ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   201
                            globalValue := Smalltalk at:nm asSymbol.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   202
                            globalValue isClass ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   203
                                srchClass := globalValue class.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   204
                            ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   205
                        ]
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
                ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   208
            ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   209
        ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   210
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   211
        receiver isLiteral ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   212
            srchClass := receiver value class
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   213
        ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   214
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   215
        srchClass notNil ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   216
            implClass := srchClass whichClassIncludesSelector:selector.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   217
            implClass isNil ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   218
                ^ '%1 is NOT understood here.' bindWith:boldSelectorString
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   219
            ].
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   220
            info := '%1 >> %2' bindWith:implClass name "allBold" with:selectorString "allBold".
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   221
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   222
            implMethod := implClass compiledMethodAt:selector.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   223
            implMethodComment := self fetchCommentOfMethod:implMethod.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   224
            implMethodComment notNil ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   225
                info := info , ' ' , implMethodComment.
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
            ^ info
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
        implementingClasses isNil ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   230
            implementingClasses := Smalltalk allImplementorsOf:selector
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   231
        ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   232
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   233
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   234
    implementingClasses size == 1 ifTrue:[
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   235
        implClass := implementingClasses anElement.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   236
        info := '%1 >> %2' bindWith:implClass name "allBold" with:selectorString.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   237
        (srchClass isNil and:[(cls includesBehavior:implClass) not]) ifTrue:[
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   238
            "/ info := 'guess: ', info.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   239
            info := info , ' (guess)'.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   240
        ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   241
    ] ifFalse:[
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   242
        info := Explainer explainSelector:selector inClass:cls short:short.
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   243
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   244
1771
9d6581314aed avoid to put nil in Set
Stefan Vogel <sv@exept.de>
parents: 1763
diff changeset
   245
    implementingClasses notEmptyOrNil ifTrue:[
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   246
        implMethods := implementingClasses collect:[:implClass | implClass compiledMethodAt:selector].
3321
362fd46a9f90 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3320
diff changeset
   247
        implMethods size <= 8 ifTrue:[
362fd46a9f90 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3320
diff changeset
   248
            implMethods size < 4 ifTrue:[
362fd46a9f90 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3320
diff changeset
   249
                "/ show full comments
362fd46a9f90 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3320
diff changeset
   250
                comments := implMethods 
362fd46a9f90 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3320
diff changeset
   251
                                collect:[:implMethod | implMethod comment]
362fd46a9f90 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3320
diff changeset
   252
                                thenSelect:[:comment | comment notEmptyOrNil].
362fd46a9f90 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3320
diff changeset
   253
            ] ifFalse:[
362fd46a9f90 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3320
diff changeset
   254
                "/ show first lines one
362fd46a9f90 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3320
diff changeset
   255
                comments := implMethods 
362fd46a9f90 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3320
diff changeset
   256
                                collect:[:implMethod | (self fetchCommentOfMethod:implMethod)]
362fd46a9f90 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3320
diff changeset
   257
                                thenSelect:[:comment | comment notEmptyOrNil].
362fd46a9f90 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3320
diff changeset
   258
            ].
362fd46a9f90 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3320
diff changeset
   259
            comments := comments collect:[:each | each colorizeAllWith:(UserPreferences current commentColor) ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   260
            short ifTrue:[
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   261
                comments := comments collect:[:implMethodComment | implMethodComment firstLine] as:Set.
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   262
                comments size == 1 ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   263
                    ^ info , ' ' , (comments first).
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   264
                ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   265
                ^ info
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   266
            ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   267
            info := info,'\'withCRs.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   268
            comments 
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   269
                with:implementingClasses 
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   270
                do:[:eachComment :eachClass | 
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   271
                    info := info,'\comment in ',eachClass name,':\',(eachComment asStringCollection asString) 
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   272
                ].
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
   273
        ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   274
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   275
    ^ info
1854
9dcdec831c46 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1771
diff changeset
   276
1979
847742bcb22d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1943
diff changeset
   277
    "Modified: / 06-02-2007 / 19:26:11 / cg"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   278
!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   279
2193
9416fc17ee62 pass the interval to the explainer
Claus Gittinger <cg@exept.de>
parents: 2191
diff changeset
   280
explainMethodNode:node in:code forClass:cls short:short interval:intervalIfKnown
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   281
    |srchClass selector selectorString implClass
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   282
     "sendingMethods numSendingMethods sendingClasses" boldSelectorString|
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   283
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   284
    selector := node selector.
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   285
    selectorString := selector printString contractTo:30.
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   286
    boldSelectorString := selectorString "allBold".
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   287
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   288
    (srchClass := cls superclass) notNil ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   289
	implClass := srchClass whichClassIncludesSelector:selector.
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   290
	implClass notNil ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   291
	    ^ '%1 hides implementation in %2.'
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   292
	      bindWith:boldSelectorString
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   293
	      with:implClass name "allBold"
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   294
	].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   295
    ].
2223
50b76baab48b changed: #explainMethodNode:in:forClass:short:interval:
Claus Gittinger <cg@exept.de>
parents: 2214
diff changeset
   296
    (cls includesSelector:selector) ifFalse:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   297
	^ '%1: a new method.' bindWith:boldSelectorString
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   298
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   299
"/
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   300
"/        sendingMethods := SystemBrowser
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   301
"/                                allCallsOn:selector
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   302
"/                                in:(cls withAllSubclasses , cls allSubclasses)
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   303
"/                                ignoreCase:false
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   304
"/                                match:false.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   305
"/        sendingMethods := sendingMethods select:[:eachMethod | eachMethod mclass notNil].  "/ remove unbound ones
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   306
"/
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   307
"/        sendingClasses := (sendingMethods collect:[:eachMethod | eachMethod mclass]) asSet.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   308
"/        numSendingMethods := sendingMethods size.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   309
"/        numSendingMethods == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   310
"/            sendingClasses first == cls ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   311
"/                ^ '%1: sent locally from %2.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   312
"/                    bindWith:boldSelectorString
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   313
"/                    with:sendingMethods first selector "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   314
"/            ].
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   315
"/            ^ '%1: sent in hierarchy from %2 in %3.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   316
"/                bindWith:boldSelectorString
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   317
"/                with:sendingMethods first selector "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   318
"/                with:sendingClasses first name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   319
"/        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   320
"/        numSendingMethods == 2 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   321
"/            sendingClasses asIdentitySet size == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   322
"/                sendingClasses first == cls ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   323
"/                    ^ '%1: sent locally from %2 and %3.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   324
"/                        bindWith:boldSelectorString
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   325
"/                        with:sendingMethods first selector "allBold"
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   326
"/                        with:sendingMethods second selector "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   327
"/                ].
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   328
"/                ^ '%1: sent in hierarchy from %2 and %3 in %4.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   329
"/                    bindWith:boldSelectorString
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   330
"/                    with:sendingMethods first selector "allBold"
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   331
"/                    with:sendingMethods second selector "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   332
"/                    with:sendingClasses first name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   333
"/            ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   334
"/        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   335
"/        numSendingMethods == 0 ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   336
"/"/            ^ '%1: no sender found.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   337
"/"/                bindWith:boldSelectorString.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   338
"/            ^ nil
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: %2 sending methods in hierarchy.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   341
"/            bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   342
"/            with:numSendingMethods.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   343
"/
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   344
"/        "/ the following is too expensive...
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   345
"/"/        sendingMethods := SystemBrowser allCallsOn:selector in:Smalltalk allClasses.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   346
"/"/        numSendingMethods == 0 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   347
"/"/            ^ '%1: nowhere sent.' bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   348
"/"/        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   349
"/"/        numSendingMethods == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   350
"/"/            sendingMethods first mclass == cls ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   351
"/"/                ^ '%1: only sent from %2.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   352
"/"/                    bindWith:boldSelectorString
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   353
"/"/                    with:sendingMethods first selector "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   354
"/"/            ].
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   355
"/"/            ^ '%1: only sent from %2 in %3.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   356
"/"/                bindWith:boldSelectorString
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   357
"/"/                with:sendingMethods first selector "allBold"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   358
"/"/                with:sendingMethods first mclass name.
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
"/"/        sendingClasses := (sendingMethods collect:[:eachMethod | eachMethod mclass]) asSet.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   361
"/"/        sendingClasses size == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   362
"/"/            sendingClasses first == cls ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   363
"/"/                ^ '%1: locally sent from %2 methods.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   364
"/"/                    bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   365
"/"/                    with:numSendingMethods
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   366
"/"/            ].
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   367
"/"/            ^ '%1 only sent from %2 methods in %3.'
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   368
"/"/                bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   369
"/"/                with:numSendingMethods
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   370
"/"/                with:sendingClasses first name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   371
"/"/        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   372
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   373
    ^ nil
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   374
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   375
    "Modified: / 09-10-2006 / 12:11:16 / cg"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   376
!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   377
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   378
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
   379
    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
   380
!
9416fc17ee62 pass the interval to the explainer
Claus Gittinger <cg@exept.de>
parents: 2191
diff changeset
   381
9416fc17ee62 pass the interval to the explainer
Claus Gittinger <cg@exept.de>
parents: 2191
diff changeset
   382
explainNode:node in:code forClass:cls short:short interval:intervalIfKnown
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   383
    node isVariable ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   384
	^ 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
   385
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   386
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   387
    node isLiteral ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   388
	^ 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
   389
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   390
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   391
    node isMessage ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   392
	^ 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
   393
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   394
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   395
    node isMethod ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   396
	^ 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
   397
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   398
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   399
    ^ nil
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   400
!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   401
2193
9416fc17ee62 pass the interval to the explainer
Claus Gittinger <cg@exept.de>
parents: 2191
diff changeset
   402
explainVariableNode:node in:code forClass:cls short:short interval:intervalIfKnown
1938
8d0163055b68 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1926
diff changeset
   403
    |expl nm nmBold definingNode namePart|
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   404
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   405
    nm := node name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   406
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   407
    (#( 'self' 'super' 'thisContext' 'here') includes:nm) ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   408
	^ Explainer explainPseudoVariable:nm in:cls short:short
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   409
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   410
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   411
    nm notNil ifTrue:[ nmBold := nm "allBold" ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   412
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   413
    definingNode := node whoDefines:nm.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   414
    definingNode notNil ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   415
	namePart := '''' , nmBold , ''''.
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   416
	definingNode isMethod ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   417
	    (definingNode arguments contains:[:arg | arg name = nm]) ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   418
		expl := namePart , ' is a method argument.'
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   419
	    ].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   420
	].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   421
	expl isNil ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   422
	    definingNode isBlock ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   423
		(definingNode arguments contains:[:arg | arg name = nm]) ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   424
		    expl := namePart , ' is a block argument.'
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   425
		].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   426
	    ].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   427
	].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   428
	expl isNil ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   429
	    definingNode parent notNil ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   430
		definingNode parent isMethod ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   431
		    expl := namePart , ' is a method temporary.'.
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   432
		] ifFalse:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   433
		    definingNode parent isBlock ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   434
		       expl := namePart , ' is a block temporary.'.
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   435
		    ]
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   436
		]
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   437
	    ].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   438
	].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   439
	expl isNil ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   440
	    expl := namePart , ' is a temporary.'
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   441
	].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   442
	(cls allInstanceVariableNames includes:nm) ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   443
	    expl := expl , ' (Instance Variable is hidden)'
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   444
	].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   445
	^ expl.
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   446
    ].
1938
8d0163055b68 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1926
diff changeset
   447
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   448
    ^ 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
   449
1938
8d0163055b68 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1926
diff changeset
   450
    "Modified: / 07-11-2006 / 12:22:09 / cg"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   451
!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   452
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   453
fetchCommentOfMethod:mthd
1909
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   454
    |methodComment lines|
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   455
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   456
    "/ with wait cursor, because it accesses sourcecode (via SCM)
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   457
    WindowGroup activeGroup withWaitCursorDo:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   458
        methodComment := mthd comment.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   459
    ].
3047
3ca3ad7eb9b7 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 2988
diff changeset
   460
    methodComment isEmptyOrNil ifTrue:[^ nil].
1909
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   461
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   462
    lines := methodComment asStringCollection.
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   463
    methodComment := lines first.
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   464
    methodComment := methodComment withoutSeparators.
3156
b09c18add94f Changed usage of deprecated #copyWithoutLast: to #copyButLast:
Stefan Vogel <sv@exept.de>
parents: 3111
diff changeset
   465
    (methodComment endsWith:',') ifTrue:[ methodComment := methodComment copyButLast:1].
1909
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   466
    methodComment := methodComment withoutSeparators.
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   467
    (lines size > 1) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   468
        methodComment := methodComment , ' ...'
1909
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   469
    ].
2225
caacd294cddc no need for #asText to emphasize a string
Claus Gittinger <cg@exept.de>
parents: 2223
diff changeset
   470
    ^ ('"' , methodComment , '"') colorizeAllWith:(UserPreferences current commentColor).
1909
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   471
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   472
    "Created: / 14-09-2006 / 14:11:58 / cg"
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   473
!
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
   474
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   475
guessPossibleImplementorClassesFor:node in:code forClass:cls
2191
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   476
    "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
   477
     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
   478
2809
bbf42cc4d305 changed: #guessPossibleImplementorClassesFor:in:forClass:
Claus Gittinger <cg@exept.de>
parents: 2471
diff changeset
   479
    |nm globalValue definer instances classesOfInstVars ns|
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   480
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   481
    node isVariable ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   482
	nm := node name.
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   483
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   484
	nm = #self ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   485
	    ^ cls withAllSubclasses
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   486
	].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   487
	nm = #here ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   488
	    ^ cls withAllSuperclasses
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   489
	].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   490
	nm = #super ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   491
	    ^ cls allSuperclasses
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   492
	].
1728
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
	definer := node whoDefines:nm.
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   495
	definer isNil ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   496
	    "/ not a local or argument
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   497
	    (cls instanceVariableNames includes:nm) ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   498
		"/ ok - an instVar; see what values we find...
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   499
		instances := cls allSubInstances.
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   500
		classesOfInstVars := instances collect:[:eachInst | (eachInst instVarNamed:nm) class] as:Set.
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   501
		^ classesOfInstVars.
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   502
	    ].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   503
	    (cls classVariableNames includes:nm) ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   504
		^ Array with:(cls classVarAt:nm asSymbol) class.
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   505
	    ].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   506
	    nm isUppercaseFirst ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   507
		nm knownAsSymbol ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   508
		    globalValue := Smalltalk at:nm asSymbol.
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   509
		    globalValue isClass ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   510
			^ Array with:globalValue class.
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   511
		    ].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   512
		].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   513
		((ns := cls topNameSpace) notNil and:[ns ~~ Smalltalk]) ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   514
		    globalValue := ns at:nm asSymbol.
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   515
		    globalValue isClass ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   516
			^ Array with:globalValue class.
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   517
		    ].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   518
		]
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   519
	    ].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   520
	].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   521
	^ nil
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   522
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   523
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   524
    node isLiteral ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   525
	^ Array with:(node value class)
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   526
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   527
2191
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   528
"/    node isMessage ifTrue:[
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   529
"/        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
   530
"/        recClassSet isNil ifTrue:[ ^ nil ].
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   531
"/        recClassSet isEmpty ifTrue:[ ^ nil ].
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   532
"/
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   533
"/        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
   534
"/        "/ 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
   535
"/        ^ rsltClassSet.
87e08ab150e2 improved explain (symbol in an array literal)
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   536
"/    ].
1731
f10b69e9c3a1 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1729
diff changeset
   537
    ^ nil
2809
bbf42cc4d305 changed: #guessPossibleImplementorClassesFor:in:forClass:
Claus Gittinger <cg@exept.de>
parents: 2471
diff changeset
   538
bbf42cc4d305 changed: #guessPossibleImplementorClassesFor:in:forClass:
Claus Gittinger <cg@exept.de>
parents: 2471
diff changeset
   539
    "Modified: / 07-02-2012 / 22:19:53 / cg"
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   540
! !
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   541
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   542
!Explainer class methodsFor:'explaining-naive'!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   543
1316
30806ca08095 commonSuperClassOf: - allow for classes and names in arg
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   544
commonSuperClassOf:listOfClassesOrClassNames
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   545
    <resource: #obsolete>
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   546
1637
993d58b1789b refactored
Claus Gittinger <cg@exept.de>
parents: 1438
diff changeset
   547
    ^ Behavior commonSuperclassOf:listOfClassesOrClassNames
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   548
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   549
    "Modified (format): / 28-02-2012 / 09:00:37 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   550
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   551
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   552
explain:someText in:source forClass:aClass
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   553
    "Given a source and a substring of it, return a string containing
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   554
     an explanation.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   555
     This is just a q&d implementation - to be correct, it should use the parser,
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   556
     and explain from the parsetree (instead of doing string matches).
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   557
     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
   558
     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
   559
     message selector. I.e. the explanation should be context sensitive.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   560
     Also, there could be much more detailed explanations."
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   561
2037
003d9b5a2788 explain shared pool variables
Claus Gittinger <cg@exept.de>
parents: 2031
diff changeset
   562
    ^ self explain:someText in:source forClass:aClass short:false
003d9b5a2788 explain shared pool variables
Claus Gittinger <cg@exept.de>
parents: 2031
diff changeset
   563
003d9b5a2788 explain shared pool variables
Claus Gittinger <cg@exept.de>
parents: 2031
diff changeset
   564
    "Modified: / 07-06-2007 / 11:34:05 / cg"
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   565
!
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   566
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   567
explain:someText in:source forClass:aClass short:shortText
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   568
    "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
   569
     an explanation.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   570
     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
   571
     and explain from the parsetree (instead of doing string matches).
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   572
     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
   573
     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
   574
     message selector. I.e. the explanation should be context sensitive.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   575
     Also, there could be much more detailed explanations."
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   576
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   577
    |explainer variables c string explanation tmp1
3049
a2d17670f62a class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3047
diff changeset
   578
     spc sym sel stringText cls clsName val valString|
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   579
675
a2f41004c24d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 509
diff changeset
   580
    string := someText string withoutSeparators.
2314
0c590d9937bd changed: #explain:in:forClass:short:
Claus Gittinger <cg@exept.de>
parents: 2292
diff changeset
   581
    string isEmpty ifTrue:[ ^ nil ].
0c590d9937bd changed: #explain:in:forClass:short:
Claus Gittinger <cg@exept.de>
parents: 2292
diff changeset
   582
2214
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
   583
    stringText := string allBold.
2414
4da315c5bcf4 changed: #explain:in:forClass:short:
Claus Gittinger <cg@exept.de>
parents: 2316
diff changeset
   584
    "/ stringText := '''' , stringText , ''''.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   585
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   586
    "
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   587
     ask parser for variable names
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   588
    "
3070
aceab5843775 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3059
diff changeset
   589
    ParseError catch:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   590
        explainer := self parseMethod:source in:aClass ignoreErrors:true ignoreWarnings:true.
1357
3936e1d64491 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1352
diff changeset
   591
    ].
3320
d7f6dce69619 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3319
diff changeset
   592
    "/ bad leftover from a stupid return value from ancient times
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   593
    explainer == #Error ifTrue:[ explainer := nil ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   594
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   595
    (explainer notNil) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   596
        "look for variables"
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   597
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   598
        variables := explainer methodVars.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   599
        (variables notNil and:[variables includes:string]) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   600
            ^ stringText , ' a method variable.'
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   601
        ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   602
        variables := explainer methodArgs.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   603
        (variables notNil and:[variables includes:string]) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   604
            ^ stringText , ' a method argument.'
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   605
        ]
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   606
    ].
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   607
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   608
    explainer isNil ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   609
        explainer := self for:(ReadStream on:source) in:aClass
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   610
    ].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   611
2988
f3cd958d9fd2 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 2986
diff changeset
   612
    "instvars/class instVars"
84
claus
parents: 58
diff changeset
   613
    c := aClass whichClassDefinesInstVar:string.
claus
parents: 58
diff changeset
   614
    c notNil ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   615
        c isMeta ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   616
            clsName := c theNonMetaclass name.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   617
            shortText ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   618
                stringText := stringText , ': a class instVar in ' , clsName
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   619
            ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   620
                stringText := stringText, ': a class instance variable inherited from ' , clsName
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   621
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   622
            val := aClass theNonMetaclass instVarNamed:string.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   623
            valString := self valueStringFor:val.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   624
            ^ stringText , ' (' , valString , ').'
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   625
        ].
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
   626
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   627
        clsName := c name.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   628
        shortText ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   629
            ^ stringText , ': an instVar in ' , clsName , '.'
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   630
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   631
        ^ stringText , ': an instance variable inherited from ' , clsName , '.'
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   632
    ].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   633
2986
cb591c4fc915 class: Explainer
Stefan Vogel <sv@exept.de>
parents: 2955
diff changeset
   634
    string isWideString ifFalse:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   635
        "classvars"
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   636
        c := explainer inWhichClassIsClassVar:string.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   637
        c notNil ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   638
            clsName := c name.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   639
            shortText ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   640
                stringText := stringText , ': a classVar in ' , clsName
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   641
            ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   642
                stringText := stringText , ': a class variable in ' , clsName
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   643
            ].
2315
45f09cea2063 changed: #explain:in:forClass:short:
Claus Gittinger <cg@exept.de>
parents: 2314
diff changeset
   644
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   645
            val := c theNonMetaclass classVarAt:string. "/ Smalltalk at:(clsName , ':' , string) asSymbol.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   646
            valString := self valueStringFor:val.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   647
            ^ stringText , ' (' , valString , ').'
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   648
        ].
1693
b6ac1ae4e625 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1674
diff changeset
   649
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   650
        "private classes"
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   651
        c := aClass theNonMetaclass.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   652
        c privateClasses do:[:pClass |
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   653
            (pClass name = string
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   654
             or:[pClass nameWithoutPrefix = string]) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   655
                stringText := stringText , ': a private class in ''' , c name , '''.'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   656
                shortText ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   657
                    stringText := (stringText , '\\It is only visible locally.') withCRs
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   658
                ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   659
                ^ stringText withCRs
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   660
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   661
        ].
422
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   662
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   663
        aClass theNonMetaclass sharedPoolNames do:[:eachPoolName |
3407
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   664
            |sharedPool sharedPoolSym|
2037
003d9b5a2788 explain shared pool variables
Claus Gittinger <cg@exept.de>
parents: 2031
diff changeset
   665
3407
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   666
            sharedPoolSym := string asSymbolIfInterned.
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   667
            sharedPoolSym notNil ifTrue:[
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   668
                sharedPool := Smalltalk classNamed:eachPoolName.
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   669
                sharedPool notNil ifTrue:[
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   670
                    sharedPool isSharedPool ifFalse:[
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   671
                        ^ 'oops - not a shared pool: ',eachPoolName
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   672
                    ].
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   673
                    (sharedPool includesKey:sharedPoolSym) ifTrue:[
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   674
                        stringText := stringText , ': a pool variable in ',sharedPool name.
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   675
                        val := sharedPool at:sharedPoolSym.
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   676
                        valString := self valueStringFor:val.
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   677
                        ^ stringText , ' (' , valString , ').'
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
   678
                    ].
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   679
                ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   680
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   681
        ].
2037
003d9b5a2788 explain shared pool variables
Claus Gittinger <cg@exept.de>
parents: 2031
diff changeset
   682
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   683
        "namespace & global variables"
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   684
        (spc := aClass nameSpace) notNil ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   685
            sym := (spc name , '::' , string) asSymbolIfInterned.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   686
            sym notNil ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   687
                (cls := Smalltalk at:sym) isBehavior ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   688
                    string :=  stringText , ': '.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   689
                    cls name = sym ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   690
                        string :=  string , 'refers to ',cls name,', '
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   691
                    ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   692
                    cls isSharedPool ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   693
                        string := string , 'a sharedPool'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   694
                    ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   695
                        string := string , 'a class'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   696
                    ].
3049
a2d17670f62a class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3047
diff changeset
   697
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   698
                    string :=  string , ' in the ''' , spc name , ''' nameSpace'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   699
                    string := string , ' {', cls category ,'}'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   700
                    shortText ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   701
                        string := (string
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   702
                             , '\\It is only visible within this nameSpace.'
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   703
                             , '\Access from the outside is possible'
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   704
                             , '\by the special name ''' , spc name , '::' , string , '''.') 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
                    ^ string withCRs
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   707
                ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   708
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   709
        ].
422
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   710
2315
45f09cea2063 changed: #explain:in:forClass:short:
Claus Gittinger <cg@exept.de>
parents: 2314
diff changeset
   711
    "/    string knownAsSymbol ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   712
            "globals & symbols"
839
021af12ebd18 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 835
diff changeset
   713
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   714
            explanation := self explainKnownSymbol:string inClass:aClass short:shortText.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   715
            explanation notNil ifTrue:[ 
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   716
                string isBinarySelector ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   717
                    "/ some are both known as syntax AND as selector (for example: #| )
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   718
                    tmp1 := self explainSyntax:string short:shortText.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   719
                    tmp1 notNil ifTrue:[ 
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   720
                        ^ tmp1 , '\\also:\\' withCRs , explanation
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   721
                    ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   722
                ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   723
                ^ explanation
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   724
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   725
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   726
            "/ try with added colon ...
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   727
            sel := string , ':'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   728
            Symbol allInstancesDo:[:sym |
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   729
                (sym startsWith:sel) ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   730
                    explanation := self explainKnownSymbol:sym inClass:aClass short:shortText.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   731
                    explanation notNil ifTrue:[ ^ explanation].
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   732
                ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   733
            ].
2315
45f09cea2063 changed: #explain:in:forClass:short:
Claus Gittinger <cg@exept.de>
parents: 2314
diff changeset
   734
    "/    ].
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   735
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   736
        "try for some obvious things"
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   737
        explanation := self explainPseudoVariable:string in:aClass short:true.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   738
        explanation notNil ifTrue:[ ^ explanation].
2315
45f09cea2063 changed: #explain:in:forClass:short:
Claus Gittinger <cg@exept.de>
parents: 2314
diff changeset
   739
    ].
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   740
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   741
    "try syntax ..."
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   742
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   743
    explanation := self explainSyntax:string short:shortText.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   744
    explanation notNil ifTrue:[ ^ explanation].
20
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
   745
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   746
    shortText ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   747
        ^ 'no explanation'
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   748
    ].
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   749
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   750
    explainer isNil ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   751
        ^ 'parse error - no explanation'
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   752
    ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   753
    ^ 'Sorry, I cannot explain this (could not figure out what this is).
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   754
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
   755
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   756
    "Created: / 03-12-1995 / 12:47:37 / cg"
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   757
    "Modified: / 16-04-1997 / 12:46:11 / stefan"
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
   758
    "Modified: / 27-07-2013 / 09:53:30 / cg"
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   759
!
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   760
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   761
explainGlobal:string inClass:aClass short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   762
    "return an explanation or nil"
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   763
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   764
    ^ self explainGlobalOrPoolVariable:string inClass:aClass short:shortText
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   765
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   766
    "Modified: / 14-10-2010 / 11:33:17 / cg"
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   767
    "Modified (comment): / 28-02-2012 / 10:45:58 / cg"
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   768
!
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   769
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   770
explainGlobalOrPoolVariable:string inClass:aClass short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   771
    "return an explanation or nil"
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   772
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   773
    |sym stringText explanation val classCategory what pool valText doc|
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   774
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   775
    "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
   776
    sym := string asSymbolIfInterned.
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
   777
    sym isNil ifTrue:[^ nil].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   778
2471
2d80a20bde1c changed:
Claus Gittinger <cg@exept.de>
parents: 2470
diff changeset
   779
    stringText := string allBold.
2d80a20bde1c changed:
Claus Gittinger <cg@exept.de>
parents: 2470
diff changeset
   780
    "/ stringText := '''' , stringText , ''''.
2d80a20bde1c changed:
Claus Gittinger <cg@exept.de>
parents: 2470
diff changeset
   781
    stringText := stringText , ': '.
2d80a20bde1c changed:
Claus Gittinger <cg@exept.de>
parents: 2470
diff changeset
   782
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   783
    "a pool variable?"
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   784
    aClass notNil ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   785
        aClass theNonMetaclass sharedPoolNames do:[:eachPoolName |
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   786
            pool := Smalltalk at:eachPoolName.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   787
            pool isNil ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   788
            ] ifFalse:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   789
                (pool classVarNames includes:string) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   790
                    what := 'a pool variable in "%1".' bindWith:eachPoolName.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   791
                    val := pool classVarAt:sym.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   792
                ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   793
            ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   794
        ].
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   795
    ].
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   796
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   797
    what isNil ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   798
        "try globals"
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   799
        (Smalltalk includesKey:sym) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   800
            what := 'a global variable.'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   801
            val := Smalltalk at:sym.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   802
        ] ifFalse:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   803
           (aClass theNonMetaclass sharedPoolNames includes:string) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   804
                pool := Smalltalk at:sym ifAbsent:nil.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   805
                pool isNil ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   806
                    ^ stringText,'a missing pool'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   807
                ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   808
            ] ifFalse:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   809
                ^ nil
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   810
            ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   811
        ].
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   812
    ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   813
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   814
    explanation := stringText , what.
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   815
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   816
    val isBehavior ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   817
        "/ a class
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   818
        val name = sym ifFalse:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   819
            stringText := stringText , ' a global; refers to ',val name,', '.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   820
        ].
1979
847742bcb22d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1943
diff changeset
   821
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   822
        (val isRealNameSpace) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   823
            ^ stringText , 'a namespace.'
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   824
        ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   825
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   826
        classCategory := val category ? 'uncategorized'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   827
        shortText ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   828
            stringText := stringText , (val isLoaded ifTrue:['a'] ifFalse:['an autoloaded']).
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   829
            stringText := stringText , (val isSharedPool ifTrue:[' sharedPool'] ifFalse:[' class']).
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   830
            ^ stringText , ' in ',val package,' {' , classCategory , '}.'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   831
        ].
1330
100f022924b6 oops - care for namespaces
ca
parents: 1317
diff changeset
   832
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   833
        val name = string ifTrue:[
3322
c4dfa6cff14b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3321
diff changeset
   834
            false ifTrue:[
c4dfa6cff14b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3321
diff changeset
   835
                "/ TODO: generate a short documentation string (comment plus interface)
c4dfa6cff14b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3321
diff changeset
   836
                "/ and return { #html->htmlText . #text->regularText}
c4dfa6cff14b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3321
diff changeset
   837
                "/ so caller can extrat what he wants to see...
c4dfa6cff14b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3321
diff changeset
   838
                ^ (HTMLDocGenerator htmlDocOf:val).
c4dfa6cff14b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3321
diff changeset
   839
            ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   840
            explanation := explanation , '\' withCRs , string , ' is '.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   841
            explanation := explanation , (val isLoaded ifTrue:['a'] ifFalse:['an autoloaded']).
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   842
            explanation := explanation , (val isSharedPool ifTrue:[' sharedPool'] ifFalse:[' class']).
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   843
            explanation := explanation , ' categorized as "' , classCategory , '"'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   844
            explanation := explanation , '\' withCRs , 'in the "' , val package , '" package.'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   845
            (doc := val commentOrDocumentationString) notEmptyOrNil ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   846
                doc := doc asStringCollection.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   847
                doc size > 25 ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   848
                    doc := doc copyTo:25.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   849
                    doc add:''; add:'   ... <more documentation cut off>'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   850
                ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   851
                doc := doc asString colorizeAllWith:(UserPreferences current commentColor).
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   852
                explanation := explanation,'\\' withCRs,val name,'''s documentation:\'withCRs, doc
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   853
            ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   854
            ^ explanation.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   855
        ].
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   856
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   857
        explanation := explanation , '
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   858
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   859
' , string , ' is bound to the class ' , val name ,
3049
a2d17670f62a class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3047
diff changeset
   860
' in the "' , classCategory , '" category.'.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   861
        ^ explanation.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   862
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   863
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   864
    valText := self valueStringFor:val.
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   865
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   866
    shortText ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   867
        ^ stringText,' a global (',valText,')'.
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   868
    ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   869
    explanation := explanation , '
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   870
2466
75b29e4a34c0 changed: #explainGlobalOrPoolVariable:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2427
diff changeset
   871
Its current value is "%1".' bindWith:valText.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
   872
    ^ explanation.
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
   873
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   874
    "Created: / 14-10-2010 / 11:33:04 / cg"
2815
a04d0047c512 changed:
Claus Gittinger <cg@exept.de>
parents: 2809
diff changeset
   875
    "Modified: / 14-02-2012 / 15:31:28 / cg"
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   876
    "Modified (comment): / 28-02-2012 / 10:45:48 / cg"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   877
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   878
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   879
explainHereIn:aClass
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   880
    "return an explanation"
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   881
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   882
    <resource: #obsolete>
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   883
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   884
    ^ self explainHereIn:aClass short:false
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   885
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   886
    "Modified (comment): / 28-02-2012 / 10:47:29 / cg"
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   887
!
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   888
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   889
explainHereIn:aClass short:shortText
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   890
    "return an explanation"
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   891
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   892
    |className|
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   893
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   894
    className := aClass name.
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   895
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   896
    shortText ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   897
	^ '"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
   898
    ].
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   899
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   900
    ^ '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
   901
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   902
However, when sending a message to "here", the search for methods
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   903
implementing this message will start in the defining class (' , className , '),
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   904
instead of the receiver''s class (' , className , ' or subclass).
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   905
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
   906
that the local method is called.'
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   907
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   908
    "Created: / 28-02-2012 / 10:44:55 / cg"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   909
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   910
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   911
explainKnownSymbol:string inClass:aClass
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   912
    "return an explanation or nil"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   913
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   914
    ^ self explainKnownSymbol:string inClass:aClass short:false
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   915
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   916
    "Modified (comment): / 28-02-2012 / 10:45:40 / cg"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   917
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   918
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   919
explainKnownSymbol:string inClass:aClass short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   920
    "return an explanation or nil"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   921
2471
2d80a20bde1c changed:
Claus Gittinger <cg@exept.de>
parents: 2470
diff changeset
   922
    |sym expl|
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   923
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   924
    sym := string asSymbolIfInterned.
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   925
    sym isNil ifTrue:[^ nil].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   926
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   927
    "try globals and pools"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   928
    (Smalltalk includesKey:sym) ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   929
	expl := self explainGlobalOrPoolVariable:string inClass:aClass short:shortText.
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   930
	expl notNil ifTrue:[^ expl].
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   931
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   932
2471
2d80a20bde1c changed:
Claus Gittinger <cg@exept.de>
parents: 2470
diff changeset
   933
    expl := self explainSelector:string inClass:aClass short:shortText.
2d80a20bde1c changed:
Claus Gittinger <cg@exept.de>
parents: 2470
diff changeset
   934
    expl notNil ifTrue:[^ expl].
2d80a20bde1c changed:
Claus Gittinger <cg@exept.de>
parents: 2470
diff changeset
   935
    ^ self explainGlobalOrPoolVariable:string inClass:aClass short:shortText.
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
   936
2471
2d80a20bde1c changed:
Claus Gittinger <cg@exept.de>
parents: 2470
diff changeset
   937
    "Modified: / 18-01-2011 / 19:13:07 / cg"
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   938
    "Modified (comment): / 28-02-2012 / 10:46:06 / cg"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   939
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   940
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   941
explainPseudoVariable:string in:aClass
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   942
    "return an explanation for the pseudoVariables self, super etc."
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   943
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   944
    <resource: #obsolete>
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   945
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   946
    ^ self explainPseudoVariable:string in:aClass short:false
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   947
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   948
    "Modified (format): / 28-02-2012 / 10:47:17 / cg"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   949
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   950
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   951
explainPseudoVariable:string in:aClass short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
   952
    "return an explanation for the pseudoVariables self, super etc."
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   953
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   954
    (string = 'self') ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   955
	^ self explainSelfIn:aClass short:shortText
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   956
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   957
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   958
    (string = 'super') ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   959
	^ self explainSuperIn:aClass short:shortText
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   960
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   961
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   962
    (string = 'here') ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   963
	^ self explainHereIn:aClass short:shortText
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   964
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   965
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   966
    (string = 'thisContext') ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   967
	shortText ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   968
	    ^ '''thisContext'' - the current stack frame as an object.'
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   969
	].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   970
	^ '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
   971
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   972
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
   973
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
   974
receivers/selectors can be accessed via thisContext.'
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   975
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   976
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   977
    (string = 'true') ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   978
	shortText ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   979
	    ^ '''true'' - the truth and nothing but the truth.'
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   980
	].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   981
	^ '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
   982
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   983
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
   984
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   985
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   986
    (string = 'false') ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   987
	shortText ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   988
	    ^ '''false'' - obvisously not true.'
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   989
	].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   990
	^ '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
   991
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   992
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
   993
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   994
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   995
    (string = 'nil') ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   996
	shortText ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   997
	    ^ '''nil'' - undefined, unknown, void or dont care.'
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   998
	].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
   999
	^ '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
  1000
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1001
Nil is used for unitialized variables (among other uses).
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1002
Nil is the one and only instance of class UndefinedObject.'
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1003
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1004
    ^ nil
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1005
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1006
    "Modified (comment): / 28-02-2012 / 10:46:18 / cg"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1007
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1008
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1009
explainSelector:string inClass:aClass short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1010
    "return an explanation or nil"
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1011
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1012
    |sym listOfImplementingClasses listOfSimilarSelectors
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1013
     firstImplementingClassOfSimilar count tmp commonSuperClass s s2
2288
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1014
     firstImplementingClass cm msg t check|
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1015
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1016
    sym := string asSymbolIfInterned.
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1017
    sym isNil ifTrue:[^ nil].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1018
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1019
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1020
     try selectors
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1021
     look who implements it
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1022
    "
3174
e3e1c0bde329 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3156
diff changeset
  1023
    listOfImplementingClasses := Set new.
e3e1c0bde329 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3156
diff changeset
  1024
    listOfSimilarSelectors := Set new.
2288
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1025
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1026
    check :=
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1027
        [:sel :mthd :cls |
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1028
            sel == sym ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1029
                listOfImplementingClasses add:(cls name).
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1030
                firstImplementingClass isNil ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1031
                    firstImplementingClass := cls
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1032
                ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1033
            ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1034
                (sel startsWith:sym) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1035
                    listOfSimilarSelectors add:sel.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1036
                    firstImplementingClassOfSimilar isNil ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1037
                        firstImplementingClassOfSimilar := cls
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1038
                    ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1039
                ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1040
            ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1041
        ].
2288
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1042
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1043
    Smalltalk allClassesDo:[:c|
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1044
        c methodDictionary keysAndValuesDo:[:sel :mthd |
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1045
            check value:sel value:mthd value:c
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1046
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1047
        c class methodDictionary keysAndValuesDo:[:sel :mthd |
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1048
            check value:sel value:mthd value:c class
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1049
        ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1050
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1051
835
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
  1052
    (aClass canUnderstand:sym) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1053
        s2 := ('Instances of ''' , aClass name , ''' respond to #') , sym "allBold" , '.'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1054
        shortText ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1055
            s2 := '\\' , s2
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1056
                  , '\- inherited from ' withCRs
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1057
                  , (aClass whichClassIncludesSelector:sym) name "allBold".
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1058
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1059
        firstImplementingClass := (aClass whichClassIncludesSelector:sym)
835
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
  1060
    ] ifFalse:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1061
        s2 := ''.
835
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
  1062
    ].
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
  1063
3174
e3e1c0bde329 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3156
diff changeset
  1064
    count := listOfImplementingClasses size.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1065
    (count ~~ 0) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1066
        "
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1067
         for up-to 4 implementing classes,
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1068
         list them
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1069
        "
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1070
        listOfImplementingClasses := listOfImplementingClasses asOrderedCollection sort.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1071
        shortText ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1072
            tmp := ' is implemented in '.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1073
        ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1074
            tmp := ' is a selector implemented in '.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1075
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1076
        s := "'#' ," string allBold.
911
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
  1077
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1078
        (count == 1) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1079
            (t := listOfImplementingClasses first) isMeta ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1080
                t := 'the ' , t
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1081
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1082
            msg := s , tmp , t , '.'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1083
            shortText ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1084
                msg := msg , s2.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1085
            ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1086
        ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1087
            (count == 2) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1088
                msg := s,tmp,(listOfImplementingClasses at:1),' and ',(listOfImplementingClasses at:2),'.'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1089
                shortText ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1090
                    msg := msg , s2.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1091
                ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1092
            ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1093
                (count == 3) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1094
                    msg := s,tmp,(listOfImplementingClasses at:1),',',(listOfImplementingClasses at:2),' and ',(listOfImplementingClasses at:3),'.'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1095
                    shortText ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1096
                        msg := msg , s2.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1097
                    ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1098
                ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1099
                    shortText ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1100
                        msg := s , tmp , count printString , ' classes'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1101
                        commonSuperClass := Class commonSuperclassOf:listOfImplementingClasses.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1102
                        (commonSuperClass == Object
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1103
                        and:[commonSuperClass includesSelector:sym]) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1104
                            msg := msg , ' (including ' , 'Object' "allBold", ')'
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1105
                        ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1106
                            (commonSuperClass ~= Object) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1107
                                msg := msg , ' (under ' , commonSuperClass name, ')'
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1108
                            ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1109
                        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1110
                        msg := msg , '.'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1111
                        ^ msg
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1112
                    ].
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1113
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1114
                    (count == 3) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1115
                        msg := s , tmp , '
3174
e3e1c0bde329 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3156
diff changeset
  1116
' , (listOfImplementingClasses at:1) , ', ' , (listOfImplementingClasses at:2) , ' and ' , (listOfImplementingClasses at:3) , '.' , s2
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1117
                    ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1118
                        (count == 4) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1119
                            msg := s , tmp , '
3174
e3e1c0bde329 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3156
diff changeset
  1120
' , (listOfImplementingClasses at:1) , ', ' , (listOfImplementingClasses at:2) , ', ' , (listOfImplementingClasses at:3), ' and ' , (listOfImplementingClasses at:4) , '.' , s2
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1121
                        ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1122
                            "
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1123
                             if there are more, look for a common
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1124
                             superclass and show it ...
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1125
                            "
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1126
                            commonSuperClass := Behavior commonSuperclassOf:listOfImplementingClasses.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1127
                            (commonSuperClass ~~ Object
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1128
                            and:[commonSuperClass ~~ Behavior
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1129
                            and:[commonSuperClass ~~ Class
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1130
                            and:[commonSuperClass ~~ ClassDescription]]]) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1131
                                (listOfImplementingClasses includes:commonSuperClass) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1132
                                    msg := s . tmp , count printString , commonSuperClass name
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1133
                                             , ' and redefined in ' , (count - 1) printString
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1134
                                             , ' subclasses'
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1135
                                             , s2.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1136
                                    firstImplementingClass := commonSuperClass
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1137
                                ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1138
                                    msg := s , tmp, count printString , ' subclasses of ' , commonSuperClass name , s2
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1139
                                ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1140
                            ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1141
                                (commonSuperClass == Object
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1142
                                and:[commonSuperClass includesSelector:sym]) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1143
                                    msg := s , tmp , count printString , ' classes.
834
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1144
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1145
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
  1146
since there is an implementation in Object.' , s2.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1147
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1148
                                    firstImplementingClass := Object
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1149
                                ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1150
                                    ((commonSuperClass == Behavior
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1151
                                     or:[commonSuperClass == Class
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1152
                                     or:[commonSuperClass == ClassDescription]])
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1153
                                    and:[commonSuperClass includesSelector:sym]) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1154
                                        msg := s , tmp , count printString , ' classes.
913
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
  1155
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1156
All classes seem to respond to that message,
913
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
  1157
since there is an implementation in ' , commonSuperClass name , '.' , s2.
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
  1158
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1159
                                        firstImplementingClass := commonSuperClass
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1160
                                    ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1161
                                        "
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1162
                                         otherwise just give the number.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1163
                                        "
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1164
                                        msg := s , tmp , count printString , ' classes.' , s2
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1165
                                    ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1166
                                ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1167
                            ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1168
                        ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1169
                    ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1170
                ]
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
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1173
        shortText ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1174
            count == 1 ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1175
                cm := self fetchCommentOfMethod:(firstImplementingClass compiledMethodAt:sym).
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1176
                cm notNil ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1177
                    msg := msg,'',cm
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1178
                ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1179
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1180
        ] ifFalse:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1181
"/            firstImplementingClass notNil ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1182
"/                WindowGroup activeGroup withWaitCursorDo:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1183
"/                    cm := self fetchCommentOfMethod:(firstImplementingClass compiledMethodAt:sym).
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1184
"/                ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1185
"/                cm notNil ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1186
"/                    msg := msg , '\\The comment in ' withCRs
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1187
"/                               , firstImplementingClass name "allBold" , ' is:\' withCRs
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1188
"/                               , '"' , cm allItalic , '"'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1189
"/                ]
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1190
"/            ].
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1191
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1192
        ^ msg
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1193
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1194
3174
e3e1c0bde329 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3156
diff changeset
  1195
    count := listOfSimilarSelectors size.
2288
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1196
    (count ~~ 0) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1197
        listOfSimilarSelectors := listOfSimilarSelectors asOrderedCollection sort.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1198
        shortText ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1199
            tmp := ' is implemented in '.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1200
        ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1201
            tmp := ' is a selector implemented in '.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1202
        ].
2288
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1203
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1204
        (count == 1) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1205
            msg := listOfSimilarSelectors first allBold , tmp , firstImplementingClassOfSimilar name , '.'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1206
            shortText ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1207
                msg := msg , s2.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1208
            ]
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1209
        ] ifFalse:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1210
            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
  1211
            count > 2 ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1212
                msg := msg,'...'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1213
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1214
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1215
        ^ msg
2288
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1216
    ].
92c7e16d6916 changed: #explainSelector:inClass:short:
Claus Gittinger <cg@exept.de>
parents: 2287
diff changeset
  1217
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1218
    ^ nil
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
  1219
1909
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
  1220
    "Modified: / 17-06-1996 / 17:09:30 / stefan"
3e273cee71af *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1869
diff changeset
  1221
    "Created: / 23-03-1999 / 13:29:33 / cg"
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1222
    "Modified: / 27-07-2013 / 09:59:46 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1223
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1224
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1225
explainSelfIn:aClass short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1226
    "return an explanation"
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1227
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1228
    |sub subNames selfString className nSubClasses|
1198
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
  1229
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
  1230
    selfString := '''' , 'self' "allBold" , ''''.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1231
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1232
    sub := aClass allSubclasses.
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1233
    nSubClasses := sub size.
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1234
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1235
    aClass isMeta ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1236
	className := aClass theNonMetaclass name.
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1237
	subNames := sub collect:[:c | c theNonMetaclass name].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1238
	nSubClasses == 0 ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1239
	    shortText ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1240
		^ selfString , ' - the ''' , className , '''-class.'
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1241
	    ].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1242
	    ^ selfString , 'refers to the object which received the message.
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1243
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1244
In this case, it will be the ' , className , '-class itself.'
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1245
	].
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1246
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1247
	shortText ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1248
	    nSubClasses == 1 ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1249
		^ selfString , ' - the ''' , className , '''- or ''' , subNames first , '''-class.'
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1250
	    ].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1251
	    ^ selfString , ' - the ''' , className , '''-class or one of its subclasses.'
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1252
	].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1253
	nSubClasses <= 5 ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1254
	    ^ selfString , ' refers to the object which received the message.
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1255
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1256
In this case, it will be the ' , className , '-class
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1257
or one of its subclasses:
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1258
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1259
' , subNames asStringCollection asString
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1260
	].
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1261
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1262
	^ selfString , ' refers to the object which received the message.
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1263
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1264
In this case, it will be the ' , className , '-class
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1265
or one of its ' , nSubClasses printString , ' subclasses.'
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1266
    ].
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1267
1256
cc3fa02585ec *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
  1268
    subNames := aClass allSubclasses collect:[:c | c theNonMetaclass name].
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1269
    className := aClass name.
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1270
    nSubClasses == 0 ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1271
	shortText ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1272
	    ^ selfString , ' - an instance of ''' , className , '''.'
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1273
	].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1274
	^ selfString , 'refers to the object which received the message.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1275
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1276
In this case, it will be an instance of ' , className , '.'
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1277
    ].
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1278
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1279
    shortText ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1280
	nSubClasses == 1 ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1281
	    ^ selfString , ' - an instance of ''' , className , ''' or ''' , subNames first , '''.'
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1282
	].
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1283
	^ selfString , ' - an instance of ''' , className , ''' or one of its subclasses.'
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1284
    ].
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1285
    nSubClasses <= 5 ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1286
	^ selfString , ' refers to the object which received the message.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1287
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1288
In this case, it will be an instance of ' , className , '
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1289
or one of its subclasses:
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1290
1256
cc3fa02585ec *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
  1291
' , subNames asStringCollection asString
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1292
    ].
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1293
1198
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
  1294
    ^ selfString , ' refers to the object which received the message.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1295
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1296
In this case, it will be an instance of ' , className , '
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1297
or one of its ' , nSubClasses printString , ' subclasses.'
1926
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
  1298
935dbaeca76f show class package in explanation
Claus Gittinger <cg@exept.de>
parents: 1910
diff changeset
  1299
    "Modified: / 09-10-2006 / 12:11:44 / cg"
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1300
    "Modified (comment): / 28-02-2012 / 10:47:06 / cg"
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1301
!
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1302
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1303
explainSuperIn:aClass short:shortText
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1304
    "return an explanation"
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1305
1352
e9e91394ca1a Remove unused method variables
Stefan Vogel <sv@exept.de>
parents: 1331
diff changeset
  1306
    |superName|
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1307
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
  1308
    superName := aClass superclass name.
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1309
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1310
    shortText ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1311
	^ '"super" - message lookup starts in superclass "%1" (call redefined method).' bindWith:superName
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1312
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
  1313
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1314
    ^ 'like "self", "','super'allBold,'" refers to the object which received the message.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1315
2828
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1316
However, when sending a message to "super", the search for methods
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1317
implementing this message will start in the superclass (' , superName , '),
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1318
instead of the receiver''s class (' , aClass name , ' or subclass).
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1319
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
  1320
aa93cebd33e4 added: #explainHereIn:short:
Claus Gittinger <cg@exept.de>
parents: 2815
diff changeset
  1321
    "Modified (comment): / 28-02-2012 / 10:47:03 / cg"
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
  1322
!
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
  1323
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1324
explainSyntax:string
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1325
    "try syntax ...; return explanation or nil"
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1326
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1327
    ^ self explainSyntax:string short:false
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1328
!
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1329
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1330
explainSyntax:string short:shortText
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1331
    "try syntax ...; return explanation or nil"
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1332
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1333
    ((string = ':=') or:[string = '_']) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1334
        shortText ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1335
            ^ '":=" - assign to variable on the left side.'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1336
        ].
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1337
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1338
        ^ '<variable> := <expression>
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1339
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1340
":=" and "_" (which is left-arrow in some fonts) mean assignment.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1341
The variable is bound to (i.e. points to) the value of <expression>.'
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1342
The "_" form is historic and should not be used with new code.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1343
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1344
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1345
    (string = '^') ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1346
        shortText ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1347
            ^ '"^" - return value from method.'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1348
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1349
        ^ '^ <expression>
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1350
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1351
A return statement evaluates <expression> and returns its value from the method.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1352
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
  1353
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1354
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1355
    (string = ';') ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1356
        shortText ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1357
            ^ '";" - a cascade expression.'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1358
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1359
        ^ '<expression> ; selector1 ; .... ; selectorN
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1360
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1361
a cascade expression; evaluate expression, and send messages
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1362
<selector1> ... <selectorN> to the first expression''s receiver.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1363
Returns the value of the last send. The cascade sends may also have arguments.'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1364
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1365
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1366
    (string = '|') ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1367
        shortText ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1368
            ^ '"|" - local variables'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1369
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1370
        ^ '| locals |  or: [:arg | statements]
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1371
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1372
"|" is used to mark a local variable declaration or separates arguments
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1373
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
  1374
these arg nams must be prefixed by a colon character.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1375
"|" is also a selector understood by Booleans.'
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1376
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1377
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1378
    (string startsWith:'$' ) ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1379
        shortText ifTrue:[
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1380
            ^ '"$x" - character literal.'.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1381
        ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1382
        ^ 'is a Character literal constant.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1383
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1384
Character objects represent indivdual text cheracters in Unicode encoding.
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1385
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
  1386
Smalltalk/X supports unicode and uses this encoding internally for all characters
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1387
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
  1388
    ].
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1389
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1390
    (string startsWith:'#' ) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1391
        (string startsWith:'#(' ) ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1392
            shortText ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1393
                ^ '"#(..)" - array literal.'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1394
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1395
            ^ 'is a constant Array.
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1396
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1397
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
  1398
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
  1399
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
  1400
other array constants or byte-arrays.
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1401
(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
  1402
 element in an Array-constant).'
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1403
        ].
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1404
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1405
        (string startsWith:'#[') ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1406
            shortText ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1407
                ^ '"#[..]" - byteArray literal.'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1408
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1409
            ^ 'is a constant ByteArray.
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1410
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1411
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
  1412
0 .. 255.
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1413
(notice, that not all Smalltalk implementations support constant ByteArrays).'
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1414
        ].
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1415
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1416
        (string startsWith:'#''') ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1417
            shortText ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1418
                ^ '"#''..''" - symbol literal.'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1419
            ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1420
            ^ 'is a constant symbol containing non-alphanumeric characters.
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1421
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1422
Symbols are unique strings, meaning that there exists
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1423
exactly one instance of a given symbol. Therefore symbols can
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1424
be compared using == (identity compare) in addition to = (contents compare).
3194
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1425
Beside this, Symbols behave mostly like Strings but are immutable.'
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1426
        ].
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1427
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1428
        shortText ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1429
            ^ '"#.." - symbol literal.'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1430
        ].
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1431
        ^ 'is a constant symbol.
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1432
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1433
Symbols are unique strings, meaning that there exists
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1434
exactly one instance of a given symbol. Therefore symbols can
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1435
be compared using == (identity compare) in addition to = (contents compare).
3194
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1436
Beside this, Symbols behave mostly like Strings but are immutable.'
2287
61f5dfccf2c0 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2286
diff changeset
  1437
    ].
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1438
    ((string startsWith:'(') or:[string endsWith:')']) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1439
        shortText ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1440
            ^ ''.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1441
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1442
        ^ '( <expression> )
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1443
3194
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1444
expression grouping. Without them, expressions are evaluated left to right,
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1445
with unary messages preceeding binary messages, preceeding keyword mesages.'
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1446
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1447
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1448
    ((string startsWith:'[') or:[string endsWith:']']) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1449
        shortText ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1450
            ^ '"[..]" - a block (aka lambda/closure for experts)'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1451
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1452
        ^ '[:arg1 .. :argN | statements]
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1453
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1454
defines a block.
3194
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1455
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
  1456
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
  1457
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
  1458
(it can be even evaluated multiple times).
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1459
Blocks are often passed as arguments to Booleans (i.e. "bool ifTrue:[...]"),
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1460
other blocks (i.e. "[...] whileTrue: [...]"]) or collections (i.e. "coll do:[...]").
364362530bcd class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3193
diff changeset
  1461
Blocks are also often used as callbacks from UI components or as exception handlers.'
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1462
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1463
2286
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1464
    ((string startsWith:'{') or:[string endsWith:'}']) ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1465
        shortText ifTrue:[
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1466
            ^ '"{..}" array instantiation'.
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1467
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1468
        ^ '{ <expr1>. .. <exprN> }
2286
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1469
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1470
This is syntactic sugar for "Array with:<expr1> .. with:<exprN>".
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1471
2286
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1472
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
  1473
The expressions are separated by a period statement separator.
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1474
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
  1475
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
  1476
compilation time) and which is shared.
3319
83ed09191e6b class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3233
diff changeset
  1477
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
  1478
makes your program somewhat dialect specific.'
2286
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1479
    ].
cabf7db33a38 changed: #explainSyntax:short:
Claus Gittinger <cg@exept.de>
parents: 2226
diff changeset
  1480
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1481
    (string = ':') ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1482
        shortText ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1483
            ^ ''.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1484
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1485
        ^ 'colons have different meaning depending on context:
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1486
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1487
1) they separate keyword-parts in symbols and keyword-messages as in:
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1488
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1489
    #at:put:                     a constant keyword symbol
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1490
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1491
    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
  1492
                                 passing index and value as arguments.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1493
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1494
2) within block-argument declarations as in:
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1495
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1496
    [:arg1 :arg2 | statements]
834
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1497
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1498
3) within an identifier, they separate the nameSpace part from
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1499
   the name part; as in:
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1500
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1501
    Smalltalk::Array    - the Array class in the Smalltalk nameSpace.
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1502
    Foo::Array          - the Array class in the Foo nameSpace.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1503
'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1504
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1505
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1506
    (string = '.') ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1507
        ^ 'statement. "<- period here"
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1508
statement
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1509
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1510
within a method or block, individual statements are separated by periods.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1511
'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1512
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1513
3193
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1514
    (string withoutSeparators startsWith:'"/') ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1515
        shortText ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1516
            ^ 'an end-of-line comment'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1517
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1518
        ^ '"/ comment
3193
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1519
EOL (end-of-line) comment
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1520
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1521
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
  1522
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
  1523
'
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1524
    ].
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1525
    (string withoutSeparators startsWith:'"') ifTrue:[
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1526
        shortText ifTrue:[
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1527
            ^ 'a comment'.
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1528
        ].
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1529
        ^ '" comment ... "
3193
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1530
comment
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1531
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1532
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
  1533
'
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1534
    ].
581cfb33f8ac class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3174
diff changeset
  1535
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1536
    "/ is it a symbol without hash-character ?
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1537
    "/
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1538
"/    string knownAsSymbol ifTrue:[
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1539
"/        ^ 'is nothing, but #' , string , ' is known as a symbol.
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1540
"/
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1541
"/Symbols are unique strings, meaning that there exists
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1542
"/exactly one instance of a given symbol. Therefore symbols can
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1543
"/be compared using == (identity compare) in addition to = (contents compare).
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1544
"/Beside this, Symbols behave mostly like Strings.'
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1545
"/    ].
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1546
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1547
    ^ nil
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1548
3233
0761ca178615 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3209
diff changeset
  1549
    "Modified: / 27-07-2013 / 10:08:57 / cg"
2214
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1550
!
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1551
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1552
valueStringFor:aValue
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1553
    |valString|
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1554
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1555
    "/ only show the value, if it is really short...
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1556
    (aValue isBoolean
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1557
	or:[aValue isNil
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1558
	or:[aValue isString
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1559
	or:[aValue isNumber
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1560
	or:[aValue isPoint
2899
8b8701a65441 Avoid #isKindOf: where possible
Stefan Vogel <sv@exept.de>
parents: 2828
diff changeset
  1561
    ]]]]) ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1562
	^ aValue storeString.
2226
d628e2ef289e changed: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2225
diff changeset
  1563
    ].
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1564
2226
d628e2ef289e changed: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2225
diff changeset
  1565
    (aValue isColor) ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1566
	^ 'Color: ',('   ' emphasizeAllWith:(#backgroundColor->aValue)).
2226
d628e2ef289e changed: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2225
diff changeset
  1567
    ].
d628e2ef289e changed: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2225
diff changeset
  1568
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1569
    ((aValue isKindOf:GUID)
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1570
     or:[aValue isUUID]) ifTrue:[
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1571
	valString := aValue printString.
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1572
    ].
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1573
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1574
    (valString isEmptyOrNil
2899
8b8701a65441 Avoid #isKindOf: where possible
Stefan Vogel <sv@exept.de>
parents: 2828
diff changeset
  1575
     or:[ valString size > 50
8b8701a65441 Avoid #isKindOf: where possible
Stefan Vogel <sv@exept.de>
parents: 2828
diff changeset
  1576
     or:[ valString includes:Character cr ]]) ifTrue:[
3203
d6685b9ffe5d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3194
diff changeset
  1577
	valString := aValue classNameWithArticle.
2214
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1578
    ].
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1579
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1580
    ^ valString
2427
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1581
Claus Gittinger <cg@exept.de>
parents: 2414
diff changeset
  1582
    "Modified: / 14-10-2010 / 11:57:52 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1583
! !
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1584
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
  1585
!Explainer class methodsFor:'documentation'!
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
  1586
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
  1587
version
3407
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
  1588
    ^ '$Header: /cvs/stx/stx/libcomp/Explainer.st,v 1.133 2014-03-12 13:42:02 stefan Exp $'
2214
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1589
!
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1590
b06f6576c314 added: #valueStringFor:
Claus Gittinger <cg@exept.de>
parents: 2204
diff changeset
  1591
version_CVS
3407
ced75e88cf6a class: Explainer
Stefan Vogel <sv@exept.de>
parents: 3322
diff changeset
  1592
    ^ '$Header: /cvs/stx/stx/libcomp/Explainer.st,v 1.133 2014-03-12 13:42:02 stefan Exp $'
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
  1593
! !
3209
af924bf746f3 class: Explainer
Claus Gittinger <cg@exept.de>
parents: 3203
diff changeset
  1594