Explainer.st
author Claus Gittinger <cg@exept.de>
Tue, 28 Mar 2006 19:45:42 +0200
changeset 1729 cab536ed26c6
parent 1728 f2a7a491889f
child 1731 f10b69e9c3a1
permissions -rw-r--r--
*** empty log message ***
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
"
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    12
1081
6e6255672d68 allBehaviors vs. allClasses
Claus Gittinger <cg@exept.de>
parents: 913
diff changeset
    13
"{ Package: 'stx:libcomp' }"
6e6255672d68 allBehaviors vs. allClasses
Claus Gittinger <cg@exept.de>
parents: 913
diff changeset
    14
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
    15
Parser subclass:#Explainer
263
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    16
	instanceVariableNames:''
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    17
	classVariableNames:''
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    18
	poolDictionaries:''
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    19
	category:'System-Compiler'
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    20
!
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    21
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
    22
!Explainer class methodsFor:'documentation'!
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    23
20
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    24
copyright
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    25
"
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    26
 COPYRIGHT (c) 1993 by Claus Gittinger
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
    27
	      All Rights Reserved
20
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    28
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    29
 This software is furnished under a license and may be used
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    30
 only in accordance with the terms of that license and with the
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    31
 inclusion of the above copyright notice.   This software may not
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    32
 be provided or otherwise made available to, or used by, any
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    33
 other person.  No title to or ownership of the software is
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    34
 hereby transferred.
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    35
"
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    36
!
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    37
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    38
documentation
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    39
"
20
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    40
    a very simple explainer - much more should be added ...
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
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    45
    [author:]
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    46
        Claus Gittinger
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    47
"
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    48
! !
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    49
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
    50
