DebugView.st
author claus
Mon, 28 Nov 1994 22:11:47 +0100
changeset 56 d0cb937cbcaa
parent 55 abfd613f95d9
child 57 36e13831b62d
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
     1
"
4
77d8e96499b2 *** empty log message ***
claus
parents: 2
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
     3
	      All Rights Reserved
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
     4
571fd5eee315 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
571fd5eee315 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
571fd5eee315 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
571fd5eee315 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
571fd5eee315 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
571fd5eee315 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
571fd5eee315 Initial revision
claus
parents:
diff changeset
    11
"
571fd5eee315 Initial revision
claus
parents:
diff changeset
    12
571fd5eee315 Initial revision
claus
parents:
diff changeset
    13
StandardSystemView subclass:#DebugView
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
    14
       instanceVariableNames:'busy haveControl exitAction canContinue
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    15
			      contextView codeView
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    16
			      receiverInspector contextInspector
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    17
			      contextArray selectedContext
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    18
			      catchBlock grabber traceView tracing
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    19
			      bigStep skipLineNr steppedContextAddress canAbort
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    20
			      abortButton terminateButton continueButton
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    21
			      stepButton sendButton returnButton restartButton
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    22
			      exclusive inspecting nChainShown
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    23
			      inspectedProcess updateProcess
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    24
			      monitorToggle'
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
    25
       classVariableNames:'CachedDebugger CachedExclusive MoreDebuggingDetail'
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    26
       poolDictionaries:''
571fd5eee315 Initial revision
claus
parents:
diff changeset
    27
       category:'Interface-Debugger'
571fd5eee315 Initial revision
claus
parents:
diff changeset
    28
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
    29
571fd5eee315 Initial revision
claus
parents:
diff changeset
    30
DebugView comment:'
4
77d8e96499b2 *** empty log message ***
claus
parents: 2
diff changeset
    31
COPYRIGHT (c) 1989 by Claus Gittinger
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    32
	      All Rights Reserved
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    33
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
    34
$Header: /cvs/stx/stx/libtool/DebugView.st,v 1.20 1994-11-28 21:11:09 claus Exp $
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    35
'!
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    36
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    37
!DebugView class methodsFor:'documentation'!
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    38
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    39
copyright
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    40
"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    41
 COPYRIGHT (c) 1989 by Claus Gittinger
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    42
	      All Rights Reserved
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    43
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    44
 This software is furnished under a license and may be used
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    45
 only in accordance with the terms of that license and with the
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    46
 inclusion of the above copyright notice.   This software may not
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    47
 be provided or otherwise made available to, or used by, any
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    48
 other person.  No title to or ownership of the software is
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    49
 hereby transferred.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    50
"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    51
!
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    52
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    53
version
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    54
"
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
    55
$Header: /cvs/stx/stx/libtool/DebugView.st,v 1.20 1994-11-28 21:11:09 claus Exp $
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    56
"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    57
!
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    58
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    59
documentation
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    60
"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    61
    this class implements a graphical debugger interface.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    62
    The debugger usually sits on top of the faulting process,
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    63
    taking over its event processing. Thus only the 'stopped' process is affected;
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    64
    other processes continue to respond to events.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    65
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    66
    The one exception is when an error occurs within the dispatcher process
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    67
    or in one of the eventhandler processes - in this case, the debugger
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    68
    will sit on an exclusive display connection.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    69
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    70
    The whole debugging will be changed, once the required process primitives
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    71
    are available, which allow control of another processes execution
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    72
    (i.e. single-step, restart & return). The setup will be changed then,
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    73
    to have the debugger control the debuggee (i.e. two processes)
35
cd5cb075fd6a *** empty log message ***
claus
parents: 29
diff changeset
    74
cd5cb075fd6a *** empty log message ***
claus
parents: 29
diff changeset
    75
    See additional information in 'doc/misc/debugger.doc'.
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    76
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    77
    Notice: the DebugView class caches the last used debugger in a class
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    78
    variable. It may happen, that a malfunctioning debugger (for example,
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    79
    a halfway destoyed one) is kept there. You will notice this, if a
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    80
    debugger comes up without showing any contents. In this case, close
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    81
    (or destroy) the broken debugView, and execute
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    82
	Debugger newDebugger
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    83
    which removes the cached debugger and forces creation of a new one the
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    84
    next time. This is a temporary workaround - the debugger will be fixed to
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    85
    avoid this problem.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    86
"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    87
! !
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    88
571fd5eee315 Initial revision
claus
parents:
diff changeset
    89
!DebugView class methodsFor:'instance creation'!
571fd5eee315 Initial revision
claus
parents:
diff changeset
    90
571fd5eee315 Initial revision
claus
parents:
diff changeset
    91
new
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
    92
    "return a new DebugView - return a cached debugger if it already
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    93
     exists"
571fd5eee315 Initial revision
claus
parents:
diff changeset
    94
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    95
    |debugger active|
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    96
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
    97
    "need a blocking debugger if no processes or 
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    98
     or if its a timing/interrupt process 
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    99
     (because otherwise we would not get any events here ..."
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   100
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   101
    active := Processor activeProcess.
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   102
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   103
    (ProcessorScheduler isPureEventDriven 
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   104
    or:[(active priority >= Processor userInterruptPriority)
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   105
    or:[active id == 0
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   106
    or:[active nameOrId endsWith:'dispatcher']]]) ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   107
	CachedExclusive isNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   108
	    debugger := self newExclusive
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   109
	] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   110
	    debugger := CachedExclusive.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   111
	    CachedExclusive := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   112
	].
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
   113
    ] ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   114
	CachedDebugger isNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   115
	    debugger := super new.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   116
	    debugger label:'Debugger'.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   117
	    debugger icon:(Form fromFile:'Debugger.xbm' resolution:100).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   118
	] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   119
	    debugger := CachedDebugger.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   120
	    CachedDebugger := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   121
	]
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
   122
    ].
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
   123
    ^ debugger
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   124
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   125
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   126
newExclusive
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   127
    "return a debugger for exclusive display access"
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   128
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   129
    |debugger|
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   130
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   131
    debugger := super on:ModalDisplay.
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   132
    debugger label:'Debugger'.
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   133
    debugger icon:(Form fromFile:'Debugger.xbm' resolution:100).
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   134
    debugger exclusive:true.
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   135
    ^ debugger
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   136
!
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   137
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   138
newDebugger
571fd5eee315 Initial revision
claus
parents:
diff changeset
   139
    "force creation of a new debugger"
571fd5eee315 Initial revision
claus
parents:
diff changeset
   140
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   141
    CachedDebugger := nil.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   142
    CachedExclusive := nil
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   143
571fd5eee315 Initial revision
claus
parents:
diff changeset
   144
    "DebugView newDebugger"
571fd5eee315 Initial revision
claus
parents:
diff changeset
   145
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   146
571fd5eee315 Initial revision
claus
parents:
diff changeset
   147
enterWithMessage:aString
571fd5eee315 Initial revision
claus
parents:
diff changeset
   148
    "the standard way of entering the debugger - sent from Objects
571fd5eee315 Initial revision
claus
parents:
diff changeset
   149
     error- and halt messages"
571fd5eee315 Initial revision
claus
parents:
diff changeset
   150
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   151
    thisContext isRecursive ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   152
	^ MiniDebugger enterWithMessage:aString
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   153
    ].
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   154
    ^ self enter:(thisContext sender) withMessage:aString
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   155
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   156
    "Debugger enterWithMessage:'hi there'"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   157
!
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   158
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   159
enter
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   160
    "another way of entering the debugger"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   161
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   162
    ^ self enter:(thisContext sender) withMessage:'Debugger'
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   163
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   164
    "Debugger enter"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   165
!
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   166
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   167
enter:aContext
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   168
    "enter the debugger on aContext"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   169
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   170
    ^ self enter:aContext withMessage:'Debugger'
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   171
!
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   172
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   173
enter:aContext withMessage:aString
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   174
    "enter a debugger; if this is a recursive invocation, enter
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   175
     a MiniDebugger instead.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   176
     This is the standard way of entering the debugger;
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   177
     sent from error- and halt messages."
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   178
14
e07eee5d93ca *** empty log message ***
claus
parents: 13
diff changeset
   179
    thisContext isRecursive ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   180
	^ MiniDebugger enterWithMessage:'recursive error'.
14
e07eee5d93ca *** empty log message ***
claus
parents: 13
diff changeset
   181
    ].
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   182
    ^ self enterUnconditional:aContext withMessage:aString
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   183
!
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   184
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   185
enterUnconditional:aContext withMessage:aString
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   186
    "enter a debugger - do not check for recursive invocation"
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   187
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   188
    |aDebugger|
