MemoryMonitor.st
author Claus Gittinger <cg@exept.de>
Thu, 23 Jan 1997 22:39:55 +0100
changeset 989 0f047353b974
parent 972 7f8884cb99e2
child 994 1734123c7520
permissions -rw-r--r--
need a lock while drawing (especially: while waiting for exposes)
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
45
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
     1
"
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
     2
 COPYRIGHT (c) 1991 by Claus Gittinger
45
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
     3
	      All Rights Reserved
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
     4
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
     5
 This software is furnished under a license and may be used
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
     6
 only in accordance with the terms of that license and with the
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
     8
 be provided or otherwise made available to, or used by, any
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
     9
 other person.  No title to or ownership of the software is
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
    10
 hereby transferred.
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
    11
"
19
4cde336c0794 Initial revision
claus
parents:
diff changeset
    12
4cde336c0794 Initial revision
claus
parents:
diff changeset
    13
StandardSystemView subclass:#MemoryMonitor
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
    14
	instanceVariableNames:'updateInterval updateBlock myProcess oldData newData freeData
93
claus
parents: 91
diff changeset
    15
		updateIndex org maxTotal minTotal dX newColor freeColor oldColor
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
    16
		prevTotal prevFree prevFree2 prevOld scale drawLock'
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
    17
	classVariableNames:''
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
    18
	poolDictionaries:''
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
    19
	category:'Interface-Tools'
19
4cde336c0794 Initial revision
claus
parents:
diff changeset
    20
!
4cde336c0794 Initial revision
claus
parents:
diff changeset
    21
798
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
    22
!MemoryMonitor class methodsFor:'documentation'!
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    23
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    24
copyright
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    25
"
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    26
 COPYRIGHT (c) 1991 by Claus Gittinger
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    27
	      All Rights Reserved
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    28
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    29
 This software is furnished under a license and may be used
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    30
 only in accordance with the terms of that license and with the
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    31
 inclusion of the above copyright notice.   This software may not
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    32
 be provided or otherwise made available to, or used by, any
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    33
 other person.  No title to or ownership of the software is
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    34
 hereby transferred.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    35
"
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    36
!
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    37
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    38
documentation
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    39
"
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    40
    Shows memory usage (oldspace + newspace). Simple, but useful.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    41
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    42
    The numbers shown are:
512
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    43
        tot     total memory usage (i.e. allocated oldSpace + allocated newSpace)
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    44
                (does not include the second semispace and other help-areas,
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    45
                 such as the remembered set etc.)
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    46
512
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    47
        all     current oldSpace in use + newSpace in use
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    48
512
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    49
        new     current newSpace in use
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    50
512
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    51
        frl     free space in (fragmented) free lists
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    52
        fre     compact free area above the used oldSpace
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    53
512
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    54
        old     current oldSpace in use
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    55
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
    56
        cod     dynamic compiled code space size (just in time compiler)
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
    57
512
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    58
        max,    extreme values of 'tot' since the monitor started
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    59
        min     (can be reset by typing 'r' in the view)
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    60
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
    61
        t       tenure threshold (1 .. 30)
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    62
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
    63
        I       incremental GC state (2 = idle)
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    64
512
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    65
        weak    number of weak objects
109
claus
parents: 108
diff changeset
    66
512
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    67
        rem     size of rememberedSet
108
claus
parents: 107
diff changeset
    68
512
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    69
        minsc:  percent of newspace remaining after scavenge (worst case)
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    70
                (i.e. the minimum %% of scavenged objects)
108
claus
parents: 107
diff changeset
    71
512
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    72
        count   number of scavenges since system started
108
claus
parents: 107
diff changeset
    73
512
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    74
        %       percentage of live objects in newSpace after last scavenge
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    75
                (i.e. this is the garbage vs. living objects ratio of
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    76
                 newSpace objects after the last scavenge)
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
    77
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    78
    the graphic shows:
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
    79
        orange  newSpace used
512
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    80
        green   free memory in freeLists
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    81
        white   oldSpace used
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
    82
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
    83
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
    84
    the popupMenu offers GC functions; keyboard options are:
512
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    85
        'f' -> faster; 's' -> slower; 'r' -> reset min/max
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    86
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    87
    [author:]
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    88
        Claus Gittinger
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    89
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    90
    [see also:]
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    91
        ObjectMemory
b576020aa9be documentation
Claus Gittinger <cg@exept.de>
parents: 469
diff changeset
    92
        MemoryUsageMonitor ProcessMonitor
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    93
"
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    94
! !
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    95
798
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
    96
!MemoryMonitor class methodsFor:'defaults'!
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    97
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    98
defaultExtent
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
    99
    ^ (200 @ 320)
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   100
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   101
    "Modified: 24.8.1996 / 12:04:21 / cg"
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   102
!
19
4cde336c0794 Initial revision
claus
parents:
diff changeset
   103
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   104
defaultIcon
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   105
    |i|
19
4cde336c0794 Initial revision
claus
parents:
diff changeset
   106
93
claus
parents: 91
diff changeset
   107
    i := Image fromFile:'MemMonitor.xbm'.
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   108
    i notNil ifTrue:[^ i].
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   109
    ^ super defaultIcon
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   110
!
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   111
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   112
defaultLabel
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   113
    ^ 'Memory Monitor'
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   114
! !
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   115
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   116
!MemoryMonitor methodsFor:'destroying'!
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   117
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   118
destroy
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   119
    updateBlock notNil ifTrue:[
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   120
	Processor removeTimedBlock:updateBlock.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   121
    ] ifFalse:[
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   122
	myProcess terminate.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   123
	myProcess := nil
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   124
    ].
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   125
    oldData := newData := freeData := nil.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   126
    super destroy