!Explainer class methodsFor:'explaining'!
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    51
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    52
explainLiteralNode:node in:code forClass:cls short:short
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    53
    |expl literalValue|
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    54
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    55
    literalValue := node value.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    56
    expl := literalValue class name allBold , '-constant.'.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    57
    (literalValue isArray or:[ literalValue isByteArray ]) ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    58
        literalValue size == 0 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    59
            ^ 'empty ' , expl
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    60
        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    61
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    62
    ^ expl
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    63
!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    64
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    65
explainMessageNode:node in:code forClass:cls short:short
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    66
    |receiver nm srchClass selector selectorString implClass 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    67
     boldSelectorString globalValue recClassSet
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    68
     implMethod comment info implMethods comments definer instances classesOfInstVars implementingClasses canBeNil|
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    69
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    70
    selector := node selector.      
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    71
    selectorString := selector printString contractTo:30.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    72
    boldSelectorString := selectorString allBold.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    73
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    74
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    75
recClassSet := self guessPossibleImplementorClassesFor:(node receiver) in:code forClass:cls.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    76
recClassSet size == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    77
    implementingClasses := recClassSet collect:[:cls | cls whichClassImplements:selector]. 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    78
    (implementingClasses includes:nil) ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    79
        ^ 'possibly not understood: ' , selector allBold
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    80
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    81
].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    82
implementingClasses isNil ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    83
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    84
    receiver := node receiver.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    85
    receiver isVariable ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    86
        nm := receiver name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    87
        nm = 'self' ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    88
            srchClass := cls
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    89
        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    90
        nm = 'super' ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    91
            srchClass := cls superclass
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    92
        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    93
        definer := receiver whoDefines:nm.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    94
        definer isNil ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    95
            "/ not a local or argument
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    96
            (cls instanceVariableNames includes:nm) ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    97
                "/ ok - an instVar; see what values we find...
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    98
                instances := cls allSubInstances.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
    99
                classesOfInstVars := instances collect:[:eachInst | (eachInst instVarNamed:nm) class].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   100
                classesOfInstVars := classesOfInstVars asSet.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   101
                canBeNil := classesOfInstVars includes:UndefinedObject.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   102
                classesOfInstVars remove:UndefinedObject ifAbsent:[].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   103
                implementingClasses := classesOfInstVars collect:[:cls | cls whichClassImplements:selector]. 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   104
            ] ifFalse:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   105
                nm isUppercaseFirst ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   106
                    nm knownAsSymbol ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   107
                        globalValue := Smalltalk at:nm asSymbol.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   108
                        globalValue isClass ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   109
                            srchClass := globalValue class.    
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   110
                        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   111
                    ]
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   112
                ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   113
            ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   114
        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   115
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   116
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   117
    receiver isLiteral ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   118
        srchClass := receiver value class
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   119
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   120
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   121
    srchClass notNil ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   122
        implClass := srchClass whichClassImplements:selector.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   123
        implClass isNil ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   124
            ^ '%1 is NOT understood here.' bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   125
        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   126
        info := '%1 >> %2' bindWith:implClass name allBold with:selectorString allBold.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   127
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   128
        implMethod := implClass compiledMethodAt:selector.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   129
        comment := implMethod comment.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   130
        comment notNil ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   131
            comment := comment firstLine.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   132
            comment := comment asText colorizeAllWith:(UserPreferences current commentColor).
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   133
            info := info , ' "' , comment , '"'.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   134
        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   135
        ^ info
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   136
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   137
    implementingClasses isNil ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   138
        implementingClasses := Smalltalk allImplementorsOf:selector
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   139
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   140
].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   141
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   142
    implementingClasses size == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   143
        implClass := implementingClasses anElement.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   144
        info := 'guess: %1 >> %2' bindWith:implClass name allBold with:selectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   145
    ] ifFalse:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   146
        info := Explainer explainSelector:selector inClass:cls short:short.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   147
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   148
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   149
    implementingClasses size > 0 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   150
        implMethods := implementingClasses collect:[:implClass | implClass compiledMethodAt:selector].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   151
        implMethods size <= 5 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   152
            comments := implMethods collect:[:implMethod | implMethod comment].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   153
            (comments includes:nil) ifFalse:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   154
                comments := comments collect:[:comment | comment firstLine].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   155
                comments asSet size == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   156
                    comment := comments first.    
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   157
                    comment := comment asText colorizeAllWith:(UserPreferences current commentColor).
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   158
                    info := info , ' "' , comment , '"'.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   159
                ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   160
            ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   161
        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   162
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   163
    ^ info
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   164
!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   165
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   166
explainMethodNode:node in:code forClass:cls short:short
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   167
    |srchClass selector selectorString implClass 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   168
     "sendingMethods numSendingMethods sendingClasses" boldSelectorString|
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   169
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   170
    selector := node selector.      
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   171
    selectorString := selector printString contractTo:30.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   172
    boldSelectorString := selectorString allBold.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   173
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   174
    (srchClass := cls superclass) notNil ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   175
        implClass := srchClass whichClassImplements:selector.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   176
        implClass notNil ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   177
            ^ '%1 hides implementation in %2.' 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   178
              bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   179
              with:implClass name allBold
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   180
        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   181
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   182
    (cls implements:selector) ifFalse:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   183
        ^ '%1: a new method.' bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   184
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   185
"/
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   186
"/        sendingMethods := SystemBrowser 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   187
"/                                allCallsOn:selector 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   188
"/                                in:(cls withAllSubclasses , cls allSubclasses) 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   189
"/                                ignoreCase:false 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   190
"/                                match:false.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   191
"/        sendingMethods := sendingMethods select:[:eachMethod | eachMethod mclass notNil].  "/ remove unbound ones
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   192
"/
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   193
"/        sendingClasses := (sendingMethods collect:[:eachMethod | eachMethod mclass]) asSet.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   194
"/        numSendingMethods := sendingMethods size.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   195
"/        numSendingMethods == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   196
"/            sendingClasses first == cls ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   197
"/                ^ '%1: sent locally from %2.' 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   198
"/                    bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   199
"/                    with:sendingMethods first selector allBold
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   200
"/            ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   201
"/            ^ '%1: sent in hierarchy from %2 in %3.' 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   202
"/                bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   203
"/                with:sendingMethods first selector allBold
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   204
"/                with:sendingClasses first name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   205
"/        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   206
"/        numSendingMethods == 2 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   207
"/            sendingClasses asIdentitySet size == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   208
"/                sendingClasses first == cls ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   209
"/                    ^ '%1: sent locally from %2 and %3.' 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   210
"/                        bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   211
"/                        with:sendingMethods first selector allBold
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   212
"/                        with:sendingMethods second selector allBold
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   213
"/                ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   214
"/                ^ '%1: sent in hierarchy from %2 and %3 in %4.' 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   215
"/                    bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   216
"/                    with:sendingMethods first selector allBold
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   217
"/                    with:sendingMethods second selector allBold
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   218
"/                    with:sendingClasses first name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   219
"/            ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   220
"/        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   221
"/        numSendingMethods == 0 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   222
"/"/            ^ '%1: no sender found.' 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   223
"/"/                bindWith:boldSelectorString.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   224
"/            ^ nil
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
"/        ^ '%1: %2 sending methods in hierarchy.' 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   227
"/            bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   228
"/            with:numSendingMethods.
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
"/        "/ the following is too expensive...
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   231
"/"/        sendingMethods := SystemBrowser allCallsOn:selector in:Smalltalk allClasses.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   232
"/"/        numSendingMethods == 0 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   233
"/"/            ^ '%1: nowhere sent.' bindWith: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
"/"/        numSendingMethods == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   236
"/"/            sendingMethods first mclass == cls ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   237
"/"/                ^ '%1: only sent from %2.' 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   238
"/"/                    bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   239
"/"/                    with:sendingMethods first selector allBold
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   240
"/"/            ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   241
"/"/            ^ '%1: only sent from %2 in %3.' 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   242
"/"/                bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   243
"/"/                with:sendingMethods first selector allBold
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   244
"/"/                with:sendingMethods first mclass name.
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
"/"/        sendingClasses := (sendingMethods collect:[:eachMethod | eachMethod mclass]) asSet.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   247
"/"/        sendingClasses size == 1 ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   248
"/"/            sendingClasses first == cls ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   249
"/"/                ^ '%1: locally sent from %2 methods.' 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   250
"/"/                    bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   251
"/"/                    with:numSendingMethods
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   252
"/"/            ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   253
"/"/            ^ '%1 only sent from %2 methods in %3.' 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   254
"/"/                bindWith:boldSelectorString
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   255
"/"/                with:numSendingMethods
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   256
"/"/                with:sendingClasses first name.
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
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   259
    ^ nil
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   260
!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   261
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   262
explainNode:node in:code forClass:cls short:short
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   263
    node isVariable ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   264
        ^ self explainVariableNode:node in:code forClass:cls short:short.
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
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   267
    node isLiteral ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   268
        ^ self explainLiteralNode:node in:code forClass:cls short:short
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   269
    ].
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
    node isMessage ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   272
        ^ self explainMessageNode:node in:code forClass:cls short:short
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   273
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   274
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   275
    node isMethod ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   276
        ^ self explainMethodNode:node in:code forClass:cls short:short
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   277
    ].
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
    ^ nil
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   280
!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   281
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   282
explainVariableNode:node in:code forClass:cls short:short
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   283
    |expl nm nmBold definingNode|
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
    nm := node name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   286
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   287
    (#( 'self' 'super' 'thisContext' 'here') includes:nm) ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   288
        ^ Explainer explainPseudoVariable:nm in:cls short:short
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   289
    ].
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
    nm notNil ifTrue:[ nmBold := nm allBold ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   292
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   293
    definingNode := node whoDefines:nm.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   294
    definingNode notNil ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   295
        expl := '''' , nmBold , ''''. 
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   296
        definingNode isMethod ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   297
            (definingNode arguments contains:[:arg | arg name = nm]) ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   298
                ^ expl , ' is a method argument.'
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
        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   301
        definingNode isBlock ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   302
            (definingNode arguments contains:[:arg | arg name = nm]) ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   303
                ^ expl , ' is a block argument.'
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   304
            ].
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
        definingNode parent notNil ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   307
            definingNode parent isMethod ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   308
                ^ expl , ' is a method temporary.'
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   309
            ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   310
            definingNode parent isBlock ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   311
                ^ expl , ' is a block temporary.'
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   312
            ]
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   313
        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   314
        ^ expl , ' is a temporary.'
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   315
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   316
    ^ Explainer explain:node name in:code forClass:cls short:short
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
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   319
guessPossibleImplementorClassesFor:node in:code forClass:cls
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   320
    |nm globalValue recClassSet rsltClassSet implSet definer instances classesOfInstVars|
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   321
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   322
    node isVariable ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   323
        nm := node name.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   324
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   325
        nm = 'self' ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   326
            ^ cls withAllSubclasses
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
        nm = 'here' ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   329
            ^ cls withAllSuperclasses
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   330
        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   331
        nm = 'super' ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   332
            ^ cls allSuperclasses
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   333
        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   334
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   335
        definer := node whoDefines:nm.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   336
        definer isNil ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   337
            "/ not a local or argument
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   338
            (cls instanceVariableNames includes:nm) ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   339
                "/ ok - an instVar; see what values we find...
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   340
                instances := cls allSubInstances.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   341
                classesOfInstVars := instances collect:[:eachInst | (eachInst instVarNamed:nm) class].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   342
                classesOfInstVars := classesOfInstVars asSet.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   343
                ^ classesOfInstVars. 
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
            nm isUppercaseFirst ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   346
                nm knownAsSymbol ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   347
                    globalValue := Smalltalk at:nm asSymbol.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   348
                    globalValue isClass ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   349
                        ^ Array with:globalValue class.    
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   350
                    ].
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
                (cls nameSpace notNil and:[cls nameSpace ~~ Smalltalk]) ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   353
                    globalValue := cls nameSpace at:nm asSymbol.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   354
                    globalValue isClass ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   355
                        ^ Array with:globalValue class.    
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   356
                    ].
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
            ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   359
        ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   360
        ^ nil
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   361
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   362
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   363
    node isLiteral ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   364
        ^ Array with:(node value class)
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   365
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   366
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   367
    node isMessage ifTrue:[
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   368
        recClassSet := self guessPossibleImplementorClassesFor:(node receiver) in:code forClass:cls.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   369
        recClassSet isNil ifTrue:[ ^ nil ].
1729
cab536ed26c6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1728
diff changeset
   370
        recClassSet isEmpty ifTrue:[ ^ nil ].
1728
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   371
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   372
        implSet := recClassSet collect:[:recClass | recClass whichClassImplements:node selector].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   373
        "/ toDo: for each implementor, parse its method for possible return types.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   374
        ^ rsltClassSet.
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   375
    ].
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   376
    self halt.
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
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   379
!Explainer class methodsFor:'explaining-naive'!
f2a7a491889f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1693
diff changeset
   380
