ProjectChecker.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Wed, 31 Oct 2012 17:40:51 +0000
branchjv
changeset 3092 432aa120d8d2
parent 3091 afe091fa9820
child 3094 4ec645987e2d
permissions -rw-r--r--
Fixed #checkClassListConsistency - class order (first common classes, then platform-specific)
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
3012
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
     1
"
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
     2
 COPYRIGHT (c) 2006 by eXept Software AG
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
     3
              All Rights Reserved
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
     4
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
     5
 This software is furnished under a license and may be used
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
     6
 only in accordance with the terms of that license and with the
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
     8
 be provided or otherwise made available to, or used by, any
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
     9
 other person.  No title to or ownership of the software is
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    10
 hereby transferred.
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    11
"
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    12
"{ Package: 'stx:libbasic3' }"
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    13
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    14
Object subclass:#ProjectChecker
3064
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
    15
	instanceVariableNames:'package packageDef classes methods problems phase'
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    16
	classVariableNames:''
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    17
	poolDictionaries:''
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    18
	category:'System-Support-Projects'
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    19
!
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    20
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    21
!ProjectChecker class methodsFor:'documentation'!
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    22
3012
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    23
copyright
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    24
"
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    25
 COPYRIGHT (c) 2006 by eXept Software AG
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    26
              All Rights Reserved
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    27
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    28
 This software is furnished under a license and may be used
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    29
 only in accordance with the terms of that license and with the
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    30
 inclusion of the above copyright notice.   This software may not
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    31
 be provided or otherwise made available to, or used by, any
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    32
 other person.  No title to or ownership of the software is
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    33
 hereby transferred.
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    34
"
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    35
!
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
    36
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    37
documentation
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    38
"
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    39
    A simple project checker that can search whole projects or individual
3064
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
    40
    classes or methods for various problems that may cause build problems such
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
    41
    as:
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
    42
        - inconsistent/messed up project definition class
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
    43
        - method code problems
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    44
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    45
    NOTE: Not yet finished. This code is meant as a single central entry for all the
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    46
    source code management tools like SCM Utilities, NewSystemBrowser ets. That code
3019
4eb74fb0cae6 Access methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3018
diff changeset
    47
    will be refactored later once this tool prooves itself useful and mature enough.
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    48
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    49
    [author:]
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    50
        Jan Vrany <jan.vrany@fit.cvut.cz>
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    51
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    52
    [instance variables:]
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    53
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    54
    [class variables:]
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    55
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    56
    [see also:]
3064
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
    57
        Tools::ProjectCheckerBrowser
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    58
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    59
"
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    60
!
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    61
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    62
examples
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    63
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    64
    "
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    65
        ProjectChecker check: 'stx:libbasic'
3019
4eb74fb0cae6 Access methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3018
diff changeset
    66
        ProjectChecker check: 'stx:libtool'
4eb74fb0cae6 Access methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3018
diff changeset
    67
        ProjectChecker check: 'stx:libbasic3'
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    68
    "
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    69
! !
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    70
3064
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
    71
!ProjectChecker class methodsFor:'instance creation'!
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
    72
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
    73
forPackage: packageId
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
    74
    ^self new
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
    75
        package: packageId;
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
    76
        yourself.
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
    77
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
    78
    "Created: / 25-07-2012 / 18:00:06 / Jan Vrany <jan.vrany@fit.cvut.cz>"
3084
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
    79
!
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
    80
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
    81
new
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
    82
    "return an initialized instance"
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
    83
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
    84
    ^ self basicNew initialize.
3064
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
    85
! !
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
    86
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    87
!ProjectChecker class methodsFor:'checking'!
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    88
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    89
check: package
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    90
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    91
    ^self new check: package
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    92
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    93
    "Created: / 11-01-2012 / 16:46:38 / Jan Vrany <jan.vrany@fit.cvut.cz>"
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    94
! !
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    95
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    96
!ProjectChecker methodsFor:'accessing'!
68860a7700c2 initial checkin
vrany
parents:
diff changeset
    97
3019
4eb74fb0cae6 Access methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3018
diff changeset
    98
classes: aCollection
4eb74fb0cae6 Access methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3018
diff changeset
    99
    classes := aCollection.
4eb74fb0cae6 Access methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3018
diff changeset
   100
