ProfileTree.st
author claus
Thu, 09 Mar 1995 11:46:36 +0100
changeset 23 a85cd774be98
parent 22 2911230f8e8e
child 24 10e1150b1f4b
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
     1
'From Smalltalk/X, Version:2.10.4 on 8-mar-1995 at 22:37:26'!
2911230f8e8e Initial revision
claus
parents:
diff changeset
     2
2911230f8e8e Initial revision
claus
parents:
diff changeset
     3
Object subclass:#ProfileTree
2911230f8e8e Initial revision
claus
parents:
diff changeset
     4
	 instanceVariableNames:'receiver selector class leafTally totalTally called isBlock'
2911230f8e8e Initial revision
claus
parents:
diff changeset
     5
	 classVariableNames:''
2911230f8e8e Initial revision
claus
parents:
diff changeset
     6
	 poolDictionaries:''
2911230f8e8e Initial revision
claus
parents:
diff changeset
     7
	 category:'System-Profiler'
2911230f8e8e Initial revision
claus
parents:
diff changeset
     8
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
     9
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    10
!ProfileTree class methodsFor:'documentation'!
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    11
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    12
documentation
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    13
"
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    14
    This is is used as a companion to MessageTally.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    15
    Instances of it are used to represent the calling tree.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    16
"
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    17
! !
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    18
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    19
!ProfileTree methodsFor:'prettyPrinting'!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    20
2911230f8e8e Initial revision
claus
parents:
diff changeset
    21