1316
30806ca08095 commonSuperClassOf: - allow for classes and names in arg
Claus Gittinger <cg@exept.de>
parents: 1289
diff changeset
   381
commonSuperClassOf:listOfClassesOrClassNames
1637
993d58b1789b refactored
Claus Gittinger <cg@exept.de>
parents: 1438
diff changeset
   382
    ^ Behavior commonSuperclassOf:listOfClassesOrClassNames
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   383
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   384
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   385
explain:someText in:source forClass:aClass
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   386
    "Given a source and a substring of it, return a string containing
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   387
     an explanation.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   388
     This is just a q&d implementation - to be correct, it should use the parser,
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   389
     and explain from the parsetree (instead of doing string matches).
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   390
     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
   391
     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
   392
     message selector. I.e. the explanation should be context sensitive.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   393
     Also, there could be much more detailed explanations."
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   394
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   395
    ^ self
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   396
        explain:someText in:source forClass:aClass short:false
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   397
!
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   398
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   399
explain:someText in:source forClass:aClass short:shortText
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   400
    "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
   401
     an explanation.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   402
     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
   403
     and explain from the parsetree (instead of doing string matches).
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   404
     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
   405
     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
   406
     message selector. I.e. the explanation should be context sensitive.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   407
     Also, there could be much more detailed explanations."
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   408
1159
24a034278a55 Remove unused method vars
Stefan Vogel <sv@exept.de>
parents: 1151
diff changeset
   409
    |parser variables c string tmp
1289
2434f1ee11ee show classVars
Claus Gittinger <cg@exept.de>
parents: 1256
diff changeset
   410
     spc sym sel stringText clsName val valString|
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   411
675
a2f41004c24d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 509
diff changeset
   412
    string := someText string withoutSeparators.
1198
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
   413
    stringText := string allBold.
1233
1015bcce9646 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1232
diff changeset
   414
    stringText := '''' , stringText , ''''.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   415
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   416
    "
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   417
     ask parser for variable names
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   418
    "
1357
3936e1d64491 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1352
diff changeset
   419
    ParseErrorSignal catch:[
3936e1d64491 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1352
diff changeset
   420
        parser := self parseMethod:source in:aClass ignoreErrors:true ignoreWarnings:true.
3936e1d64491 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1352
diff changeset
   421
    ].
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   422
    parser notNil ifTrue:[
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   423
        "look for variables"
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   424
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   425
        variables := parser methodVars.
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   426
        (variables notNil and:[variables includes:string]) ifTrue:[
1233
1015bcce9646 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1232
diff changeset
   427
            ^ stringText , ' is a method variable.'
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   428
        ].
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   429
        variables := parser methodArgs.
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   430
        (variables notNil and:[variables includes:string]) ifTrue:[
1233
1015bcce9646 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1232
diff changeset
   431
            ^ stringText , ' is a method argument.'
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   432
        ]
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   433
    ].
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   434
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   435
    parser isNil ifTrue:[
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   436
        parser := self for:(ReadStream on:source) in:aClass
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   437
    ].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   438
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   439
    "instvars"
84
claus
parents: 58
diff changeset
   440
    c := aClass whichClassDefinesInstVar:string.
claus
parents: 58
diff changeset
   441
    c notNil ifTrue:[
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
   442
        c isMeta ifTrue:[
1211
91e94e294819 isMeta/soleInstance -> theMetaclass / theNonMetaclass
Claus Gittinger <cg@exept.de>
parents: 1210
diff changeset
   443
            clsName := c theNonMetaclass name.
1198
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
   444
            shortText ifTrue:[
1233
1015bcce9646 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1232
diff changeset
   445
                ^ stringText , ' is a class instVar in ' , clsName , '.'
1198
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
   446
            ].
1233
1015bcce9646 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1232
diff changeset
   447
            ^ stringText, ' is a class instance variable in ' , clsName , '.'
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
   448
        ].
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
   449
1233
1015bcce9646 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1232
diff changeset
   450
        clsName := c name.
1198
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
   451
        shortText ifTrue:[
1233
1015bcce9646 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1232
diff changeset
   452
            ^ stringText , ' is an instVar in ' , clsName , '.'
1198
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
   453
        ].
1233
1015bcce9646 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1232
diff changeset
   454
        ^ stringText , ' is an instance variable in ' , clsName , '.'
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   455
    ].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   456
84
claus
parents: 58
diff changeset
   457
"/    variables := aClass allInstVarNames.
claus
parents: 58
diff changeset
   458
"/    (variables notNil and:[variables includes:string]) ifTrue:[
claus
parents: 58
diff changeset
   459
"/        "where is it"
claus
parents: 58
diff changeset
   460
"/        c := aClass.
1159
24a034278a55 Remove unused method vars
Stefan Vogel <sv@exept.de>
parents: 1151
diff changeset
   461
"/        [c notNil] whileTrue:[ |v|
84
claus
parents: 58
diff changeset
   462
"/            v := c instVarNames.
claus
parents: 58
diff changeset
   463
"/            (v notNil and:[v includes:string]) ifTrue:[
claus
parents: 58
diff changeset
   464
"/                ^ string , ' is an instance variable in ' , c name
claus
parents: 58
diff changeset
   465
"/            ].
claus
parents: 58
diff changeset
   466
"/            c := c superclass
claus
parents: 58
diff changeset
   467
"/        ].
claus
parents: 58
diff changeset
   468
"/        self error:'oops'
claus
parents: 58
diff changeset
   469
"/    ].
claus
parents: 58
diff changeset
   470
