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