4eb74fb0cae6 Access methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3018
diff changeset
   101
    "Created: / 13-02-2012 / 17:06:31 / Jan Vrany <jan.vrany@fit.cvut.cz>"
4eb74fb0cae6 Access methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3018
diff changeset
   102
!
4eb74fb0cae6 Access methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3018
diff changeset
   103
4eb74fb0cae6 Access methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3018
diff changeset
   104
methods
4eb74fb0cae6 Access methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3018
diff changeset
   105
    ^ methods
4eb74fb0cae6 Access methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3018
diff changeset
   106
!
4eb74fb0cae6 Access methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3018
diff changeset
   107
4eb74fb0cae6 Access methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3018
diff changeset
   108
methods:something
4eb74fb0cae6 Access methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3018
diff changeset
   109
    methods := something.
4eb74fb0cae6 Access methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3018
diff changeset
   110
!
4eb74fb0cae6 Access methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3018
diff changeset
   111
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   112
package
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   113
    ^ package
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   114
!
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   115
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   116
package:packageId
3046
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   117
    package := packageId asSymbol.
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   118
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   119
    "Modified: / 11-04-2012 / 16:00:23 / Jan Vrany <jan.vrany@fit.cvut.cz>"
3018
9eb47024eba1 added #problems to ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3012
diff changeset
   120
!
9eb47024eba1 added #problems to ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3012
diff changeset
   121
9eb47024eba1 added #problems to ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3012
diff changeset
   122
problems
3064
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
   123
    ^ problems
3023
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   124
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   125
    "Modified: / 23-02-2012 / 15:14:24 / Jan Vrany <jan.vrany@fit.cvut.cz>"
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   126
! !
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   127
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   128
!ProjectChecker methodsFor:'checking'!
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   129
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   130
check
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   131
3084
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   132
    problems removeAll.
3020
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   133
    packageDef := ProjectDefinition definitionClassForPackage: package.
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   134
    packageDef isNil ifTrue:[
3023
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   135
        self addProblem: 
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   136
            (ProjectProblem newProjectDefinitionDoesNotExist package: package).
3020
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   137
        ^self    
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   138
    ].
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   139
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   140
    self
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   141
        checkPackage;
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   142
        checkClasses;
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   143
        checkMethods
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   144
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   145
    "Created: / 11-01-2012 / 16:47:21 / Jan Vrany <jan.vrany@fit.cvut.cz>"
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   146
!
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   147
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   148
check: package
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   149
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   150
    self package: package.
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   151
    self check.
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   152
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   153
    "Created: / 11-01-2012 / 16:47:21 / Jan Vrany <jan.vrany@fit.cvut.cz>"
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   154
! !
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   155
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   156
!ProjectChecker methodsFor:'checks-individual'!
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   157
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   158
checkClassListConsistency
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   159
    "Checks whether all classes listed in #classNamesAndAttributes are present
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   160
    and if all present classes are listed"
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   161
3084
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   162
    |classesInImage classesInDescription classesInDescriptionChecked onlyInDescription|
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   163
    "WARNING: Copy/paste of ProjectDefinition>>validateDescription"
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   164
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   165
    classesInImage := Smalltalk allClasses select:[:cls | (cls package = self package) and:[cls isPrivate not]].
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   166
    "/ classesInDescription := self classes asIdentitySet.
3084
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   167
    classesInDescription := OrderedCollection new.
