ProfileTree.st
author Claus Gittinger <cg@exept.de>
Thu, 25 Apr 1996 19:12:40 +0200
changeset 236 7f570e0a0a75
parent 120 950e4628d657
child 261 2fb596a13d0c
permissions -rw-r--r--
documentation
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
24
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
     1
"
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
     2
 COPYRIGHT (c) 1995 by Claus Gittinger
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
     3
	      All Rights Reserved
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
     4
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
     5
 This software is furnished under a license and may be used
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
     6
 only in accordance with the terms of that license and with the
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
     8
 be provided or otherwise made available to, or used by, any
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
     9
 other person.  No title to or ownership of the software is
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
    10
 hereby transferred.
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
    11
"
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
    12
120
950e4628d657 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 119
diff changeset
    13
Object subclass:#ProfileTree
236
7f570e0a0a75 documentation
Claus Gittinger <cg@exept.de>
parents: 120
diff changeset
    14
	instanceVariableNames:'receiver selector class leafTally totalTally called isBlock'
7f570e0a0a75 documentation
Claus Gittinger <cg@exept.de>
parents: 120
diff changeset
    15
	classVariableNames:''
7f570e0a0a75 documentation
Claus Gittinger <cg@exept.de>
parents: 120
diff changeset
    16
	poolDictionaries:''
7f570e0a0a75 documentation
Claus Gittinger <cg@exept.de>
parents: 120
diff changeset
    17
	category:'System-Debugging-Support'
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    18
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    19
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    20
!ProfileTree class methodsFor:'documentation'!
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    21
24
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
    22
copyright
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
    23
"
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
    24
 COPYRIGHT (c) 1995 by Claus Gittinger
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
    25
	      All Rights Reserved
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
    26
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
    27
 This software is furnished under a license and may be used
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
    28
 only in accordance with the terms of that license and with the
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
    29
 inclusion of the above copyright notice.   This software may not
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
    30
 be provided or otherwise made available to, or used by, any
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
    31
 other person.  No title to or ownership of the software is
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
    32
 hereby transferred.
10e1150b1f4b *** empty log message ***
claus
parents: 23
diff changeset
    33
"
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    34
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    35
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    36
documentation
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    37
"
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    38
    This is is used as a companion to MessageTally.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    39
    Instances of it are used to represent the calling tree.
236
7f570e0a0a75 documentation
Claus Gittinger <cg@exept.de>
parents: 120
diff changeset
    40
7f570e0a0a75 documentation
Claus Gittinger <cg@exept.de>
parents: 120
diff changeset
    41
    [author:]
7f570e0a0a75 documentation
Claus Gittinger <cg@exept.de>
parents: 120
diff changeset
    42
        Claus Gittinger
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    43
"
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    44
! !
2911230f8e8e Initial revision
claus
parents:
diff changeset
    45
2911230f8e8e Initial revision
claus
parents:
diff changeset
    46
!ProfileTree methodsFor:'accessing'!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    47
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    48
called
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    49
    ^ called
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    50
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    51
2911230f8e8e Initial revision
claus
parents:
diff changeset
    52
called:aCollection
2911230f8e8e Initial revision
claus
parents:
diff changeset
    53
    called := aCollection
2911230f8e8e Initial revision
claus
parents:
diff changeset
    54
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    55
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    56
isBlock 
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    57
    ^ isBlock 
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    58
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    59
2911230f8e8e Initial revision
claus
parents:
diff changeset
    60
isBlock:aBoolean
2911230f8e8e Initial revision
claus
parents:
diff changeset
    61
    isBlock  := aBoolean
2911230f8e8e Initial revision
claus
parents:
diff changeset
    62
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    63
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    64
leafTally
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    65
    ^ leafTally
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    66
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    67
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    68
methodClass 
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    69
    ^ class 
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    70
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    71
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    72
receiver
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    73
    ^ receiver
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    74
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    75
2911230f8e8e Initial revision
claus
parents:
diff changeset
    76
receiver:r selector:s class:cls 
2911230f8e8e Initial revision
claus
parents:
diff changeset
    77
    receiver := r.
2911230f8e8e Initial revision
claus
parents:
diff changeset
    78
    selector := s.
2911230f8e8e Initial revision
claus
parents:
diff changeset
    79
    class := cls
2911230f8e8e Initial revision
claus
parents:
diff changeset
    80
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    81
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    82
selector 
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    83
    ^ selector
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    84
!
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    85
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    86
totalTally
2911230f8e8e Initial revision
claus
parents:
diff changeset
    87
    ^ totalTally
