Explainer.st
author Claus Gittinger <cg@exept.de>
Fri, 24 Apr 1998 11:05:13 +0200
changeset 693 f8a474713980
parent 675 a2f41004c24d
child 796 65a547620ef4
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
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
    13
Parser subclass:#Explainer
263
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    14
	instanceVariableNames:''
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    15
	classVariableNames:''
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    16
	poolDictionaries:''
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    17
	category:'System-Compiler'
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    18
!
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    19
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
    20
!Explainer class methodsFor:'documentation'!
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    21
20
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    22
copyright
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    23
"
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    24
 COPYRIGHT (c) 1993 by Claus Gittinger
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
    25
	      All Rights Reserved
20
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    26
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    27
 This software is furnished under a license and may be used
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    28
 only in accordance with the terms of that license and with the
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    29
 inclusion of the above copyright notice.   This software may not
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    30
 be provided or otherwise made available to, or used by, any
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    31
 other person.  No title to or ownership of the software is
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    32
 hereby transferred.
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    33
"
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    34
!
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    35
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    36
documentation
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    37
"
20
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    38
    a very simple explainer - much more should be added ...
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
    39
    This one is involved, when the 'explain' function is used in a 
84
claus
parents: 58
diff changeset
    40
    codeView (popup or via CMD-E).
263
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    41
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    42
    [author:]
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 146
diff changeset
    43
        Claus Gittinger
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    44
"
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    45
! !
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    46
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
    47
!Explainer class methodsFor:'explaining'!
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    48
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
    49
commonSuperClassOf:listOfClassNames
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
    50
    |common found|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
    51
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
    52
    listOfClassNames do:[:className |
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    53
        |class|
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
    54
336
b99c14f17afc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
    55
        class := Smalltalk classNamed:className.
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    56
        common isNil ifTrue:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    57
            common := class
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    58
        ] ifFalse:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    59
            (class isSubclassOf:common) ifTrue:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    60
                "keep common"
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    61
            ] ifFalse:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    62
                (common isSubclassOf:class) ifTrue:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    63
                    common := class
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    64
                ] ifFalse:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    65
                    "walk up, checking"
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    66
                    found := false.
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    67
                    common allSuperclassesDo:[:sup |
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    68
                        (class isSubclassOf:sup) ifTrue:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    69
                            common := sup
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    70
                        ]
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    71
                    ].
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    72
                    found ifFalse:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    73
                        class allSuperclassesDo:[:sup |
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    74
                            (common isSubclassOf:sup) ifTrue:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    75
                                common := sup
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    76
                            ]
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    77
                        ].
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    78
                    ].
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    79
                ]
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    80
            ].
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    81
        ].
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    82
        common == Object ifTrue:[^ common]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
    83
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
    84
    ^ common
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    85
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
    86
    "Modified: 17.6.1996 / 17:09:21 / stefan"
336
b99c14f17afc checkin from browser
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
    87
    "Modified: 5.9.1996 / 19:34:41 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
    88
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
    89
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    90
explain:someText in:source forClass:aClass
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
    91
    "Given a source and a substring of it, return a string containing
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
    92
     an explanation.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
    93
     This is just a q&d implementation - to be correct, it should use the parser,
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
    94
     and explain from the parsetree (instead of doing string matches).
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
    95
     This leads to some wrong explanations, for example if some string is
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
    96
     used as selector within a string.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
    97
     Also, there could be much more detailed explanations."
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
    98
693
f8a474713980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 675
diff changeset
    99
    |parser variables v c string tmp