3092
432aa120d8d2 Fixed #checkClassListConsistency - class order (first common classes, then platform-specific)
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3091
diff changeset
   168
    ( (packageDef compiled_classNames_common)
432aa120d8d2 Fixed #checkClassListConsistency - class order (first common classes, then platform-specific)
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3091
diff changeset
   169
    , (packageDef compiled_classNamesForPlatform:(OperatingSystem platformName))
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   170
    , (packageDef autoloaded_classNames)) do:[:nm |
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   171
        |cls|
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   172
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   173
        cls := Smalltalk at:nm asSymbol.
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   174
        cls isNil ifTrue:[
3023
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   175
            self addProblem: 
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   176
                (ProjectProblem newClassListedButDoesNotExist className: nm)
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   177
        ] ifFalse:[
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   178
            classesInDescription add:cls.
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   179
        ].
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   180
    ].
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   181
3084
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   182
    classesInDescriptionChecked := OrderedCollection new.
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   183
    classesInDescription do:[:eachClass |
3084
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   184
        (classesInDescriptionChecked includes: eachClass) ifTrue:[
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   185
                    self addProblem: 
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   186
                        (ProjectProblem newClassListedMultipleTimes
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   187
                            className: eachClass name)
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   188
        ].
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   189
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   190
        eachClass sharedPoolNames do:[:eachPoolName |
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   191
            |pool|
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   192
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   193
            pool := eachClass nameSpace classNamed:eachPoolName.
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   194
            pool isNil ifTrue:[
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   195
                eachClass nameSpace ~~ Smalltalk ifTrue:[
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   196
                    pool := Smalltalk classNamed:eachPoolName.
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   197
                ]
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   198
            ].
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   199
            pool isNil ifTrue:[
3023
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   200
                self addProblem: 
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   201
                    (ProjectProblem newClassUsesPoolButItDoesNotExist
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   202
                        className: eachClass name;
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   203
                        poolName: eachPoolName).
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   204
            ] ifFalse:[
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   205
                pool isSharedPool ifFalse:[
3023
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   206
                    self addProblem: 
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   207
                        (ProjectProblem newClassUsesPoolButItIsNotASharedPool
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   208
                            className: eachClass name;
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   209
                            poolName: eachPoolName).                
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   210
                ].
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   211
            ].
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   212
        ].
3084
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   213
3091
afe091fa9820 Fix in #checkClassListConsistency - care about classes with nil superclass (Object/Autoload)
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3088
diff changeset
   214
        (eachClass superclass notNil "/Care about classes with nil superclass - Object & Autoload
afe091fa9820 Fix in #checkClassListConsistency - care about classes with nil superclass (Object/Autoload)
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3088
diff changeset
   215
            and:[eachClass superclass package == eachClass package]) ifTrue:[
3084
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   216
            (classesInDescriptionChecked includes: eachClass superclass) ifFalse:[
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   217
                self addProblem:
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   218
                    (ProjectProblem newClassListedBeforeItsSuperclass
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   219
                        className: eachClass name;
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   220
                        superClassName: eachClass superclass name)
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   221
            ].
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   222
        ].
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   223
        eachClass sharedPools do:[:eachPool|
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   224
            eachPool package == eachClass package ifTrue:[
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   225
                (classesInDescriptionChecked includes: eachPool) ifFalse:[
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   226
                    self addProblem:
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   227
                        (ProjectProblem newClassListedBeforeItsPool
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   228
                            className: eachClass name;
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   229
                            poolName: eachPool name)
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   230
                ].
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   231
            ].
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   232
        ].
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   233
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   234
        classesInDescriptionChecked add: eachClass.
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   235
    ].
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   236
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   237
    classesInImage ~= classesInDescription ifTrue:[
3065
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3064
diff changeset
   238
        "This is done later in checkClassesListedInProjectDefinition:"
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3064
diff changeset
   239
"/        onlyInImage := (classesInImage reject:[:cls | classesInDescription includes:cls]).
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3064
diff changeset
   240
"/        onlyInImage do:[:cls|
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3064
diff changeset
   241
"/            self addProblem: 
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3064
diff changeset
   242
"/                (ProjectProblem newClassNotListed className: cls name).
c60f15e53fce Merged with /trunk
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3064
diff changeset
   243
"/        ].
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   244
        onlyInDescription := (classesInDescription reject:[:cls | classesInImage includes:cls]).
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   245
        onlyInDescription do:[:cls|
3023
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   246
            self addProblem: 
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   247
                (ProjectProblem newClassListedButDoesNotExist className: cls name)
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   248
        ].
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   249
    ].
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   250
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   251
    "Created: / 11-01-2012 / 17:14:33 / Jan Vrany <jan.vrany@fit.cvut.cz>"
3092
432aa120d8d2 Fixed #checkClassListConsistency - class order (first common classes, then platform-specific)
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3091
diff changeset
   252
    "Modified: / 31-10-2012 / 17:40:56 / Jan Vrany <jan.vrany@fit.cvut.cz>"
2718
vrany
parents: 2716
diff changeset
   253
!
vrany
parents: 2716
diff changeset
   254
