Tools__ClassSorter.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Wed, 19 Jul 2017 09:42:32 +0200
branchjv
changeset 17619 edb119820fcb
parent 12431 9f0c59c742d5
child 18532 cccb41254edf
permissions -rw-r--r--
Issue #154: Set window style using `#beToolWindow` to indicate that the minirunner window is kind of support tool rather than some X11 specific code (which does not work on Windows of course) See https://swing.fit.cvut.cz/projects/stx-jv/ticket/154
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
9995
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     1
"
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     2
 COPYRIGHT (c) 2006 by eXept Software AG
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
	      All Rights Reserved
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     5
 This software is furnished under a license and may be used
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
 hereby transferred.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
"
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
"{ Package: 'stx:libtool' }"
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
"{ NameSpace: Tools }"
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    15
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
Object subclass:#ClassSorter
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
	instanceVariableNames:'indents order'
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
	classVariableNames:''
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
	poolDictionaries:''
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
	category:'Interface-Browsers-New'
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
!
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
!ClassSorter class methodsFor:'documentation'!
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
copyright
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
"
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    27
 COPYRIGHT (c) 2006 by eXept Software AG
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
	      All Rights Reserved
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    30
 This software is furnished under a license and may be used
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
 only in accordance with the terms of that license and with the
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
 inclusion of the above copyright notice.   This software may not
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    33
 be provided or otherwise made available to, or used by, any
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
 other person.  No title to or ownership of the software is
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
 hereby transferred.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    36
"
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    37
! !
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    38
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    39
!ClassSorter class methodsFor:'sorting'!
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    40
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
sort: classes
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
    ^self new sort: classes
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    44
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    45
    "Created: / 21-01-2008 / 19:40:19 / janfrog"
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    46
! !
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    47
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    48
!ClassSorter methodsFor:'filtering'!
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    49
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    50
sort: classes
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    51
        "Sort nodes according to their position in the class hierarchy"
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    52
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    53
        | supersChain |
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    54
        self initializeResults.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    55
        classes do: 
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
                [:class | 
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
                supersChain := class  withAllSuperclasses reversed.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    58
                supersChain removeAllSuchThat: [:cl | (classes includes: cl) not].
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
                order add: supersChain "contents" -> class].
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    60
        self buildIndentIndex.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    61
        ^self collectSortedClasses
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    62
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    63
    "Modified: / 21-01-2008 / 19:43:24 / janfrog"
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    64
! !
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    66
!ClassSorter methodsFor:'private'!
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    67
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    68
buildIndentIndex
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
	indents := IdentityDictionary new.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
	order do: [:assoc | indents at: assoc value put: assoc key size - 1].
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    71
!
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    72
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    73
collectSortedClasses
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
        ^order asArray collect: [:assoc | assoc value]
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    75
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    76
    "Created: / 21-01-2008 / 19:41:54 / janfrog"
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    77
!
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
initializeResults
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
	| i chain2 chain1 result max |
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
	order := SortedCollection sortBlock: 
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
					[:assoc1 :assoc2 | 
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    83
					result := nil.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
					chain1 := assoc1 key.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
					chain2 := assoc2 key.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
					max := chain1 size min: chain2 size.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    87
					i := 1.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    88
					[result isNil and: [i <= max]] whileTrue: 
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    89
							[(chain1 at: i) = (chain2 at: i) 
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    90
								ifTrue: [i := i + 1]
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
								ifFalse: [result := (chain1 at: i) name < (chain2 at: i) name]].
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    92
					result isNil ifTrue: [chain1 size < chain2 size] ifFalse: [result]]
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    93
! !
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    94
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    95
!ClassSorter class methodsFor:'documentation'!
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    96
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    97
version_CVS
12123
4bde08cebd48 trunk branched into /branches/jv
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 9995
diff changeset
    98
    ^ '§Header: /cvs/stx/stx/libtool/Tools__ClassSorter.st,v 1.1 2011/07/01 13:28:45 cg Exp §'
9995
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    99
!
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   100
12431
9f0c59c742d5 Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12128
diff changeset
   101
version_HG
9f0c59c742d5 Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12128
diff changeset
   102
9f0c59c742d5 Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12128
diff changeset
   103
    ^ '$Changeset: <not expanded> $'
9f0c59c742d5 Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12128
diff changeset
   104
!
9f0c59c742d5 Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12128
diff changeset
   105
9995
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   106
version_SVN
12128
a7ff7d66ee85 Improvements in LintHighlighter, few fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12123
diff changeset
   107
    ^ '$Id: Tools__ClassSorter.st 7854 2012-01-30 17:49:41Z vranyj1 $'
12431
9f0c59c742d5 Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12128
diff changeset
   108
! !
9f0c59c742d5 Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12128
diff changeset
   109