442
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   471
"/    "class instvars"
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   472
"/    variables := aClass class allInstVarNames.
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   473
"/    (variables notNil and:[variables includes:string]) ifTrue:[
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   474
"/        "where is it"
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   475
"/        c := aClass.
1159
24a034278a55 Remove unused method vars
Stefan Vogel <sv@exept.de>
parents: 1151
diff changeset
   476
"/        [c notNil] whileTrue:[ |v|
442
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   477
"/            v := c class instVarNames.
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   478
"/            (v notNil and:[v includes:string]) ifTrue:[
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   479
"/                ^ string , ' is a class instance variable in ' , c name
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   480
"/            ].
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   481
"/            c := c superclass
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   482
"/        ].
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   483
"/        self error:'oops'
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   484
"/    ].
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   485
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   486
    "classvars"
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   487
    c := parser inWhichClassIsClassVar:string.
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   488
    c notNil ifTrue:[
1233
1015bcce9646 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1232
diff changeset
   489
        clsName := c name.
1198
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
   490
        shortText ifTrue:[
1289
2434f1ee11ee show classVars
Claus Gittinger <cg@exept.de>
parents: 1256
diff changeset
   491
            stringText := stringText , ' is a classVar in ' , clsName 
2434f1ee11ee show classVars
Claus Gittinger <cg@exept.de>
parents: 1256
diff changeset
   492
        ] ifFalse:[
2434f1ee11ee show classVars
Claus Gittinger <cg@exept.de>
parents: 1256
diff changeset
   493
            stringText := stringText , ' is a class variable in ' , clsName
1198
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
   494
        ].
1693
b6ac1ae4e625 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1674
diff changeset
   495
1289
2434f1ee11ee show classVars
Claus Gittinger <cg@exept.de>
parents: 1256
diff changeset
   496
        val := Smalltalk at:(clsName , ':' , string) asSymbol.
1693
b6ac1ae4e625 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1674
diff changeset
   497
        (val isBoolean or:[val isNil]) ifTrue:[
b6ac1ae4e625 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1674
diff changeset
   498
            valString := val storeString .
1289
2434f1ee11ee show classVars
Claus Gittinger <cg@exept.de>
parents: 1256
diff changeset
   499
        ] ifFalse:[
1693
b6ac1ae4e625 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1674
diff changeset
   500
            (val isSymbol or:[val isNumber]) ifTrue:[
b6ac1ae4e625 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1674
diff changeset
   501
                valString := val className, ' ' , val storeString .
b6ac1ae4e625 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1674
diff changeset
   502
            ] ifFalse:[
b6ac1ae4e625 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1674
diff changeset
   503
                valString := val classNameWithArticle.
b6ac1ae4e625 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1674
diff changeset
   504
            ].
1289
2434f1ee11ee show classVars
Claus Gittinger <cg@exept.de>
parents: 1256
diff changeset
   505
        ].
2434f1ee11ee show classVars
Claus Gittinger <cg@exept.de>
parents: 1256
diff changeset
   506
        ^ stringText , ' (' , valString , ').'
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   507
    ].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   508
1210
e3174ccbb5bb isMeta/soleInstance -> theMetaclass / theNonMetaclass
Claus Gittinger <cg@exept.de>
parents: 1198
diff changeset
   509
    c := aClass theNonMetaclass.