3084
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   255
checkClassesForMethodsInNoProject:classesToCheck 
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   256
    | checker |
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   257
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   258
    checker := [:cls | 
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   259
        cls 
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   260
            selectorsAndMethodsDo:[:sel :mth | 
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   261
                (mth package isNil or:[ mth package == PackageId noProjectID ]) ifTrue:[
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   262
                    "Sigh, special hack for Expecco"
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   263
                    ((cls name = 'Expecco::AbstractApplication class' and:[ sel = 'flags' ]) or:[
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   264
                     (cls name = 'Expecco::Browser class' and:[ sel = 'flags' ])]) ifFalse:[
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   265
                        self addProblem:(ProjectProblem newMethodInNoPackage className:cls name
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   266
                                    selector:sel).
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   267
                    ]
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   268
                ]
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   269
            ]
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   270
    ].
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   271
    classesToCheck do:[:class | 
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   272
        checker value:class theMetaclass.
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   273
        checker value:class theNonMetaclass.
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   274
    ]
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   275
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   276
    "Created: / 13-02-2012 / 18:18:18 / Jan Vrany <jan.vrany@fit.cvut.cz>"
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   277
!
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   278
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   279
checkClassesForNonQualifiedSharedPools: classesToCheck 
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   280
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   281
    classesToCheck do:[:cls|
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   282
        cls sharedPoolNames do:[:poolName|
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   283
            (Smalltalk at: poolName asSymbol) isNil ifTrue:[
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   284
                | ns |
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   285
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   286
                ns := cls nameSpace.
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   287
                (ns ~~ Smalltalk and:[(ns at: poolName asSymbol) notNil]) ifTrue:[
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   288
                    self addProblem:
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   289
                        (ProjectProblem newClassUsesPoolButItIsNotASharedPool
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   290
                                className: cls name;
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   291
                                poolName: poolName)
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   292
                ]
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   293
            ]
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   294
        ]
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   295
    ].
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   296
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   297
    "Created: / 13-09-2012 / 16:34:16 / Jan Vrany <jan.vrany@fit.cvut.cz>"
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   298
!
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   299
3020
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   300
checkClassesListedInProjectDefinition: classesToCheck
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   301
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   302
    | classNamesListed |
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   303
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   304
    classNamesListed := packageDef classNames.
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   305
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   306
    classesToCheck do:[:class|
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   307
        (class isPrivate not and:[(classNamesListed includes: class name) not]) ifTrue:[
3023
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   308
            self addProblem: 
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   309
                (ProjectProblem newClassNotListed className: class name).
3020
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   310
        ]
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   311
    ].
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   312
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   313
    "Created: / 13-02-2012 / 18:18:17 / Jan Vrany <jan.vrany@fit.cvut.cz>"
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   314
!
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   315
2718
vrany
parents: 2716
diff changeset
   316
checkExtensionsListConsistency
vrany
parents: 2716
diff changeset
   317
    "Checks whether all extensions listed in #extensionMethodNames are present
vrany
parents: 2716
diff changeset
   318
    and if all extension methods are listed"
vrany
parents: 2716
diff changeset
   319
vrany
parents: 2716
diff changeset
   320
    | extensionsListed extensionsPresent |
vrany
parents: 2716
diff changeset
   321
vrany
parents: 2716
diff changeset
   322
    extensionsListed := OrderedCollection new.
vrany
parents: 2716
diff changeset
   323
    packageDef extensionMethodNames pairWiseDo:[:cls :sel|
vrany
parents: 2716
diff changeset
   324
        extensionsListed add: (Array with: cls with: sel)
vrany
parents: 2716
diff changeset
   325
    ].
vrany
parents: 2716
diff changeset
   326
    extensionsPresent := OrderedCollection new.
vrany
parents: 2716
diff changeset
   327
    packageDef searchForExtensions do:[:each|
3081
712525843aef - ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3065
diff changeset
   328
        "JV@2012-09-07: Do not take Java methods into an account, they
712525843aef - ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3065
diff changeset
   329
         should not be listed in extensionMethodNames.
712525843aef - ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3065
diff changeset
   330
         They are loaded lazily by JavaClassReader and if listed here,
712525843aef - ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3065
diff changeset
   331
         they would cause an error if the package is loaded from source.
712525843aef - ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3065
diff changeset
   332
         Sort of a HACK, indeed"
712525843aef - ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3065
diff changeset
   333
        each mclass isJavaClass ifFalse:[
712525843aef - ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3065
diff changeset
   334
            extensionsPresent add: (Array with: each mclass name with: each selector)
712525843aef - ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3065
diff changeset
   335
        ].
2718
vrany
parents: 2716
diff changeset
   336
    ].