19
4cde336c0794 Initial revision
claus
parents:
diff changeset
   127
! !
4cde336c0794 Initial revision
claus
parents:
diff changeset
   128
4cde336c0794 Initial revision
claus
parents:
diff changeset
   129
!MemoryMonitor methodsFor:'drawing'!
4cde336c0794 Initial revision
claus
parents:
diff changeset
   130
798
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
   131
displayKilo:aNumber name:nm y:y
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
   132
    |s|
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
   133
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
   134
    s := nm , ((aNumber // 1024) printStringLeftPaddedTo:5) , 'k '.
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
   135
    self displayOpaqueString:s x:0 y:y.
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
   136
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
   137
!
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
   138
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   139
redraw
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   140
    "redraw all"
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   141
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   142
    self clear.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   143
    self redrawX:0 y:0 width:width height:height
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   144
!
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   145
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   146
redrawX:x y:y width:w height:h
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   147
    "redraw data"
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   148
107
claus
parents: 105
diff changeset
   149
    |total oldSpaceUsed newSpaceUsed freeMem lx startIdx endIdx
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   150
     right|
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   151
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   152
    shown ifFalse:[^ self].
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   153
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   154
    right := x + w - 1.
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   155
    right >= org ifTrue:[
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   156
	lx := x.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   157
	lx < org ifTrue:[
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   158
	    lx := org
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   159
	].
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   160
91
claus
parents: 85
diff changeset
   161
	total := ObjectMemory symSpaceSize 
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   162
		 + ObjectMemory oldSpaceSize 
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   163
		 + ObjectMemory newSpaceSize.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   164
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   165
	startIdx := (lx-org+1).
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   166
	startIdx < 1 ifTrue:[
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   167
	    startIdx := 1
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   168
	].
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   169
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   170
	endIdx := right-org+1.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   171
	endIdx >= updateIndex ifTrue:[
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   172
	    endIdx := updateIndex-1.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   173
	].
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   174
	dX := 0.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   175
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   176
	startIdx to:endIdx do:[:i |
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   177
	    newSpaceUsed := newData at:i.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   178
	    newSpaceUsed notNil ifTrue:[
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   179
		oldSpaceUsed := oldData at:i.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   180
		freeMem := freeData at:i.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   181
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   182
		self updateLineX:lx - dX
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   183
		       total:total 
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   184
		       old:oldSpaceUsed 
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   185
		       new:newSpaceUsed 
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   186
		       free:freeMem.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   187
	    ].
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   188
	    lx := lx + 1
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   189
	]
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   190
    ].
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   191
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   192
    x < org ifTrue:[
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   193
	prevFree := prevFree2 := prevOld := prevTotal := nil.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   194
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   195
	self updateNumbers.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   196
    ]
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   197
!
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   198
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   199
updateDisplay
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   200
    "update picture; trigger next update"
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   201
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   202
    |total oldSpaceUsed newSpaceUsed freeMem oldSpaceSize
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   203
     gWidth shift scaleChange margin mustWait|
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   204
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   205
    shown ifTrue:[
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   206
        drawLock wouldBlock ifFalse:[
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   207
            drawLock critical:[
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   208
                oldSpaceUsed := ObjectMemory oldSpaceUsed + ObjectMemory symSpaceUsed.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   209
                newSpaceUsed := ObjectMemory newSpaceUsed.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   210
                freeMem := ObjectMemory freeListSpace + (ObjectMemory oldSpaceSize - ObjectMemory oldSpaceUsed).
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   211
                oldSpaceSize := ObjectMemory oldSpaceSize + ObjectMemory symSpaceSize.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   212
                total := oldSpaceSize + ObjectMemory newSpaceSize.
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   213
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   214
                scaleChange := false.
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   215
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   216
                ((total - freeMem) < minTotal) ifTrue:[
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   217
                    minTotal := total - freeMem.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   218
                    scaleChange := true
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   219
                ].
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   220
                (total > maxTotal) ifTrue:[
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   221
                    maxTotal := total.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   222
                    scaleChange := true
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   223
                ].
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   224
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   225
                oldData at:updateIndex put:oldSpaceSize. "/ oldSpaceUsed.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   226
                newData at:updateIndex put:newSpaceUsed.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   227
                freeData at:updateIndex put:freeMem.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   228
                updateIndex := updateIndex + 1.
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   229
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   230
                scaleChange ifTrue:[
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   231
                    scale := height asFloat / (maxTotal + 100000).
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   232
                    self redraw
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   233
                ].
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   234
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   235
                gWidth := width - org.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   236
                margin := 1.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   237
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   238
                mustWait := false.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   239
                ((updateIndex-1) >= (gWidth - margin)) ifTrue:[
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   240
        "on slow displays, use:"
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   241
        "/            shift := gWidth // 4.
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   242
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   243
        "for smooth display, use:"
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   244
                    shift := 1.
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   245
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   246
                    oldData replaceFrom:1 with:oldData startingAt:shift+1.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   247
                    newData replaceFrom:1 with:newData startingAt:shift+1.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   248
                    freeData replaceFrom:1 with:freeData startingAt:shift+1.
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   249
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   250
                    updateIndex := updateIndex - shift.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   251
                    dX := dX + shift.
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   252
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   253
                    self catchExpose.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   254
                    self copyFrom:self 
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   255
                                x:(org + shift) y:0
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   256
                              toX:org y:0
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   257
                            width:(gWidth - shift - margin)
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   258
                           height:height.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   259
                    self clearRectangleX:(width - margin - shift) y:0 
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   260
                                   width:shift height:height.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   261
                    mustWait := true.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   262
                ].
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   263
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   264
                self updateLineX:(updateIndex - 1 + org - 1)
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   265
                           total:total 
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   266
                           old:oldSpaceSize "/ oldSpaceUsed
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   267
                           new:newSpaceUsed 
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   268
                           free:freeMem.
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   269
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   270
                self updateNumbers.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   271
                self flush.
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   272
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   273
                mustWait ifTrue:[
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   274
                    self waitForExpose.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   275
                ]
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   276
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   277
            ].
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   278
        ].
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   279
    ].
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   280
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   281
    updateBlock notNil ifTrue:[
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   282
        Processor addTimedBlock:updateBlock afterSeconds:updateInterval
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   283
    ].
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   284
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   285
    "Modified: 23.1.1997 / 22:38:08 / cg"
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   286
!
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   287
109
claus
parents: 108
diff changeset
   288
updateLineX:x total:total old:oldSpaceSize new:newSpaceUsed free:freeMem
claus
parents: 108
diff changeset
   289
    |hNew hOld hFree y1 y2 y3|
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   290
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   291
    hNew := (newSpaceUsed * scale) asInteger.
109
claus
parents: 108
diff changeset
   292
    hOld := (oldSpaceSize * scale) // 2.
claus
parents: 108
diff changeset
   293
    hFree := (freeMem * scale) // 2.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   294
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   295
    y1 := height - 1.
109
claus
parents: 108
diff changeset
   296
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   297
    y2 := y1 - hOld.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   298
    self paint:oldColor.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   299
    self displayLineFromX:x y:y1 toX:x y:y2.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   300
109
claus
parents: 108
diff changeset
   301
    y3 := y1 - hFree.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   302
    self paint:freeColor.
109
claus
parents: 108
diff changeset
   303
    self displayLineFromX:x y:y1 toX:x y:y3.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   304
109
claus
parents: 108
diff changeset
   305
    y1 := y2 - hNew.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   306
    self paint:newColor.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   307
    self displayLineFromX:x y:y1 toX:x y:y2.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   308
!
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   309
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   310
updateNumbers
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   311
    "redraw numbers.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   312
     The values shown are:
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   313
        max:    maximum memory used since monitor started
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   314
        min:    minimum memory used since monitor started
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   315
        tot:    total memory used (overall oldSpace + overall newSpace)
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   316
        all:    current memory in use (oldSpace + newSpace)
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   317
        new:    current newSpace in use
735
600fe3dab131 comment
Claus Gittinger <cg@exept.de>
parents: 696
diff changeset
   318
        fre:    current size of freelist in oldSpace
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   319
        old:    current oldSpace in use
735
600fe3dab131 comment
Claus Gittinger <cg@exept.de>
parents: 696
diff changeset
   320
        code:   current just-in-time compiled code cache size
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   321
        t:      current tenure age
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   322
        I:      IGC state
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   323
        weak:   number of weak arrays in the system
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   324
        rem     remembered set size
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   325
        lrem    lifo remembered set size
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   326
        minsc:  percent of newspace remaining after scavenge (worst case)
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   327
        irq:    max. interrupt delay
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   328
        count of scavenges / last scavenge survivor rate
156
e6a7f80e2a71 show irq latency
Claus Gittinger <cg@exept.de>
parents: 128
diff changeset
   329
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   330
    "
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   331
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   332
    |oldSpaceSize newSpaceSize memUsed oldMemUsed newMemUsed freeMem free2 
107
claus
parents: 105
diff changeset
   333
     y half s fontHeight total n|
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   334
91
claus
parents: 85
diff changeset
   335
    oldMemUsed := ObjectMemory oldSpaceUsed + ObjectMemory symSpaceUsed.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   336
    newMemUsed := ObjectMemory newSpaceUsed.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   337
    freeMem := ObjectMemory freeListSpace.
91
claus
parents: 85
diff changeset
   338
    oldSpaceSize := ObjectMemory oldSpaceSize + ObjectMemory symSpaceSize.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   339
    newSpaceSize := ObjectMemory newSpaceSize.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   340
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   341
    memUsed := oldMemUsed + newMemUsed "- freeMem".
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   342
    total := oldSpaceSize + newSpaceSize.
68
b70257a99e48 *** empty log message ***
claus
parents: 61
diff changeset
   343
    free2 := ObjectMemory freeSpace.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   344
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   345
    self paint:White on:Black.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   346
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   347
    fontHeight := font height + font descent.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   348
    half := height // 2 + font descent.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   349
109
claus
parents: 108
diff changeset
   350
    y := half - (fontHeight * 5).
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   351
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   352
    total ~~ prevTotal ifTrue:[
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   353
        ((total - freeMem) < minTotal) ifTrue:[
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   354
            minTotal := total - freeMem.
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   355
        ].
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   356
        (total > maxTotal) ifTrue:[
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   357
            maxTotal := total.
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   358
        ].
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   359
798
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
   360
        self displayKilo:maxTotal name:'max ' y:font ascent.
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
   361
        self displayKilo:minTotal name:'min ' y:(height - font descent).
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
   362
        self displayKilo:total    name:'tot ' y:y.
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   363
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   364
        prevTotal := total.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   365
    ].
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   366
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   367
    y := y + fontHeight.
798
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
   368
    self displayKilo:memUsed name:'all ' y:y.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   369
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   370
    y := y + fontHeight.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   371
    self paint:newColor.
798
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
   372
    self displayKilo:newMemUsed name:'new ' y:y.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   373
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   374
    y := y + fontHeight.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   375
    freeMem ~~ prevFree ifTrue:[
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   376
        self paint:freeColor.
798
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
   377
        self displayKilo:freeMem name:'frl ' y:y.
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   378
        prevFree := freeMem.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   379
    ].
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   380
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   381
    y := y + fontHeight.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   382
    free2 ~~ prevFree2 ifTrue:[
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   383
        self paint:freeColor.
798
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
   384
        self displayKilo:free2 name:'fre ' y:y.
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   385
        prevFree2 := free2.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   386
    ].
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   387
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   388
    y := y + fontHeight.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   389
    (oldMemUsed - freeMem) ~~ prevOld ifTrue:[
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   390
        self paint:oldColor.
798
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
   391
        self displayKilo:(oldMemUsed - freeMem) name:'old ' y:y.
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   392
        prevOld := (oldMemUsed - freeMem).
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   393
    ].
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   394
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   395
    ObjectMemory supportsJustInTimeCompilation ifTrue:[
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   396
        y := y + fontHeight.
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   397
        self paint:oldColor.
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   398
        n := ObjectMemory compiledCodeSpaceUsed.
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   399
        n > 9999 ifTrue:[
735
600fe3dab131 comment
Claus Gittinger <cg@exept.de>
parents: 696
diff changeset
   400
            s := 'code ' , ((n // 1024) printStringLeftPaddedTo:4) , 'k'.
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   401
        ] ifFalse:[
735
600fe3dab131 comment
Claus Gittinger <cg@exept.de>
parents: 696
diff changeset
   402
            s := 'code ' , (n printStringLeftPaddedTo:4) , ' '.
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   403
        ].
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   404
        self displayOpaqueString:s x:0 y:y.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   405
    ].
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   406
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   407
    "
303
1d94813f1977 interest is written with one 'r' (shame on me)
Claus Gittinger <cg@exept.de>
parents: 168
diff changeset
   408
     the following is internal - normally only interesting when debugging the VM
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   409
    "
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   410
    y := y + fontHeight.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   411
    self paint:oldColor.
60
claus
parents: 57
diff changeset
   412
    s := 't:' , (ObjectMemory tenureAge printStringLeftPaddedTo:2) , ' '.
108
claus
parents: 107
diff changeset
   413
    s := s , ' I:' , (ObjectMemory incrementalGCPhase printStringLeftPaddedTo:2) , ' '.
claus
parents: 107
diff changeset
   414
    self displayOpaqueString:s x:0 y:y.
claus
parents: 107
diff changeset
   415
claus
parents: 107
diff changeset
   416
    y := y + fontHeight.
109
claus
parents: 108
diff changeset
   417
    s := 'weak: ' , (ObjectMemory numberOfWeakObjects printStringLeftPaddedTo:4).
claus
parents: 108
diff changeset
   418
    self displayOpaqueString:s x:0 y:y.
claus
parents: 108
diff changeset
   419
claus
parents: 108
diff changeset
   420
    y := y + fontHeight.
108
claus
parents: 107
diff changeset
   421
    s := 'rem: ' , (ObjectMemory rememberedSetSize printStringLeftPaddedTo:5).
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   422
    self displayOpaqueString:s x:0 y:y.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   423
109
claus
parents: 108
diff changeset
   424
    y := y + fontHeight.
claus
parents: 108
diff changeset
   425
    s := 'lrem: ' , (ObjectMemory lifoRememberedSetSize printStringLeftPaddedTo:4 ifLarger:['****']).
claus
parents: 108
diff changeset
   426
    self displayOpaqueString:s x:0 y:y.
claus
parents: 108
diff changeset
   427
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   428
"/ does no longer make sense to show ....
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   429
"/    y := y + fontHeight.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   430
"/    ObjectMemory runsSingleOldSpace ifTrue:[
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   431
"/        self displayOpaqueString:'single' x:0 y:(half + (fontHeight*4)).
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   432
"/    ].
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   433
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   434
    y := y + fontHeight.
108
claus
parents: 107
diff changeset
   435
    n := ObjectMemory minScavengeReclamation / ObjectMemory newSpaceSize * 100.0.
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   436
    n := 100 - n asInteger.
108
claus
parents: 107
diff changeset
   437
    s := 'minSc ', (n printStringLeftPaddedTo:3) , '%'.
claus
parents: 107
diff changeset
   438
    self displayOpaqueString:s x:0 y:y.
claus
parents: 107
diff changeset
   439
claus
parents: 107
diff changeset
   440
    y := y + fontHeight.
157
77f56399cc5f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 156
diff changeset
   441
    n := ObjectMemory maxInterruptLatency.
156
e6a7f80e2a71 show irq latency
Claus Gittinger <cg@exept.de>
parents: 128
diff changeset
   442
    n notNil ifTrue:[
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   443
        s := 'irq ', (n printStringLeftPaddedTo:3) , ' ms'.
156
e6a7f80e2a71 show irq latency
Claus Gittinger <cg@exept.de>
parents: 128
diff changeset
   444
    ] ifFalse:[
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   445
        s := ''
156
e6a7f80e2a71 show irq latency
Claus Gittinger <cg@exept.de>
parents: 128
diff changeset
   446
    ].
e6a7f80e2a71 show irq latency
Claus Gittinger <cg@exept.de>
parents: 128
diff changeset
   447
    self displayOpaqueString:s x:0 y:y.
e6a7f80e2a71 show irq latency
Claus Gittinger <cg@exept.de>
parents: 128
diff changeset
   448
e6a7f80e2a71 show irq latency
Claus Gittinger <cg@exept.de>
parents: 128
diff changeset
   449
    y := y + fontHeight.
108
claus
parents: 107
diff changeset
   450
    n := ObjectMemory lastScavengeReclamation / ObjectMemory newSpaceSize * 100.0.
claus
parents: 107
diff changeset
   451
    n := 100 - n asInteger.
claus
parents: 107
diff changeset
   452
    s := (ObjectMemory scavengeCount printStringLeftPaddedTo:6)
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   453
         , (n printStringLeftPaddedTo:3) , '%'.
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   454
    self displayOpaqueString:s x:0 y:y.
156
e6a7f80e2a71 show irq latency
Claus Gittinger <cg@exept.de>
parents: 128
diff changeset
   455
e6a7f80e2a71 show irq latency
Claus Gittinger <cg@exept.de>
parents: 128
diff changeset
   456
    "Created: 7.11.1995 / 14:48:16 / cg"
696
b55f8705bb41 show memory use of dynamic code cache
Claus Gittinger <cg@exept.de>
parents: 517
diff changeset
   457
    "Modified: 24.8.1996 / 11:57:22 / cg"
19
4cde336c0794 Initial revision
claus
parents:
diff changeset
   458
! !
4cde336c0794 Initial revision
claus
parents:
diff changeset
   459
4cde336c0794 Initial revision
claus
parents:
diff changeset
   460
!MemoryMonitor methodsFor:'events'!
4cde336c0794 Initial revision
claus
parents:
diff changeset
   461
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   462
keyPress:key x:x y:y
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   463
    key == $f ifTrue:[
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   464
	"faster"
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   465
	updateInterval := updateInterval / 2
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   466
    ].
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   467
    key == $s ifTrue:[
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   468
	"slower"
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   469
	updateInterval := updateInterval * 2
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   470
    ].
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   471
    key == $r ifTrue:[
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   472
	"reset max"
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   473
	maxTotal := prevTotal.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   474
	scale := height asFloat / (maxTotal + 100000).
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   475
	self resetStatisticValues.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   476
	self redraw.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   477
    ]
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   478
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   479
    "Modified: 7.11.1995 / 17:45:13 / cg"
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   480
!
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   481
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   482
sizeChanged:how
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   483
    |nn no nf delta oldSize newSize|
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   484
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   485
    super sizeChanged:how.
19
4cde336c0794 Initial revision
claus
parents:
diff changeset
   486
45
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   487
    oldSize := oldData size.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   488
    newSize := width-org+1.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   489
168
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   490
    (newSize ~~ oldSize) ifTrue:[
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   491
	nn := Array new:newSize.
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   492
	no := Array new:newSize.
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   493
	nf := Array new:newSize.
45
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   494
168
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   495
	(newSize > oldSize) ifTrue:[
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   496
	    nn replaceFrom:1 to:oldSize with:newData.
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   497
	    no replaceFrom:1 to:oldSize with:oldData.
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   498
	    nf replaceFrom:1 to:oldSize with:freeData
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   499
	] ifFalse:[
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   500
	    delta := (oldSize - newSize).
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   501
	    nn replaceFrom:1 with:newData startingAt:delta+1.
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   502
	    no replaceFrom:1 with:oldData startingAt:delta+1.
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   503
	    nf replaceFrom:1 with:freeData startingAt:delta+1.
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   504
	    updateIndex > newSize ifTrue:[
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   505
		updateIndex := updateIndex - delta.
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   506
	    ]
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   507
	].
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   508
	newData := nn.
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   509
	oldData := no.
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   510
	freeData := nf.
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   511
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   512
	scale := height asFloat / (maxTotal + 100000).
19
4cde336c0794 Initial revision
claus
parents:
diff changeset
   513
    ].
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   514
    self clear.
168
0ca5ca046b22 Redraw text on vertical window size changes.
Stefan Vogel <sv@exept.de>
parents: 165
diff changeset
   515
    self redraw.
19
4cde336c0794 Initial revision
claus
parents:
diff changeset
   516
! !
45
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   517
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   518
!MemoryMonitor methodsFor:'initialization'!
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   519
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   520
initialize
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   521
    super initialize.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   522
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   523
    drawLock := Semaphore forMutualExclusion.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   524
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   525
    updateInterval := 0.5.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   526
    ProcessorScheduler isPureEventDriven ifTrue:[
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   527
        updateBlock := [self updateDisplay].
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   528
    ].
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   529
    oldData := Array new:1000.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   530
    newData := Array new:1000.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   531
    freeData := Array new:1000.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   532
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   533
    updateIndex := 1.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   534
    org := font widthOf:'max 99999k'.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   535
    level := 0.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   536
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   537
    maxTotal := minTotal := ObjectMemory oldSpaceSize 
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   538
                            + ObjectMemory symSpaceSize
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   539
                            + ObjectMemory newSpaceSize.
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   540
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   541
    viewBackground := Black.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   542
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   543
    device hasColors ifTrue:[
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   544
        newColor := Color orange. "/ yellow.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   545
        freeColor := Color green.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   546
        oldColor := Color white.
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   547
    ] ifFalse:[
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   548
        newColor := Color grey:67.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   549
        freeColor := Color grey:33.
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   550
        oldColor := Color white.
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   551
    ].
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   552
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   553
    self font:(Font family:'courier' face:'medium' style:'roman' size:10).
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   554
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   555
    self model:self.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   556
    self menu:#memoryMenu
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   557
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   558
    "
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   559
     MemoryMonitor open
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   560
    "
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   561
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   562
    "Modified: 23.1.1997 / 22:37:06 / cg"
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   563
!
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   564
85
d9713a3ca092 *** empty log message ***
claus
parents: 79
diff changeset
   565
memoryMenu
323
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   566
    |m specialMenu labels selectors|
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   567
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   568
    labels :=    #(
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   569
                    'scavenge'
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   570
                    'tenure'
972
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   571
                    'hi prio incremental collect'
323
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   572
                    '-'
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   573
                    'cleanup memory'
844
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   574
                    'flush method history'
323
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   575
                    '-'
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   576
                    'compress sources'
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   577
                  ).
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   578
    selectors := #(
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   579
                    scavenge
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   580
                    tenure
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   581
                    incrementalCollect
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   582
                    nil
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   583
                    cleanupMemory
844
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   584
                    cleanupMethodHistory
323
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   585
                    nil
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   586
                    compressSources
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   587
                  ).
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   588
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   589
    specialMenu := PopUpMenu
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   590
                        labels:(resources array:labels)
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   591
                        selectors:selectors.
85
d9713a3ca092 *** empty log message ***
claus
parents: 79
diff changeset
   592
105
claus
parents: 93
diff changeset
   593
    device ctrlDown ifTrue:[
323
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   594
        ^ specialMenu
105
claus
parents: 93
diff changeset
   595
    ].
85
d9713a3ca092 *** empty log message ***
claus
parents: 79
diff changeset
   596
972
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   597
    ObjectMemory backgroundCollectorRunning ifFalse:[
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   598
        labels :=    #(
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   599
                        'collect garbage'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   600
                        'collect garbage & symbols'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   601
                        'collect garbage & compress'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   602
                        '-'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   603
                        'background collect now'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   604
                        'start background collector'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   605
                        '-'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   606
                        'reset statistic values'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   607
                        '-'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   608
                        'others'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   609
                      ).
323
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   610
972
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   611
        selectors := #(
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   612
                        garbageCollect
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   613
                        garbageCollectAndSymbols
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   614
                        compressingGarbageCollect
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   615
                        nil
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   616
                        backgroundCollect
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   617
                        restartBackgroundCollector
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   618
                        nil
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   619
                        resetStatisticValues
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   620
                        nil
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   621
                        otherMenu
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   622
                      ).
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   623
    ] ifTrue:[
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   624
        labels :=    #(
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   625
                        'collect garbage'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   626
                        'collect garbage & symbols'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   627
                        'collect garbage & compress'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   628
                        '-'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   629
                        'background collect'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   630
                        '-'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   631
                        'reset statistic values'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   632
                        '-'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   633
                        'others'
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   634
                      ).
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   635
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   636
        selectors := #(
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   637
                        garbageCollect
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   638
                        garbageCollectAndSymbols
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   639
                        compressingGarbageCollect
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   640
                        nil
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   641
                        backgroundCollect
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   642
                        nil
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   643
                        resetStatisticValues
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   644
                        nil
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   645
                        otherMenu
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   646
                      ).
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   647
    ].