14
e07eee5d93ca *** empty log message ***
claus
parents: 13
diff changeset
   189
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   190
    StepInterruptPending := nil.
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
   191
    aDebugger := self new.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   192
    aDebugger label:aString , ' (' , Processor activeProcess nameOrId , ')'.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   193
    aDebugger enter:aContext.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   194
    ^ nil
571fd5eee315 Initial revision
claus
parents:
diff changeset
   195
571fd5eee315 Initial revision
claus
parents:
diff changeset
   196
    "nil halt"
571fd5eee315 Initial revision
claus
parents:
diff changeset
   197
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   198
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   199
openOn:aProcess
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   200
    "start a  debugger on aProcess
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   201
     (actually not more than a good-looking inspector)"
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   202
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   203
    |aDebugger label nm|
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   204
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   205
    aDebugger := super new.
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   206
    aDebugger icon:(Form fromFile:'Debugger.xbm' resolution:100).
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   207
    aProcess notNil ifTrue:[
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   208
	nm := aProcess name.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   209
	nm notNil ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   210
	    nm := (aProcess nameOrId contractTo:17) , '-' , aProcess id printString
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   211
	] ifFalse:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   212
	    nm := aProcess id printString
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   213
	].
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   214
	label := 'Debugger [' , nm , ']'.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   215
    ] ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   216
	label := 'no process'
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   217
    ].
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   218
    aDebugger label:label.
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   219
    aDebugger iconLabel:'Debugger'.
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   220
    aDebugger openOn:aProcess.
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   221
    ^ nil
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   222
! !
571fd5eee315 Initial revision
claus
parents:
diff changeset
   223
571fd5eee315 Initial revision
claus
parents:
diff changeset
   224
!DebugView methodsFor:'initialization'!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   225
571fd5eee315 Initial revision
claus
parents:
diff changeset
   226
initialize
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   227
    |v panel hpanel bpanel dummy|
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   228
571fd5eee315 Initial revision
claus
parents:
diff changeset
   229
    super initialize.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   230
571fd5eee315 Initial revision
claus
parents:
diff changeset
   231
    font := font on:device.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   232
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
   233
    busy := false.
14
e07eee5d93ca *** empty log message ***
claus
parents: 13
diff changeset
   234
    exclusive := false.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   235
    inspecting := false.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   236
    exitAction := nil.
10
46e0d4f2079f *** empty log message ***
claus
parents: 7
diff changeset
   237
    bigStep := false.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   238
    canContinue := false.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   239
    canAbort := false.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   240
571fd5eee315 Initial revision
claus
parents:
diff changeset
   241
    bpanel := HorizontalPanelView
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   242
			origin:(0.0 @ 0.0)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   243
			extent:(1.0 @ (font height * 2))
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   244
			    in:self.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   245
    bpanel layout:#left.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   246
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
   247
    terminateButton := Button
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   248
			label:(resources at:'terminate')
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   249
			action:[terminateButton turnOffWithoutRedraw. self doTerminate]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   250
			in:bpanel.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   251
    dummy := View extent:(20 @ 5) in:bpanel.
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   252
    dummy borderWidth:0; level:0.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   253
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   254
    abortButton := Button
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   255
			label:(resources at:'abort')
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   256
			action:[abortButton turnOffWithoutRedraw. self doAbort]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   257
			in:bpanel.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   258
    returnButton := Button
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   259
			label:(resources at:'return')
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   260
			action:[returnButton turnOff. self doReturn]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   261
			in:bpanel.
20
c09545d02817 *** empty log message ***
claus
parents: 15
diff changeset
   262
c09545d02817 *** empty log message ***
claus
parents: 15
diff changeset
   263
    restartButton := Button
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   264
			label:(resources at:'restart')
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   265
			action:[restartButton turnOff. self doRestart]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   266
			in:bpanel.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   267
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   268
    dummy := View extent:(20 @ 5) in:bpanel.
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   269
    dummy borderWidth:0; level:0.
20
c09545d02817 *** empty log message ***
claus
parents: 15
diff changeset
   270
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   271
    continueButton := Button
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   272
			label:(resources at:'continue')
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   273
			action:[continueButton turnOffWithoutRedraw. self doContinue]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   274
			in:bpanel.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   275
    dummy := View extent:(20 @ 5) in:bpanel.
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   276
    dummy borderWidth:0; level:0.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   277
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   278
    stepButton := Button
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   279
			label:(resources at:'step')
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   280
			action:[stepButton turnOff. self doStep]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   281
			in:bpanel.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   282
    sendButton := Button
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   283
			label:(resources at:'send')
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   284
			action:[sendButton turnOff. self doSend]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   285
			in:bpanel.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   286
571fd5eee315 Initial revision
claus
parents:
diff changeset
   287
    panel := VariableVerticalPanel
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   288
			origin:(0.0 @ bpanel height)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   289
			corner:(1.0 @ 1.0)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   290
			    in:self.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   291
571fd5eee315 Initial revision
claus
parents:
diff changeset
   292
    v := ScrollableView for:SelectionInListView in:panel.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   293
    v origin:(0.0 @ 0.0) corner:(1.0 @ 0.25).
571fd5eee315 Initial revision
claus
parents:
diff changeset
   294
571fd5eee315 Initial revision
claus
parents:
diff changeset
   295
    contextView := v scrolledView.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   296
    contextView action:[:lineNr | self showSelection:lineNr].
571fd5eee315 Initial revision
claus
parents:
diff changeset
   297
571fd5eee315 Initial revision
claus
parents:
diff changeset
   298
    v := ScrollableView for:CodeView in:panel.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   299
    v origin:(0.0 @ 0.25) corner:(1.0 @ 0.75).
571fd5eee315 Initial revision
claus
parents:
diff changeset
   300
571fd5eee315 Initial revision
claus
parents:
diff changeset
   301
    codeView := v scrolledView.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   302
571fd5eee315 Initial revision
claus
parents:
diff changeset
   303
    hpanel := VariableHorizontalPanel in:panel.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   304
    hpanel origin:(0.0 @ 0.75) corner:(1.0 @ 1.0).
571fd5eee315 Initial revision
claus
parents:
diff changeset
   305
571fd5eee315 Initial revision
claus
parents:
diff changeset
   306
    receiverInspector := InspectorView
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   307
				origin:(0.0 @ 0.0) corner:(0.5 @ 1.0)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   308
				    in:hpanel.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   309
571fd5eee315 Initial revision
claus
parents:
diff changeset
   310
    contextInspector := ContextInspectorView
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   311
				origin:(0.5 @ 0.0) corner:(1.0 @ 1.0)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   312
				    in:hpanel
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   313
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   314
571fd5eee315 Initial revision
claus
parents:
diff changeset
   315
initializeMiddleButtonMenu
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   316
    |labels m|
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   317
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   318
    labels := resources array:#(
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   319
				'show more'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   320
				'-'
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   321
"
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   322
				'continue'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   323
				'terminate'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   324
				'abort'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   325
				'-'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   326
				'step'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   327
				'send'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   328
				'-'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   329
				'return'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   330
				'restart'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   331
				'-'
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   332
"
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   333
				'remove breakpoint'
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   334
				'remove all trace & breakpoints'
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   335
				'-'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   336
				'implementors ...'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   337
				'senders ...'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   338
				'-'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   339
				'inspect context'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   340
				'-'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   341
				'quickTerminate'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   342
				'-'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   343
				'exit smalltalk'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   344
			      ).
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   345
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   346
    m := (PopUpMenu 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   347
				labels:labels
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   348
			     selectors:#(
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   349
					 doShowMore
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   350
					 nil
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   351
"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   352
					 doContinue
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   353
					 doTerminate
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   354
					 doAbort
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   355
					 nil
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   356
					 doStep
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   357
					 doSend
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   358
					 nil
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   359
					 doReturn
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   360
					 doRestart
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   361
					 nil
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   362
"
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   363
					 doRemoveBreakpoint
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   364
					 doRemoveAllBreakpoints
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   365
					 nil
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   366
					 doImplementors
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   367
					 doSenders
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   368
					 nil
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   369
					 doInspectContext
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   370
					 nil
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   371
					 doQuickTerminate
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   372
					 nil
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   373
					 doExit
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   374
					)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   375
				  receiver:self
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   376
				       for:contextView).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   377
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   378
    contextView middleButtonMenu:m. 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   379
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   380
    inspecting ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   381
	m notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   382
	    m disable:#doTraceStep.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   383
	    m disable:#doRemoveBreakpoint.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   384
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   385
    ]
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   386
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   387
46
6c8670b88024 *** empty log message ***
claus
parents: 45
diff changeset
   388