vrany
parents: 2716
diff changeset
   337
vrany
parents: 2716
diff changeset
   338
    (extensionsListed \ extensionsPresent) do:[:clsAndSel|
3023
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   339
         self addProblem: 
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   340
            (ProjectProblem newExtensionMethodListedButDoesNotExist
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   341
                className: clsAndSel first selector: clsAndSel second).                            
2718
vrany
parents: 2716
diff changeset
   342
    ].
vrany
parents: 2716
diff changeset
   343
vrany
parents: 2716
diff changeset
   344
    (extensionsPresent \ extensionsListed) do:[:clsAndSel|
3023
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   345
         self addProblem: 
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   346
            (ProjectProblem newExtensionMethodNotListed
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   347
                className: clsAndSel first selector: clsAndSel second).                            
2718
vrany
parents: 2716
diff changeset
   348
    ].
vrany
parents: 2716
diff changeset
   349
vrany
parents: 2716
diff changeset
   350
    "Created: / 12-01-2012 / 12:31:55 / Jan Vrany <jan.vrany@fit.cvut.cz>"
vrany
parents: 2716
diff changeset
   351
!
vrany
parents: 2716
diff changeset
   352
vrany
parents: 2716
diff changeset
   353
checkExtensionsPrerequisites
vrany
parents: 2716
diff changeset
   354
    "Checks whether packages of all extensions method classes are listed
vrany
parents: 2716
diff changeset
   355
     in package prerequisites"
vrany
parents: 2716
diff changeset
   356
vrany
parents: 2716
diff changeset
   357
    packageDef searchForExtensions do:[:mthd|
vrany
parents: 2716
diff changeset
   358
        (packageDef preRequisites includes: mthd mclass package) ifFalse:[
3023
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   359
"/            self problem: ('%3 required by extension method but not in prerequisites' bindWith: mthd mclass package)
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   360
"/                 description: ('An extension method %1>>%2 extends class in package %3 but the package is not listed in package''s prerequisited. This leads into missing methods and strange bugs when application is compiled and run!!' bindWith: mthd class with: mthd selector with: mthd class package)
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   361
"/                 severity: #error data: mthd
2718
vrany
parents: 2716
diff changeset
   362
         ].
vrany
parents: 2716
diff changeset
   363
    ]
vrany
parents: 2716
diff changeset
   364
vrany
parents: 2716
diff changeset
   365
    "Created: / 12-01-2012 / 12:41:40 / Jan Vrany <jan.vrany@fit.cvut.cz>"
3020
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   366
!
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   367
3046
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   368
checkMethodCodingStyle: method
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   369
    "Checks for various coding style violations such as 'self halt' or
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   370
     improper indentation :-)"
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   371
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   372
    "To be implemented"
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   373
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   374
    "Created: / 11-04-2012 / 12:38:59 / Jan Vrany <jan.vrany@fit.cvut.cz>"
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   375
!
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   376
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   377
checkMethodSTCCompilability1: method into: problem
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   378
    "Checks is the method can be compiled by STC based on Parser error/warnings"
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   379
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   380
    | lang |
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   381
    lang := method programmingLanguage.
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   382
    lang isSmalltalk ifFalse:[ ^ self ].
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   383
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   384
    lang compilerClass new
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   385
        compile:method source
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   386
        forClass:method mclass
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   387
        inCategory:'others'
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   388
        notifying:problem
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   389
        install:false
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   390
        skipIfSame:false
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   391
        silent:false
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   392
        foldConstants:true
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   393
        ifFail:[ ]
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   394
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   395
    "Created: / 11-04-2012 / 15:31:00 / Jan Vrany <jan.vrany@fit.cvut.cz>"
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   396
!
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   397
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   398
checkMethodSTCCompilability2: method into: problem
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   399
    "Checks is the method can be compiled by STC based on selected lint rules"
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   400
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   401
    "Not yet implemented"
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   402
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   403
    "Created: / 11-04-2012 / 15:54:06 / Jan Vrany <jan.vrany@fit.cvut.cz>"
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   404
!
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   405
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   406
checkMethodSTCCompilability: method
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   407
    "Checks is the method can be compiled by STC (since STC won't compile
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   408
     everything bytecode compiler/jit compiler does, sigh"
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   409
3064
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
   410
    | issue |