2911230f8e8e Initial revision
claus
parents:
diff changeset
    88
! !
2911230f8e8e Initial revision
claus
parents:
diff changeset
    89
2911230f8e8e Initial revision
claus
parents:
diff changeset
    90
!ProfileTree methodsFor:'adding info'!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    91
2911230f8e8e Initial revision
claus
parents:
diff changeset
    92
addChain:aCallChain
2911230f8e8e Initial revision
claus
parents:
diff changeset
    93
    |node found subTree chain called|
2911230f8e8e Initial revision
claus
parents:
diff changeset
    94
2911230f8e8e Initial revision
claus
parents:
diff changeset
    95
    node := self.
2911230f8e8e Initial revision
claus
parents:
diff changeset
    96
    chain := aCallChain.
2911230f8e8e Initial revision
claus
parents:
diff changeset
    97
2911230f8e8e Initial revision
claus
parents:
diff changeset
    98
    [chain notNil] whileTrue:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
    99
	node incrementTotalTally.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   100
2911230f8e8e Initial revision
claus
parents:
diff changeset
   101
	found := false.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   102
	(called := node called) notNil ifTrue:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   103
	    called do:[:subTree |
2911230f8e8e Initial revision
claus
parents:
diff changeset
   104
		found ifFalse:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   105
		    (chain = subTree) ifTrue:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   106
			node := subTree.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   107
			chain := chain rest.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   108
			found := true
2911230f8e8e Initial revision
claus
parents:
diff changeset
   109
		    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   110
		].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   111
	    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   112
	] ifFalse:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   113
	    node called:(OrderedCollection new)
2911230f8e8e Initial revision
claus
parents:
diff changeset
   114
	].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   115
	found ifFalse:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   116
	    subTree := ProfileTree new.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   117
	    subTree receiver:chain receiver
2911230f8e8e Initial revision
claus
parents:
diff changeset
   118
		    selector:chain selector
2911230f8e8e Initial revision
claus
parents:
diff changeset
   119
		       class:chain methodClass.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   120
	    subTree isBlock:(chain isBlock).
2911230f8e8e Initial revision
claus
parents:
diff changeset
   121
2911230f8e8e Initial revision
claus
parents:
diff changeset
   122
	    node called add:subTree.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   123
	    node := subTree.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   124
	    chain := chain rest
2911230f8e8e Initial revision
claus
parents:
diff changeset
   125
	]
2911230f8e8e Initial revision
claus
parents:
diff changeset
   126
2911230f8e8e Initial revision
claus
parents:
diff changeset
   127
    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   128
2911230f8e8e Initial revision
claus
parents:
diff changeset
   129
    node incrementTotalTally.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   130
    node incrementLeafTally.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   131
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   132
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   133
computePercentage:total
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   134
    totalTally := (totalTally / total * 1000) rounded / 10.0.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   135
    leafTally notNil ifTrue:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   136
	leafTally := (leafTally / total * 1000) rounded / 10.0
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   137
    ].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   138
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   139
    called notNil ifTrue:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   140
	called do:[:subTree |
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   141
	    subTree computePercentage:total
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   142
	]
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   143
    ].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   144
!
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   145
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   146
incrementLeafTally
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   147
    leafTally isNil ifTrue:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   148
	leafTally := 1
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   149
    ] ifFalse:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   150
	leafTally := leafTally + 1.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   151
    ].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   152
!
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   153
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   154
incrementTotalTally
2911230f8e8e Initial revision
claus
parents:
diff changeset
   155
    totalTally isNil ifTrue:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   156
	totalTally := 1
2911230f8e8e Initial revision
claus
parents:
diff changeset
   157
    ] ifFalse:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   158
	totalTally := totalTally + 1.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   159
    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   160
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   161
2911230f8e8e Initial revision
claus
parents:
diff changeset
   162
leafTally:aCount
2911230f8e8e Initial revision
claus
parents:
diff changeset
   163
    leafTally := aCount
2911230f8e8e Initial revision
claus
parents:
diff changeset
   164
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   165
2911230f8e8e Initial revision
claus
parents:
diff changeset
   166
totalTally:aCount
2911230f8e8e Initial revision
claus
parents:
diff changeset
   167
    totalTally := aCount
2911230f8e8e Initial revision
claus
parents:
diff changeset
   168
