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