reinitialize
6c8670b88024 *** empty log message ***
claus
parents: 45
diff changeset
   389
    super reinitialize.
6c8670b88024 *** empty log message ***
claus
parents: 45
diff changeset
   390
    "
6c8670b88024 *** empty log message ***
claus
parents: 45
diff changeset
   391
     this is reached, when we come up after a restart.
6c8670b88024 *** empty log message ***
claus
parents: 45
diff changeset
   392
     ST/X does not support this, since the contexts are
6c8670b88024 *** empty log message ***
claus
parents: 45
diff changeset
   393
     all dead, and processes have been recreated.
6c8670b88024 *** empty log message ***
claus
parents: 45
diff changeset
   394
    "
6c8670b88024 *** empty log message ***
claus
parents: 45
diff changeset
   395
    super destroy
6c8670b88024 *** empty log message ***
claus
parents: 45
diff changeset
   396
!
6c8670b88024 *** empty log message ***
claus
parents: 45
diff changeset
   397
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   398
addToCurrentProject
571fd5eee315 Initial revision
claus
parents:
diff changeset
   399
    "ignored here"
571fd5eee315 Initial revision
claus
parents:
diff changeset
   400
571fd5eee315 Initial revision
claus
parents:
diff changeset
   401
    ^ self
571fd5eee315 Initial revision
claus
parents:
diff changeset
   402
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   403
571fd5eee315 Initial revision
claus
parents:
diff changeset
   404
createOnTop
571fd5eee315 Initial revision
claus
parents:
diff changeset
   405
    ^ false "true"
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   406
!
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   407
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   408
realize
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   409
    super realize.
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   410
    exclusive ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   411
	windowGroup := nil
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   412
    ].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   413
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   414
    inspectedProcess notNil ifTrue:[
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   415
	"
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   416
	 set prio somewhat higher (by 2, to allow walkBack-update process
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   417
	 to run between mine and the debugged processes prio)
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   418
	"
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   419
	Processor activeProcess 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   420
	    priority:(inspectedProcess priority + 2 min:16).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   421
    ]
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   422
! !
571fd5eee315 Initial revision
claus
parents:
diff changeset
   423
571fd5eee315 Initial revision
claus
parents:
diff changeset
   424
!DebugView methodsFor:'interrupt handling'!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   425
571fd5eee315 Initial revision
claus
parents:
diff changeset
   426
stepInterrupt
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   427
    |where here s isWrap method lastWrappedConAddr wrappedMethod|
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   428
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   429
    Processor activeProcess ~~ inspectedProcess ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   430
	'stray step interrupt' errorPrintNL.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   431
	^ self
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   432
    ].
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   433
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   434
    "
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   435
     kludge: check if we are in a wrapper methods hidden setup-sequence
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   436
    "
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   437
    here := thisContext.        "stepInterrupt"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   438
    here := here sender.        "the interrupted context"  
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   439
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   440
"/ 'here in ' print.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   441
"/  ((ObjectMemory addressOf:here) printStringRadix:16)print. '' printNL.
10
46e0d4f2079f *** empty log message ***
claus
parents: 7
diff changeset
   442
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   443
    where := here.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   444
    isWrap := false.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   445
    wrappedMethod := nil.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   446
    5 timesRepeat:[
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   447
"/ where selector printNL.
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   448
	where notNil ifTrue:[
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   449
	    method := where method.
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   450
	    (method notNil and:[method isWrapped]) ifTrue:[
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   451
		"
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   452
		 in a wrapper method
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   453
		"
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   454
		wrappedMethod ~~ method ifTrue:[
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   455
		    wrappedMethod := method.
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   456
		    lastWrappedConAddr := ObjectMemory addressOf:where.
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   457
		    where sender receiver == method originalMethod ifFalse:[
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   458
			isWrap := true.
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   459
		    ]
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   460
		] ifFalse:[
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   461
		    (ObjectMemory addressOf:where) == steppedContextAddress ifTrue:[
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   462
"/ 'change stepCon from: ' print.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   463
"/  (steppedContextAddress printStringRadix:16)print.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   464
"/ ' to: ' print.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   465
"/  (lastWrappedConAddr printStringRadix:16)printNL.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   466
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   467
			steppedContextAddress := lastWrappedConAddr
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   468
		    ]
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   469
		]
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   470
	    ].
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   471
	    where := where sender
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   472
	]
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   473
    ].
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   474
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   475
    isWrap ifTrue:[
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   476
"/ 'ignore wrap' printNL.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   477
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   478
	  ignore, while in wrappers hidden setup
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   479
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   480
	where := nil. here := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   481
	ObjectMemory flushInlineCaches.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   482
	StepInterruptPending := true.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   483
	InterruptPending := true.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   484
	InStepInterrupt := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   485
	^ nil
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   486
    ].
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   487
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   488
    "
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   489
     is this for a send or a step ?
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   490
    "
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   491
    bigStep ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   492
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   493
	 a step - ignore all contexts below the interresting one
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   494
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   495
	where := here.      "the interrupted context"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   496
	(ObjectMemory addressOf:where) == steppedContextAddress ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   497
	    where := where sender.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   498
"/ 'look for ' print.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   499
"/  (steppedContextAddress printStringRadix:16)print. '' printNL.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   500
	    (ObjectMemory addressOf:where) == steppedContextAddress ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   501
		"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   502
		 check if we are in a context below steppedContext
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   503
		 (i.e. if steppedContext can be reached from
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   504
		  interrupted context. Not using context-ref but its
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   505
		  address to avoid creation of many useless contexts.)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   506
		"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   507
		[where notNil] whileTrue:[
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   508
"/  ((ObjectMemory addressOf:where) printStringRadix:16)print. ' ' print.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   509
"/  where selector printNL.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   510
		    (ObjectMemory addressOf:where) == steppedContextAddress ifTrue:[
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   511
"/ 'found it - below' printNL.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   512
			"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   513
			 found the interresting context somwehere up in the
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   514
			 chain. We seem to be still below the interresting one ...
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   515
			"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   516
			tracing == true ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   517
			    here printString printNewline
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   518
			].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   519
			where := nil. here := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   520
			"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   521
			  yes, a context below
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   522
			  - continue and schedule another stepInterrupt.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   523
			  Must flush caches since optimized methods not always
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   524
			  look for pending interrupts
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   525
			"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   526
			ObjectMemory flushInlineCaches.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   527
			StepInterruptPending := true.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   528
			InterruptPending := true.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   529
			InStepInterrupt := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   530
			^ nil
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   531
		    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   532
		    where := where sender
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   533
		].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   534
		s := 'left stepped method'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   535
	    ] ifTrue:[
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   536
"/ 'found it right in sender' printNL.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   537
		s := 'after step'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   538
	    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   539
	] ifTrue:[
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   540
"/ 'found it right away' printNL.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   541
	    s := 'after step'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   542
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   543
	tracing := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   544
	bigStep := false.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   545
    ] ifFalse:[
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   546
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   547
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   548
	 a send
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   549
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   550
	steppedContextAddress := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   551
	s := 'after send'
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   552
    ].
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
   553
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   554
    name := Processor activeProcess nameOrId.
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
   555
    self label:(s , ' (process: ' , name , ')').
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
   556
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   557
    "release refs to context"
571fd5eee315 Initial revision
claus
parents:
diff changeset
   558
    where := nil. here := nil.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   559
    self enter:thisContext sender 
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   560
! !
571fd5eee315 Initial revision
claus
parents:
diff changeset
   561
571fd5eee315 Initial revision
claus
parents:
diff changeset
   562
!DebugView methodsFor:'basic'!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   563
571fd5eee315 Initial revision
claus
parents:
diff changeset
   564
enter
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   565
    "enter the debugger - on the sending context"
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   566
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   567
    |where|
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   568
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   569
    busy := true.
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   570
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   571
    where := thisContext.      "enter"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   572
    where := where sender.     "the calling context"
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   573
    where notNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   574
	(where receiver == DebugView) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   575
	    where := where sender
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   576
	]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   577
	"where is now interrupted methods context"
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   578
    ].
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   579
    ^ self enter:where
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   580
!
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   581
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   582
enter:aContext
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   583
    "enter the debugger - get and display the context, then start an