3046
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   411
3064
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
   412
    "No need to check the method if the class is autoloaded"
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
   413
    (packageDef autoloaded_classNames includes: method mclass theNonMetaclass name) ifTrue:[
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
   414
        ^ self
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
   415
    ].
5aaeb66c9663 - ProjectProblem
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3046
diff changeset
   416
    
3046
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   417
    issue := ProjectProblem newMethodCompilabilityIssue.
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   418
    issue method: method.
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   419
    self checkMethodSTCCompilability1: method into: issue.
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   420
    self checkMethodSTCCompilability2: method into: issue.
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   421
    issue hasIssue ifTrue:[
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   422
        self addProblem: issue
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   423
    ]
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   424
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   425
    "Created: / 11-04-2012 / 12:37:17 / Jan Vrany <jan.vrany@fit.cvut.cz>"
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   426
!
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   427
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   428
checkMethodSourceCode: method
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   429
    "Checks, whether method's source code is both
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   430
     available and parseable. Return true if the code
3085
01e9d0823966 - ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3084
diff changeset
   431
     is syntactically correct, false otherwise"
3046
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   432
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   433
    | source |
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   434
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   435
    [    
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   436
        source := method source.
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   437
    ] on: Error do:[
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   438
        self addProblem:
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   439
            (ProjectProblem newMethodSourceNotAvailable method: method).
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   440
        ^false
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   441
    ].
3085
01e9d0823966 - ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3084
diff changeset
   442
    method programmingLanguage isSmalltalk ifFalse:[ ^ false ].
01e9d0823966 - ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3084
diff changeset
   443
3046
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   444
    [
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   445
        (Parser parseMethod: method source) == #Error ifTrue:[
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   446
            self addProblem:
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   447
                (ProjectProblem newMethodSourceCorrupted method: method).
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   448
            ^false.
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   449
        ]
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   450
    ] on: Error do:[
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   451
        self addProblem:
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   452
            (ProjectProblem newMethodSourceCorrupted method: method).
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   453
        ^false.
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   454
    ].
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   455
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   456
    ^true
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   457
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   458
    "Created: / 11-04-2012 / 12:29:06 / Jan Vrany <jan.vrany@fit.cvut.cz>"
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   459
! !
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   460
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   461
!ProjectChecker methodsFor:'checks-private'!
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   462
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   463
checkClasses
3020
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   464
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   465
    classes notNil ifTrue:[
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   466
        self checkClasses: classes
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   467
    ] ifFalse:[
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   468
        self checkClasses: (Smalltalk allClasses select:[:cls | (cls package = self package)]).
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   469
    ].
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   470
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   471
    "Created: / 11-01-2012 / 16:55:48 / Jan Vrany <jan.vrany@fit.cvut.cz>"
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   472
!
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   473
3020
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   474
checkClasses: classesToCheck
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   475
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   476
    self checkClassesListedInProjectDefinition: classesToCheck.
3084
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   477
    self checkClassesForMethodsInNoProject:classesToCheck.
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   478
    self checkClassesForNonQualifiedSharedPools:classesToCheck.
3020
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   479
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   480
    "Created: / 13-02-2012 / 18:18:18 / Jan Vrany <jan.vrany@fit.cvut.cz>"
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   481
!
240c299584af Improvements in project checker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3019
diff changeset
   482
3046
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   483
checkMethod: method
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   484
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   485
    (self checkMethodSourceCode: method) ifTrue:[
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   486
        "/OK, method's source is OK, perform further checks
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   487
        self checkMethodSTCCompilability: method.
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   488
        self checkMethodCodingStyle: method.
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   489
    ]
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   490
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   491
    "Created: / 11-04-2012 / 12:27:33 / Jan Vrany <jan.vrany@fit.cvut.cz>"
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   492
!
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   493
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   494
checkMethods
3046
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   495
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   496
    methods notEmptyOrNil ifTrue:[
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   497
        self checkMethods: methods.
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   498
        ^self.
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   499
    ].
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   500
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   501
    self checkMethods:
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   502
        (Iterator on:[:whatToDo|
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   503
            (classes notNil ifTrue:[classes] ifFalse:[Smalltalk allClasses]) do:[:cls|
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   504
                cls theNonMetaclass withAllPrivateClassesDo:[:each |
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   505
                    each instAndClassSelectorsAndMethodsDo:[:s :m | m package = package ifTrue:[whatToDo value:m]]
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   506
                ].
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   507
            ]
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   508
        ])
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   509
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   510
    "Created: / 11-01-2012 / 16:55:49 / Jan Vrany <jan.vrany@fit.cvut.cz>"
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   511
!
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   512
3046
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   513
checkMethods: methodsToCheck
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   514
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   515
    methodsToCheck do:[:m|self checkMethod: m].
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   516
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   517
    "Created: / 11-04-2012 / 12:16:58 / Jan Vrany <jan.vrany@fit.cvut.cz>"
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   518
!
c99775eaf08a Improvements in ProjectChecker - now it checks for corrupted source and uncompilable methods
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3037
diff changeset
   519
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   520
checkPackage
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   521
2716
9a74597bcd4b Do not use annotations as stc crashes when compiling them
vrany
parents: 2707
diff changeset
   522
    self checkClassListConsistency.