! !
2911230f8e8e Initial revision
claus
parents:
diff changeset
   169
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   170
!ProfileTree methodsFor:'prettyPrinting'!
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   171
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   172
printLeafsOn:aStream
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   173
    |leafNodes|
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   174
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   175
    leafNodes := OrderedCollection new.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   176
    self addLeafNodesTo:leafNodes.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   177
    leafNodes := leafNodes asSortedCollection:[:a :b |
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   178
					a leafTally < b leafTally].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   179
    leafNodes do:[:aNode |
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   180
	aNode printSingleOn:aStream.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   181
	aStream cr.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   182
    ].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   183
!
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   184
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   185
printOn:aStream
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   186
    |s|
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   187
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   188
"/    self printOn:aStream indent:0
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   189
    s := WriteStream on:String new.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   190
    self printOn:s indent:0.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   191
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   192
    aStream nextPutAll:s contents
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   193
!
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   194
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   195
printOn:aStream indent:i
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   196
    selector notNil ifTrue:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   197
	aStream spaces:i.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   198
	self printSingleOn:aStream.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   199
	aStream cr.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   200
    ].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   201
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   202
    called notNil ifTrue:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   203
	called do:[:sub|
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   204
	    sub printOn:aStream indent:(i + 1)
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   205
	].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   206
    ].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   207
!
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   208
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   209
printSingleOn:aStream
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   210
    selector notNil ifTrue:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   211
	isBlock == true ifTrue:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   212
	    '[] in ' printOn:aStream
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   213
	].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   214
	receiver name printOn:aStream.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   215
	(class notNil and:[class ~~ receiver class]) ifTrue:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   216
	    '>>' printOn:aStream.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   217
	    class name printOn:aStream
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   218
	].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   219
	aStream space.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   220
	selector printOn:aStream.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   221
	aStream space.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   222
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   223
	aStream nextPutAll:'(total '.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   224
	totalTally printOn:aStream.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   225
	aStream nextPutAll:'%)'.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   226
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   227
	leafTally notNil ifTrue:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   228
	    aStream nextPutAll:'(leaf '.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   229
	    leafTally printOn:aStream.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   230
	    aStream nextPutAll:'%)'.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   231
	].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   232
    ].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   233
! !
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   234
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   235
!ProfileTree methodsFor:'private'!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   236
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   237
= aProfileTreeNode
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   238
    receiver ~= aProfileTreeNode receiver ifTrue:[^ false].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   239
    selector ~~ aProfileTreeNode selector ifTrue:[^ false].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   240
    class ~~ aProfileTreeNode methodClass ifTrue:[^ false].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   241
    ^ true
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   242
!
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   243
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   244
addLeafNodesTo:aCollection
2911230f8e8e Initial revision
claus
parents:
diff changeset
   245
    |idx|
2911230f8e8e Initial revision
claus
parents:
diff changeset
   246
2911230f8e8e Initial revision
claus
parents:
diff changeset
   247
    leafTally notNil ifTrue:[
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   248
	idx := aCollection  indexOf:self.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   249
	idx == 0 ifTrue:[
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   250
	    aCollection add:self copy
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   251
	] ifFalse:[
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   252
	    |nd|
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   253
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   254
	    nd := aCollection at:idx.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   255
	    nd leafTally:(nd leafTally + leafTally).
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   256
	    nd totalTally:(nd totalTally max: totalTally)
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   257
	]
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   258
    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   259
    called notNil ifTrue:[
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   260
	called do:[:aNode |
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   261
	    aNode addLeafNodesTo:aCollection
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   262
	]
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   263
    ]
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   264
! !
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   265
98
123d948aacd1 version at the end
Claus Gittinger <cg@exept.de>
parents: 88
diff changeset
   266
!ProfileTree class methodsFor:'documentation'!
123d948aacd1 version at the end
Claus Gittinger <cg@exept.de>
parents: 88
diff changeset
   267
123d948aacd1 version at the end
Claus Gittinger <cg@exept.de>
parents: 88
diff changeset
   268
version
236
7f570e0a0a75 documentation
Claus Gittinger <cg@exept.de>
parents: 120
diff changeset
   269
    ^ '$Header: /cvs/stx/stx/libbasic3/ProfileTree.st,v 1.11 1996-04-25 17:11:26 cg Exp $'
98
123d948aacd1 version at the end
Claus Gittinger <cg@exept.de>
parents: 88
diff changeset
   270
! !