571fd5eee315 Initial revision
claus
parents:
diff changeset
   584
     exclusive event loop on top of eveything else"
571fd5eee315 Initial revision
claus
parents:
diff changeset
   585
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   586
    |con selection m|
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   587
14
e07eee5d93ca *** empty log message ***
claus
parents: 13
diff changeset
   588
    busy := true.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   589
    inspecting := false.
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   590
    inspectedProcess := Processor activeProcess.
10
46e0d4f2079f *** empty log message ***
claus
parents: 7
diff changeset
   591
    bigStep := false.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   592
    nChainShown := 50.
10
46e0d4f2079f *** empty log message ***
claus
parents: 7
diff changeset
   593
46e0d4f2079f *** empty log message ***
claus
parents: 7
diff changeset
   594
    "if debugger is entered while a box has grabbed the
46e0d4f2079f *** empty log message ***
claus
parents: 7
diff changeset
   595
     pointer, we must ungrab - otherwise X wont talk to
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   596
     us here
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   597
    "
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   598
    (grabber := device activePointerGrab) notNil ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   599
	device ungrabPointer
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   600
    ].
571fd5eee315 Initial revision
claus
parents:
diff changeset
   601
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   602
    terminateButton enable.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   603
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
   604
    drawableId notNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   605
	"not the first time - realize at old position"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   606
	terminateButton turnOffWithoutRedraw.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   607
	continueButton turnOffWithoutRedraw.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   608
	abortButton turnOffWithoutRedraw.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   609
	stepButton turnOffWithoutRedraw.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   610
	sendButton turnOffWithoutRedraw.
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   611
"/        self rerealize
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
   612
    ] ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   613
	exclusive ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   614
	    windowGroup isNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   615
		windowGroup := WindowGroup new.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   616
		windowGroup addTopView:self.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   617
	    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   618
	].
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   619
"/        self realize.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   620
	self iconLabel:'Debugger'.
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
   621
    ].
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   622
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   623
"/    "
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   624
"/   bring us to the top
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   625
"/  "
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   626
"/  self raise.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   627
"/  Display synchronizeOutput.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   628
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   629
    "
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   630
     get the walkback list
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   631
    "
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   632
    self setContext:aContext.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   633
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   634
    "
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   635
     and find one to show
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   636
    "
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   637
    exitAction == #step ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   638
	selection := 1.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   639
	steppedContextAddress notNil ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   640
	    "
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   641
	     if we came here by a big-step, show the method where we are
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   642
	    "
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   643
	    steppedContextAddress notNil ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   644
		(ObjectMemory addressOf:aContext) == steppedContextAddress ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   645
		    selection := 1
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   646
		] ifFalse:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   647
		    (ObjectMemory addressOf:aContext sender) == steppedContextAddress ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   648
			selection := 2
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   649
		    ]
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   650
		]
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   651
	    ]
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   652
	]
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   653
    ] ifFalse:[
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   654
	steppedContextAddress isNil ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   655
	    "
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   656
	     preselect a more interresting context, (where halt/raise was ...)
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   657
	    "
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   658
	    selection := self interrestingContextFrom:aContext.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   659
	] ifFalse:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   660
	    "
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   661
	     if we came here by a big-step, show the method where we are
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   662
	    "
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   663
	    steppedContextAddress notNil ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   664
		(ObjectMemory addressOf:aContext) == steppedContextAddress ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   665
		    selection := 1
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   666
		] ifFalse:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   667
		    (ObjectMemory addressOf:aContext sender) == steppedContextAddress ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   668
			selection := 2
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   669
		    ]
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   670
		]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   671
	    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   672
	]
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   673
    ].
571fd5eee315 Initial revision
claus
parents:
diff changeset
   674
571fd5eee315 Initial revision
claus
parents:
diff changeset
   675
    selection notNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   676
	self showSelection:selection.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   677
	contextView selection:selection
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   678
    ].
571fd5eee315 Initial revision
claus
parents:
diff changeset
   679
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   680
    m := contextView middleButtonMenu.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   681
    m notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   682
	canAbort := inspecting or:[Object abortSignal isHandled].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   683
	canAbort ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   684
	    abortButton enable.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   685
	    m enable:#doAbort.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   686
	] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   687
	    abortButton disable.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   688
	    m disable:#doAbort.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   689
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   690
	exclusive ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   691
	    terminateButton disable.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   692
	    m disable:#doTerminate.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   693
	] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   694
	    terminateButton enable.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   695
	    m enable:#doTerminate.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   696
	]
14
e07eee5d93ca *** empty log message ***
claus
parents: 13
diff changeset
   697
    ].
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
   698
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   699
    drawableId notNil ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   700
	self rerealize
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   701
    ] ifFalse:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   702
	self realize.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   703
    ].
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   704
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   705
    "
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   706
     bring us to the top
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   707
    "
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   708
    self raise.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   709
    Display synchronizeOutput.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   710
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   711
    "
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   712
     enter private event handling loop
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   713
    "
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   714
    canContinue := true.
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   715
    exitAction := nil.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   716
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   717
    self controlLoop.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   718
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   719
    "
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   720
     release all context stuff.
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   721
     This is required, since the debugger is reused,
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   722
     to avoid keeping references to the debuggees objects
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   723
     forever.
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   724
    "
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   725
    contextArray := nil.
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   726
    codeView contents:nil.
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   727
    codeView acceptAction:nil.
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
   728
    contextView contents:nil.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   729
    receiverInspector release.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   730
    contextInspector release.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   731
571fd5eee315 Initial revision
claus
parents:
diff changeset
   732
    (exitAction == #step) ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   733
	self unrealize.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   734
	device synchronizeOutput.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   735
	(exitAction == #abort) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   736
	    selectedContext := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   737
	    busy := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   738
	    exclusive ifTrue:[CachedExclusive := self] ifFalse:[CachedDebugger := self].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   739
	    "
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   740
	     have to catch errors occuring in unwind-blocks
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   741
	    "
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   742
	    Object errorSignal handle:[:ex |
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   743
		'ignored error while unwinding: ' errorPrint.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   744
		ex errorString errorPrintNL.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   745
		ex proceed
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   746
	    ] do:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   747
		Object abortSignal raise.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   748
	    ].
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   749
	    'abort failed' errorPrintNL
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   750
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   751
	(exitAction == #return) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   752
	    selectedContext notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   753
		con := selectedContext.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   754
		selectedContext := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   755
		busy := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   756
		exclusive ifTrue:[CachedExclusive := self] ifFalse:[CachedDebugger := self].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   757
		"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   758
		 have to catch errors occuring in unwind-blocks
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   759
		"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   760
		Object errorSignal handle:[:ex |
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   761
		    'ignored error while unwinding: ' errorPrint.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   762
		    ex errorString errorPrintNL.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   763
		    ex proceed
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   764
		] do:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   765
		    con unwind.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   766
		].
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   767
		'cannot return selected context' errorPrintNL
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   768
	    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   769
	] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   770
	    (exitAction == #restart) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   771
		selectedContext notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   772
		    con := selectedContext.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   773
		    selectedContext := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   774
		    busy := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   775
		    exclusive ifTrue:[CachedExclusive := self] ifFalse:[CachedDebugger := self].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   776
		    "
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   777
		     have to catch errors occuring in unwind-blocks
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   778
		    "
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   779
		    Object errorSignal handle:[:ex |
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   780
			'ignored error while unwinding: ' errorPrint.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   781
			ex errorString errorPrintNL.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   782
			ex proceed
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   783
		    ] do:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   784
			con restart.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   785
		    ].
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   786
		    'cannot restart selected context' errorPrintNL
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   787
		]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   788
	    ] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   789
		((exitAction == #terminate) or:[exitAction == #quickTerminate]) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   790
		    selectedContext := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   791
		    busy := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   792
		    exclusive ifTrue:[CachedExclusive := self] ifFalse:[CachedDebugger := self].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   793
		    exitAction == #quickTerminate ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   794
			Processor activeProcess terminateNoSignal
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   795
		    ] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   796
			"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   797
			 have to catch errors occuring in unwind-blocks
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   798
			"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   799
			Object errorSignal handle:[:ex |
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   800
			    'ignored error while unwinding: ' errorPrint.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   801
			    ex errorString errorPrintNL.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   802
			    ex proceed
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   803
			] do:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   804
			    Processor activeProcess terminate.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   805
			].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   806
		    ].
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   807
		    'cannot terminate process' errorPrintNL
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   808
		]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   809
	    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   810
	]
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   811
    ].