323
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   648
    m := PopUpMenu labels:(resources array:labels)
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   649
                   selectors:selectors.
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   650
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   651
    m subMenuAt:#otherMenu put:specialMenu.
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   652
    ^ m
972
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   653
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   654
    "Modified: 21.1.1997 / 00:20:27 / cg"
85
d9713a3ca092 *** empty log message ***
claus
parents: 79
diff changeset
   655
!
d9713a3ca092 *** empty log message ***
claus
parents: 79
diff changeset
   656
45
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   657
realize
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   658
    super realize.
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   659
    updateBlock notNil ifTrue:[
93
claus
parents: 91
diff changeset
   660
	Processor addTimedBlock:updateBlock afterSeconds:updateInterval.
45
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   661
    ] ifFalse:[
93
claus
parents: 91
diff changeset
   662
	myProcess := [
claus
parents: 91
diff changeset
   663
	    |d|
45
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   664
93
claus
parents: 91
diff changeset
   665
	    [true] whileTrue:[
claus
parents: 91
diff changeset
   666
		(Delay forSeconds:updateInterval) wait.
claus
parents: 91
diff changeset
   667
		self updateDisplay
claus
parents: 91
diff changeset
   668
	    ]
claus
parents: 91
diff changeset
   669
	] forkAt:6.
claus
parents: 91
diff changeset
   670
	myProcess name:'monitor [' , 
claus
parents: 91
diff changeset
   671
		       Processor activeProcess id printString ,
claus
parents: 91
diff changeset
   672
		       '] update'
45
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   673
    ].
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   674
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   675
    newColor := newColor on:device.
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   676
    freeColor := freeColor on:device.
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   677
    oldColor := oldColor on:device.
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   678
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   679
    font := font on:device.
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   680
! !
950b84ba89e6 *** empty log message ***
claus
parents: 19
diff changeset
   681
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   682
!MemoryMonitor methodsFor:'menu functions'!
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   683
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   684
backgroundCollect
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   685
    "start a background (non disturbing) incremental GC. 
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   686
     Since the GC is performed at a low priority, it may not make progress if higher
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   687
     prio processes are running"
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   688
 
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   689
    [
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   690
	ObjectMemory incrementalGC
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   691
    ] forkAt:5 
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   692
!
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   693
105
claus
parents: 93
diff changeset
   694