509
d8475399ca3e Correct handling of private classes.
Stefan Vogel <sv@exept.de>
parents: 503
diff changeset
   510
    c privateClasses do:[:pClass |
d8475399ca3e Correct handling of private classes.
Stefan Vogel <sv@exept.de>
parents: 503
diff changeset
   511
        (pClass name = string 
d8475399ca3e Correct handling of private classes.
Stefan Vogel <sv@exept.de>
parents: 503
diff changeset
   512
         or:[pClass nameWithoutPrefix = string]) ifTrue:[
1233
1015bcce9646 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1232
diff changeset
   513
            string := stringText , ' is a private class in ''' , c name , '''.'.
1015bcce9646 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1232
diff changeset
   514
            shortText ifFalse:[
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   515
                string := (string , '\\It is only visible locally.') withCRs
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   516
            ].
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   517
            ^ string withCRs
422
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   518
        ].
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   519
    ].
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   520
456
abe32fed9c0d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 442
diff changeset
   521
    (spc := aClass nameSpace) notNil ifTrue:[
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
   522
        sym := (spc name , '::' , string) asSymbolIfInterned.
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
   523
        sym notNil ifTrue:[
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
   524
            (Smalltalk at:sym) isBehavior ifTrue:[
1233
1015bcce9646 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1232
diff changeset
   525
                string :=  stringText , ' is a class in the ''' , spc name , ''' nameSpace.'.
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   526
                shortText ifFalse:[
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   527
                    string := (string 
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
   528
                         , '\\It is only visible within this nameSpace.'
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
   529
                         , '\Access from the outside is possible'
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
   530
                         , '\by the special name ''' , spc name , '::' , string , '''.') withCRs
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   531
                ].
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   532
                ^ string withCRs
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
   533
            ].
422
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   534
        ].
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   535
    ].
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   536
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
   537
"/    string knownAsSymbol ifTrue:[
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   538
        "globals & symbols"
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   539
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   540
        tmp := self explainKnownSymbol:string inClass:aClass short:shortText.
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   541
        tmp notNil ifTrue:[ ^ tmp].
839
021af12ebd18 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 835
diff changeset
   542
021af12ebd18 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 835
diff changeset
   543
        "/ try with added colon ...
021af12ebd18 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 835
diff changeset
   544
        sel := string , ':'.
021af12ebd18 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 835
diff changeset
   545
        Symbol allInstancesDo:[:sym |
021af12ebd18 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 835
diff changeset
   546
            (sym startsWith:sel) ifTrue:[
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   547
                tmp := self explainKnownSymbol:sym inClass:aClass short:shortText.
839
021af12ebd18 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 835
diff changeset
   548
                tmp notNil ifTrue:[ ^ tmp].
021af12ebd18 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 835
diff changeset
   549
            ]
021af12ebd18 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 835
diff changeset
   550
        ].
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
   551
"/    ].
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   552
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   553
    "try for some obvious things"
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   554
    tmp := self explainPseudoVariable:string in:aClass short:true.
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   555
    tmp notNil ifTrue:[ ^ tmp].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   556
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   557
    "try syntax ..."
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   558
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   559
    tmp := self explainSyntax:string short:shortText.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   560
    tmp notNil ifTrue:[ ^ tmp].
20
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
   561
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   562
    shortText ifTrue:[
1438
d8553b015a28 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1428
diff changeset
   563
        ^ 'no explanation'
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   564
    ].
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   565
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   566
    parser isNil ifTrue:[
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   567
        ^ 'parse error - no explanation'
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   568
    ].
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
   569
    ^ '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
   570
675
a2f41004c24d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 509
diff changeset
   571
    "Created: / 3.12.1995 / 12:47:37 / cg"
a2f41004c24d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 509
diff changeset
   572
    "Modified: / 16.4.1997 / 12:46:11 / stefan"
1211
91e94e294819 isMeta/soleInstance -> theMetaclass / theNonMetaclass
Claus Gittinger <cg@exept.de>
parents: 1210
diff changeset
   573
    "Modified: / 5.11.2001 / 16:54:23 / cg"
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   574
!
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   575
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   576
explainGlobal:string inClass:aClass short:shortText
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   577
    "return explanation or nil"
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   578
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   579
    |sym stringText tmp val classCategory|
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   580
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   581
    "if not even known as key, its definitely not a global"
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   582
    sym := string asSymbolIfInterned. 
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
   583
    sym isNil ifTrue:[^ nil].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   584
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   585
    "try globals"
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   586
    (Smalltalk includesKey:sym) ifFalse:[ ^ nil].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   587
1198
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
   588
    stringText := string allBold.
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
   589
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   590
    "/ stringText := '''' , stringText , ''''.
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   591
    tmp := stringText , ' is a global variable.'.
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   592
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   593
    val := Smalltalk at:sym.
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   594
    val isBehavior ifTrue:[
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   595
        "/ a class
1331
0951a2122a85 Fix obsolete method usage
Stefan Vogel <sv@exept.de>
parents: 1330
diff changeset
   596
        val isNameSpace ifTrue:[
1330
100f022924b6 oops - care for namespaces
ca
parents: 1317
diff changeset
   597
            ^ stringText , ' is a namespace.'
100f022924b6 oops - care for namespaces
ca
parents: 1317
diff changeset
   598
        ].
100f022924b6 oops - care for namespaces
ca
parents: 1317
diff changeset
   599
100f022924b6 oops - care for namespaces
ca
parents: 1317
diff changeset
   600
        classCategory := val category ? 'uncategorized'.
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   601
        shortText ifTrue:[
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   602
            ^ stringText , ' is ' , (val isLoaded ifTrue:['a'] ifFalse:['an autoloaded'])
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   603
, ' class in the ''' , classCategory , ''' category.'.
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   604
        ].
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   605
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   606
        val name = string ifTrue:[
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   607
            tmp := tmp , '
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   608
' , string , ' is ' , (val isLoaded ifTrue:['a'] ifFalse:['an autoloaded'])
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   609
, ' class categorized as ' , classCategory , '
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   610
in the ''' , val package , ''' package.'.
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   611
            ^ tmp.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   612
        ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   613
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   614
        tmp := tmp , '
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   615
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   616
' , string , ' is bound to the class ' , val name ,
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   617
' 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
   618
        ^ tmp.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   619
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   620
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   621
    shortText ifTrue:[
1674
942a9a3acfc9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1637
diff changeset
   622
        val isNil ifTrue:[
942a9a3acfc9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1637
diff changeset
   623
            ^ stringText , ' is a global, currently nil.'.
942a9a3acfc9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1637
diff changeset
   624
        ].
1245
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   625
        ^ stringText , ' is a global, currently bound to ''' , val classNameWithArticle , '''.'.
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   626
    ].
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   627
    tmp := tmp , '
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   628
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   629
Its current value is ''' , val classNameWithArticle , '''.'.
fa98b7f89dd3 explaining
Claus Gittinger <cg@exept.de>
parents: 1244
diff changeset
   630
    ^ tmp.
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   631
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   632
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   633
explainHereIn:aClass
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   634
    ^ 'like self, here refers to the object which received the message.
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   635
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   636
However, when sending a message to here the search for methods
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   637
implementing this message will start in the defining class (' , aClass name , ')
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   638
instead of the receivers class (' , aClass name , ' or subclass).
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   639
Thus, using here, redefined methods will NOT be reached with a here-send.'
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   640
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   641
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   642
explainKnownSymbol:string inClass:aClass
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   643
    "return explanation or nil"
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   644
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   645
    ^ self explainKnownSymbol:string inClass:aClass short:false
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   646
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   647
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   648
explainKnownSymbol:string inClass:aClass short:shortText
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   649
    "return explanation or nil"
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   650
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   651
    |sym|
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   652
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   653
    sym := string asSymbolIfInterned.
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   654
    sym isNil ifTrue:[^ nil].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   655
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   656
    "try globals"
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   657
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   658
    (Smalltalk includesKey:sym) ifTrue:[
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   659
        ^ self explainGlobal:string inClass:aClass short:shortText
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   660
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   661
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   662
    ^ self explainSelector:string inClass:aClass short:shortText
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   663
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   664
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   665
explainPseudoVariable:string in:aClass
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   666
    "return explanation for the pseudoVariables self, super etc."
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   667
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   668
    ^ self explainPseudoVariable:string in:aClass short:false
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   669
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   670
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   671
explainPseudoVariable:string in:aClass short:shortText
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   672
    "return explanation for the pseudoVariables self, super etc."
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   673
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   674
    (string = 'self') ifTrue:[
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   675
        ^ self explainSelfIn:aClass short:shortText
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   676
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   677
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   678
    (string = 'super') ifTrue:[
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   679
        shortText ifTrue:[
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   680
            ^ '''super'' - message lookup starts in superclass ''' , aClass superclass name , '''.'
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   681
        ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   682
        ^ self explainSuperIn:aClass short:shortText
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   683
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   684
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   685
    (string = 'here') ifTrue:[
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   686
        shortText ifTrue:[
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   687
            ^ '''here'' - message lookup always starts in ''' , aClass name , '''.'
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   688
        ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   689
        ^ self explainHereIn:aClass
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   690
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   691
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   692
    (string = 'thisContext') ifTrue:[
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   693
        shortText ifTrue:[
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   694
            ^ '''thisContext'' - the current stack frame as an object.'
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   695
        ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   696
        ^ 'thisContext is a pseudo variable (i.e. it is built in).
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   697
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   698
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
   699
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
   700
receivers/selectors can be accessed via thisContext.'
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   701
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   702
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   703
    (string = 'true') ifTrue:[
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   704
        shortText ifTrue:[
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   705
            ^ '''true'' - the truth and nothing but the truth.'
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   706
        ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   707
        ^ 'true is a pseudo variable (i.e. it is built in).
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   708
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   709
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
   710
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   711
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   712
    (string = 'false') ifTrue:[
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   713
        shortText ifTrue:[
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   714
            ^ '''false'' - obvisously not true.'
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   715
        ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   716
        ^ 'false is a pseudo variable (i.e. it is built in).
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   717
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   718
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
   719
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   720
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   721
    (string = 'nil') ifTrue:[
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   722
        shortText ifTrue:[
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   723
            ^ '''nil'' - undefined, unknown, void or dont care.'
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   724
        ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   725
        ^ 'nil is a pseudo variable (i.e. it is built in).
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   726
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   727
Nil is used for unitialized variables (among other uses).
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   728
Nil is the one and only instance of class UndefinedObject.'
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   729
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   730
    ^ nil
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   731
!
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   732
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   733
explainSelector:string inClass:aClass short:shortText
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   734
    "return explanation or nil"
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   735
1352
e9e91394ca1a Remove unused method variables
Stefan Vogel <sv@exept.de>
parents: 1331
diff changeset
   736
    |sym list count tmp commonSuperClass s s2 
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   737
     firstImplementingClass cm msg t|
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   738
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   739
    sym := string asSymbolIfInterned.
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   740
    sym isNil ifTrue:[^ nil].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   741
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   742
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   743
     try selectors
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   744
     look who implements it
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   745
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   746
    list := Set new.
1081
6e6255672d68 allBehaviors vs. allClasses
Claus Gittinger <cg@exept.de>
parents: 913
diff changeset
   747
    Smalltalk allClassesDo:[:c|
1249
780b4a1a3967 implements -> includesSelector
Claus Gittinger <cg@exept.de>
parents: 1245
diff changeset
   748
        (c includesSelector:sym) ifTrue:[
911
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   749
            list add:(c name).
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   750
            firstImplementingClass isNil ifTrue:[
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   751
                firstImplementingClass := c
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   752
            ]
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   753
        ].
1249
780b4a1a3967 implements -> includesSelector
Claus Gittinger <cg@exept.de>
parents: 1245
diff changeset
   754
        (c class includesSelector:sym) ifTrue:[
911
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   755
            list add:(c name , ' class').
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   756
            firstImplementingClass isNil ifTrue:[
912
41eaf4909608 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 911
diff changeset
   757
                firstImplementingClass := c class
911
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   758
            ]
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   759
        ]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   760
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   761
835
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
   762
    (aClass canUnderstand:sym) ifTrue:[
1428
593b1af9d563 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1357
diff changeset
   763
        s2 := ('Instances of ''' , aClass name , ''' respond to #') , sym allBold , '.'.
1184
b091e74f640f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   764
        shortText ifFalse:[
b091e74f640f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   765
            s2 := '\\' , s2 
b091e74f640f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   766
                  , '\- inherited from ' withCRs
1428
593b1af9d563 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1357
diff changeset
   767
                  , (aClass whichClassImplements:sym) name allBold.
1184
b091e74f640f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   768
        ].
911
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   769
        firstImplementingClass := (aClass whichClassImplements:sym)
835
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
   770
    ] ifFalse:[
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
   771
        s2 := ''.
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
   772
    ].
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
   773
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   774
    count := list size.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   775
    (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
   776
        "
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   777
         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
   778
         list them
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   779
        "
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   780
        list := list asOrderedCollection sort.
1185
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   781
        shortText ifTrue:[
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   782
            tmp := ' is implemented in '.
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   783
        ] ifFalse:[
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   784
            tmp := ' is a selector implemented in '.
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   785
        ].
1428
593b1af9d563 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1357
diff changeset
   786
        s := '#' , string allBold.
911
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   787
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   788
        (count == 1) ifTrue:[
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   789
            (t := list first) isMeta ifTrue:[
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   790
                t := 'the ' , t
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   791
            ].
1184
b091e74f640f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   792
            msg := s , tmp , t , '.'.
b091e74f640f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   793
            shortText ifFalse:[
b091e74f640f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   794
                msg := msg , s2.
b091e74f640f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1183
diff changeset
   795
            ]
911
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   796
        ] ifFalse:[
1185
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   797
            (count == 2) ifTrue:[
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   798
                msg := s , tmp , (list at:1) , ' and ' , (list at:2) , '.'.
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   799
                shortText ifFalse:[
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   800
                    msg := msg , s2.
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   801
                ].
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   802
            ] ifFalse:[
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   803
                shortText ifTrue:[
1428
593b1af9d563 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1357
diff changeset
   804
                    msg := s , tmp , count printString , ' classes'.
1637
993d58b1789b refactored
Claus Gittinger <cg@exept.de>
parents: 1438
diff changeset
   805
                    commonSuperClass := Class commonSuperclassOf:list.
1428
593b1af9d563 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1357
diff changeset
   806
                    (commonSuperClass == Object
593b1af9d563 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1357
diff changeset
   807
                    and:[commonSuperClass includesSelector:sym]) ifTrue:[
593b1af9d563 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1357
diff changeset
   808
                        msg := msg , ' (including ' , 'Object' allBold, ')'
593b1af9d563 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1357
diff changeset
   809
                    ].
593b1af9d563 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1357
diff changeset
   810
                    msg := msg , '.'.
1185
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   811
                    ^ msg
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   812
                ].
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   813
911
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   814
                (count == 3) ifTrue:[
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   815
                    msg := s , tmp , '
835
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
   816
' , (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
   817
                ] ifFalse:[
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   818
                    (count == 4) ifTrue:[
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   819
                        msg := s , tmp , '
835
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
   820
' , (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
   821
                    ] ifFalse:[
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   822
                        "
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   823
                         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
   824
                         superclass and show it ...
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   825
                        "
1637
993d58b1789b refactored
Claus Gittinger <cg@exept.de>
parents: 1438
diff changeset
   826
                        commonSuperClass := Behavior commonSuperclassOf:list.
913
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   827
                        (commonSuperClass ~~ Object 
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   828
                        and:[commonSuperClass ~~ Behavior
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   829
                        and:[commonSuperClass ~~ Class
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   830
                        and:[commonSuperClass ~~ ClassDescription]]]) ifTrue:[
911
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   831
                            (list includes:commonSuperClass) ifTrue:[
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   832
                                msg := s . tmp , count printString , commonSuperClass name 
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   833
                                         , ' and redefined in ' , (count - 1) printString  
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   834
                                         , ' subclasses'
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   835
                                         , s2.
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   836
                                firstImplementingClass := commonSuperClass
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   837
                            ] ifFalse:[
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   838
                                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
   839
                            ]
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   840
                        ] ifFalse:[
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   841
                            (commonSuperClass == Object
1249
780b4a1a3967 implements -> includesSelector
Claus Gittinger <cg@exept.de>
parents: 1245
diff changeset
   842
                            and:[commonSuperClass includesSelector:sym]) ifTrue:[
911
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   843
                                msg := s , tmp , count printString , ' classes.
834
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
   844
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
   845
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
   846
since there is an implementation in Object.' , s2.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   847
911
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   848
                                firstImplementingClass := Object
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   849
                            ] ifFalse:[
913
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   850
                                ((commonSuperClass == Behavior
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   851
                                 or:[commonSuperClass == Class
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   852
                                 or:[commonSuperClass == ClassDescription]])
1249
780b4a1a3967 implements -> includesSelector
Claus Gittinger <cg@exept.de>
parents: 1245
diff changeset
   853
                                and:[commonSuperClass includesSelector:sym]) ifTrue:[
913
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   854
                                    msg := s , tmp , count printString , ' classes.
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   855
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   856
All classes seem to respond to that message, 
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   857
since there is an implementation in ' , commonSuperClass name , '.' , s2.
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   858
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   859
                                    firstImplementingClass := commonSuperClass
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   860
                                ] ifFalse:[
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   861
                                    "
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   862
                                     otherwise just give the number.
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   863
                                    "
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   864
                                    msg := s , tmp , count printString , ' classes.' , s2
bd05fb9dbc9a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 912
diff changeset
   865
                                ]
911
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   866
                            ]
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   867
                        ]
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   868
                    ]
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   869
                ]
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   870
            ].
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   871
        ].
1185
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   872
        shortText ifFalse:[
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   873
            firstImplementingClass notNil ifTrue:[
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   874
                WindowGroup activeGroup withWaitCursorDo:[
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   875
                    cm := firstImplementingClass compiledMethodAt:sym.
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   876
                    cm notNil ifTrue:[
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   877
                        cm := cm methodComment.
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   878
                    ]
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   879
                ].
911
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   880
                cm notNil ifTrue:[
1185
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   881
                    msg := msg , '\\The comment in ' withCRs , firstImplementingClass name allBold , ' is:\' withCRs , cm allItalic.
911
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   882
                ]
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   883
            ].
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   884
        ].
be6ce6482a7f extract the methods comment and show it.
Claus Gittinger <cg@exept.de>
parents: 839
diff changeset
   885
        ^ msg
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   886
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   887
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   888
    ^ nil
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   889
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
   890
    "Modified: / 17.6.1996 / 17:09:30 / stefan"
835
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
   891
    "Created: / 23.3.1999 / 13:29:33 / cg"
84c5b20b91c5 more explaining
Claus Gittinger <cg@exept.de>
parents: 834
diff changeset
   892
    "Modified: / 23.3.1999 / 13:40:40 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   893
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   894
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   895
explainSelfIn:aClass short:shortText
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   896
    |sub subNames selfString className nSubClasses|
1198
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
   897
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
   898
    selfString := '''' , 'self' allBold , ''''.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   899
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   900
    sub := aClass allSubclasses.
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   901
    nSubClasses := sub size.
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   902
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   903
    aClass isMeta ifTrue:[
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   904
        className := aClass theNonMetaclass name.
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   905
        subNames := sub collect:[:c | c theNonMetaclass name].
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   906
        nSubClasses == 0 ifTrue:[
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   907
            shortText ifTrue:[
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   908
                ^ selfString , ' - the ''' , className , '''-class.'
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   909
            ].
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   910
            ^ selfString , 'refers to the object which received the message.
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   911
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   912
In this case, it will be the ' , className , '-class itself.'
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   913
        ].
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   914
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   915
        shortText ifTrue:[
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   916
            nSubClasses == 1 ifTrue:[
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   917
                ^ selfString , ' - the ''' , className , '''- or ''' , subNames first , '''-class.'
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   918
            ].
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   919
            ^ selfString , ' - the ''' , className , '''-class or one of its subclasses.'
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   920
        ].
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   921
        nSubClasses <= 5 ifTrue:[
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   922
            ^ selfString , ' refers to the object which received the message.
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   923
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   924
In this case, it will be the ' , className , '-class
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   925
or one of its subclasses:
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   926
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   927
' , subNames asStringCollection asString
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   928
        ].
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   929
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   930
        ^ selfString , ' refers to the object which received the message.
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   931
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   932
In this case, it will be the ' , className , '-class
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   933
or one of its ' , nSubClasses printString , ' subclasses.'
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   934
    ].
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   935
1256
cc3fa02585ec *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
   936
    subNames := aClass allSubclasses collect:[:c | c theNonMetaclass name].
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   937
    className := aClass name.
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   938
    nSubClasses == 0 ifTrue:[
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   939
        shortText ifTrue:[
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   940
            ^ selfString , ' - an instance of ''' , className , '''.'
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   941
        ].
1198
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
   942
        ^ selfString , 'refers to the object which received the message.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   943
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   944
In this case, it will be an instance of ' , className , '.'
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   945
    ].
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   946
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   947
    shortText ifTrue:[
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   948
        nSubClasses == 1 ifTrue:[
1256
cc3fa02585ec *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
   949
            ^ selfString , ' - an instance of ''' , className , ''' or ''' , subNames first , '''.'
1185
7030f795b00d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1184
diff changeset
   950
        ].
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   951
        ^ selfString , ' - an instance of ''' , className , ''' or one of its subclasses.'
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   952
    ].
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   953
    nSubClasses <= 5 ifTrue:[
1198
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
   954
        ^ selfString , ' refers to the object which received the message.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   955
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   956
In this case, it will be an instance of ' , className , '
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   957
or one of its subclasses:
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   958
1256
cc3fa02585ec *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
   959
' , subNames asStringCollection asString
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   960
    ].
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   961
1198
f81479b0d838 better explanations
Claus Gittinger <cg@exept.de>
parents: 1188
diff changeset
   962
    ^ selfString , ' refers to the object which received the message.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   963
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   964
In this case, it will be an instance of ' , className , '
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   965
or one of its ' , nSubClasses printString , ' subclasses.'
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   966
!
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   967
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   968
explainSuperIn:aClass short:shortText
1352
e9e91394ca1a Remove unused method variables
Stefan Vogel <sv@exept.de>
parents: 1331
diff changeset
   969
    |superName|
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   970
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   971
    superName := aClass superclass name.
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   972
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   973
    shortText ifTrue:[
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   974
        ^ '''super'' - message lookup starts in ' , superName , '.'
1188
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   975
    ].
8c0408dc39f2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1185
diff changeset
   976
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   977
    ^ 'like self, super refers to the object which received the message.
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   978
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   979
However, when sending a message to super the search for methods
1244
e9bb700040fd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1233
diff changeset
   980
implementing this message will start in the superclass (' , superName , ')
84
claus
parents: 58
diff changeset
   981
instead of the receivers class (' , aClass name , ' or subclass).
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   982
Thus, using super, a redefined method can call the original method in its superclass.'
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   983
!
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   984
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   985
explainSyntax:string
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   986
    "try syntax ...; return explanation or nil"
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   987
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   988
    ^ self explainSyntax:string short:false
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   989
!
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   990
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   991
explainSyntax:string short:shortText
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   992
    "try syntax ...; return explanation or nil"
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   993
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   994
    ((string = ':=') or:[string = '_']) ifTrue:[
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   995
        shortText ifTrue:[
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   996
            ^ 'Assign to variable on the left side.'.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   997
        ].
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
   998
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
   999
        ^ '<variable> := <expression>
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1000
834
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1001
'':='' and ''_'' (which is left-arrow in some fonts) mean assignment.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1002
The variable is bound to (i.e. points to) the value of <expression>.'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1003
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1004
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1005
    (string = '^') ifTrue:[
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1006
        shortText ifTrue:[
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1007
            ^ 'Return value from method.'.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1008
        ].
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1009
        ^ '^ <expression>
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1010
834
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1011
returns the value of <expression> as value from the method.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1012
A return from within a block exits the method where the block is defined.'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1013
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1014
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1015
    (string = ';') ifTrue:[
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1016
        shortText ifTrue:[
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1017
            ^ 'Cascade expression.'.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1018
        ].
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1019
        ^ '<expression> ; selector1 ; .... ; selectorN
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1020
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1021
a cascade expression; evaluate expression, and send messages 
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1022
<selector1> ... <selectorN> to the first expressions receiver. 
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1023
Returns the value of the last send. The cascade sends may also have arguments.'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1024
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1025
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1026
    (string = '|') ifTrue:[
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1027
        shortText ifTrue:[
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1028
            ^ ''.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1029
        ].
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1030
        ^ '| locals |  or: [:arg | statements]
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1031
834
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1032
''|'' is used to mark a local variable declaration or separates arguments
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1033
from the statements in a block. Notice, that in a block-argument declaration
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1034
these must be prefixed by a colon character.
834
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1035
''|'' is also a selector understood by Booleans.'
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1036
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1037
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1038
    ((string startsWith:'(') or:[string endsWith:')']) ifTrue:[
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1039
        shortText ifTrue:[
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1040
            ^ ''.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1041
        ].
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1042
        ^ '(<expression>)
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1043
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1044
expression grouping.'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1045
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1046
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1047
    ((string startsWith:'[') or:[string endsWith:']']) ifTrue:[
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1048
        shortText ifTrue:[
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1049
            ^ ''.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1050
        ].
834
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1051
        ^ '[:arg1 .. :argN | statements]
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1052
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1053
defines a block. 
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1054
Blocks represent pieces of executable code. Definition of a block does
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1055
not evaluate it. The block is evaluated by sending it a value/value:
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1056
message.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1057
Blocks are often passed as arguments to Booleans (i.e. ifTrue:[...]) or
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1058
collections (i.e. do:[...]).'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1059
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1060
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1061
    (string = ':') ifTrue:[
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1062
        shortText ifTrue:[
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1063
            ^ ''.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1064
        ].
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1065
        ^ 'colons have different meaning depending on context:
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1066
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1067
1) they separate keyword-parts in symbols and keyword-messages as in:
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1068
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1069
    #at:put:                     a constant keyword symbol
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1070
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1071
    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
  1072
                                 passing index and value as arguments.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1073
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1074
2) within block-argument declarations as in:
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1075
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1076
    [:arg1 :arg2 | statements]
834
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1077
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1078
3) within an identifier, they separate the nameSpace part from
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1079
   the name part; as in:
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1080
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1081
    Smalltalk::Array    - the Array class in the Smalltalk nameSpace.
34cef8ff7c05 more explaining
Claus Gittinger <cg@exept.de>
parents: 796
diff changeset
  1082
    Foo::Array          - the Array class in the Foo nameSpace.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1083
'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1084
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1085
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1086
    (string = '.') ifTrue:[
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1087
        ^ 'statement. "<- period here"
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1088
statement
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1089
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1090
within a method or block, individual statements are separated by periods.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1091
'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1092
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1093
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1094
    (string startsWith:'#' ) ifTrue:[
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1095
        (string startsWith:'#(' ) ifTrue:[
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1096
            shortText ifTrue:[
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1097
                ^ 'Array Literal.'.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1098
            ].
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1099
            ^ 'is a constant Array.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1100
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1101
The elements of a constant Array must be Number-constants, nil, true or false.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1102
(notice, that not all Smalltalk implementations allow true, false and nil as
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1103
 constant-Array elements).'
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1104
        ].
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1105
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1106
        (string startsWith:'#[') ifTrue:[
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1107
            shortText ifTrue:[
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1108
                ^ 'ByteArray Literal.'.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1109
            ].
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1110
            ^ 'is a constant ByteArray.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1111
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1112
The elements of a constant ByteArray must be Integer constants in the range
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1113
0 .. 255.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1114
(notice, that not all Smalltalk implementations support constant ByteArrays).'
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1115
        ].
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1116
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1117
        (string startsWith:'#''') ifTrue:[
1183
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1118
            shortText ifTrue:[
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1119
                ^ 'Symbol Literal.'.
39f5ca4778d5 added short explanations
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  1120
            ].
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1121
            ^ 'is a constant symbol containing non-alphanumeric characters.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1122
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1123
Symbols are unique strings, meaning that there exists
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1124
exactly one instance of a given symbol. Therefore symbols can
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1125
be compared using == (identity compare) in addition to = (contents compare).
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1126
Beside this, Symbols behave mostly like Strings.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1127
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1128
Notice, that not all Smalltalk implementations support this kind of symbols.'
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1129
        ].
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1130
1232
2113cc4dd269 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1211
diff changeset
  1131
        shortText ifTrue:[
2113cc4dd269 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1211
diff changeset
  1132
            ^ 'Symbol Literal.'.
2113cc4dd269 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1211
diff changeset
  1133
        ].
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1134
        ^ 'is a symbol.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1135
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1136
Symbols are unique strings, meaning that there exists
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1137
exactly one instance of a given symbol. Therefore symbols can
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1138
be compared using == (identity compare) in addition to = (contents compare).
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1139
Beside this, Symbols behave mostly like Strings.'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1140
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1141
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1142
    "/ is it a symbol without hash-character ?
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1143
    "/
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1144
"/    string knownAsSymbol ifTrue:[
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1145
"/        ^ 'is nothing, but #' , string , ' is known as a symbol.
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1146
"/
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1147
"/Symbols are unique strings, meaning that there exists
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1148
"/exactly one instance of a given symbol. Therefore symbols can
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1149
"/be compared using == (identity compare) in addition to = (contents compare).
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1150
"/Beside this, Symbols behave mostly like Strings.'
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1151
"/    ].
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1152
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1153
    ^ nil
796
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1154
65a547620ef4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 693
diff changeset
  1155
    "Modified: / 31.10.1998 / 14:28:58 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  1156
! !
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
  1157
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
  1158
!Explainer class methodsFor:'documentation'!
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
  1159
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
  1160
version
1729
cab536ed26c6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1728
diff changeset
  1161
    ^ '$Header: /cvs/stx/stx/libcomp/Explainer.st,v 1.66 2006-03-28 17:45:42 cg Exp $'
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
  1162
! !