571fd5eee315 Initial revision
claus
parents:
diff changeset
   812
571fd5eee315 Initial revision
claus
parents:
diff changeset
   813
    selectedContext := nil.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   814
571fd5eee315 Initial revision
claus
parents:
diff changeset
   815
    grabber notNil ifTrue:[
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   816
	device grabPointerInView:grabber.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   817
	grabber := nil.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   818
    ].
571fd5eee315 Initial revision
claus
parents:
diff changeset
   819
571fd5eee315 Initial revision
claus
parents:
diff changeset
   820
    (exitAction == #step) ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   821
	"scedule another stepInterrupt
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   822
	 - must flush caches since optimized methods not always
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   823
	 look for pending interrupts"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   824
	ObjectMemory flushInlineCaches.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   825
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   826
	ObjectMemory stepInterruptHandler:self.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   827
	StepInterruptPending := true.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   828
	InterruptPending := true.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   829
	InStepInterrupt := nil
20
c09545d02817 *** empty log message ***
claus
parents: 15
diff changeset
   830
    ] ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   831
	busy := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   832
	exclusive ifTrue:[CachedExclusive := self] ifFalse:[CachedDebugger := self]
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   833
    ]
571fd5eee315 Initial revision
claus
parents:
diff changeset
   834
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   835
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   836
openOn:aProcess
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   837
    "enter the debugger on a process - 
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   838
     in this case, we are just inspecting the context chain of the process,
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   839
     not running on top of the debugged process, but as a separate
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   840
     one. (think of it as an inspector showing more detail, and offering
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   841
     some more control operations)"
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   842
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   843
    |bpanel updateButton stopButton dummy|
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   844
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   845
    busy := true.
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   846
    bigStep := false.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   847
    inspecting := true.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   848
    inspectedProcess := aProcess.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   849
    nChainShown := 50.
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   850
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   851
    bpanel := abortButton superView.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   852
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   853
    stopButton := Button new.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   854
    stopButton label:(resources at:'stop');
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   855
	       action:[self doStop].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   856
    bpanel addSubView:stopButton after:continueButton.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   857
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   858
    dummy := View extent:(20 @ 5) in:bpanel.
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   859
    dummy borderWidth:0; level:0.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   860
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   861
"/    stepButton destroy.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   862
"/    sendButton destroy.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   863
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   864
    updateButton := Button
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   865
			label:(resources at:'update')
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   866
			action:[self updateContext]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   867
			in:bpanel.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   868
    monitorToggle := Toggle in:bpanel.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   869
    monitorToggle label:(resources at:'monitor').
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   870
    monitorToggle pressAction:[self autoUpdateOn].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   871
    monitorToggle releaseAction:[self autoUpdateOff].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   872
20
c09545d02817 *** empty log message ***
claus
parents: 15
diff changeset
   873
    "can only look into process - context chain is not active"
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   874
    canContinue := true.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   875
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   876
    terminateButton enable.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   877
    abortButton enable.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   878
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   879
    sendButton disable.
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   880
    stepButton disable.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   881
"/    continueButton disable.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   882
"/    returnButton disable.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   883
"/    restartButton disable.
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   884
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   885
    aProcess isNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   886
	terminateButton disable.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   887
	abortButton disable.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   888
	continueButton disable.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   889
	returnButton disable.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   890
	restartButton disable.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   891
    ] ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   892
	aProcess suspendedContext isNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   893
	    terminateButton disable.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   894
	].
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   895
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   896
	self setContext:aProcess suspendedContext.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   897
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   898
	catchBlock := [
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   899
	    catchBlock := nil.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   900
	    contextArray := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   901
	    selectedContext := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   902
	    (exitAction == #terminate) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   903
		aProcess terminate.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   904
	    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   905
	    (exitAction == #quickTerminate) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   906
		aProcess terminateNoSignal.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   907
	    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   908
	    super destroy
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   909
	].
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   910
    ].
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   911
    self open
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   912
! !
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   913
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   914
!DebugView methodsFor:'private control loop'!
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   915
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   916
controlLoop
571fd5eee315 Initial revision
claus
parents:
diff changeset
   917
    "this is a kludge:
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   918
	start a dispatchloop which exits when
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   919
	either continue, return or step is pressed
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   920
    "
571fd5eee315 Initial revision
claus
parents:
diff changeset
   921
571fd5eee315 Initial revision
claus
parents:
diff changeset
   922
    haveControl := true.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   923
    [haveControl] whileTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   924
	self controlLoopCatchingErrors
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   925
    ].
571fd5eee315 Initial revision
claus
parents:
diff changeset
   926
    catchBlock := nil.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   927
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   928
571fd5eee315 Initial revision
claus
parents:
diff changeset
   929
controlLoopCatchingErrors
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   930
    "setup a self removing catch-block"
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   931
    catchBlock := [catchBlock := nil. ^ nil].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   932
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   933
    exclusive ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   934
	"if we do not have multiple processes or its a system process
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   935
	 we start another dispatch loop, which exits when
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   936
	 either continue, return or step is pressed
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   937
	 or (via the catchBlock) if an error occurs.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   938
	 Since our display is an extra exclusive one (ModalDisplay)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   939
	 all processing for normal views stops here ...
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   940
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   941
	device dispatchModalWhile:[haveControl]
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   942
    ] ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   943
	"we do have multiple processes -
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   944
	 simply enter the DebugViews-Windowgroup event loop.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   945
	 effectively suspending event processing for the currently 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   946
	 active group.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   947
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   948
	SignalSet anySignal handle:[:ex |
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   949
	    |answer|
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   950
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   951
	    answer := self confirm:('error in debugger: ' , ex errorString , '\\debug again ?') withCRs. 
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   952
	    answer ifTrue:[
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   953
		Debugger enterUnconditional:(ex suspendedContext) withMessage:'error in debugger: ' , ex errorString.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   954
	    ] ifFalse:[
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   955
		'ignored error in debugger: ' errorPrint. 
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   956
		ex errorString errorPrintNL.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   957
	    ].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   958
	    ex return.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   959
	] do:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   960
	    windowGroup eventLoopWhile:[true]
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   961
	].
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   962
    ].
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   963
    catchBlock := nil.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   964