cleanupMemory
claus
parents: 93
diff changeset
   695
    "let all classes release unneeded, cached
claus
parents: 93
diff changeset
   696
     data ..."
claus
parents: 93
diff changeset
   697
469
3653317928e2 dont repeat coding in ObjectMemory ...
Claus Gittinger <cg@exept.de>
parents: 360
diff changeset
   698
    ObjectMemory performLowSpaceCleanup.
3653317928e2 dont repeat coding in ObjectMemory ...
Claus Gittinger <cg@exept.de>
parents: 360
diff changeset
   699
105
claus
parents: 93
diff changeset
   700
    "
claus
parents: 93
diff changeset
   701
     then, perform a GC (incl. symbol reclamation)
claus
parents: 93
diff changeset
   702
    "
claus
parents: 93
diff changeset
   703
    ObjectMemory reclaimSymbols.
claus
parents: 93
diff changeset
   704
    "
claus
parents: 93
diff changeset
   705
     finally, compress
claus
parents: 93
diff changeset
   706
    "
claus
parents: 93
diff changeset
   707
    ObjectMemory verboseGarbageCollect.
claus
parents: 93
diff changeset
   708
!
claus
parents: 93
diff changeset
   709
844
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   710
cleanupMethodHistory
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   711
    "release the oldMethod history"
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   712
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   713
    (self confirm:'This removes the previous method history,
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   714
which is kept for all changed methods in the system.
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   715
After that, the browsers cannot easily switch back to a methods
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   716
previous version.
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   717
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   718
However, this is normally not a problem, since
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   719
a methods previous code should still be accessable through
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   720
either the changes-file, the sourceCode repository or the classes original
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   721
source file.
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   722
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   723
cleanup now ?') ifTrue:[
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   724
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   725
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   726
        Class flushMethodHistory.
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   727
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   728
        "
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   729
         then, perform a GC (incl. symbol reclamation)
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   730
        "
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   731
        ObjectMemory reclaimSymbols.
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   732
        "
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   733
         finally, compress
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   734
        "
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   735
        ObjectMemory verboseGarbageCollect.
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   736
   ]
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   737
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   738
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   739
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   740
!
95fde6837db3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 798
diff changeset
   741
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   742
compressSources
323
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   743
    (self confirm:'This saves all in-memory source strings into a file
360
5347e1bfae74 box text in compressSources
Claus Gittinger <cg@exept.de>
parents: 350
diff changeset
   744
and makes methods reference these (file-) strings,
5347e1bfae74 box text in compressSources
Claus Gittinger <cg@exept.de>
parents: 350
diff changeset
   745
freeing all in-memory sources.
323
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   746
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   747
If that source file is ever lost or gets out of sync with
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   748
your system, those method sources are lost and the browser
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   749
will show garbage. 
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   750
However, you still have a change file as backup.
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   751
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   752
(Be especially careful, if you move images around:
360
5347e1bfae74 box text in compressSources
Claus Gittinger <cg@exept.de>
parents: 350
diff changeset
   753
 the source file must then be the correct one for that image)
323
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   754
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   755
A compress is only useful, if you added many methods
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   756
and the systems response time suffers from paging.
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   757
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   758
Compress anyway ?') ifTrue:[
350
68c5fed6c9bc show waitCursor while collecting
Claus Gittinger <cg@exept.de>
parents: 323
diff changeset
   759
        windowGroup withWaitCursorDo:[
68c5fed6c9bc show waitCursor while collecting
Claus Gittinger <cg@exept.de>
parents: 323
diff changeset
   760
            Smalltalk compressSources.
68c5fed6c9bc show waitCursor while collecting
Claus Gittinger <cg@exept.de>
parents: 323
diff changeset
   761
            ObjectMemory markAndSweep
68c5fed6c9bc show waitCursor while collecting
Claus Gittinger <cg@exept.de>
parents: 323
diff changeset
   762
        ]
323
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   763
    ]
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   764
360
5347e1bfae74 box text in compressSources
Claus Gittinger <cg@exept.de>
parents: 350
diff changeset
   765
    "Modified: 9.2.1996 / 18:17:22 / cg"
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   766
!
156
e6a7f80e2a71 show irq latency
Claus Gittinger <cg@exept.de>
parents: 128
diff changeset
   767
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   768
compressingGarbageCollect
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   769
    "perform a blocking compressing garbage collect."
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   770
350
68c5fed6c9bc show waitCursor while collecting
Claus Gittinger <cg@exept.de>
parents: 323
diff changeset
   771
    windowGroup withWaitCursorDo:[
68c5fed6c9bc show waitCursor while collecting
Claus Gittinger <cg@exept.de>
parents: 323
diff changeset
   772
        ObjectMemory verboseGarbageCollect
68c5fed6c9bc show waitCursor while collecting
Claus Gittinger <cg@exept.de>
parents: 323
diff changeset
   773
    ]