f8a474713980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 675
diff changeset
   100
     spc|
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   101
675
a2f41004c24d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 509
diff changeset
   102
    string := someText string withoutSeparators.
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   103
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   104
    "
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   105
     ask parser for variable names
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   106
    "
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   107
    parser := self parseMethod:source in:aClass ignoreErrors:true ignoreWarnings:true.
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   108
    parser notNil ifTrue:[
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   109
        "look for variables"
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   110
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   111
        variables := parser methodVars.
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   112
        (variables notNil and:[variables includes:string]) ifTrue:[
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   113
            ^ string , ' is a method variable'
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   114
        ].
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   115
        variables := parser methodArgs.
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   116
        (variables notNil and:[variables includes:string]) ifTrue:[
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   117
            ^ string , ' is a method argument'
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   118
        ]
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   119
    ].
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   120
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   121
    parser isNil ifTrue:[
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   122
        parser := self for:(ReadStream on:source) in:aClass
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   123
    ].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   124
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   125
    "instvars"
84
claus
parents: 58
diff changeset
   126
    c := aClass whichClassDefinesInstVar:string.
claus
parents: 58
diff changeset
   127
    c notNil ifTrue:[
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
   128
        c isMeta ifTrue:[
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
   129
            ^ string , ' is a class instance variable in ' , c soleInstance name
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
   130
        ].
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
   131
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   132
        ^ string , ' is an instance variable in ' , c name
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   133
    ].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   134
84
claus
parents: 58
diff changeset
   135
"/    variables := aClass allInstVarNames.
claus
parents: 58
diff changeset
   136
"/    (variables notNil and:[variables includes:string]) ifTrue:[
claus
parents: 58
diff changeset
   137
"/        "where is it"
claus
parents: 58
diff changeset
   138
"/        c := aClass.
claus
parents: 58
diff changeset
   139
"/        [c notNil] whileTrue:[
claus
parents: 58
diff changeset
   140
"/            v := c instVarNames.
claus
parents: 58
diff changeset
   141
"/            (v notNil and:[v includes:string]) ifTrue:[
claus
parents: 58
diff changeset
   142
"/                ^ string , ' is an instance variable in ' , c name
claus
parents: 58
diff changeset
   143
"/            ].
claus
parents: 58
diff changeset
   144
"/            c := c superclass
claus
parents: 58
diff changeset
   145
"/        ].
claus
parents: 58
diff changeset
   146
"/        self error:'oops'
claus
parents: 58
diff changeset
   147
"/    ].
claus
parents: 58
diff changeset
   148
442
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   149
"/    "class instvars"
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   150
"/    variables := aClass class allInstVarNames.
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   151
"/    (variables notNil and:[variables includes:string]) ifTrue:[
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   152
"/        "where is it"
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   153
"/        c := aClass.
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   154
"/        [c notNil] whileTrue:[
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   155
"/            v := c class instVarNames.
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   156
"/            (v notNil and:[v includes:string]) ifTrue:[
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   157
"/                ^ string , ' is a class instance variable in ' , c name
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   158
"/            ].
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   159
"/            c := c superclass
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   160
"/        ].
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   161
"/        self error:'oops'
80b2e3bf3e93 explaining class-instVars
Claus Gittinger <cg@exept.de>
parents: 422
diff changeset
   162
"/    ].
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   163
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   164
    "classvars"
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   165
    c := parser inWhichClassIsClassVar:string.
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   166
    c notNil ifTrue:[
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   167
        ^ string , ' is a class variable in ' , c name
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   168
    ].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   169
509
d8475399ca3e Correct handling of private classes.
Stefan Vogel <sv@exept.de>
parents: 503
diff changeset
   170
    aClass isMeta ifTrue:[
d8475399ca3e Correct handling of private classes.
Stefan Vogel <sv@exept.de>
parents: 503
diff changeset
   171
        c := aClass soleInstance.
d8475399ca3e Correct handling of private classes.
Stefan Vogel <sv@exept.de>
parents: 503
diff changeset
   172
    ] ifFalse:[
d8475399ca3e Correct handling of private classes.
Stefan Vogel <sv@exept.de>
parents: 503
diff changeset
   173
        c := aClass.
d8475399ca3e Correct handling of private classes.
Stefan Vogel <sv@exept.de>
parents: 503
diff changeset
   174
    ].