! !
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   965
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   966
!DebugView methodsFor:'private'!
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   967
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   968
busy
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   969
    ^ busy
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   970
!
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   971
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   972
showError:message
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   973
    codeView contents:(resources string:message).
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   974
    codeView flash
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   975
!
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   976
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   977
showTerminated
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   978
    self showError:'** the process has terminated **'
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   979
!
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   980
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   981
processAction:aBlock
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   982
    "do something, then update the context list"
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   983
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   984
    inspectedProcess isDead ifTrue:[
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   985
	self showTerminated.
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   986
	^ self
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   987
    ].
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   988
    inspectedProcess interruptWith:aBlock.
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   989
    "
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   990
     give the process a chance to run, then update
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   991
    "
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   992
    (Delay forSeconds:0.2) wait.
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   993
    self setContext:(inspectedProcess suspendedContext).
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   994
!
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   995
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   996
interruptProcessWith:aBlock
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   997
    "let inspected process do something, then update the context list"
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   998
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   999
    self processAction:[inspectedProcess interruptWith:aBlock.]
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1000
!
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1001
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1002
exclusive:aBoolean
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1003
    exclusive := aBoolean
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1004
!
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1005
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1006
interrestingContextFrom:aContext
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1007
    "return an interresting contexts offset, or nil.
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1008
     This is the context initially shown in the walkback.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1009
     We move up the calling chain, skipping all intermediate Signal
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1010
     and Exception contexts, to present the context in which the error
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1011
     actually occured.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1012
     Just for your convenience :-)"
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1013
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1014
    |c found offset sel prev|
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1015
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1016
    "somewhere, at the bottom, there must be a raise ..."
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1017
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1018
    c := aContext.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1019
    1 to:5 do:[:i |
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1020
	c isNil ifTrue:[^ 1 "^ nil"].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1021
	sel := c selector.
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1022
	(sel == #raise) ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1023
	    offset := i.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1024
	    found := c
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1025
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1026
	c := c sender.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1027
    ].
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1028
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1029
    (c := found) isNil ifTrue:[^ 1].
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1030
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1031
    "
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1032
     got it; move up, skipping all intermediate Signal and
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1033
     Exception contexts
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1034
    "
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1035
    prev := nil.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1036
    [   
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1037
	((c receiver isKindOf:Signal)
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1038
	or:[(c receiver isKindOf:Exception)])
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1039
    ] whileTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1040
	prev := c.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1041
	(c := c sender) isNil ifTrue:[^ offset].
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1042
	offset := offset + 1.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1043
    ].
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1044
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1045
    "
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1046
     now, we are one above the raise
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1047
    "
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1048
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1049
    "
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1050
     if the sender of the raise is one of objects error methods ...
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1051
    "
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1052
    ( #( halt halt: 
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1053
	 error error: 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1054
	 doesNotUnderstand: 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1055
	 subclassResponsibility 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1056
	 primitiveFailed) includes:c selector) 
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1057
    ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1058
	c selector == #doesNotUnderstand: ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1059
	    "
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1060
	     one more up, to get to the originating context
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1061
	    "
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1062
	    (c := c sender) isNil ifTrue:[^ offset].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1063
	    offset := offset + 1.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1064
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1065
	(c := c sender) isNil ifTrue:[^ offset].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1066
	offset := offset + 1.
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1067
    ] ifFalse:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1068
	"
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1069
	 ok, got the raise - if its a BreakPoint, look for the sender
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1070
	"
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1071
	prev receiver == MessageTracer breakpointSignal ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1072
	    offset := offset + 1
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1073
	].
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1074
    ].
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1075
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1076
    ^ offset
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1077
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1078
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1079
setContext:aContext
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1080
    "show calling chain from aContext in the walk-back listview"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1081
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1082
    |con text method caller caller2 m|
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1083
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1084
    (contextArray notNil and:[aContext == (contextArray at:1)]) ifTrue:[
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1085
	"no change"
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1086
	^ false
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1087
    ].
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1088
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1089
    m := contextView middleButtonMenu.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1090
    m notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1091
	m disable:#doShowMore.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1092
    ].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1093
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1094
    aContext isNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1095
	text := Array with:'** no context **'.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1096
	contextArray := nil.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1097
    ] ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1098
	text := OrderedCollection new:nChainShown.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1099
	contextArray := OrderedCollection new:nChainShown.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1100
	con := aContext.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1101
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1102
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1103
	 get them all
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1104
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1105
	[con notNil and:[contextArray size <= nChainShown]] whileTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1106
	    contextArray add:con.
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1107
	    (MoreDebuggingDetail == true) ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1108
		text add:(((ObjectMemory addressOf:con) printStringRadix:16) , ' ' , con printString).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1109
	    ] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1110
		text add:con printString.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1111
	    ].
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1112
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1113
	    method := con method.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1114
	    (method notNil and:[method isWrapped]) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1115
		"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1116
		 kludge: if its a wrapped method, then hide the wrap-call
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1117
		"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1118
		caller := con sender.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1119
		(caller notNil and:[caller receiver == method originalMethod]) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1120
		    caller2 := caller sender.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1121
		    (caller2 notNil and:[caller2 method == method]) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1122
			con := caller2
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1123
		    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1124
		].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1125
		caller := caller2 := nil
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1126
	    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1127
	    con := con sender
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1128
	].
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1129
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1130
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1131
	 did we reach the end ?
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1132
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1133
	(con isNil or:[con sender isNil]) ifTrue:[
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1134
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1135
	    "
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1136
	     the very last one is the startup context
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1137
	     (in main) - it has nil as receiver and nil as selector
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1138
	    "
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1139
	    contextArray last selector isNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1140
		contextArray removeLast.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1141
		text removeLast
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1142
	    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1143
	] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1144
	    m notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1145
		m enable:#doShowMore.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1146
		text add:(resources string:'*** more walkback follows - click here to see them ***')
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1147
	    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1148
	].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1149
    ].
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1150
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1151
    contextView setList: "list:" text.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1152
    receiverInspector release.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1153
    contextInspector release.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1154
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1155
    m notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1156
	m disable:#doRemoveBreakpoint.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1157
	m disable:#doImplementors.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1158
	m disable:#doSenders.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1159
    ].
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1160
    ^ true
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1161
!
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1162
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1163
updateContext
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1164
    |oldContext idx|
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1165
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1166
    inspectedProcess state == #dead ifTrue:[
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1167
	self showTerminated.
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1168
	^ self
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1169
    ].
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1170
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1171
    oldContext := selectedContext.
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1172
    (self setContext:(inspectedProcess suspendedContext)) ifTrue:[
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1173
	oldContext notNil ifTrue:[
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1174
	    contextArray notNil ifTrue:[
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1175
		idx := contextArray identityIndexOf:oldContext.
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1176
		idx ~~ 0 ifTrue:[
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1177
		    self showSelection:idx
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1178
		] ifFalse:[
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1179
		    codeView contents:('** context returned **')
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1180
		]
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1181
	    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1182
	]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1183
    ]
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1184
! !
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1185
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1186
!DebugView methodsFor:'user interaction'!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1187
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1188
showSelection:lineNr
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1189
    "user clicked on a header line - show selected code in textView"
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1190
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1191
    |con homeContext sel method code canAccept
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1192
     implementorClass lineNrInMethod rec m line|
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1193
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1194
    contextArray notNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1195
	lineNr <= contextArray size ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1196
	    con := contextArray at:lineNr.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1197
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1198
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1199
	 clicking on the '** ...'-line shows more ...
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1200
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1201
	con isNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1202
	    line := contextView list at:lineNr.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1203
	    (line startsWith:'**') ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1204
		self doShowMore.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1205
		contextView selection:lineNr.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1206
		con := contextArray at:lineNr
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1207
	    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1208
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1209
	lineNrInMethod := con lineNumber.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1210
	con isBlockContext ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1211
	    homeContext := con methodHome
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1212
	] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1213
	    homeContext := con
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1214
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1215
	contextInspector inspect:con.
55
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1216
	homeContext isNil ifTrue:[
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1217
	    "
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1218
	     mhmh - an optimized block
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1219
	     should get the block here, and get the method from
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1220
	     that one ...
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1221
	    "
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1222
	    self showError:'** sorry; cannot show code of optimized blocks (yet) **'
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1223
	] ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1224
	    sel := homeContext selector.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1225
	    sel notNil ifTrue:[
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1226
		canAccept := true.
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1227
55
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1228
"/                implementorClass := homeContext searchClass whichClassImplements:sel.
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1229
		implementorClass := homeContext methodClass.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1230
		implementorClass isNil ifTrue:[
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1231
		    "
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1232
		     special: look if this context was create by
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1233
		     valueWithReceiver kind of method invocation;
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1234
		     if so, grab the method from the sender and show it
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1235
		    "
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1236
"/                    con sender selector printNL.
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1237
		    (con sender notNil
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1238
		    and:[(con sender selector == #valueWithReceiver:arguments:selector:search:)
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1239
		    and:[con sender receiver isKindOf:Method]]) ifTrue:[
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1240
			method := con sender receiver.
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1241
			code := method source.
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1242
			canAccept := false.
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1243
		    ] ifFalse:[
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1244
			self showError:'** no method - no source **'
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1245
		    ]
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1246
		] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1247
		    method := implementorClass compiledMethodAt:sel.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1248
		    code := method source.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1249
		    code isNil ifTrue:[
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1250
			method sourceFilename notNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1251
			    codeView contents:(resources 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1252
						   string:'** no sourcefile: %1 **'
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1253
						   with:method sourceFilename).
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1254
			    codeView flash
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1255
			] ifFalse:[
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1256
			    self showError:'** no source **'
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1257
			]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1258
		    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1259
		].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1260
		code isNil ifTrue:[
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1261
		    canAccept := false.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1262
		] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1263
		    codeView contents:code.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1264
		    (lineNrInMethod notNil and:[lineNrInMethod ~~ 0]) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1265
			lineNrInMethod > codeView list size ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1266
			    lineNrInMethod := codeView list size + 1
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1267
			].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1268
			codeView selectLine:lineNrInMethod.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1269
			codeView makeSelectionVisible
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1270
		    ].
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1271
		].
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1272
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1273
		canAccept ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1274
		    codeView acceptAction:[:code | self codeAccept:code asString]
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1275
		] ifFalse:[
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1276
		    codeView acceptAction:nil.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1277
		].
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
  1278
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1279
		"fetch rec here - so we wont need context in doItAction"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1280
		rec := homeContext receiver.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1281
	    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1282
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1283
	receiverInspector inspect:rec.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1284
	codeView doItAction:[:theCode |
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1285
			 rec class compiler 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1286
			     evaluate:theCode 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1287
			     in:nil 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1288
			     receiver:rec 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1289
			     notifying:codeView 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1290
			     logged:true 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1291
			     ifFail:nil 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1292
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1293
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1294
	selectedContext := homeContext
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1295
    ].
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1296
    "clear out locals to prevent keeping around unneeded contexts (due to the
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1297
     block held in codeView).
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1298
     (not really needed, since stuff gets collected away sooner or later ..."
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1299
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1300
    con := nil.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1301
    homeContext := nil.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1302
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1303
    m := contextView middleButtonMenu.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1304
    m notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1305
	m enable:#doImplementors.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1306
	m enable:#doSenders.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1307
	m enable:#doInspectContext.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1308
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1309
	(method notNil and:[method isWrapped]) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1310
	    m enable:#doRemoveBreakpoint.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1311
	] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1312
	    m disable:#doRemoveBreakpoint.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1313
	]
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1314
    ]
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1315
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1316
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1317
codeAccept:someCode
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1318
    "user wants some code to be recompiled - must unwind stack since everything above
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1319
     and including selected method cannot be continued."
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1320
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1321
    "
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1322
     actually, this is not true, since the active methods will still be
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1323
     executed correctly - however, the code shown in the debugger is no
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1324
     longer in sync (showing the new code) with the executed code.
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1325
     Therefore, we hide those contexts to avoid confusion ....
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1326
     If you dont like this behavior, remove the 'inspecting ifFalse:' check below"
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1327
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1328
    "walk up context chain and find highest context which is either the selected context,
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1329
     or - if its a block-context - whose home is the selected context"
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1330
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1331
    |con top sel implementorClass method newMethod|
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1332
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1333
    codeView cursor:Cursor execute.
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1334
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1335
    "
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1336
     find the method-home context for this one
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1337
    "
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1338
    con := selectedContext.
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1339
    top := con.
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1340
    [con notNil] whileTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1341
	(con methodHome == selectedContext) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1342
	    top := con
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1343
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1344
	con := con sender
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1345
    ].
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1346
    "
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1347
     use class&selector to find the method for the compilation
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1348
     and compile.
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1349
    "
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1350
    sel := selectedContext selector.