156
e6a7f80e2a71 show irq latency
Claus Gittinger <cg@exept.de>
parents: 128
diff changeset
   774
!
e6a7f80e2a71 show irq latency
Claus Gittinger <cg@exept.de>
parents: 128
diff changeset
   775
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   776
garbageCollect
159
159f86b6395a comments added
Claus Gittinger <cg@exept.de>
parents: 158
diff changeset
   777
    "perform a blocking (non compressing) garbage collect"
159f86b6395a comments added
Claus Gittinger <cg@exept.de>
parents: 158
diff changeset
   778
350
68c5fed6c9bc show waitCursor while collecting
Claus Gittinger <cg@exept.de>
parents: 323
diff changeset
   779
    windowGroup withWaitCursorDo:[
68c5fed6c9bc show waitCursor while collecting
Claus Gittinger <cg@exept.de>
parents: 323
diff changeset
   780
        ObjectMemory markAndSweep
68c5fed6c9bc show waitCursor while collecting
Claus Gittinger <cg@exept.de>
parents: 323
diff changeset
   781
    ]
68c5fed6c9bc show waitCursor while collecting
Claus Gittinger <cg@exept.de>
parents: 323
diff changeset
   782
68c5fed6c9bc show waitCursor while collecting
Claus Gittinger <cg@exept.de>
parents: 323
diff changeset
   783
    "Modified: 2.1.1996 / 12:17:33 / cg"
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   784
!
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   785
105
claus
parents: 93
diff changeset
   786
