Tools__ClassSorter.st
author mawalch
Thu, 03 Aug 2017 23:00:17 +0200
changeset 17609 f9e1b73ce2ae
parent 17602 36908309a12c
child 17643 15c9a7e95913
permissions -rw-r--r--
#OTHER by mawalch Some delintification.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
17602
36908309a12c #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 9995
diff changeset
     1
"{ Encoding: utf8 }"
36908309a12c #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 9995
diff changeset
     2
9995
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
"
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
 COPYRIGHT (c) 2006 by eXept Software AG
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     5
	      All Rights Reserved
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
 This software is furnished under a license and may be used
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
 only in accordance with the terms of that license and with the
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
 inclusion of the above copyright notice.   This software may not
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
 be provided or otherwise made available to, or used by, any
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
 other person.  No title to or ownership of the software is
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
 hereby transferred.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
"
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
"{ Package: 'stx:libtool' }"
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    15
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
"{ NameSpace: Tools }"
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
Object subclass:#ClassSorter
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
	instanceVariableNames:'indents order'
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
	classVariableNames:''
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
	poolDictionaries:''
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
	category:'Interface-Browsers-New'
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
!
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
!ClassSorter class methodsFor:'documentation'!
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
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
"
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
 COPYRIGHT (c) 2006 by eXept Software AG
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    30
	      All Rights Reserved
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
 This software is furnished under a license and may be used
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    33
 only in accordance with the terms of that license and with the
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
 inclusion of the above copyright notice.   This software may not
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
 be provided or otherwise made available to, or used by, any
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    36
 other person.  No title to or ownership of the software is
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    37
 hereby transferred.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    38
"
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    39
! !
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    40
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
!ClassSorter class methodsFor:'sorting'!
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
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
    ^self new sort: classes
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    46
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    47
    "Created: / 21-01-2008 / 19:40:19 / janfrog"
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    48
! !
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    49
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    50
!ClassSorter methodsFor:'filtering'!
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    51
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    52
sort: classes
17602
36908309a12c #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 9995
diff changeset
    53
    "Sort nodes according to their position in the class hierarchy"
36908309a12c #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 9995
diff changeset
    54
36908309a12c #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 9995
diff changeset
    55
    | supersChain |
9995
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
17602
36908309a12c #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 9995
diff changeset
    57
    self initializeResults.
36908309a12c #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 9995
diff changeset
    58
    classes do:[:eachClass | 
36908309a12c #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 9995
diff changeset
    59
        supersChain := eachClass withAllSuperclasses intersect:classes.
36908309a12c #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 9995
diff changeset
    60
        order add: supersChain reverse "contents" -> eachClass
36908309a12c #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 9995
diff changeset
    61
    ].
36908309a12c #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 9995
diff changeset
    62
    self buildIndentIndex.
36908309a12c #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 9995
diff changeset
    63
    ^ self collectSortedClasses
9995
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    64
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
    "Modified: / 21-01-2008 / 19:43:24 / janfrog"
17602
36908309a12c #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 9995
diff changeset
    66
    "Modified: / 27-07-2017 / 09:38:20 / stefan"
9995
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    67
! !
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    68
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
!ClassSorter methodsFor:'private'!
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    71
buildIndentIndex
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    72
	indents := IdentityDictionary new.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    73
	order do: [:assoc | indents at: assoc value put: assoc key size - 1].
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
!
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    75
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    76
collectSortedClasses
17602
36908309a12c #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 9995
diff changeset
    77
    ^ order collect:[:assoc | assoc value] as:Array
9995
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
    "Created: / 21-01-2008 / 19:41:54 / janfrog"
17602
36908309a12c #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 9995
diff changeset
    80
    "Modified (format): / 25-07-2017 / 18:05:14 / stefan"
9995
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
!
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    83
initializeResults
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
	| i chain2 chain1 result max |
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
	order := SortedCollection sortBlock: 
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
					[:assoc1 :assoc2 | 
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    87
					result := nil.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    88
					chain1 := assoc1 key.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    89
					chain2 := assoc2 key.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    90
					max := chain1 size min: chain2 size.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
					i := 1.
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    92
					[result isNil and: [i <= max]] whileTrue: 
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    93
							[(chain1 at: i) = (chain2 at: i) 
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    94
								ifTrue: [i := i + 1]
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    95
								ifFalse: [result := (chain1 at: i) name < (chain2 at: i) name]].
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    96
					result isNil ifTrue: [chain1 size < chain2 size] ifFalse: [result]]
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    97
! !
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    98
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    99
!ClassSorter class methodsFor:'documentation'!
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   100
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   101
version_CVS
17602
36908309a12c #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 9995
diff changeset
   102
    ^ '$Header$'
9995
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   103
!
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   104
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   105
version_SVN
17602
36908309a12c #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 9995
diff changeset
   106
    ^ '$Id$'
9995
febbd7fc31a0 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   107
! !
17602
36908309a12c #REFACTORING by stefan
Stefan Vogel <sv@exept.de>
parents: 9995
diff changeset
   108