55
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1351
"/    implementorClass := selectedContext searchClass whichClassImplements:sel.
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1352
    implementorClass := selectedContext methodClass.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1353
    method := implementorClass compiledMethodAt:sel.
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  1354
    newMethod := implementorClass compiler compile:someCode
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1355
					  forClass:implementorClass
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1356
					inCategory:(method category)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1357
					 notifying:codeView.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1358
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1359
    inspecting ifFalse:[
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1360
	"
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1361
	 if it worked, remove everything up to and including top
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1362
	 from context chain
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1363
	"
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1364
	(newMethod notNil and:[newMethod ~~ #Error]) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1365
	    self setContext:(top sender).
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1366
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1367
	    "
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1368
	     continue/step is no longer possible
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1369
	    "
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1370
	    canContinue := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1371
	    self showSelection:1.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1372
	    exitAction := #return
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1373
	].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1374
    ].
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1375
    codeView cursor:Cursor normal
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1376
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1377
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1378
destroy
35
cd5cb075fd6a *** empty log message ***
claus
parents: 29
diff changeset
  1379
    "closing the debugger implies an abort or continue"
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1380
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1381
    contextView middleButtonMenu hide.
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1382
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1383
    "
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1384
     we manually release all private data, since the Debugger
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1385
     is cached for reuse - thus the memory would not be collectable
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1386
     otherwise.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1387
    "
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1388
    receiverInspector release.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1389
    contextInspector release.
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1390
    inspectedProcess := nil.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1391
    exitAction := nil.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1392
    contextArray := nil.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1393
    selectedContext := nil.
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1394
"/    catchBlock := nil.
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1395
    grabber := nil.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1396
    self autoUpdateOff.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1397
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1398
    inspecting ifTrue:[
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1399
	super destroy.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1400
    ] ifFalse:[
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1401
	exclusive ifTrue:[
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1402
	    CachedExclusive := nil.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1403
	] ifFalse:[
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1404
	    CachedDebugger := nil
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1405
	]
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1406
    ].
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1407
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1408
    inspecting ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1409
	canAbort ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1410
	    self doAbort.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1411
	] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1412
	    self doContinue
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1413
	]
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1414
    ].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1415
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1416
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1417
doExit
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1418
    "exit from menu: immediate exit from smalltalk"
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1419
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1420
    Smalltalk exit
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1421
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1422
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1423
doRemoveBreakpoint
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1424
    "remove breakpoint on the selected contexts method - if any"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1425
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1426
    |implementorClass method|
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1427
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1428
    selectedContext isNil ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1429
	^ self showError:'** select a context first **'
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1430
    ].
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1431
55
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1432
"/    implementorClass := selectedContext searchClass 
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1433
"/                            whichClassImplements:selectedContext selector.
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1434
    implementorClass := selectedContext methodClass. 
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1435
    implementorClass notNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1436
	method := implementorClass compiledMethodAt:selectedContext selector.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1437
	(method notNil and:[method isWrapped]) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1438
	    MessageTracer unwrapMethod:method
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1439
	]
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1440
    ].
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1441
    contextView middleButtonMenu disable:#doRemoveBreakpoint.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1442
!
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1443
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1444
doRemoveAllBreakpoints
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1445
    "remove all trace & breakpoints - if any"
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1446
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1447
    MessageTracer unwrapAllMethods
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1448
!
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1449
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1450
doSenders
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1451
    "open a browser on the senders"
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
  1452
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1453
    selectedContext isNil ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1454
	^ self showError:'** select a context first **'
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1455
    ].
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1456
    SystemBrowser browseAllCallsOn:selectedContext selector.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1457
!
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1458
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1459
doImplementors
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1460
    "open a browser on the implementors"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1461
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1462
    selectedContext isNil ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1463
	^ self showError:'** select a context first **'
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1464
    ].
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1465
    SystemBrowser browseImplementorsOf:selectedContext selector.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1466
!
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1467
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1468
doShowMore
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1469
    "double number of contexts shown"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1470
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1471
    |oldSelection con|
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1472
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1473
    contextArray notNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1474
	oldSelection := contextView selection.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1475
	nChainShown := nChainShown * 2.
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1476
	con := contextArray at:1.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1477
	contextArray at:1 put:nil.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1478
	self setContext:con.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1479
	contextView selection:oldSelection.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1480
    ]
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1481
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1482
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1483
doSend
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1484
    "send from menu"
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1485
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1486
    inspecting ifTrue:[^ self].
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1487
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1488
    canContinue ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1489
	steppedContextAddress := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1490
	haveControl := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1491
	exitAction := #step.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1492
	ProcessorScheduler isPureEventDriven ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1493
	    "exit private event-loop"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1494
	    catchBlock notNil ifTrue:[catchBlock value].
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1495
	    'DEBUGGER: oops, send failed' errorPrintNL.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1496
"/            self warn:'send failed'.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1497
	    sendButton turnOff.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1498
"/          sendButton disable.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1499
	].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1500
    ]
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1501
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1502
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1503
doStep:lineNr
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1504
    "step from menu"
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1505
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1506
    inspecting ifTrue:[^ self].
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1507
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1508
    canContinue ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1509
	selectedContext notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1510
	    steppedContextAddress := ObjectMemory addressOf:selectedContext
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1511
	] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1512
	    steppedContextAddress := ObjectMemory addressOf:(contextArray at:2)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1513
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1514
	bigStep := true.
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1515
	skipLineNr := lineNr.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1516
	haveControl := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1517
	exitAction := #step.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1518
	ProcessorScheduler isPureEventDriven ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1519
	    "exit private event-loop"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1520
	    catchBlock notNil ifTrue:[catchBlock value].
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1521
	    'DEBUGGER: oops, step failed' errorPrintNL.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1522
"/            self warn:'step failed'.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1523
	    stepButton turnOff.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1524
"/          stepButton disable.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1525
	].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1526
    ]
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1527
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1528
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1529
doStep
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1530
    "step from menu"
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1531
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1532
    self doStep:nil
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1533
!
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1534
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1535
doSkip
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1536
    "step from menu"
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1537
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1538
    self doStep:codeView cursorLine.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1539