garbageCollectAndSymbols
159
159f86b6395a comments added
Claus Gittinger <cg@exept.de>
parents: 158
diff changeset
   787
    "perform a blocking (non compressing) garbage collect
159f86b6395a comments added
Claus Gittinger <cg@exept.de>
parents: 158
diff changeset
   788
     and reclaim unreferenced symbols."
159f86b6395a comments added
Claus Gittinger <cg@exept.de>
parents: 158
diff changeset
   789
350
68c5fed6c9bc show waitCursor while collecting
Claus Gittinger <cg@exept.de>
parents: 323
diff changeset
   790
    windowGroup withWaitCursorDo:[
68c5fed6c9bc show waitCursor while collecting
Claus Gittinger <cg@exept.de>
parents: 323
diff changeset
   791
        ObjectMemory reclaimSymbols
68c5fed6c9bc show waitCursor while collecting
Claus Gittinger <cg@exept.de>
parents: 323
diff changeset
   792
    ]
68c5fed6c9bc show waitCursor while collecting
Claus Gittinger <cg@exept.de>
parents: 323
diff changeset
   793
68c5fed6c9bc show waitCursor while collecting
Claus Gittinger <cg@exept.de>
parents: 323
diff changeset
   794
    "Modified: 2.1.1996 / 12:17:36 / cg"