printOn:aStream indent:i
2911230f8e8e Initial revision
claus
parents:
diff changeset
    22
    selector notNil ifTrue:[
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    23
	aStream spaces:i.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    24
	self printSingleOn:aStream.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    25
	aStream cr.
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    26
    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
    27
2911230f8e8e Initial revision
claus
parents:
diff changeset
    28
    called notNil ifTrue:[
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    29
	called do:[:sub|
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    30
	    sub printOn:aStream indent:(i + 1)
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    31
	].
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    32
    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
    33
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    34
2911230f8e8e Initial revision
claus
parents:
diff changeset
    35
printOn:aStream
2911230f8e8e Initial revision
claus
parents:
diff changeset
    36
    |s|
2911230f8e8e Initial revision
claus
parents:
diff changeset
    37
2911230f8e8e Initial revision
claus
parents:
diff changeset
    38
"/    self printOn:aStream indent:0
2911230f8e8e Initial revision
claus
parents:
diff changeset
    39
    s := WriteStream on:String new.
2911230f8e8e Initial revision
claus
parents:
diff changeset
    40
    self printOn:s indent:0.
2911230f8e8e Initial revision
claus
parents:
diff changeset
    41
2911230f8e8e Initial revision
claus
parents:
diff changeset
    42
    aStream nextPutAll:s contents
2911230f8e8e Initial revision
claus
parents:
diff changeset
    43
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    44
2911230f8e8e Initial revision
claus
parents:
diff changeset
    45
printSingleOn:aStream
2911230f8e8e Initial revision
claus
parents:
diff changeset
    46
    selector notNil ifTrue:[
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    47
	isBlock == true ifTrue:[
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    48
	    '[] in ' printOn:aStream
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    49
	].
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    50
	receiver name printOn:aStream.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    51
	(class notNil and:[class ~~ receiver class]) ifTrue:[
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    52
	    '>>' printOn:aStream.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    53
	    class name printOn:aStream
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    54
	].
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    55
	aStream space.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    56
	selector printOn:aStream.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    57
	aStream space.
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    58
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    59
	aStream nextPutAll:'(total '.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    60
	totalTally printOn:aStream.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    61
	aStream nextPutAll:'%)'.
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    62
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    63
	leafTally notNil ifTrue:[
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    64
	    aStream nextPutAll:'(leaf '.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    65
	    leafTally printOn:aStream.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    66
	    aStream nextPutAll:'%)'.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    67
	].
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    68
    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
    69
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    70
2911230f8e8e Initial revision
claus
parents:
diff changeset
    71
printLeafsOn:aStream
2911230f8e8e Initial revision
claus
parents:
diff changeset
    72
    |leafNodes|
2911230f8e8e Initial revision
claus
parents:
diff changeset
    73
2911230f8e8e Initial revision
claus
parents:
diff changeset
    74
    leafNodes := OrderedCollection new.
2911230f8e8e Initial revision
claus
parents:
diff changeset
    75
    self addLeafNodesTo:leafNodes.
2911230f8e8e Initial revision
claus
parents:
diff changeset
    76
    leafNodes := leafNodes asSortedCollection:[:a :b |
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    77
					a leafTally < b leafTally].
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    78
    leafNodes do:[:aNode |
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    79
	aNode printSingleOn:aStream.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
    80
	aStream cr.
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
    81
    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
    82
! !
2911230f8e8e Initial revision
claus
parents:
diff changeset
    83
2911230f8e8e Initial revision
claus
parents:
diff changeset
    84
!ProfileTree methodsFor:'accessing'!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    85
2911230f8e8e Initial revision
claus
parents:
diff changeset
    86
selector 
2911230f8e8e Initial revision
claus
parents:
diff changeset
    87
    ^ selector
2911230f8e8e Initial revision
claus
parents:
diff changeset
    88
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    89
2911230f8e8e Initial revision
claus
parents:
diff changeset
    90
called:aCollection
2911230f8e8e Initial revision
claus
parents:
diff changeset
    91
    called := aCollection
2911230f8e8e Initial revision
claus
parents:
diff changeset
    92
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    93
2911230f8e8e Initial revision
claus
parents:
diff changeset
    94
methodClass 
2911230f8e8e Initial revision
claus
parents:
diff changeset
    95
    ^ class 
2911230f8e8e Initial revision
claus
parents:
diff changeset
    96
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
    97
2911230f8e8e Initial revision
claus
parents:
diff changeset
    98
isBlock:aBoolean
2911230f8e8e Initial revision
claus
parents:
diff changeset
    99
    isBlock  := aBoolean
2911230f8e8e Initial revision
claus
parents:
diff changeset
   100
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   101
2911230f8e8e Initial revision
claus
parents:
diff changeset
   102
receiver
2911230f8e8e Initial revision
claus
parents:
diff changeset
   103
    ^ receiver
2911230f8e8e Initial revision
claus
parents:
diff changeset
   104
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   105
2911230f8e8e Initial revision
claus
parents:
diff changeset
   106
called
2911230f8e8e Initial revision
claus
parents:
diff changeset
   107
    ^ called
2911230f8e8e Initial revision
claus
parents:
diff changeset
   108
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   109
2911230f8e8e Initial revision
claus
parents:
diff changeset
   110
leafTally
2911230f8e8e Initial revision
claus
parents:
diff changeset
   111
    ^ leafTally
2911230f8e8e Initial revision
claus
parents:
diff changeset
   112
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   113
2911230f8e8e Initial revision
claus
parents:
diff changeset
   114
receiver:r selector:s class:cls 
2911230f8e8e Initial revision
claus
parents:
diff changeset
   115
    receiver := r.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   116
    selector := s.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   117
    class := cls
2911230f8e8e Initial revision
claus
parents:
diff changeset
   118
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   119
2911230f8e8e Initial revision
claus
parents:
diff changeset
   120
totalTally
2911230f8e8e Initial revision
claus
parents:
diff changeset
   121
    ^ totalTally
2911230f8e8e Initial revision
claus
parents:
diff changeset
   122
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   123
2911230f8e8e Initial revision
claus
parents:
diff changeset
   124
isBlock 
2911230f8e8e Initial revision
claus
parents:
diff changeset
   125
    ^ isBlock 
2911230f8e8e Initial revision
claus
parents:
diff changeset
   126
! !
2911230f8e8e Initial revision
claus
parents:
diff changeset
   127
2911230f8e8e Initial revision
claus
parents:
diff changeset
   128
!ProfileTree methodsFor:'adding info'!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   129
2911230f8e8e Initial revision
claus
parents:
diff changeset
   130
computePercentage:total
2911230f8e8e Initial revision
claus
parents:
diff changeset
   131
    totalTally := (totalTally / total * 1000) rounded / 10.0.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   132
    leafTally notNil ifTrue:[
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   133
	leafTally := (leafTally / total * 1000) rounded / 10.0
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   134
    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   135
2911230f8e8e Initial revision
claus
parents:
diff changeset
   136
    called notNil ifTrue:[
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   137
	called do:[:subTree |
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   138
	    subTree computePercentage:total
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   139
	]
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   140
    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   141
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   142
2911230f8e8e Initial revision
claus
parents:
diff changeset
   143
addChain:aCallChain
2911230f8e8e Initial revision
claus
parents:
diff changeset
   144
    |node found subTree chain called|
2911230f8e8e Initial revision
claus
parents:
diff changeset
   145
2911230f8e8e Initial revision
claus
parents:
diff changeset
   146
    node := self.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   147
    chain := aCallChain.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   148
2911230f8e8e Initial revision
claus
parents:
diff changeset
   149
    [chain notNil] whileTrue:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   150
	node incrementTotalTally.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   151
2911230f8e8e Initial revision
claus
parents:
diff changeset
   152
	found := false.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   153
	(called := node called) notNil ifTrue:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   154
	    called do:[:subTree |
2911230f8e8e Initial revision
claus
parents:
diff changeset
   155
		found ifFalse:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   156
		    (chain = subTree) ifTrue:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   157
			node := subTree.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   158
			chain := chain rest.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   159
			found := true
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
	] ifFalse:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   164
	    node called:(OrderedCollection new)
2911230f8e8e Initial revision
claus
parents:
diff changeset
   165
	].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   166
	found ifFalse:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   167
	    subTree := ProfileTree new.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   168
	    subTree receiver:chain receiver
2911230f8e8e Initial revision
claus
parents:
diff changeset
   169
		    selector:chain selector
2911230f8e8e Initial revision
claus
parents:
diff changeset
   170
		       class:chain methodClass.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   171
	    subTree isBlock:(chain isBlock).
2911230f8e8e Initial revision
claus
parents:
diff changeset
   172
2911230f8e8e Initial revision
claus
parents:
diff changeset
   173
	    node called add:subTree.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   174
	    node := subTree.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   175
	    chain := chain rest
2911230f8e8e Initial revision
claus
parents:
diff changeset
   176
	]
2911230f8e8e Initial revision
claus
parents:
diff changeset
   177
2911230f8e8e Initial revision
claus
parents:
diff changeset
   178
    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   179
2911230f8e8e Initial revision
claus
parents:
diff changeset
   180
    node incrementTotalTally.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   181
    node incrementLeafTally.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   182
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   183
2911230f8e8e Initial revision
claus
parents:
diff changeset
   184
incrementTotalTally
2911230f8e8e Initial revision
claus
parents:
diff changeset
   185
    totalTally isNil ifTrue:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   186
	totalTally := 1
2911230f8e8e Initial revision
claus
parents:
diff changeset
   187
    ] ifFalse:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   188
	totalTally := totalTally + 1.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   189
    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   190
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   191
2911230f8e8e Initial revision
claus
parents:
diff changeset
   192
leafTally:aCount
2911230f8e8e Initial revision
claus
parents:
diff changeset
   193
    leafTally := aCount
2911230f8e8e Initial revision
claus
parents:
diff changeset
   194
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   195
2911230f8e8e Initial revision
claus
parents:
diff changeset
   196
incrementLeafTally
2911230f8e8e Initial revision
claus
parents:
diff changeset
   197
    leafTally isNil ifTrue:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   198
	leafTally := 1
2911230f8e8e Initial revision
claus
parents:
diff changeset
   199
    ] ifFalse:[
2911230f8e8e Initial revision
claus
parents:
diff changeset
   200
	leafTally := leafTally + 1.
2911230f8e8e Initial revision
claus
parents:
diff changeset
   201
    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   202
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   203
2911230f8e8e Initial revision
claus
parents:
diff changeset
   204
totalTally:aCount
2911230f8e8e Initial revision
claus
parents:
diff changeset
   205
    totalTally := aCount
2911230f8e8e Initial revision
claus
parents:
diff changeset
   206
! !
2911230f8e8e Initial revision
claus
parents:
diff changeset
   207
2911230f8e8e Initial revision
claus
parents:
diff changeset
   208
!ProfileTree methodsFor:'private'!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   209
2911230f8e8e Initial revision
claus
parents:
diff changeset
   210
addLeafNodesTo:aCollection
2911230f8e8e Initial revision
claus
parents:
diff changeset
   211
    |idx|
2911230f8e8e Initial revision
claus
parents:
diff changeset
   212
2911230f8e8e Initial revision
claus
parents:
diff changeset
   213
    leafTally notNil ifTrue:[
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   214
	idx := aCollection  indexOf:self.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   215
	idx == 0 ifTrue:[
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   216
	    aCollection add:self copy
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   217
	] ifFalse:[
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   218
	    |nd|
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   219
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   220
	    nd := aCollection at:idx.
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   221
	    nd leafTally:(nd leafTally + leafTally).
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   222
	    nd totalTally:(nd totalTally max: totalTally)
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   223
	]
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   224
    ].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   225
    called notNil ifTrue:[
23
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   226
	called do:[:aNode |
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   227
	    aNode addLeafNodesTo:aCollection
a85cd774be98 *** empty log message ***
claus
parents: 22
diff changeset
   228
	]
22
2911230f8e8e Initial revision
claus
parents:
diff changeset
   229
    ]
2911230f8e8e Initial revision
claus
parents:
diff changeset
   230
!
2911230f8e8e Initial revision
claus
parents:
diff changeset
   231
2911230f8e8e Initial revision
claus
parents:
diff changeset
   232
= aProfileTreeNode
2911230f8e8e Initial revision
claus
parents:
diff changeset
   233
    receiver ~= aProfileTreeNode receiver ifTrue:[^ false].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   234
    selector ~~ aProfileTreeNode selector ifTrue:[^ false].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   235
    class ~~ aProfileTreeNode methodClass ifTrue:[^ false].
2911230f8e8e Initial revision
claus
parents:
diff changeset
   236
    ^ true
2911230f8e8e Initial revision
claus
parents:
diff changeset
   237
! !