d8475399ca3e Correct handling of private classes.
Stefan Vogel <sv@exept.de>
parents: 503
diff changeset
   175
    c privateClasses do:[:pClass |
d8475399ca3e Correct handling of private classes.
Stefan Vogel <sv@exept.de>
parents: 503
diff changeset
   176
        (pClass name = string 
d8475399ca3e Correct handling of private classes.
Stefan Vogel <sv@exept.de>
parents: 503
diff changeset
   177
         or:[pClass nameWithoutPrefix = string]) ifTrue:[
422
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   178
            ^ (string , ' is a private class in ''' , c name , '''.'
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   179
                     , '\\It is only visible locally.') withCRs
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   180
        ].
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   181
    ].
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   182
456
abe32fed9c0d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 442
diff changeset
   183
    (spc := aClass nameSpace) notNil ifTrue:[
422
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   184
        (Smalltalk at:(spc name , '::' , string) asSymbol) isBehavior ifTrue:[
456
abe32fed9c0d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 442
diff changeset
   185
            ^ (string , ' is a class in the ''' , spc name , ''' nameSpace.'
abe32fed9c0d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 442
diff changeset
   186
                     , '\\It is only visible within this nameSpace.'
422
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   187
                     , '\Access from the outside is possible'
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   188
                     , '\by the special name ''' , spc name , '::' , string , '''.') withCRs
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   189
        ].
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   190
    ].
bdc16e1e31ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 396
diff changeset
   191
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   192
    string knownAsSymbol ifTrue:[
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   193
        "globals & symbols"
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   194
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   195
        tmp := self explainKnownSymbol:string.
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   196
        tmp notNil ifTrue:[ ^ tmp].
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   197
    ].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   198
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   199
    "try for some obvious things"
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   200
    tmp := self explainPseudoVariable:string in:aClass.
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   201
    tmp notNil ifTrue:[ ^ tmp].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   202
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   203
    "try syntax ..."
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   204
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   205
    tmp := self explainSyntax:string.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   206
    tmp notNil ifTrue:[ ^ tmp].
20
f8dd8ba75205 *** empty log message ***
claus
parents: 15
diff changeset
   207
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   208
    parser isNil ifTrue:[
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   209
        ^ 'parse error - no explanation'
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   210
    ].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   211
    ^ 'cannot explain this - select individual tokens for an explanation.'
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   212
675
a2f41004c24d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 509
diff changeset
   213
    "Created: / 3.12.1995 / 12:47:37 / cg"
a2f41004c24d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 509
diff changeset
   214
    "Modified: / 16.4.1997 / 12:46:11 / stefan"
a2f41004c24d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 509
diff changeset
   215
    "Modified: / 2.4.1998 / 11:55:05 / cg"
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   216
!
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   217
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   218
explainHereIn:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   219
    ^ 'like self, here refers to the object which received the message.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   220
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   221
However, when sending a message to here the search for methods
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   222
implementing this message will start in the defining class (' , aClass name , ')
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   223
instead of the receivers class (' , aClass name , ' or subclass).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   224
Thus, using here, redefined methods will NOT be reached with a here-send.'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   225
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   226
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   227
explainKnownSymbol:string
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   228
    "return explanation or nil"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   229
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   230
    |sym list count tmp commonSuperClass val|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   231
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   232
    sym := string asSymbol.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   233
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   234
    "try globals"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   235
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   236
    (Smalltalk includesKey:sym) ifTrue:[
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   237
        tmp := string , ' is a global variable.'.
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   238
        val := Smalltalk at:sym.
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   239
        val isBehavior ifTrue:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   240
            val name = string ifTrue:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   241
                tmp := tmp , '
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   242
503
b0d10f53a820 show 'autoloaded' for classes
Claus Gittinger <cg@exept.de>
parents: 497
diff changeset
   243
' , string , ' is ' , (val isLoaded ifTrue:['a'] ifFalse:['an autoloaded'])
b0d10f53a820 show 'autoloaded' for classes
Claus Gittinger <cg@exept.de>
parents: 497
diff changeset
   244
, ' class categorized as ' , val category , '
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   245
in the ''' , val package , ''' package.'
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   246
            ] ifFalse:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   247
                tmp := tmp , '
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   248
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   249
' , string , ' is bound to the class ' , val name ,
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   250
' in category ' , val category , '.'
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   251
            ]
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   252
        ] ifFalse:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   253
            tmp := tmp , '
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   254
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   255
Its current value is ' , val classNameWithArticle , '.'
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   256
        ].
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   257
        ^ tmp.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   258
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   259
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   260
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   261
     try selectors
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   262
     look who implements it
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   263
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   264
    list := Set new.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   265
    Smalltalk allBehaviorsDo:[:c|
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   266
        (c implements:sym) ifTrue:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   267
            list add:(c name)
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   268
        ].
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   269
        (c class implements:sym) ifTrue:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   270
            list add:(c name , ' class')
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   271
        ]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   272
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   273
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   274
    count := list size.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   275
    (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
   276
        "
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   277
         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
   278
         list them
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   279
        "
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   280
        list := list asOrderedCollection sort.
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   281
        tmp := ' is a selector implemented in '.
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   282
        (count == 1) ifTrue:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   283
            ^ string , tmp , (list at:1) , '.'
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   284
        ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   285
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   286
        (count == 2) ifTrue:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   287
            ^ string , tmp , (list at:1) , ' and ' , (list at:2) , '.'
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   288
        ].
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   289
        (count == 3) ifTrue:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   290
            ^ string , tmp , '
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   291
' , (list at:1) , ', ' , (list at:2) , ' and ' , (list at:3) , '.'
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   292
        ].
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   293
        (count == 4) ifTrue:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   294
            ^ string , tmp , '
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   295
' , (list at:1) , ', ' , (list at:2) , ', ' , (list at:3), ' and ' , (list at:4) , '.'
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   296
        ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   297
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   298
        "
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   299
         if there are more, look for a common
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   300
         superclass and show it ...
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   301
        "
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   302
        commonSuperClass := self commonSuperClassOf:list.
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   303
        commonSuperClass ~~ Object ifTrue:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   304
            (list includes:commonSuperClass) ifTrue:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   305
                ^ string , tmp, count printString , commonSuperClass name 
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   306
                         , ' and redefined in ' , (count - 1) printString  
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   307
                         , ' subclasses'
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   308
            ].
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   309
            ^ string , tmp, count printString , ' subclasses of ' , commonSuperClass name
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   310
        ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   311
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   312
        "
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   313
         otherwise just give the number.
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   314
        "
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   315
        ^ string , tmp , count printString , ' classes.'
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   316
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   317
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   318
    ^ nil
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   319
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 263
diff changeset
   320
    "Modified: 17.6.1996 / 17:09:30 / stefan"
503
b0d10f53a820 show 'autoloaded' for classes
Claus Gittinger <cg@exept.de>
parents: 497
diff changeset
   321
    "Modified: 10.4.1997 / 17:53:58 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   322
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   323
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   324
explainPseudoVariable:string in:aClass
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   325
    "return explanation for the pseudoVariables self, super etc."
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   326
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   327
    (string = 'self') ifTrue:[
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   328
	^ self explainSelfIn:aClass
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   329
    ].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   330
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   331
    (string = 'super') ifTrue:[
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   332
	^ self explainSuperIn:aClass
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   333
    ].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   334
84
claus
parents: 58
diff changeset
   335
    (string = 'here') ifTrue:[
claus
parents: 58
diff changeset
   336
	^ self explainHereIn:aClass
claus
parents: 58
diff changeset
   337
    ].
claus
parents: 58
diff changeset
   338
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   339
    (string = 'thisContext') ifTrue:[
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   340
	^ 'thisContext is a pseudo variable (i.e. it is built in).
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   341
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   342
ThisContext always refers to the context object for the currently executed method or
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   343
block (an instance of Context or BlockContext respectively). The calling chain and calling
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   344
receivers/selectors can be accessed via thisContext.'
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   345
    ].
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   346
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   347
    (string = 'true') ifTrue:[
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   348
	^ 'true is a pseudo variable (i.e. it is built in).
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   349
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   350
True represents logical truth. It is the one and only instance of class True.'
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   351
    ].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   352
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   353
    (string = 'false') ifTrue:[
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   354
	^ 'false is a pseudo variable (i.e. it is built in).
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   355
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   356
False represents logical falseness. It is the one and only instance of class False.'
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   357
    ].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   358
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   359
    (string = 'nil') ifTrue:[
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   360
	^ 'nil is a pseudo variable (i.e. it is built in).
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   361
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   362
Nil is used for unitialized variables (among other uses).
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   363
Nil is the one and only instance of class UndefinedObject.'
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   364
    ].
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   365
    ^ nil
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   366
!
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   367
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   368
explainSelfIn:aClass
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   369
    |sub|
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   370
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   371
    sub := aClass allSubclasses collect:[:c | c name].
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   372
    sub size == 0 ifTrue:[
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   373
	^ 'self refers to the object which received the message.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   374
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   375
In this case, it will be an instance of ' , aClass name , '.'
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   376
    ].
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   377
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   378
    sub size <= 5 ifTrue:[
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   379
	^ 'self refers to the object which received the message.
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   380
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   381
In this case, it will be an instance of ' , aClass name , '
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   382
or one of its subclasses:
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   383
58
15b00d1236db asText eliminated
claus
parents: 54
diff changeset
   384
' , sub asStringCollection asString
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   385
    ].
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   386
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   387
    ^ 'self refers to the object which received the message.
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   388
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   389
In this case, it will be an instance of ' , aClass name , '
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   390
or one of its ' , sub size printString , ' subclasses.'
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   391
!
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   392
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   393
explainSuperIn:aClass
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   394
    ^ 'like self, super refers to the object which received the message.
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   395
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   396
However, when sending a message to super the search for methods
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   397
implementing this message will start in the superclass (' , aClass superclass name , ')
84
claus
parents: 58
diff changeset
   398
instead of the receivers class (' , aClass name , ' or subclass).
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   399
Thus, using super, a redefined method can call the original method in its superclass.'
6
0cd4e7480440 *** empty log message ***
claus
parents: 2
diff changeset
   400
!
2
0aae80a0ae84 Initial revision
claus
parents:
diff changeset
   401
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   402
explainSyntax:string
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   403
    "try syntax ...; return explanation or nil"
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   404
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   405
    ((string = ':=') or:[string = '_']) ifTrue:[
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   406
	^ '<variable> := <expression>
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   407
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   408
:= and _ (which is left-arrow in some fonts) mean assignment.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   409
The variable is bound to (i.e. points to) the value of <expression>.'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   410
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   411
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   412
    (string = '^') ifTrue:[
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   413
	^ '^ <expression>
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   414
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   415
return the value of <expression> as value from the method.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   416
A return from within a block exits the method where the block is defined.'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   417
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   418
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   419
    (string = ';') ifTrue:[
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   420
	^ '<expression> ; selector1 ; .... ; selectorN
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   421
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   422
a cascade expression; evaluate expression, and send messages 
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   423
<selector1> ... <selectorN> to the first expressions receiver. 
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   424
Returns the value of the last send. The cascade sends may also have arguments.'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   425
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   426
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   427
    (string = '|') ifTrue:[
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   428
	^ '| locals |  or: [:arg | statements]
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   429
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   430
| is used to mark a local variable declaration or separates arguments
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   431
from the statements in a block. Notice, that in a block-argument declaration
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   432
these must be prefixed by a colon character.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   433
| is also a selector understood by Booleans.'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   434
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   435
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   436
    ((string startsWith:'(') or:[string endsWith:')']) ifTrue:[
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   437
	^ '(<expression>)
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   438
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   439
expression grouping.'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   440
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   441
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   442
    ((string startsWith:'[') or:[string endsWith:']']) ifTrue:[
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   443
	^ '[arguments | statements]
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   444
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   445
defines a block. 
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   446
Blocks represent pieces of executable code. Definition of a block does
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   447
not evaluate it. The block is evaluated by sending it a value/value:
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   448
message.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   449
Blocks are often passed as arguments to Booleans (i.e. ifTrue:[...]) or
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   450
collections (i.e. do:[...]).'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   451
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   452
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   453
    (string = ':') ifTrue:[
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   454
	^ 'colons have different meaning depending on context:
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   455
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   456
1) they separate keyword-parts in symbols and keyword-messages as in:
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   457
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   458
    #at:put:                     a constant keyword symbol
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   459
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   460
    rec at:index put:value       sends the #at:put: message to rec,
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   461
				 passing index and value as arguments.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   462
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   463
2) within block-argument declarations as in:
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   464
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   465
    [:arg1 :arg2 | statements]
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   466
'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   467
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   468
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   469
    (string = '.') ifTrue:[
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   470
	^ 'statement. "<- period here"
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   471
statement
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   472
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   473
within a method or block, individual statements are separated by periods.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   474
'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   475
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   476
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   477
    (string startsWith:'#' ) ifTrue:[
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   478
	(string startsWith:'#(' ) ifTrue:[
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   479
	    ^ 'is a constant Array.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   480
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   481
The elements of a constant Array must be Number-constants, nil, true or false.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   482
(notice, that not all Smalltalk implementations allow true, false and nil as
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   483
 constant-Array elements).'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   484
	].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   485
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   486
	(string startsWith:'#[') ifTrue:[
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   487
	    ^ 'is a constant ByteArray.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   488
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   489
The elements of a constant ByteArray must be Integer constants in the range
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   490
0 .. 255.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   491
(notice, that not all Smalltalk implementations support constant ByteArrays).'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   492
	].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   493
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   494
	(string startsWith:'#''') ifTrue:[
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   495
	    ^ 'is a constant symbol containing non-alphanumeric characters.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   496
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   497
Symbols are unique strings, meaning that there exists
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   498
exactly one instance of a given symbol. Therefore symbols can
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   499
be compared using == (identity compare) in addition to = (contents compare).
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   500
Beside this, Symbols behave mostly like Strings.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   501
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   502
Notice, that not all Smalltalk implementations support this kind of symbols.'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   503
	].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   504
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   505
	^ 'is a symbol.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   506
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   507
Symbols are unique strings, meaning that there exists
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   508
exactly one instance of a given symbol. Therefore symbols can
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   509
be compared using == (identity compare) in addition to = (contents compare).
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   510
Beside this, Symbols behave mostly like Strings.'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   511
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   512
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   513
    "/ is it a symbol without hash-character ?
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   514
    "/
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   515
    string knownAsSymbol ifTrue:[
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   516
	^ 'is nothing, but #' , string , ' is known as a symbol.
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   517
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   518
Symbols are unique strings, meaning that there exists
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   519
exactly one instance of a given symbol. Therefore symbols can
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   520
be compared using == (identity compare) in addition to = (contents compare).
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   521
Beside this, Symbols behave mostly like Strings.'
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   522
    ].
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   523
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   524
    ^ nil
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
   525
! !
49
02660b790c3e *** empty log message ***
claus
parents: 24
diff changeset
   526
396
26c32f1f791b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 336
diff changeset
   527
!Explainer class methodsFor:'documentation'!
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   528
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   529
version
693
f8a474713980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 675
diff changeset
   530
    ^ '$Header: /cvs/stx/stx/libcomp/Explainer.st,v 1.28 1998-04-24 09:05:13 cg Exp $'
146
3d407ab8ac44 suppress messages on transcript when explaining
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
   531
! !