ProfileTree.st
author Claus Gittinger <cg@exept.de>
Thu, 23 Nov 1995 03:11:50 +0100
changeset 88 070ba8eb911e
parent 68 5f7ac0b5c903
child 98 123d948aacd1
permissions -rw-r--r--
checkin from browser
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
Object subclass:#ProfileTree
2911230f8e8e Initial revision
claus
parents:
diff changeset
    14
	 instanceVariableNames:'receiver selector class leafTally totalTally called isBlock'
2911230f8e8e Initial revision
claus
parents:
diff changeset
    15
	 classVariableNames:''
2911230f8e8e Initial revision
claus
parents:
diff changeset
    16
	 poolDictionaries:''
24
10e1150b1f4b *** empty log message ***
claus
parents: 23
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.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    40
"
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    41
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    42
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    43
version
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    44
    ^ '$Header: /cvs/stx/stx/libbasic3/ProfileTree.st,v 1.7 1995-11-23 02:11:50 cg Exp $'
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    45
! !
2911230f8e8e Initial revision
claus
parents:
diff changeset
    46
2911230f8e8e Initial revision
claus
parents:
diff changeset
    47
!ProfileTree methodsFor:'accessing'!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    48
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    49
called
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    50
    ^ called
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    51
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    52
2911230f8e8e Initial revision
claus
parents:
diff changeset
    53
called:aCollection
2911230f8e8e Initial revision
claus
parents:
diff changeset
    54
    called := aCollection
2911230f8e8e Initial revision
claus
parents:
diff changeset
    55
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    56
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    57
isBlock 
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    58
    ^ isBlock 
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
isBlock:aBoolean
2911230f8e8e Initial revision
claus
parents:
diff changeset
    62
    isBlock  := aBoolean
2911230f8e8e Initial revision
claus
parents:
diff changeset
    63
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    64
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    65
leafTally
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    66
    ^ leafTally
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    67
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    68
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    69
methodClass 
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    70
    ^ class 
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    71
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    72
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    73
receiver
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    74
    ^ receiver
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    75
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    76
2911230f8e8e Initial revision
claus
parents:
diff changeset
    77
receiver:r selector:s class:cls 
2911230f8e8e Initial revision
claus
parents:
diff changeset
    78
    receiver := r.
2911230f8e8e Initial revision
claus
parents:
diff changeset
    79
    selector := s.
2911230f8e8e Initial revision
claus
parents:
diff changeset
    80
    class := cls
2911230f8e8e Initial revision
claus
parents:
diff changeset
    81
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    82
88
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
    ^ selector
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    85
!
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
    86
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    87
totalTally
2911230f8e8e Initial revision
claus
parents:
diff changeset
    88
    ^ totalTally
2911230f8e8e Initial revision
claus
parents:
diff changeset
    89
! !
2911230f8e8e Initial revision
claus
parents:
diff changeset
    90
2911230f8e8e Initial revision
claus
parents:
diff changeset
    91
!ProfileTree methodsFor:'adding info'!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    92
2911230f8e8e Initial revision
claus
parents:
diff changeset
    93
addChain:aCallChain
2911230f8e8e Initial revision
claus
parents:
diff changeset
    94
    |node found subTree chain called|
2911230f8e8e Initial revision
claus
parents:
diff changeset
    95
2911230f8e8e Initial revision
claus
parents:
diff changeset
    96
    node := self.
2911230f8e8e Initial revision
claus
parents:
diff changeset
    97
    chain := aCallChain.
2911230f8e8e Initial revision
claus
parents:
diff changeset
    98
2911230f8e8e Initial revision
claus
parents:
diff changeset
    99
    [chain notNil] whileTrue:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   100
	node incrementTotalTally.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   101
2911230f8e8e Initial revision
claus
parents:
diff changeset
   102
	found := false.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   103
	(called := node called) notNil ifTrue:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   104
	    called do:[:subTree |
2911230f8e8e Initial revision
claus
parents:
diff changeset
   105
		found ifFalse:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   106
		    (chain = subTree) ifTrue:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   107
			node := subTree.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   108
			chain := chain rest.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   109
			found := true
2911230f8e8e Initial revision
claus
parents:
diff changeset
   110
		    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   111
		].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   112
	    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   113
	] ifFalse:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   114
	    node called:(OrderedCollection new)
2911230f8e8e Initial revision
claus
parents:
diff changeset
   115
	].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   116
	found ifFalse:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   117
	    subTree := ProfileTree new.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   118
	    subTree receiver:chain receiver
2911230f8e8e Initial revision
claus
parents:
diff changeset
   119
		    selector:chain selector
2911230f8e8e Initial revision
claus
parents:
diff changeset
   120
		       class:chain methodClass.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   121
	    subTree isBlock:(chain isBlock).
2911230f8e8e Initial revision
claus
parents:
diff changeset
   122