105
claus
parents: 93
diff changeset
   795
!
claus
parents: 93
diff changeset
   796
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   797
incrementalCollect
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   798
    "start an incremental GC which does not disturb too much, but is guaranteed to
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   799
     make progress.
323
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   800
     This is done by doing the IGC at a very high priority, but giving up the CPU after
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   801
     every step. Due to the long delays, this may take a while to finish.
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   802
     Notice, that this is different from doing a background collect: that one
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   803
     may not make any progress if higher prio processes are runnable."
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   804
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   805
    |done delay|
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   806
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   807
    [
323
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   808
        done := false.
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   809
        delay := Delay new.
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   810
        [done] whileFalse:[
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   811
            10 timesRepeat:[
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   812
                done ifFalse:[done := ObjectMemory gcStep].
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   813
            ].
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   814
            (delay delay:10) wait
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   815
        ]
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   816
    ] forkAt:Processor highestPriority
323
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   817
f443d7e5bab0 special menu published
Claus Gittinger <cg@exept.de>
parents: 311
diff changeset
   818
    "Modified: 23.12.1995 / 17:31:55 / cg"
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   819
!
159
159f86b6395a comments added
Claus Gittinger <cg@exept.de>
parents: 158
diff changeset
   820
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   821
resetStatisticValues 
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   822
    ObjectMemory resetMaxInterruptLatency.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   823
    ObjectMemory resetMinScavengeReclamation.
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   824
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   825
    "Created: 7.11.1995 / 17:44:59 / cg"
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   826
!
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   827
972
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   828
restartBackgroundCollector
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   829
    "start a background (non disturbing) incremental GC. 
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   830
     Since the GC is performed at a low priority, it may not make progress if higher
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   831
     prio processes are running"
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   832
 
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   833
    ObjectMemory backgroundCollectorRunning
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   834
    ifFalse:[
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   835
        ObjectMemory startBackgroundCollectorAt:5.
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   836
        ObjectMemory startBackgroundCollectorAt:5
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   837
    ]
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   838
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   839
    "Created: 21.1.1997 / 00:09:30 / cg"
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   840
!
7f8884cb99e2 items renamed;
Claus Gittinger <cg@exept.de>
parents: 844
diff changeset
   841
