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