!
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1540
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1541
doTraceStep
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
  1542
    "tracestep - not implemented yet"
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1543
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1544
    canContinue ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1545
	tracing := true.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1546
	self doStep
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1547
    ]
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1548
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1549
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1550
doAbort
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1551
    "abort - send Object>>abortSignal, which is usually cought
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1552
     at save places (for example: in the event loop) and returns back
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1553
     from whatever the process is doing, but does not terminate it."
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1554
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1555
    inspecting ifTrue:[
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1556
	inspectedProcess isDead ifTrue:[
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1557
	    self showTerminated.
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1558
	    ^ self
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1559
	].
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1560
	(Object abortSignal isHandledIn:inspectedProcess suspendedContext) ifFalse:[
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1561
	    self showError:'** the process does not handle the abort signal **'
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1562
	] ifTrue:[
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1563
	    self interruptProcessWith:[Object abortSignal raise].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1564
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1565
	^ self
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1566
    ].
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1567
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1568
    steppedContextAddress := nil.
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1569
    haveControl := false.
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  1570
    exitAction := #abort.
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
  1571
    ProcessorScheduler isPureEventDriven ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1572
	"exit private event-loop"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1573
	catchBlock notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1574
	    abortButton turnOff.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1575
	    catchBlock value.
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1576
	    'DEBUGGER: oops, abort failed' errorPrintNL.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1577
"/            self warn:'unwind failed'.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1578
"/            abortButton disable.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1579
	]
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
  1580
    ].
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  1581
    ^ self.
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  1582
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  1583
"obsolete ..."
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1584
"/    Processor activeProcess id == 0 ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1585
"/        "dont allow termination of main-thread"
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1586
"/        exitAction := #abort
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1587
"/    ] ifFalse:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1588
"/        exitAction := #terminate 
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1589
"/    ]
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1590
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1591
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  1592
doTerminate
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1593
    "terminate - the process has a chance for cleanup"
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  1594
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1595
    inspecting ifTrue:[
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1596
	self processAction:[inspectedProcess terminate].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1597
	^ self
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1598
    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1599
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  1600
    steppedContextAddress := nil.
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  1601
    haveControl := false.
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
  1602
    exitAction := #terminate. 
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
  1603
    ProcessorScheduler isPureEventDriven ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1604
	"exit private event-loop"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1605
	catchBlock notNil ifTrue:[catchBlock value].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1606
	inspecting ifFalse:[
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1607
	    'DEBUGGER: oops, terminate failed' errorPrintNL.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1608
	    self warn:'terminate failed'.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1609
	].
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1610
	terminateButton turnOff.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1611
"/        terminateButton disable.
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
  1612
    ].
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  1613
!
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  1614
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1615
doQuickTerminate
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1616
    "quick terminate - the process will get no chance for cleanup actions"
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1617
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1618
    inspecting ifTrue:[
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1619
	self processAction:[inspectedProcess terminateNoSignal].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1620
	^ self
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1621
    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1622
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1623
    steppedContextAddress := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1624
    haveControl := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1625
    exitAction := #quickTerminate.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1626
    ProcessorScheduler isPureEventDriven ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1627
	"exit private event-loop"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1628
	catchBlock notNil ifTrue:[catchBlock value].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1629
	inspecting ifFalse:[
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1630
	    'DEBUGGER: oops, terminate failed' errorPrintNL.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1631
	    self warn:'terminate failed'.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1632
	].
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1633
	terminateButton turnOff.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1634
"/        terminateButton disable.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1635
    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1636
!
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  1637
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1638
doReturn
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1639
    "return - the selected context will do a ^nil"
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1640
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1641
    inspecting ifTrue:[
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1642
	selectedContext isNil ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1643
	    ^ self showError:'** select a context first **'
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1644
	].
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1645
	self interruptProcessWith:[selectedContext return].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1646
	^ self
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1647
    ].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1648
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1649
    steppedContextAddress := nil.
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1650
    haveControl := false.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1651
    exitAction := #return.
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
  1652
    ProcessorScheduler isPureEventDriven ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1653
	"exit private event-loop"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1654
	catchBlock notNil ifTrue:[catchBlock value].
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1655
	'DEBUGGER: oops, return failed' errorPrintNL.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1656
"/        self warn:'return failed'.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1657
	returnButton turnOff.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1658
"/        returnButton disable.
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
  1659
    ].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1660
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1661
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1662
doRestart
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1663
    "restart - the selected context will be restarted"
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1664
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1665
    inspecting ifTrue:[
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1666
	selectedContext isNil ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1667
	    ^ self showError:'** select a context first **'
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1668
	].
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1669
	self interruptProcessWith:[selectedContext restart].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1670
	^ self
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1671
    ].
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1672
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1673
    steppedContextAddress := nil.
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1674
    haveControl := false.
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
  1675
    exitAction := #restart.
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
  1676
    ProcessorScheduler isPureEventDriven ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1677
	"exit private event-loop"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1678
	catchBlock notNil ifTrue:[catchBlock value].
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1679
	'DEBUGGER: oops, restart failed' errorPrintNL.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1680
"/        self warn:'restart failed'.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1681
	restartButton turnOff.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1682
"/        restartButton disable
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
  1683
    ].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1684
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1685
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1686
doTrace
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
  1687
    "tracing - not really implemented ..."
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
  1688
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1689
    |v b|
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1690
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
  1691
    self warn:'this function is not yet implemented'.
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
  1692
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
  1693
false ifTrue:[
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1694
    traceView isNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1695
	v := StandardSystemView on:Display.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1696
	v label:'Debugger-Trace'.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1697
	v icon:icon.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1698
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1699
	b := Button label:'untrace' in:v.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1700
	b origin:(0 @ 0) extent:(1.0 @ (b height)).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1701
	b action:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1702
	    StepInterruptPending := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1703
	    tracing := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1704
	    v unrealize.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1705
	    traceView := nil
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1706
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1707
	traceView := ScrollableView for:TextCollector in:v.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1708
	traceView origin:(0 @ (b height))
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1709
		  extent:[v width @ (v height - b height)]
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1710
    ].
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1711
    v realize.
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
  1712
].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1713
    tracing := true.
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1714
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1715
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1716
doNoTrace
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1717
    traceView notNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1718
	traceView topView destroy.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1719
	traceView := nil.
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
  1720
    ].
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
  1721
    tracing := false
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1722
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1723
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1724
doStop
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1725
    "stop the process (if its running, otherwise this is a no-op)"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1726
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1727
    inspecting ifTrue:[
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1728
	self processAction:[inspectedProcess suspend].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1729
	^ self
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1730
    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1731
!
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1732
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1733
doContinue
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1734
    "continue from menu"
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1735
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1736
    inspecting ifTrue:[
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1737
	self processAction:[inspectedProcess resume].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1738
	^ self
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1739
    ].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1740
    canContinue ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1741
	steppedContextAddress := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1742
	tracing := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1743
	haveControl := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1744
	exitAction := #continue.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1745
	ProcessorScheduler isPureEventDriven ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1746
	    "exit private event-loop"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1747
	    catchBlock notNil ifTrue:[catchBlock value].
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1748
	    'DEBUGGER: oops, continue failed' errorPrintNL.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1749
"/            self warn:'continue failed'.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1750
	    continueButton turnOff.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1751
"/            continueButton disable
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1752
	].
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
  1753
    ] ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1754
	inspecting ifFalse:[
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1755
	    'resuming top context' errorPrintNL.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1756
	    self showSelection:1.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1757
	    self doReturn
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1758
	]
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1759
    ]
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1760
!
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1761
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1762
doInspectContext
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1763
    "launch an inspector on the currently selected context"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1764
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1765
    contextView selection notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1766
	(contextView selectionValue startsWith:'**') ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1767
	    (contextArray at:(contextView selection)) inspect.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1768
	]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1769
    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1770
!
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1771
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1772
autoUpdateOff
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1773
    "stop the update process"
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1774
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1775
    updateProcess notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1776
	monitorToggle lampColor:(Color yellow).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1777
	updateProcess terminate.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1778
	updateProcess := nil
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1779
    ]
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1780
!
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1781
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1782
autoUpdateOn
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1783
    "fork a subprocess which updates the contextList in regular intervals"
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1784
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1785
    updateProcess isNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1786
	updateProcess := 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1787
	    [
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1788
		[true] whileTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1789
		    monitorToggle showLamp ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1790
			monitorToggle lampColor:(Color yellow).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1791
		    ] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1792
			monitorToggle activeForegroundColor:Color black.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1793
		    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1794
		    (Delay forSeconds:0.25) wait.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1795
		    self updateContext.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1796
		    monitorToggle showLamp ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1797
			monitorToggle lampColor:(Color red).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1798
		    ] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1799
			monitorToggle activeForegroundColor:Color red.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1800
		    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1801
		    (Delay forSeconds:0.25) wait.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1802
		    self updateContext.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1803
		]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1804
	    ] forkAt:(Processor activePriority - 1)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1805
    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1806
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1807
! !