105
claus
parents: 93
diff changeset
   842
scavenge 
159
159f86b6395a comments added
Claus Gittinger <cg@exept.de>
parents: 158
diff changeset
   843
    "perform a blocking newspace garbage collect.
159f86b6395a comments added
Claus Gittinger <cg@exept.de>
parents: 158
diff changeset
   844
     (this is for debugging only - the system does this automatically)"
159f86b6395a comments added
Claus Gittinger <cg@exept.de>
parents: 158
diff changeset
   845
105
claus
parents: 93
diff changeset
   846
    ObjectMemory scavenge
claus
parents: 93
diff changeset
   847
!
claus
parents: 93
diff changeset
   848
claus
parents: 93
diff changeset
   849
tenure 
159
159f86b6395a comments added
Claus Gittinger <cg@exept.de>
parents: 158
diff changeset
   850
    "empty the newSpace, by aging all new objects immediately and transfering them
159f86b6395a comments added
Claus Gittinger <cg@exept.de>
parents: 158
diff changeset
   851
     into oldSpace.
159f86b6395a comments added
Claus Gittinger <cg@exept.de>
parents: 158
diff changeset
   852
     (this is for debugging only - the system does this automatically)"
159f86b6395a comments added
Claus Gittinger <cg@exept.de>
parents: 158
diff changeset
   853
105
claus
parents: 93
diff changeset
   854
    ObjectMemory tenure
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   855
! !
105
claus
parents: 93
diff changeset
   856
798
5ef299968209 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
   857
!MemoryMonitor class methodsFor:'documentation'!
85
d9713a3ca092 *** empty log message ***
claus
parents: 79
diff changeset
   858
311
c118ce1f8afd flush in subprocess
Claus Gittinger <cg@exept.de>
parents: 303
diff changeset
   859
version
989
0f047353b974 need a lock while drawing
Claus Gittinger <cg@exept.de>
parents: 972
diff changeset
   860
    ^ '$Header: /cvs/stx/stx/libtool/MemoryMonitor.st,v 1.41 1997-01-23 21:39:55 cg Exp $'
52
7b48409ae088 *** empty log message ***
claus
parents: 49
diff changeset
   861
! !