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