2718
vrany
parents: 2716
diff changeset
   523
    self checkExtensionsListConsistency.
vrany
parents: 2716
diff changeset
   524
    self checkExtensionsPrerequisites.
vrany
parents: 2716
diff changeset
   525
2716
9a74597bcd4b Do not use annotations as stc crashes when compiling them
vrany
parents: 2707
diff changeset
   526
    "add more here..."
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   527
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   528
    "Created: / 11-01-2012 / 16:55:32 / Jan Vrany <jan.vrany@fit.cvut.cz>"
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   529
! !
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   530
3084
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   531
!ProjectChecker methodsFor:'initialization'!
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   532
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   533
initialize
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   534
    "Invoked when a new instance is created."
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   535
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   536
    "/ please change as required (and remove this comment)
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   537
    "/ package := nil.
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   538
    "/ packageDef := nil.
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   539
    "/ classes := nil.
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   540
    "/ methods := nil.
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   541
    problems := List new.
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   542
    "/ phase := nil.
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   543
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   544
    "/ super initialize.   -- commented since inherited method does nothing
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   545
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   546
    "Modified: / 13-09-2012 / 17:24:41 / Jan Vrany <jan.vrany@fit.cvut.cz>"
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   547
! !
0288b25613a9 Merged ProjectProblem/ProjectChecker from CVS
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3081
diff changeset
   548
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   549
!ProjectChecker methodsFor:'reporting'!
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   550
3023
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   551
addProblem: aProjectProblem
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   552
    aProjectProblem package: self package.
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   553
    problems isNil ifTrue:[problems := OrderedCollection new].
3023
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   554
    problems add: aProjectProblem
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   555
3023
ed74806df5bc Improvements in ProjectChecker
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3022
diff changeset
   556
    "Created: / 23-02-2012 / 13:10:46 / Jan Vrany <jan.vrany@fit.cvut.cz>"
2718
vrany
parents: 2716
diff changeset
   557
! !
vrany
parents: 2716
diff changeset
   558
2707
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   559
!ProjectChecker class methodsFor:'documentation'!
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   560
68860a7700c2 initial checkin
vrany
parents:
diff changeset
   561
version
3092
432aa120d8d2 Fixed #checkClassListConsistency - class order (first common classes, then platform-specific)
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3091
diff changeset
   562
    ^ '$Id: ProjectChecker.st 1977 2012-10-31 17:40:51Z vranyj1 $'
432aa120d8d2 Fixed #checkClassListConsistency - class order (first common classes, then platform-specific)
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3091
diff changeset
   563
!
432aa120d8d2 Fixed #checkClassListConsistency - class order (first common classes, then platform-specific)
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3091
diff changeset
   564
432aa120d8d2 Fixed #checkClassListConsistency - class order (first common classes, then platform-specific)
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3091
diff changeset
   565
version_CVS
432aa120d8d2 Fixed #checkClassListConsistency - class order (first common classes, then platform-specific)
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3091
diff changeset
   566
    ^ '§Header: /cvs/stx/stx/libbasic3/ProjectChecker.st,v 1.11 2012-10-31 17:42:25 +0000 vrany Exp §'
3012
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
   567
!
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
   568
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
   569
version_SVN
3092
432aa120d8d2 Fixed #checkClassListConsistency - class order (first common classes, then platform-specific)
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3091
diff changeset
   570
    ^ '$Id: ProjectChecker.st 1977 2012-10-31 17:40:51Z vranyj1 $'
3012
4f40b8304d54 Added InvalidChange
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 3011
diff changeset
   571
! !