2911230f8e8e Initial revision
claus
parents:
diff changeset
   123
	    node called add:subTree.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   124
	    node := subTree.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   125
	    chain := chain rest
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
2911230f8e8e Initial revision
claus
parents:
diff changeset
   130
    node incrementTotalTally.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   131
    node incrementLeafTally.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   132
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   133
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   134
computePercentage:total
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   135
    totalTally := (totalTally / total * 1000) rounded / 10.0.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   136
    leafTally notNil ifTrue:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   137
	leafTally := (leafTally / total * 1000) rounded / 10.0
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
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   140
    called notNil ifTrue:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   141
	called do:[:subTree |
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   142
	    subTree computePercentage:total
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
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   147
incrementLeafTally
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   148
    leafTally isNil ifTrue:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   149
	leafTally := 1
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   150
    ] ifFalse:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   151
	leafTally := leafTally + 1.
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
!
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   154
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   155
incrementTotalTally
2911230f8e8e Initial revision
claus
parents:
diff changeset
   156
    totalTally isNil ifTrue:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   157
	totalTally := 1
2911230f8e8e Initial revision
claus
parents:
diff changeset
   158
    ] ifFalse:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   159
	totalTally := totalTally + 1.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   160
    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   161
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   162
2911230f8e8e Initial revision
claus
parents:
diff changeset
   163
leafTally:aCount
2911230f8e8e Initial revision
claus
parents:
diff changeset
   164
    leafTally := aCount
2911230f8e8e Initial revision
claus
parents:
diff changeset
   165
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   166
2911230f8e8e Initial revision
claus
parents:
diff changeset
   167
totalTally:aCount
2911230f8e8e Initial revision
claus
parents:
diff changeset
   168
    totalTally := aCount
2911230f8e8e Initial revision
claus
parents:
diff changeset
   169
! !
2911230f8e8e Initial revision
claus
parents:
diff changeset
   170
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   171
!ProfileTree methodsFor:'prettyPrinting'!
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   172
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   173
printLeafsOn:aStream
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   174
    |leafNodes|
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   175
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   176
    leafNodes := OrderedCollection new.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   177
    self addLeafNodesTo:leafNodes.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   178
    leafNodes := leafNodes asSortedCollection:[:a :b |
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   179
					a leafTally < b leafTally].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   180
    leafNodes do:[:aNode |
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   181
	aNode printSingleOn:aStream.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   182
	aStream cr.
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
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   186
printOn:aStream
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   187
    |s|
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   188
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   189
"/    self printOn:aStream indent:0
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   190
    s := WriteStream on:String new.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   191
    self printOn:s indent:0.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   192
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   193
    aStream nextPutAll:s contents
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
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   196
printOn:aStream indent:i
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   197
    selector notNil ifTrue:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   198
	aStream spaces:i.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   199
	self printSingleOn:aStream.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   200
	aStream cr.
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
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   203
    called notNil ifTrue:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   204
	called do:[:sub|
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   205
	    sub printOn:aStream indent:(i + 1)
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
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   210
printSingleOn:aStream
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   211
    selector notNil ifTrue:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   212
	isBlock == true ifTrue:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   213
	    '[] in ' printOn:aStream
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   214
	].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   215
	receiver name printOn:aStream.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   216
	(class notNil and:[class ~~ receiver class]) ifTrue:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   217
	    '>>' printOn:aStream.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   218
	    class name printOn:aStream
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   219
	].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   220
	aStream space.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   221
	selector printOn:aStream.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   222
	aStream space.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   223
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   224
	aStream nextPutAll:'(total '.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   225
	totalTally printOn:aStream.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   226
	aStream nextPutAll:'%)'.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   227
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   228
	leafTally notNil ifTrue:[
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   229
	    aStream nextPutAll:'(leaf '.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   230
	    leafTally printOn:aStream.
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   231
	    aStream nextPutAll:'%)'.
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
! !
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   235
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   236
!ProfileTree methodsFor:'private'!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   237
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   238
= aProfileTreeNode
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   239
    receiver ~= aProfileTreeNode receiver ifTrue:[^ false].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   240
    selector ~~ aProfileTreeNode selector ifTrue:[^ false].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   241
    class ~~ aProfileTreeNode methodClass ifTrue:[^ false].
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   242
    ^ true
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   243
!
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   244
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   245
addLeafNodesTo:aCollection
2911230f8e8e Initial revision
claus
parents:
diff changeset
   246
    |idx|
2911230f8e8e Initial revision
claus
parents:
diff changeset
   247
2911230f8e8e Initial revision
claus
parents:
diff changeset
   248
    leafTally notNil ifTrue:[
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   249
	idx := aCollection  indexOf:self.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   250
	idx == 0 ifTrue:[
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   251
	    aCollection add:self copy
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   252
	] ifFalse:[
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   253
	    |nd|
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   254
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   255
	    nd := aCollection at:idx.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   256
	    nd leafTally:(nd leafTally + leafTally).
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   257
	    nd totalTally:(nd totalTally max: totalTally)
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   258
	]
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   259
    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   260
    called notNil ifTrue:[
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   261
	called do:[:aNode |
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   262
	    aNode addLeafNodesTo:aCollection
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   263
	]
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   264
    ]
88
070ba8eb911e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 68
diff changeset
   265
! !
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   266