Tools_ClassChecker.st
author Claus Gittinger <cg@exept.de>
Thu, 26 Feb 2004 19:57:02 +0100
changeset 5591 273637686948
child 5592 d9730a8d7c52
permissions -rw-r--r--
initial checkin
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
5591
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     1
"{ Package: 'stx:__NoProject__' }"
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     2
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
"{ NameSpace: Tools }"
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     5
Object subclass:#ClassChecker
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
	instanceVariableNames:'checkedClass badClasses badClassInfo badMethods badMethodInfo
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
		obsoleteWarners allObsoleteMethods checksPerformed'
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
	classVariableNames:''
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
	poolDictionaries:''
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
	category:'Interface-Browsers-New'
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
!ClassChecker class methodsFor:'documentation'!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    15
documentation
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
"
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
    embeddable application displaying the class-categories.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
    Provides an outputGenerator, which enumerates the classes in
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
    the selected categories.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
    [author:]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
	Claus Gittinger (cg@exept.de)
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
"
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
! !
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
!ClassChecker class methodsFor:'queries'!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    27
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
individualChecks
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
    "return a list of supported checks"
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    30
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
    |checks|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    33
    checks := OrderedCollection new.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
    self methodDictionary keysAndValuesDo:[:sel :mthd |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
	(mthd category startsWith:'checks')  ifTrue:[checks add:sel]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    36
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    37
    checks sort.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    38
    ^ checks
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    39
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    40
    "
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
     self individualChecks
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
    "
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    44
    "Created: / 18.8.2000 / 22:30:46 / cg"
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    45
    "Modified: / 18.8.2000 / 22:31:02 / cg"
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    46
! !
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    47
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    48
!ClassChecker methodsFor:'accessing'!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    49
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    50
badClassInfo
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    51
    ^ badClassInfo
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    52
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    53
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    54
badMethodInfo
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    55
    ^ badMethodInfo
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    58
checkedClass
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
    "return the value of the instance variable 'checkedClass' (automatically generated)"
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    60
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    61
    ^ checkedClass
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    62
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    63
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    64
checkedClass:something
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
    "set the value of the instance variable 'checkedClass' (automatically generated)"
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    66
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    67
    checkedClass := something.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    68
    checksPerformed := nil.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
! !
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    71
!ClassChecker methodsFor:'checking'!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    72
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    73
allChecks
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
    self errorChecks.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    75
    self warningChecks.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    76
    self styleChecks.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    77
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
doCheck:whichCheck
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
    checksPerformed isNil ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
	checksPerformed := Set new.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    83
    (checksPerformed includes:whichCheck) ifFalse:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
	checksPerformed add:whichCheck.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
	self perform:whichCheck
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    87
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    88
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    89
errorChecks
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    90
    self doCheck:#subclassResponsibilityNotDefined.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
    self doCheck:#sentNotImplemented.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    92
    self doCheck:#definesEqualButNotHash.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    93
    self doCheck:#instanceVariablesNeverWritten.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    94
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    95
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    96
styleChecks
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    97
    self doCheck:#checkProtocols.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    98
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    99
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   100
warningChecks
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   101
    self doCheck:#messageNeverSentAndNotUsedAsSymbol.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   102
    self doCheck:#sendsObsoleteMessages.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   103
    self doCheck:#instanceVariablesNeverUsed.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   104
    self doCheck:#instanceVariablesNeverWritten.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   105
    self doCheck:#classVariablesNeverUsed.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   106
    self doCheck:#classVariablesNeverWritten.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   107
    self doCheck:#classInstanceVariablesNeverUsed.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   108
    self doCheck:#classInstanceVariablesNeverWritten.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   109
! !
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   110
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   111
!ClassChecker methodsFor:'checks-individual'!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   112
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   113
checkProtocols
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   114
    checkedClass instAndClassSelectorsAndMethodsDo:[:mSelector :method |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   115
	self checkProtocolOf:method
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   116
    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   117
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   118
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   119
checkVariableNameConventions
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   120
    |badInstVars badClassVars|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   121
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   122
    badInstVars := checkedClass instanceVariableNames select:[:varName | varName first isUppercase].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   123
    badClassVars := checkedClass classVarNames select:[:varName | varName first isLowercase].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   124
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   125
    badInstVars notEmpty ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   126
	badInstVars := (badInstVars collect:[:v | '''' , v , '''']) asStringWith:$, .
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   127
	self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   128
	    rememberBadClass:checkedClass
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   129
	    info:('instVars ' , badInstVars , ' should be lowercase (#checkNameConventions)').
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   130
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   131
    badClassVars notEmpty ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   132
	badClassVars := (badClassVars collect:[:v | '''' , v , '''']) asStringWith:$, .
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   133
	self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   134
	    rememberBadClass:checkedClass
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   135
	    info:('classVars ' , badClassVars , ' should be uppercase (#checkNameConventions)').
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   136
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   137
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   138
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   139
classInstanceVariablesNeverUsed
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   140
    self instanceVariablesNeverUsedIn:checkedClass theMetaclass.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   141
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   142
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   143
classInstanceVariablesNeverWritten
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   144
    self instanceVariablesNeverWrittenIn:checkedClass theMetaclass.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   145
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   146
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   147
classVariablesNeverUsed
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   148
    |cls notUsedHere notUsedAnyWhere anySubclass|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   149
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   150
    cls := checkedClass theNonMetaclass.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   151
    notUsedHere := cls classVarNames asSet.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   152
    notUsedHere isEmpty ifTrue:[^ self].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   153
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   154
    self removeUsedClassVariablesIn:cls from:notUsedHere.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   155
    self removeUsedClassVariablesIn:cls class from:notUsedHere.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   156
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   157
    notUsedHere notEmpty ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   158
	notUsedAnyWhere := notUsedHere copy.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   159
	anySubclass := false.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   160
	cls allSubclassesDo:[:eachSubclass |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   161
	    anySubclass := true.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   162
	    notUsedAnyWhere notEmpty ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   163
		self removeUsedClassVariablesIn:eachSubclass from:notUsedAnyWhere.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   164
		self removeUsedClassVariablesIn:eachSubclass class from:notUsedAnyWhere.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   165
	    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   166
	].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   167
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   168
	notUsedHere do:[:eachVariable |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   169
	    |className|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   170
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   171
	    className := checkedClass name allBold.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   172
	    self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   173
		rememberBadClass:cls
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   174
		info:('classVar ' , eachVariable allBold , ' is unused in ' , className , ' (#classVariablesNeverUsed)').
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   175
	    (notUsedAnyWhere includes:eachVariable) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   176
		self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   177
		    rememberBadClass:cls
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   178
		    info:('classVar ' , eachVariable allBold , ' is not even used in subclasses of ' , className , ' (#classVariablesNeverUsed)')
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   179
	    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   180
	].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   181
    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   182
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   183
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   184
classVariablesNeverWritten
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   185
    |cls notWrittenHere notWrittenAnyWhere anySubclass|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   186
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   187
    cls := checkedClass theNonMetaclass.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   188
    notWrittenHere := cls classVarNames asSet.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   189
    notWrittenHere isEmpty ifTrue:[^ self].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   190
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   191
    self removeWrittenClassVariablesIn:cls from:notWrittenHere.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   192
    self removeWrittenClassVariablesIn:cls class from:notWrittenHere.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   193
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   194
    notWrittenHere notEmpty ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   195
	notWrittenAnyWhere := notWrittenHere copy.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   196
	anySubclass := false.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   197
	cls allSubclassesDo:[:eachSubclass |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   198
	    anySubclass := true.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   199
	    notWrittenAnyWhere notEmpty ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   200
		self removeWrittenClassVariablesIn:eachSubclass from:notWrittenAnyWhere.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   201
		self removeWrittenClassVariablesIn:eachSubclass class from:notWrittenAnyWhere.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   202
	    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   203
	].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   204
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   205
	notWrittenHere do:[:eachVariable |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   206
	    |className|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   207
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   208
	    className := cls name allBold.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   209
	    self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   210
		rememberBadClass:cls
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   211
		info:('classVar ' , eachVariable allBold , ' is not set in ' , className , ' (#classVariablesNeverWritten)').
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   212
	    (notWrittenAnyWhere includes:eachVariable) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   213
		self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   214
		    rememberBadClass:cls
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   215
		    info:('classVar ' , eachVariable allBold , ' is not even set in subclasses of ' , className , ' (#classVariablesNeverWritten)')
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   216
	    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   217
	].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   218
    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   219
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   220
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   221
definesEqualButNotHash
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   222
    (checkedClass includesSelector:#=) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   223
	(checkedClass includesSelector:#hash) ifFalse:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   224
	    self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   225
		rememberBadClass:checkedClass 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   226
		info:(checkedClass name allBold, ' redefines #=, but not #hash (#definesEqualButNotHash)').
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   227
	]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   228
    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   229
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   230
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   231
instanceVariablesNeverUsed
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   232
    self instanceVariablesNeverUsedIn:checkedClass theNonMetaclass.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   233
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   234
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   235
instanceVariablesNeverWritten
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   236
    self instanceVariablesNeverWrittenIn:checkedClass theNonMetaclass.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   237
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   238
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   239
messageNeverSent
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   240
    "/ old code: (slow)
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   241
"/    checkedClass instAndClassSelectorsAndMethodsDo:[:mSelector :method |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   242
"/        (self anySendsOf:mSelector) ifFalse:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   243
"/            self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   244
"/                rememberBadMethod:method 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   245
"/                info:('#' , mSelector , ' is nowhere sent (#messageNeverSent)')
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   246
"/        ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   247
"/    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   248
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   249
    |selectorsOfInterest|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   250
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   251
    selectorsOfInterest := IdentitySet new.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   252
    checkedClass instAndClassSelectorsAndMethodsDo:[:mSelector :method |  selectorsOfInterest add:mSelector].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   253
    (self messagesNeverSentIn:selectorsOfInterest) do:[:eachNeverSent |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   254
	self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   255
	    rememberBadMethod:(checkedClass compiledMethodAt:eachNeverSent) 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   256
	    key:#messageNeverSent
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   257
	    info:('#' , eachNeverSent allBold, ' is nowhere sent (#messageNeverSent)')
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   258
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   259
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   260
    "Modified: / 18.8.2000 / 22:54:45 / cg"
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   261
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   262
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   263
messageNeverSentAndNotUsedAsSymbol
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   264
    |selectorsOfInterest|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   265
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   266
    selectorsOfInterest := IdentitySet new.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   267
    checkedClass instAndClassSelectorsAndMethodsDo:[:mSelector :method |  selectorsOfInterest add:mSelector].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   268
    (self messagesNeverSentAndNotUsedAsSymbolIn:selectorsOfInterest) do:[:eachNeverSent |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   269
	self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   270
	    rememberBadMethod:(checkedClass compiledMethodAt:eachNeverSent) 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   271
	    key:#messageNeverSentAndNotUsedAsSymbol
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   272
	    info:('#' , eachNeverSent allBold, ' is nowhere sent and selector-symbol not used in any method (#messageNeverSentAndNotUsedAsSymbol)')
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   273
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   274
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   275
    "Modified: / 18.8.2000 / 23:10:56 / cg"
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   276
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   277
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   278
sendsObsoleteMessages
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   279
    obsoleteWarners isNil ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   280
	obsoleteWarners := Object selectors select:[:each | each startsWith:'obsoleteMethodWarning'].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   281
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   282
    allObsoleteMethods isNil ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   283
	allObsoleteMethods := IdentitySet new.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   284
	Method allSubInstancesDo:[:eachMethod | |lits|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   285
		((lits := eachMethod literals) notNil
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   286
		and:[lits includesAny:obsoleteWarners]) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   287
		     (eachMethod messagesSent includesAny:obsoleteWarners) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   288
			 allObsoleteMethods add:(eachMethod selector).
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   289
		    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   290
		].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   291
	    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   292
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   293
	"/ manually patchup; there are some which should not be considered as bad ...
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   294
	allObsoleteMethods removeAllFoundIn:#( #','  #'at:'  #'at:put:'  #'raise').
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   295
	allObsoleteMethods removeAllFoundIn:#( #'asText').
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   296
	allObsoleteMethods removeAllFoundIn:obsoleteWarners.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   297
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   298
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   299
    checkedClass instAndClassSelectorsAndMethodsDo:[:sel :mthd | 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   300
	|lits sentMessages whichOnes pT searcher nodes|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   301
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   302
	((lits := mthd literals) notNil
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   303
	and:[lits includesAny:allObsoleteMethods]) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   304
	    sentMessages := mthd messagesSent.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   305
	    (sentMessages includesAny:allObsoleteMethods) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   306
		whichOnes := sentMessages select:[:each | allObsoleteMethods includes:each].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   307
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   308
		(RBParser notNil
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   309
		and:[RBParser isLoaded]) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   310
		    "/ lets look at this a bit more detailed;
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   311
		    "/ parse it and see if we can filter out any messages 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   312
		    "/ (i.e. look if we can figure out the receiver type)
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   313
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   314
"/                    pT := RBParser 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   315
"/                            parseMethod: (mthd source)
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   316
"/                            onError: [:aString :pos | nil].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   317
"/                    pT notNil ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   318
"/                        searcher := ParseTreeSearcher 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   319
"/                                        allMessageSendsMatchingAny:whichOnes ignoreCase:false.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   320
"/                        nodes := searcher executeTree:pT initialAnswer:(OrderedCollection new).
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   321
"/                        nodes := nodes 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   322
"/                            select:
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   323
"/                                [:aSendNode |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   324
"/                                    self halt.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   325
"/                                ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   326
"/                        whichOnes := nodes collect:[:aSendNode | aSendNode selector].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   327
"/                    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   328
		].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   329
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   330
		whichOnes asOrderedCollection sort do:[:eachObsoleteMessage |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   331
		    self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   332
			rememberBadMethod:mthd 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   333
			key:#sendsObsoleteMessages
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   334
			info:('possibly sends an obsolete message: ' , eachObsoleteMessage , ' (#sendsObsoleteMessages)')
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   335
		].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   336
	    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   337
	]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   338
    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   339
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   340
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   341
sentNotImplemented
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   342
    |alreadyChecked alreadyCheckedSelf alreadyCheckedSuper|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   343
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   344
    alreadyChecked := IdentitySet new.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   345
    alreadyCheckedSelf := IdentitySet new.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   346
    alreadyCheckedSuper := IdentitySet new.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   347
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   348
    checkedClass methodDictionary keysAndValuesDo:[:mSelector :method |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   349
	|sentSelectors selfSelectors superSelectors selectorsNoWhereImplemented|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   350
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   351
	selectorsNoWhereImplemented := IdentitySet new.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   352
	sentSelectors := method messagesSent.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   353
	sentSelectors do:[:eachSelector |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   354
	    (alreadyChecked includes:eachSelector) ifFalse:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   355
		(self anyImplementationOf:eachSelector) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   356
		    alreadyChecked add:eachSelector
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   357
		] ifFalse:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   358
		    selectorsNoWhereImplemented add:eachSelector.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   359
		    self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   360
			rememberBadMethod:method 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   361
			key:#sentNotImplemented
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   362
			info:('#' , eachSelector allBold, ' is nowhere implemented (#sentNotImplemented)')
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   363
		]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   364
	    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   365
	].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   366
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   367
	selfSelectors := method messagesSentToSelf.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   368
	selfSelectors do:[:eachSelector |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   369
	    (selectorsNoWhereImplemented includes:eachSelector) ifFalse:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   370
		(alreadyCheckedSelf includes:eachSelector) ifFalse:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   371
		    (self anyImplementationOf:eachSelector inOrAbove:checkedClass) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   372
			alreadyCheckedSelf add:eachSelector
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   373
		    ] ifFalse:[            
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   374
			self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   375
			    rememberBadMethod:method 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   376
			    key:#sentNotImplemented
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   377
			    info:('#' , eachSelector allBold, ' is not implemented in the class (#sentNotImplemented)')
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   378
		    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   379
		]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   380
	    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   381
	].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   382
        
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   383
	superSelectors := method messagesSentToSuper.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   384
	superSelectors do:[:eachSelector |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   385
	    (selectorsNoWhereImplemented includes:eachSelector) ifFalse:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   386
		(alreadyCheckedSuper includes:eachSelector) ifFalse:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   387
		    (self anyImplementationOf:eachSelector inOrAbove:(checkedClass superclass)) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   388
			alreadyCheckedSuper add:eachSelector
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   389
		    ] ifFalse:[            
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   390
			self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   391
			    rememberBadMethod:method 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   392
			    key:#sentNotImplemented
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   393
			    info:('#' , eachSelector allBold, ' is not implemented in any superclass (#sentNotImplemented)')
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   394
		    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   395
		]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   396
	    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   397
	].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   398
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   399
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   400
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   401
subclassResponsibilityNotDefined
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   402
    |classesInBetween|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   403
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   404
    checkedClass allSuperclasses do:[:eachSuperClass |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   405
	eachSuperClass methodDictionary keysAndValuesDo:[:mSelector :method |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   406
	    (method referencesLiteral:#subclassResponsibility) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   407
		"/ parse it to see if it really does ...
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   408
		(method sends:#subclassResponsibility) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   409
		    "/ ok, got one;
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   410
		    "/ now, see if it is defined below this superClass
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   411
		    classesInBetween := checkedClass withAllSuperclasses copy.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   412
		    classesInBetween removeAll:(eachSuperClass withAllSuperclasses).
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   413
		    (self anyImplementationOf:mSelector in:classesInBetween) ifFalse:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   414
			(self methodShouldBeIgnoredInSubclassResponsibilityNotDefined:method)
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   415
			ifFalse:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   416
			    self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   417
				rememberBadMethod:method 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   418
				key:#subclassResponsibilityNotDefined
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   419
				info:(checkedClass name allBold , ' should redefine the #' , mSelector allBold , ' method (#subclassResponsibilityNotDefined)').
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   420
			].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   421
		    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   422
		]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   423
	    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   424
	]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   425
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   426
! !
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   427
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   428
!ClassChecker methodsFor:'helpers'!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   429
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   430
anyImplementationOf:aSelector
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   431
    Smalltalk allClassesDo:[:eachClass |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   432
	(eachClass theNonMetaclass includesSelector:aSelector) ifTrue:[^ true].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   433
	(eachClass theMetaclass includesSelector:aSelector) ifTrue:[^ true].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   434
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   435
    ^ false
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   436
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   437
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   438
anyImplementationOf:aSelector in:aCollectionOfClasses
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   439
    aCollectionOfClasses do:[:eachClass |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   440
	(eachClass includesSelector:aSelector) ifTrue:[^ true].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   441
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   442
    ^ false
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   443
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   444
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   445
anyImplementationOf:aSelector inOrAbove:aClass
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   446
    aClass withAllSuperclassesDo:[:eachClass |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   447
	(eachClass includesSelector:aSelector) ifTrue:[^ true].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   448
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   449
    ^ false
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   450
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   451
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   452
anySendsOf:aSelector
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   453
    Smalltalk allClassesDo:[:eachClass |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   454
	eachClass instAndClassSelectorsAndMethodsDo:[:mSelector :mthd |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   455
	    (mthd sends:aSelector) ifTrue:[^ true].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   456
	].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   457
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   458
    ^ false
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   459
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   460
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   461
checkProtocolOf:aMethod
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   462
    |mClass mSelector protocol superClass implClass superProtocol|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   463
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   464
    mClass := aMethod mclass.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   465
    mSelector := aMethod selector.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   466
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   467
    protocol := aMethod category.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   468
    protocol isNil ifTrue: [^true].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   469
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   470
    superClass := mClass superclass.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   471
    superClass isNil ifTrue: [^true].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   472
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   473
    implClass := superClass whichClassIncludesSelector:mSelector.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   474
    implClass isNil ifTrue: [^true].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   475
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   476
    superProtocol := (implClass compiledMethodAt:mSelector) category.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   477
    superProtocol = protocol ifTrue: [^true].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   478
    superProtocol isNil ifTrue: [^true].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   479
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   480
    self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   481
	rememberBadMethod:aMethod
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   482
	key:#checkProtocols
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   483
	info:('#' , mSelector allBold , ' is classified under "' , protocol allBold , '" in '
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   484
	      , mClass name , ' and under "' , superProtocol allBold , '" in ' , implClass name
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   485
	      , ' (#checkProtocols)')
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   486
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   487
    "Modified: / 18.8.2000 / 23:13:53 / cg"
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   488
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   489
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   490
checkUnusedVariables:aMethod rememberReadInstVarsIn:readInstVars writtenInstVarsIn:writtenInstVars readClassVarsIn:readClassVars writtenClassVarsIn:writtenClassVars
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   491
    |p mClass sourceString|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   492
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   493
    sourceString := aMethod source.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   494
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   495
    mClass := aMethod mclass.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   496
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   497
    p := Parser parseMethodSilent:sourceString in:mClass.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   498
    readInstVars addAll:(p readInstVars).
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   499
    writtenInstVars addAll:(p modifiedInstVars).
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   500
    readClassVars addAll:(p readClassVars).
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   501
    writtenClassVars addAll:(p modifiedClassVars).
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   502
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   503
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   504
instanceVariablesNeverUsedIn:aClass
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   505
    |notUsedHere notUsedAnyWhere anySubclass|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   506
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   507
    notUsedHere := aClass instVarNames asSet.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   508
    notUsedHere isEmpty ifTrue:[^ self].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   509
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   510
    self removeUsedInstanceVariablesIn:aClass from:notUsedHere.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   511
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   512
    notUsedHere notEmpty ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   513
	notUsedAnyWhere := notUsedHere copy.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   514
	anySubclass := false.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   515
	aClass allSubclassesDo:[:eachSubclass |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   516
	    anySubclass := true.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   517
	    notUsedAnyWhere notEmpty ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   518
		self removeUsedInstanceVariablesIn:eachSubclass from:notUsedAnyWhere.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   519
	    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   520
	].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   521
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   522
	notUsedHere do:[:eachVariable |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   523
	    |className|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   524
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   525
	    className := aClass name allBold.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   526
	    self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   527
		rememberBadClass:aClass 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   528
		info:('instVar ' , eachVariable allBold , ' is unused in ' , className , ' (#instanceVariablesNeverUsed)').
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   529
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   530
	    anySubclass ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   531
		(notUsedAnyWhere includes:eachVariable) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   532
		    self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   533
			rememberBadClass:aClass 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   534
			info:('instVar ' , eachVariable allBold , ' is not even used in subclasses of ' , className , ' (#instanceVariablesNeverUsed)')
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   535
		]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   536
	    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   537
	].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   538
    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   539
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   540
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   541
instanceVariablesNeverWrittenIn:aClass
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   542
    |notWrittenHere notWrittenAnyWhere anySubclass|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   543
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   544
    notWrittenHere := aClass instVarNames asSet.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   545
    notWrittenHere isEmpty ifTrue:[^ self].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   546
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   547
    self removeWrittenInstanceVariablesIn:aClass from:notWrittenHere.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   548
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   549
    notWrittenHere notEmpty ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   550
	notWrittenAnyWhere := notWrittenHere copy.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   551
	anySubclass := false.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   552
	aClass allSubclassesDo:[:eachSubclass |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   553
	    anySubclass := true.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   554
	    notWrittenAnyWhere notEmpty ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   555
		self removeWrittenInstanceVariablesIn:eachSubclass from:notWrittenAnyWhere.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   556
	    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   557
	].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   558
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   559
	notWrittenHere do:[:eachVariable |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   560
	    |className|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   561
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   562
	    className := aClass name allBold.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   563
	    self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   564
		rememberBadClass:aClass
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   565
		info:('instVar ' , eachVariable allBold , ' is nowhere set in ' , className , ' (#instanceVariablesNeverWritten)').
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   566
	    anySubclass ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   567
		(notWrittenAnyWhere includes:eachVariable) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   568
		    self 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   569
			rememberBadClass:aClass
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   570
			info:('instVar ' , eachVariable allBold , ' is not even set in subclasses of ' , className , ' (#instanceVariablesNeverWritten)')
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   571
		]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   572
	    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   573
	].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   574
    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   575
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   576
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   577
messagesNeverSentAndNotUsedAsSymbolIn:selectorsOfInterest
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   578
    |remaining toRemove checkBlock|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   579
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   580
    remaining := selectorsOfInterest copy asIdentitySet.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   581
    toRemove := IdentitySet new.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   582
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   583
    checkBlock := [:eachClass |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   584
	eachClass instAndClassSelectorsAndMethodsDo:[:mSel :mthd | |lits|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   585
	    lits := mthd literals.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   586
	    lits notNil ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   587
		lits traverse:[:eachLiteral |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   588
		    eachLiteral isSymbol ifTrue:[        
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   589
			remaining remove:eachLiteral ifAbsent:nil.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   590
		    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   591
		].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   592
		remaining isEmpty ifTrue:[^ remaining].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   593
	    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   594
	].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   595
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   596
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   597
    "/ start searching in the checkedClass - chances are high, we find some here
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   598
    checkBlock value:checkedClass.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   599
    checkedClass superclass notNil ifTrue:[checkBlock value:checkedClass superclass].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   600
    Smalltalk allClassesDo:checkBlock.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   601
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   602
    ^ remaining
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   603
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   604
    "Modified: / 18.8.2000 / 23:05:53 / cg"
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   605
    "Created: / 18.8.2000 / 23:06:55 / cg"
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   606
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   607
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   608
messagesNeverSentIn:selectorsOfInterest
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   609
    |remaining|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   610
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   611
    remaining := selectorsOfInterest copy.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   612
    Smalltalk allClassesDo:[:eachClass |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   613
	eachClass instAndClassSelectorsAndMethodsDo:[:mSelector :mthd | |lits|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   614
	    lits := mthd literals.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   615
	    lits notNil ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   616
		(lits includesAny:remaining) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   617
		    remaining removeAllFoundIn:(mthd messagesSent).
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   618
		    remaining isEmpty ifTrue:[^ remaining].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   619
		]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   620
	    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   621
	].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   622
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   623
    ^ remaining
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   624
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   625
    "Created: / 18.8.2000 / 22:53:38 / cg"
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   626
    "Modified: / 18.8.2000 / 22:56:59 / cg"
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   627
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   628
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   629
methodShouldBeIgnoredInSubclassResponsibilityNotDefined:aMethod
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   630
    "a kludge for now - would like to have a pragma, resource or other
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   631
     way to mark such a method"
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   632
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   633
    aMethod == (Object compiledMethodAt:#implementedBySubclass) ifTrue:[^ true].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   634
    aMethod == (Object compiledMethodAt:#readBinaryContentsFromData:manager:) ifTrue:[^ true].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   635
    ^ false.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   636
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   637
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   638
rememberBadClass:class info:whatIsWrong
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   639
    |entry|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   640
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   641
    badClasses isNil ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   642
	badClasses := IdentitySet new.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   643
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   644
    badClasses add:class.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   645
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   646
    badClassInfo isNil ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   647
	badClassInfo := IdentityDictionary new.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   648
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   649
    entry := badClassInfo at:class ifAbsentPut:[ OrderedCollection new ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   650
    entry add:whatIsWrong.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   651
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   652
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   653
rememberBadMethod:method key:key info:whatIsWrong
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   654
    |entry|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   655
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   656
    badMethods isNil ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   657
	badMethods := Set new.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   658
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   659
    (badMethods includes:(method -> key)) ifTrue:[^ self].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   660
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   661
    badMethods add:(method -> key).
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   662
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   663
    badMethodInfo isNil ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   664
	badMethodInfo := IdentityDictionary new.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   665
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   666
    entry := badMethodInfo at:method ifAbsentPut:[ OrderedCollection new ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   667
    entry add:whatIsWrong.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   668
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   669
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   670
rememberBadMethods:methods key:key info:whatIsWrong
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   671
    methods do:[:eachMethod |  
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   672
	self rememberBadMethod:eachMethod key:key info:whatIsWrong
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   673
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   674
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   675
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   676
removeUsedClassVariablesIn:aClass from:aCollectionOfVariablenames
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   677
    aClass selectorsAndMethodsDo:[:mSelector :method |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   678
	|src usedVars parser|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   679
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   680
	src := method source.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   681
	src notNil ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   682
	    parser := Parser
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   683
			    parseMethod:src 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   684
			    in:aClass 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   685
			    ignoreErrors:true 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   686
			    ignoreWarnings:true.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   687
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   688
	    (parser notNil and:[parser ~~ #Error]) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   689
		aCollectionOfVariablenames removeAllFoundIn:(parser usedClassVars).
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   690
		aCollectionOfVariablenames isEmpty ifTrue:[^ self].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   691
	    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   692
	].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   693
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   694
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   695
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   696
removeUsedInstanceVariablesIn:aClass from:aCollectionOfVariablenames
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   697
    aClass selectorsAndMethodsDo:[:mSelector :method |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   698
	|src usedVars parser|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   699
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   700
	src := method source.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   701
	src notNil ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   702
	    parser := Parser
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   703
			    parseMethod:src 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   704
			    in:aClass 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   705
			    ignoreErrors:true 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   706
			    ignoreWarnings:true.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   707
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   708
	    (parser notNil and:[parser ~~ #Error]) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   709
		aCollectionOfVariablenames removeAllFoundIn:(parser usedInstVars).
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   710
		aCollectionOfVariablenames isEmpty ifTrue:[^ self].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   711
	    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   712
	].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   713
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   714
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   715
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   716
removeWrittenClassVariablesIn:aClass from:aCollectionOfVariablenames
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   717
    aClass selectorsAndMethodsDo:[:mSelector :method |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   718
	|src usedVars parser|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   719
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   720
	src := method source.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   721
	src notNil ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   722
	    parser := Parser
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   723
			    parseMethod:src 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   724
			    in:aClass 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   725
			    ignoreErrors:true 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   726
			    ignoreWarnings:true.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   727
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   728
	    (parser notNil and:[parser ~~ #Error]) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   729
		aCollectionOfVariablenames removeAllFoundIn:(parser modifiedClassVars).
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   730
		aCollectionOfVariablenames isEmpty ifTrue:[^ self].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   731
	    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   732
	].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   733
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   734
!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   735
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   736
removeWrittenInstanceVariablesIn:aClass from:aCollectionOfVariablenames
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   737
    aClass selectorsAndMethodsDo:[:mSelector :method |
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   738
	|src usedVars parser|
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   739
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   740
	src := method source.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   741
	src notNil ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   742
	    parser := Parser
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   743
			    parseMethod:src 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   744
			    in:aClass 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   745
			    ignoreErrors:true 
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   746
			    ignoreWarnings:true.
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   747
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   748
	    (parser notNil and:[parser ~~ #Error]) ifTrue:[
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   749
		aCollectionOfVariablenames removeAllFoundIn:(parser modifiedInstVars).
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   750
		aCollectionOfVariablenames isEmpty ifTrue:[^ self].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   751
	    ]
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   752
	].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   753
    ].
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   754
! !
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   755
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   756
!ClassChecker class methodsFor:'documentation'!
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   757
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   758
version
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   759
    ^ '$Header: /cvs/stx/stx/libtool/Tools_ClassChecker.st,v 1.1 2004-02-26 18:56:10 cg Exp $'
273637686948 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   760
! !