DebugView.st
author Claus Gittinger <cg@exept.de>
Sat, 11 Nov 1995 16:41:09 +0100
changeset 165 df29ee4514c1
parent 155 33c9fa03fc79
child 167 1fc176fd017e
permissions -rw-r--r--
uff - version methods changed to return stings
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
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    13
'From Smalltalk/X, Version:2.10.4 on 25-feb-1995 at 9:36:24 am'!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    14
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    15
StandardSystemView subclass:#DebugView
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    16
	 instanceVariableNames:'busy haveControl exitAction canContinue contextView codeView
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
    17
		receiverInspector contextInspector contextArray selectedContext
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
    18
		catchBlock grabber traceView tracing bigStep skipLineNr
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
    19
		steppedContextAddress canAbort abortButton terminateButton
78
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
    20
		continueButton stepButton nextButton sendButton returnButton restartButton
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
    21
		exclusive inspecting nChainShown inspectedProcess updateProcess
127
claus
parents: 126
diff changeset
    22
		stopButton updateButton monitorToggle stepping steppedContextLineno actualContext inWrap'
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    23
	 classVariableNames:'CachedDebugger CachedExclusive OpenDebuggers MoreDebuggingDetail'
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    24
	 poolDictionaries:''
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    25
	 category:'Interface-Debugger'
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    26
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
    27
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    28
!DebugView class methodsFor:'documentation'!
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    30
copyright
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    31
"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    32
 COPYRIGHT (c) 1989 by Claus Gittinger
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    33
	      All Rights Reserved
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    34
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    35
 This software is furnished under a license and may be used
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    36
 only in accordance with the terms of that license and with the
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    37
 inclusion of the above copyright notice.   This software may not
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    38
 be provided or otherwise made available to, or used by, any
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    39
 other person.  No title to or ownership of the software is
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    40
 hereby transferred.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    41
"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    42
!
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    43
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    44
version
165
df29ee4514c1 uff - version methods changed to return stings
Claus Gittinger <cg@exept.de>
parents: 155
diff changeset
    45
    ^ '$Header: /cvs/stx/stx/libtool/DebugView.st,v 1.48 1995-11-11 15:39:37 cg Exp $'
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    46
!
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    47
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    48
documentation
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    49
"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    50
    this class implements a graphical debugger interface.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    51
    The debugger usually sits on top of the faulting process,
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    52
    taking over its event processing. Thus only the 'stopped' process is affected;
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    53
    other processes continue to respond to events.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    54
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    55
    The one exception is when an error occurs within the dispatcher process
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    56
    or in one of the eventhandler processes - in this case, the debugger
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    57
    will sit on an exclusive display connection.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    58
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    59
    The whole debugging will be changed, once the required process primitives
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    60
    are available, which allow control of another processes execution
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    61
    (i.e. single-step, restart & return). The setup will be changed then,
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    62
    to have the debugger control the debuggee (i.e. two processes)
35
cd5cb075fd6a *** empty log message ***
claus
parents: 29
diff changeset
    63
cd5cb075fd6a *** empty log message ***
claus
parents: 29
diff changeset
    64
    See additional information in 'doc/misc/debugger.doc'.
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    65
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    66
    Notice: the DebugView class caches the last used debugger in a class
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    67
    variable. It may happen, that a malfunctioning debugger (for example,
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    68
    a halfway destoyed one) is kept there. You will notice this, if a
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    69
    debugger comes up without showing any contents. In this case, close
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    70
    (or destroy) the broken debugView, and execute
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    71
	Debugger newDebugger
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    72
    which removes the cached debugger and forces creation of a new one the
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    73
    next time. This is a temporary workaround - the debugger will be fixed to
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
    74
    avoid this problem.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    75
"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    76
! !
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    77
571fd5eee315 Initial revision
claus
parents:
diff changeset
    78
!DebugView class methodsFor:'instance creation'!
571fd5eee315 Initial revision
claus
parents:
diff changeset
    79
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    80
enterUnconditional:aContext withMessage:aString
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    81
    "enter a debugger - do not check for recursive invocation"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    82
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    83
    |aDebugger|
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    84
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    85
    StepInterruptPending := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    86
    aDebugger := self new.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    87
    aDebugger setLabelFor:aString in:Processor activeProcess.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    88
    aDebugger enter:aContext.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    89
    ^ nil
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    90
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    91
    "nil halt"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    92
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
    93
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    94
new
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
    95
    "return a new DebugView - return a cached debugger if it already
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    96
     exists"
571fd5eee315 Initial revision
claus
parents:
diff changeset
    97
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
    98
    |debugger|
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
    99
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   100
    "
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   101
     need a blocking debugger if no processes or 
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   102
     or if its a timing/interrupt process 
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   103
     (because otherwise we would not get any events here ...
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   104
    "
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   105
    Processor activeProcessIsSystemProcess ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   106
	CachedExclusive isNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   107
	    debugger := self newExclusive
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   108
	] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   109
	    debugger := CachedExclusive.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   110
	    CachedExclusive := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   111
	].
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
   112
    ] ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   113
	CachedDebugger isNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   114
	    debugger := super new.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   115
	    debugger label:'Debugger'.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   116
	    debugger icon:(Form fromFile:'Debugger.xbm' resolution:100).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   117
	] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   118
	    debugger := CachedDebugger.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   119
	    CachedDebugger := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   120
	]
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
   121
    ].
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
   122
    ^ debugger
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   123
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   124
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   125
enter:aContext withMessage:aString
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   126
    "enter a debugger; if this is a recursive invocation, enter
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   127
     a MiniDebugger instead.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   128
     This is the standard way of entering the debugger;
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   129
     sent from error- and halt messages."
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   130
93
claus
parents: 92
diff changeset
   131
    |active|
claus
parents: 92
diff changeset
   132
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   133
    StepInterruptPending := nil.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   134
62
8ee283ae48b2 *** empty log message ***
claus
parents: 61
diff changeset
   135
    thisContext isRecursive ifTrue:[
93
claus
parents: 92
diff changeset
   136
	^ MiniDebugger enterWithMessage:'recursive error in debugger'.
62
8ee283ae48b2 *** empty log message ***
claus
parents: 61
diff changeset
   137
    ].
8ee283ae48b2 *** empty log message ***
claus
parents: 61
diff changeset
   138
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   139
    "
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   140
     well, it could be a stepping or sending debugger up there;
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   141
     in this case, return to it. This happens, when a stepping process
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   142
     runs into an error (for example, a halt). In this case, we want the
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   143
     stepping debugger to come up again instead of a new one.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   144
    "
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   145
    OpenDebuggers notNil ifTrue:[
93
claus
parents: 92
diff changeset
   146
	active := Processor activeProcess.
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   147
	OpenDebuggers do:[:aDebugger |
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   148
	    aDebugger notNil ifTrue:[
93
claus
parents: 92
diff changeset
   149
		(aDebugger inspectedProcess == active) ifTrue:[
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   150
"/ 'entering stepping debugger again' printNL.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   151
		    aDebugger unstep.
93
claus
parents: 92
diff changeset
   152
		    aDebugger setLabelFor:aString in:active.
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   153
		    ^ aDebugger enter:aContext.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   154
		]
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   155
	    ]
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   156
	]
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   157
    ].
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   158
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   159
    ^ self enterUnconditional:aContext withMessage:aString
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   160
!
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   161
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   162
newExclusive
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   163
    "return a debugger for exclusive display access"
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
   164
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   165
    |debugger|
14
e07eee5d93ca *** empty log message ***
claus
parents: 13
diff changeset
   166
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   167
    debugger := super new.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   168
    debugger label:'Debugger'.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   169
    debugger icon:(Form fromFile:'Debugger.xbm' resolution:100).
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   170
    debugger exclusive:true.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   171
    ^ debugger
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   172
!
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   173
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   174
newDebugger
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   175
    "force creation of a new debugger"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   176
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   177
    CachedDebugger := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   178
    CachedExclusive := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   179
    OpenDebuggers := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   180
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   181
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   182
     DebugView newDebugger
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   183
    "
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   184
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   185
105
claus
parents: 101
diff changeset
   186
lowSpaceCleanup 
claus
parents: 101
diff changeset
   187
    "in low memory situations, give up cached debuggers"
claus
parents: 101
diff changeset
   188
claus
parents: 101
diff changeset
   189
    self newDebugger
claus
parents: 101
diff changeset
   190
!
claus
parents: 101
diff changeset
   191
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   192
openOn:aProcess
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   193
    "start a  debugger on aProcess
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   194
     (actually not more than a good-looking inspector)"
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   195
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   196
    |aDebugger label nm|
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   197
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   198
    aDebugger := super new.
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   199
    aDebugger icon:(Form fromFile:'Debugger.xbm' resolution:100).
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   200
    aProcess notNil ifTrue:[
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   201
	nm := aProcess name.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   202
	nm notNil ifTrue:[
61
cb5e3560bd82 *** empty log message ***
claus
parents: 58
diff changeset
   203
	    nm := (nm contractTo:17) , '-' , aProcess id printString
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   204
	] ifFalse:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   205
	    nm := aProcess id printString
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   206
	].
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
   207
	label := 'Debugger [' , nm , ']'.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   208
    ] ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   209
	label := 'no process'
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   210
    ].
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   211
    aDebugger label:label.
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   212
    aDebugger iconLabel:'Debugger'.
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   213
    aDebugger openOn:aProcess.
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
   214
    ^ nil
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   215
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   216
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   217
enterWithMessage:aString
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   218
    "the standard way of entering the debugger - sent from Objects
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   219
     error- and halt messages"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   220
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   221
    ^ self enter:(thisContext sender) withMessage:aString
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   222
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   223
    "Debugger enterWithMessage:'hi there'"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   224
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   225
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   226
enter
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   227
    "another way of entering the debugger"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   228
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   229
    ^ self enter:(thisContext sender) withMessage:'Debugger'
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   230
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   231
    "Debugger enter"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   232
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   233
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   234
enter:aContext
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   235
    "enter the debugger on aContext"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   236
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   237
    ^ self enter:aContext withMessage:'Debugger'
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   238
! !
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   239
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   240
!DebugView methodsFor:'private control loop'!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   241
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   242
controlLoop
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   243
    "this is a kludge:
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   244
	start a dispatchloop which exits when
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   245
	either continue, return or step is pressed
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   246
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   247
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   248
    haveControl := true.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   249
    [haveControl] whileTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   250
	self controlLoopCatchingErrors
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   251
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   252
    catchBlock := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   253
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   254
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   255
controlLoopCatchingErrors
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   256
    "setup a self removing catch-block"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   257
    catchBlock := [catchBlock := nil. ^ nil].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   258
155
33c9fa03fc79 dont access windowGroup if debugger is a modal one
Claus Gittinger <cg@exept.de>
parents: 132
diff changeset
   259
    (exclusive or:[windowGroup isNil]) ifTrue:[
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   260
	"if we do not have multiple processes or its a system process
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   261
	 we start another dispatch loop, which exits when
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   262
	 either continue, return or step is pressed
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   263
	 or (via the catchBlock) if an error occurs.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   264
	 Since our display is an extra exclusive one 
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   265
	 all processing for normal views stops here ...
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   266
	"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   267
	device dispatchModalWhile:[haveControl]
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   268
    ] ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   269
	"we do have multiple processes -
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   270
	 simply enter the DebugViews-Windowgroup event loop.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   271
	 effectively suspending event processing for the currently 
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   272
	 active group.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   273
	"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   274
	SignalSet anySignal handle:[:ex |
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   275
	    |answer|
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   276
108
claus
parents: 107
diff changeset
   277
"/            answer := self confirm:('error in debugger: ' , ex errorString , '\\debug again ?') withCRs. 
claus
parents: 107
diff changeset
   278
"/            answer ifTrue:[
claus
parents: 107
diff changeset
   279
"/                Debugger enterUnconditional:(ex suspendedContext) withMessage:'error in debugger: ' , ex errorString.
claus
parents: 107
diff changeset
   280
"/            ] ifFalse:[
claus
parents: 107
diff changeset
   281
"/                'ignored error in debugger: ' errorPrint. 
claus
parents: 107
diff changeset
   282
"/                ex errorString errorPrintNL.
claus
parents: 107
diff changeset
   283
"/            ].
claus
parents: 107
diff changeset
   284
	    answer := Dialog 
claus
parents: 107
diff changeset
   285
			choose:('error in debugger: ' , ex errorString , '\\debug again ?') withCRs
claus
parents: 107
diff changeset
   286
			labels:#('debug' 'proceed' 'ignore' ) 
claus
parents: 107
diff changeset
   287
			values:#(#debug #proceed #ignore) 
claus
parents: 107
diff changeset
   288
			default:#ignore.
claus
parents: 107
diff changeset
   289
	    answer == #debug ifTrue:[
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   290
		Debugger enterUnconditional:(ex suspendedContext) withMessage:'error in debugger: ' , ex errorString.
108
claus
parents: 107
diff changeset
   291
		ex proceed.
claus
parents: 107
diff changeset
   292
	    ].
claus
parents: 107
diff changeset
   293
	    answer == #proceed ifTrue:[
claus
parents: 107
diff changeset
   294
		ex proceed.
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   295
	    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   296
	    ex return.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   297
	] do:[
93
claus
parents: 92
diff changeset
   298
	    windowGroup eventLoopWhile:[true] onLeave:[]
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   299
	].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   300
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   301
    catchBlock := nil.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   302
! !
571fd5eee315 Initial revision
claus
parents:
diff changeset
   303
571fd5eee315 Initial revision
claus
parents:
diff changeset
   304
!DebugView methodsFor:'initialization'!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   305
571fd5eee315 Initial revision
claus
parents:
diff changeset
   306
initialize
101
claus
parents: 100
diff changeset
   307
    |v panel hpanel bpanel separator|
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   308
571fd5eee315 Initial revision
claus
parents:
diff changeset
   309
    super initialize.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   310
571fd5eee315 Initial revision
claus
parents:
diff changeset
   311
    font := font on:device.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   312
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
   313
    busy := false.
14
e07eee5d93ca *** empty log message ***
claus
parents: 13
diff changeset
   314
    exclusive := false.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   315
    inspecting := false.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   316
    exitAction := nil.
10
46e0d4f2079f *** empty log message ***
claus
parents: 7
diff changeset
   317
    bigStep := false.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   318
    canContinue := false.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   319
    canAbort := false.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   320
571fd5eee315 Initial revision
claus
parents:
diff changeset
   321
    bpanel := HorizontalPanelView
101
claus
parents: 100
diff changeset
   322
"/                        origin:(0.0 @ 0.0)
claus
parents: 100
diff changeset
   323
"/                        extent:(1.0 @ (font height * 2))
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   324
			    in:self.
101
claus
parents: 100
diff changeset
   325
    bpanel horizontalLayout:#leftSpace.
claus
parents: 100
diff changeset
   326
    bpanel verticalSpace:ViewSpacing // 2.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   327
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
   328
    terminateButton := Button
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   329
			label:(resources at:'terminate')
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   330
			action:[terminateButton turnOffWithoutRedraw. self doTerminate]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   331
			in:bpanel.
101
claus
parents: 100
diff changeset
   332
    separator := View extent:(10 @ 5) in:bpanel.
claus
parents: 100
diff changeset
   333
    separator borderWidth:0; level:0.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   334
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   335
    abortButton := Button
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   336
			label:(resources at:'abort')
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   337
			action:[abortButton turnOffWithoutRedraw. self doAbort]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   338
			in:bpanel.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
   339
    returnButton := Button
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   340
			label:(resources at:'return')
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   341
			action:[returnButton turnOff. self doReturn]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   342
			in:bpanel.
20
c09545d02817 *** empty log message ***
claus
parents: 15
diff changeset
   343
c09545d02817 *** empty log message ***
claus
parents: 15
diff changeset
   344
    restartButton := Button
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   345
			label:(resources at:'restart')
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   346
			action:[restartButton turnOff. self doRestart]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   347
			in:bpanel.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   348
101
claus
parents: 100
diff changeset
   349
    separator := View extent:(10 @ 5) in:bpanel.
claus
parents: 100
diff changeset
   350
    separator borderWidth:0; level:0.
20
c09545d02817 *** empty log message ***
claus
parents: 15
diff changeset
   351
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   352
    continueButton := Button
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   353
			label:(resources at:'continue')
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   354
			action:[continueButton turnOffWithoutRedraw. self doContinue]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   355
			in:bpanel.
101
claus
parents: 100
diff changeset
   356
claus
parents: 100
diff changeset
   357
    separator := View extent:(10 @ 5) in:bpanel.
claus
parents: 100
diff changeset
   358
    separator borderWidth:0; level:0.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   359
78
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
   360
    nextButton := Button
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
   361
			label:(resources at:'next')
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
   362
			action:[stepButton turnOff. self doNext]
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
   363
			in:bpanel.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   364
    stepButton := Button
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   365
			label:(resources at:'step')
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   366
			action:[stepButton turnOff. self doStep]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   367
			in:bpanel.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   368
    sendButton := Button
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   369
			label:(resources at:'send')
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   370
			action:[sendButton turnOff. self doSend]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   371
			in:bpanel.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   372
101
claus
parents: 100
diff changeset
   373
    bpanel origin:(0.0 @ 0.0)
105
claus
parents: 101
diff changeset
   374
	   extent:(1.0 @ (bpanel preferredExtent y)).
101
claus
parents: 100
diff changeset
   375
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   376
    panel := VariableVerticalPanel
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   377
			origin:(0.0 @ bpanel height)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   378
			corner:(1.0 @ 1.0)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   379
			    in:self.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   380
571fd5eee315 Initial revision
claus
parents:
diff changeset
   381
    v := ScrollableView for:SelectionInListView in:panel.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   382
    v origin:(0.0 @ 0.0) corner:(1.0 @ 0.25).
571fd5eee315 Initial revision
claus
parents:
diff changeset
   383
571fd5eee315 Initial revision
claus
parents:
diff changeset
   384
    contextView := v scrolledView.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   385
    contextView action:[:lineNr | self showSelection:lineNr].
571fd5eee315 Initial revision
claus
parents:
diff changeset
   386
571fd5eee315 Initial revision
claus
parents:
diff changeset
   387
    v := ScrollableView for:CodeView in:panel.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   388
    v origin:(0.0 @ 0.25) corner:(1.0 @ 0.75).
571fd5eee315 Initial revision
claus
parents:
diff changeset
   389
571fd5eee315 Initial revision
claus
parents:
diff changeset
   390
    codeView := v scrolledView.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   391
571fd5eee315 Initial revision
claus
parents:
diff changeset
   392
    hpanel := VariableHorizontalPanel in:panel.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   393
    hpanel origin:(0.0 @ 0.75) corner:(1.0 @ 1.0).
571fd5eee315 Initial revision
claus
parents:
diff changeset
   394
571fd5eee315 Initial revision
claus
parents:
diff changeset
   395
    receiverInspector := InspectorView
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   396
				origin:(0.0 @ 0.0) corner:(0.5 @ 1.0)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   397
				    in:hpanel.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   398
571fd5eee315 Initial revision
claus
parents:
diff changeset
   399
    contextInspector := ContextInspectorView
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   400
				origin:(0.5 @ 0.0) corner:(1.0 @ 1.0)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   401
				    in:hpanel
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   402
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   403
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   404
createOnTop
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   405
    ^ false "true"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   406
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   407
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   408
initializeMiddleButtonMenu
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   409
    |labels m|
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   410
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   411
    labels := resources array:#(
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   412
				'show more'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   413
				'-'
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   414
				'skip'
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   415
				'-'
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   416
"
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   417
				'continue'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   418
				'terminate'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   419
				'abort'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   420
				'-'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   421
				'step'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   422
				'send'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   423
				'-'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   424
				'return'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   425
				'restart'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   426
				'-'
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   427
"
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   428
				'remove breakpoint'
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
   429
				'remove all trace & breakpoints'
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   430
				'-'
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   431
				'browse class'
108
claus
parents: 107
diff changeset
   432
				'browse class hierarchy'
claus
parents: 107
diff changeset
   433
				'browse full class protocol'
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   434
				'implementors'
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   435
				'senders'
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   436
				'-'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   437
				'inspect context'
124
claus
parents: 111
diff changeset
   438
				'copy walkback text'
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   439
				'-'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   440
				'quickTerminate'
105
claus
parents: 101
diff changeset
   441
				'='
124
claus
parents: 111
diff changeset
   442
				'exit smalltalk (no confirmation)'
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   443
			      ).
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   444
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   445
    m := (PopUpMenu 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   446
				labels:labels
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   447
			     selectors:#(
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   448
					 showMore
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   449
					 nil
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   450
					 skip
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   451
					 nil
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   452
"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   453
					 doContinue
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   454
					 doTerminate
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   455
					 doAbort
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   456
					 nil
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   457
					 doStep
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   458
					 doSend
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   459
					 nil
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   460
					 doReturn
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   461
					 doRestart
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   462
					 nil
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
   463
"
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   464
					 removeBreakpoint
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   465
					 removeAllBreakpoints
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   466
					 nil
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   467
					 browseClass
108
claus
parents: 107
diff changeset
   468
					 browseClassHierarchy
claus
parents: 107
diff changeset
   469
					 browseFullClassProtocol
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   470
					 implementors
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   471
					 senders
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   472
					 nil
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   473
					 inspectContext
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   474
					 nil
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   475
					 quickTerminate
124
claus
parents: 111
diff changeset
   476
					 copyWalkbackText
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   477
					 nil
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   478
					 exit
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   479
					)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   480
				  receiver:self
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   481
				       for:contextView).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   482
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   483
    contextView middleButtonMenu:m. 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   484
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   485
    inspecting ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   486
	m notNil ifTrue:[
106
claus
parents: 105
diff changeset
   487
	    m disableAll:#(doTraceStep removeBreakpoint).
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   488
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   489
    ]
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   490
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   491
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   492
setLabelFor:aMessage in:aProcess
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   493
    |l nm|
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   494
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   495
    l := aMessage , ' ('.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   496
    nm := aProcess name.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   497
    nm notNil ifTrue:[
90
60d0bb749a1c *** empty log message ***
claus
parents: 81
diff changeset
   498
	l := l , (nm contractTo:17) , ''.
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   499
    ].
90
60d0bb749a1c *** empty log message ***
claus
parents: 81
diff changeset
   500
    l := l , '[' , aProcess id printString , '])'.
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   501
    self label:l.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   502
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   503
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   504
addToCurrentProject
571fd5eee315 Initial revision
claus
parents:
diff changeset
   505
    "ignored here"
571fd5eee315 Initial revision
claus
parents:
diff changeset
   506
571fd5eee315 Initial revision
claus
parents:
diff changeset
   507
    ^ self
571fd5eee315 Initial revision
claus
parents:
diff changeset
   508
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   509
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   510
realize
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   511
    super realize.
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   512
    exclusive ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   513
	windowGroup := nil
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
   514
    ].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   515
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   516
    inspecting ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   517
	inspectedProcess notNil ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   518
	    "
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   519
	     set prio somewhat higher (by 2, to allow walkBack-update process
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   520
	     to run between mine and the debugged processes prio)
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   521
	    "
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   522
	    Processor activeProcess 
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   523
		priority:(inspectedProcess priority + 2 min:16).
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   524
	]
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   525
    ]
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   526
! !
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   527
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   528
!DebugView methodsFor:'private'!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   529
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   530
cacheMyself
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   531
    "remember myself for next debug session"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   532
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   533
    "caching the last debugger will make the next debugger appear
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   534
     faster, since no resources have to be allocated in the display.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   535
     We have to be careful to release all refs to the debuggee, though.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   536
     Otherwise, the GC will not be able to release it"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   537
155
33c9fa03fc79 dont access windowGroup if debugger is a modal one
Claus Gittinger <cg@exept.de>
parents: 132
diff changeset
   538
    windowGroup notNil ifTrue:[
165
df29ee4514c1 uff - version methods changed to return stings
Claus Gittinger <cg@exept.de>
parents: 155
diff changeset
   539
	windowGroup setProcess:nil.
155
33c9fa03fc79 dont access windowGroup if debugger is a modal one
Claus Gittinger <cg@exept.de>
parents: 132
diff changeset
   540
    ].
132
claus
parents: 127
diff changeset
   541
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   542
    busy := false.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   543
    codeView acceptAction:nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   544
    codeView doItAction:nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   545
    codeView contents:nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   546
    receiverInspector release.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   547
    contextInspector release.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   548
    inspectedProcess := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   549
    exitAction := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   550
    contextArray := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   551
    selectedContext := actualContext := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   552
    catchBlock := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   553
    grabber := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   554
    self autoUpdateOff.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   555
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   556
    exclusive ifTrue:[CachedExclusive := self] ifFalse:[CachedDebugger := self].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   557
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   558
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   559
showError:message
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   560
    codeView contents:(resources string:message).
81
b3b4d34c5ada *** empty log message ***
claus
parents: 78
diff changeset
   561
    shown ifTrue:[
90
60d0bb749a1c *** empty log message ***
claus
parents: 81
diff changeset
   562
	exclusive ifFalse:[codeView flash]
81
b3b4d34c5ada *** empty log message ***
claus
parents: 78
diff changeset
   563
    ]
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   564
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   565
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   566
interrestingContextFrom:aContext
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   567
    "return an interresting contexts offset, or nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   568
     This is the context initially shown in the walkback.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   569
     We move up the calling chain, skipping all intermediate Signal
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   570
     and Exception contexts, to present the context in which the error
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   571
     actually occured.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   572
     Just for your convenience :-)"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   573
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   574
    |c found offset sel prev ex|
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   575
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   576
    "somewhere, at the bottom, there must be a raise ..."
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   577
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   578
    c := aContext.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   579
    1 to:5 do:[:i |
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   580
	c isNil ifTrue:[^ 1 "^ nil"].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   581
	sel := c selector.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   582
	(sel == #raise) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   583
	    (c receiver isKindOf:Exception) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   584
		ex := c receiver
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   585
	    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   586
	    offset := i.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   587
	    found := c
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   588
	].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   589
	c := c sender.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   590
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   591
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   592
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   593
     if this is a noHandler exception, skip forward
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   594
     to the erronous context
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   595
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   596
    ex notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   597
	ex signal == Signal noHandlerSignal ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   598
	    c := ex suspendedContext
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   599
	]
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   600
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   601
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   602
    (c := found) isNil ifTrue:[^ 1].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   603
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   604
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   605
     got it; move up, skipping all intermediate Signal and
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   606
     Exception contexts
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   607
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   608
    prev := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   609
    [   
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   610
	((c receiver isSignal)
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   611
	or:[(c receiver isKindOf:Exception)])
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   612
    ] whileTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   613
	prev := c.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   614
	(c := c sender) isNil ifTrue:[^ offset].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   615
	offset := offset + 1.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   616
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   617
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   618
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   619
     now, we are one above the raise
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   620
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   621
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   622
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   623
     if the sender of the raise is one of objects error methods ...
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   624
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   625
    ( #( halt halt: 
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   626
	 error error: 
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   627
	 doesNotUnderstand: 
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   628
	 subclassResponsibility 
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   629
	 primitiveFailed) includes:c selector) 
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   630
    ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   631
	c selector == #doesNotUnderstand: ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   632
	    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   633
	     one more up, to get to the originating context
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   634
	    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   635
	    (c := c sender) isNil ifTrue:[^ offset].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   636
	    offset := offset + 1.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   637
	].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   638
	(c := c sender) isNil ifTrue:[^ offset].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   639
	offset := offset + 1.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   640
    ] ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   641
	"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   642
	 ok, got the raise - if its a BreakPoint, look for the sender
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   643
	"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   644
	(MessageTracer notNil and:[prev receiver == MessageTracer breakpointSignal]) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   645
	    offset := offset + 1
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   646
	].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   647
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   648
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   649
    ^ offset
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   650
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   651
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   652
inspectedProcess 
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   653
    ^ inspectedProcess 
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   654
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   655
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   656
busy
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   657
    ^ busy
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   658
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   659
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   660
stepping 
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   661
    ^ stepping 
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   662
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   663
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   664
setContext:aContext
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   665
    "show calling chain from aContext in the walk-back listview"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   666
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   667
    |con text method caller caller2 m count|
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   668
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   669
    (contextArray notNil and:[aContext == (contextArray at:1)]) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   670
	"no change"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   671
	^ false
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   672
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   673
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   674
    m := contextView middleButtonMenu.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   675
    m notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   676
	m disable:#showMore.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   677
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   678
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   679
    aContext isNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   680
	text := Array with:'** no context **'.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   681
	contextArray := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   682
    ] ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   683
	text := OrderedCollection new:nChainShown.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   684
	contextArray := OrderedCollection new:nChainShown.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   685
	con := aContext.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   686
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   687
	"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   688
	 get them all
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   689
	"
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   690
	count := 0.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   691
	[con notNil and:[count <= nChainShown]] whileTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   692
	    contextArray add:con. count := count + 1.
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   693
	    (MoreDebuggingDetail == true) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   694
		text add:(((ObjectMemory addressOf:con) printStringRadix:16) , ' ' , con printString).
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   695
	    ] ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   696
		text add:con printString.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   697
	    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   698
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   699
	    method := con method.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   700
	    (method notNil and:[method isWrapped]) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   701
		"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   702
		 kludge: if its a wrapped method, then hide the wrap-call
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   703
		"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   704
		caller := con sender.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   705
		(caller notNil and:[caller receiver == method originalMethod]) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   706
		    caller2 := caller sender.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   707
		    (caller2 notNil and:[caller2 method == method]) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   708
			con := caller2
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   709
		    ]
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   710
		].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   711
		caller := caller2 := nil
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   712
	    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   713
	    con := con sender
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   714
	].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   715
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   716
	"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   717
	 did we reach the end ?
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   718
	"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   719
	(con isNil or:[con sender isNil]) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   720
	    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   721
	     the very last one is the startup context
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   722
	     (in main) - it has nil as receiver and nil as selector
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   723
	    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   724
	    contextArray last selector isNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   725
		contextArray removeLast.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   726
		text removeLast
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   727
	    ]
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   728
	] ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   729
	    m notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   730
		m enable:#showMore.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   731
		text add:(resources string:'*** more walkback follows - click here to see them ***')
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   732
	    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   733
	].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   734
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   735
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   736
    contextView setList:text.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   737
    receiverInspector release.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   738
    contextInspector release.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   739
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   740
    m notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   741
	m disable:#removeBreakpoint.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   742
	m disable:#implementors.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   743
	m disable:#senders.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   744
	m disable:#browseClass.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   745
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   746
    ^ true
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   747
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   748
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   749
showTerminated
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   750
    self showError:'** the process has terminated **'
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   751
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   752
92
claus
parents: 90
diff changeset
   753
processPerform:aMessage
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   754
    "do something, then update the context list"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   755
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   756
    inspectedProcess isDead ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   757
	self showTerminated.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   758
	^ self
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   759
    ].
92
claus
parents: 90
diff changeset
   760
    inspectedProcess perform:aMessage.
claus
parents: 90
diff changeset
   761
    "
claus
parents: 90
diff changeset
   762
     give the process a chance to run, then update
claus
parents: 90
diff changeset
   763
    "
claus
parents: 90
diff changeset
   764
    (Delay forSeconds:0.2) wait.
claus
parents: 90
diff changeset
   765
    self setContext:(inspectedProcess suspendedContext).
claus
parents: 90
diff changeset
   766
!
claus
parents: 90
diff changeset
   767
claus
parents: 90
diff changeset
   768
interruptProcessWith:aBlock
claus
parents: 90
diff changeset
   769
    "let inspected process do something, then update the context list"
claus
parents: 90
diff changeset
   770
claus
parents: 90
diff changeset
   771
    inspectedProcess isDead ifTrue:[
claus
parents: 90
diff changeset
   772
	self showTerminated.
claus
parents: 90
diff changeset
   773
	^ self
claus
parents: 90
diff changeset
   774
    ].
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   775
    inspectedProcess interruptWith:aBlock.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   776
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   777
     give the process a chance to run, then update
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   778
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   779
    (Delay forSeconds:0.2) wait.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   780
    self setContext:(inspectedProcess suspendedContext).
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   781
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   782
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   783
exclusive:aBoolean
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   784
    exclusive := aBoolean
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   785
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   786
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   787
unstep 
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   788
    stepping := false.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   789
    bigStep := false.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   790
    steppedContextAddress := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   791
    exitAction := nil
61
cb5e3560bd82 *** empty log message ***
claus
parents: 58
diff changeset
   792
!
cb5e3560bd82 *** empty log message ***
claus
parents: 58
diff changeset
   793
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   794
updateContext
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   795
    |oldContext idx|
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   796
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   797
    inspectedProcess state == #dead ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   798
	self showTerminated.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   799
	^ self
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   800
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   801
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   802
    oldContext := selectedContext.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   803
    (self setContext:(inspectedProcess suspendedContext)) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   804
	oldContext notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   805
	    contextArray notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   806
		idx := contextArray identityIndexOf:oldContext.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   807
		idx ~~ 0 ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   808
		    self showSelection:idx
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   809
		] ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   810
		    codeView contents:('** context returned **')
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   811
		]
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   812
	    ]
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   813
	]
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   814
    ]
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   815
! !
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   816
126
claus
parents: 124
diff changeset
   817
!DebugView methodsFor:'help'!
claus
parents: 124
diff changeset
   818
claus
parents: 124
diff changeset
   819
helpTextFor:aComponent
claus
parents: 124
diff changeset
   820
    |s|
claus
parents: 124
diff changeset
   821
claus
parents: 124
diff changeset
   822
    aComponent == abortButton ifTrue:[
claus
parents: 124
diff changeset
   823
	s := 'HELP_ABORT'
claus
parents: 124
diff changeset
   824
    ].
claus
parents: 124
diff changeset
   825
    aComponent == terminateButton ifTrue:[
claus
parents: 124
diff changeset
   826
	s := 'HELP_TERMINATE'
claus
parents: 124
diff changeset
   827
    ].
claus
parents: 124
diff changeset
   828
    aComponent == continueButton ifTrue:[
claus
parents: 124
diff changeset
   829
	s := 'HELP_CONTINUE'
claus
parents: 124
diff changeset
   830
    ].
claus
parents: 124
diff changeset
   831
    aComponent == stepButton ifTrue:[
claus
parents: 124
diff changeset
   832
	s := 'HELP_STEP'
claus
parents: 124
diff changeset
   833
    ].
claus
parents: 124
diff changeset
   834
    aComponent == nextButton ifTrue:[
claus
parents: 124
diff changeset
   835
	s := 'HELP_NEXT'
claus
parents: 124
diff changeset
   836
    ].
claus
parents: 124
diff changeset
   837
    aComponent == stepButton ifTrue:[
claus
parents: 124
diff changeset
   838
	s := 'HELP_STEP'
claus
parents: 124
diff changeset
   839
    ].
claus
parents: 124
diff changeset
   840
    aComponent == sendButton ifTrue:[
claus
parents: 124
diff changeset
   841
	s := 'HELP_SEND'
claus
parents: 124
diff changeset
   842
    ].
claus
parents: 124
diff changeset
   843
    aComponent == returnButton ifTrue:[
claus
parents: 124
diff changeset
   844
	s := 'HELP_RETURN'
claus
parents: 124
diff changeset
   845
    ].
claus
parents: 124
diff changeset
   846
    aComponent == restartButton ifTrue:[
claus
parents: 124
diff changeset
   847
	s := 'HELP_RESTART'
claus
parents: 124
diff changeset
   848
    ].
claus
parents: 124
diff changeset
   849
    aComponent == contextView ifTrue:[
claus
parents: 124
diff changeset
   850
	s := 'HELP_WALKBACK'
claus
parents: 124
diff changeset
   851
    ].
claus
parents: 124
diff changeset
   852
    aComponent == codeView ifTrue:[
claus
parents: 124
diff changeset
   853
	s := 'HELP_CODEVIEW'
claus
parents: 124
diff changeset
   854
    ].
claus
parents: 124
diff changeset
   855
    aComponent == monitorToggle ifTrue:[
claus
parents: 124
diff changeset
   856
	s := 'HELP_MONITOR'
claus
parents: 124
diff changeset
   857
    ].
127
claus
parents: 126
diff changeset
   858
    aComponent == updateButton ifTrue:[
claus
parents: 126
diff changeset
   859
	s := 'HELP_UPDATE'
claus
parents: 126
diff changeset
   860
    ].
claus
parents: 126
diff changeset
   861
    aComponent == stopButton ifTrue:[
claus
parents: 126
diff changeset
   862
	s := 'HELP_STOP'
claus
parents: 126
diff changeset
   863
    ].
126
claus
parents: 124
diff changeset
   864
    (aComponent isSubViewOf:receiverInspector) ifTrue:[
claus
parents: 124
diff changeset
   865
	s := 'HELP_REC_INSP'
claus
parents: 124
diff changeset
   866
    ].
claus
parents: 124
diff changeset
   867
    (aComponent isSubViewOf:contextInspector) ifTrue:[
claus
parents: 124
diff changeset
   868
	s := 'HELP_CON_INSP'
claus
parents: 124
diff changeset
   869
    ].
claus
parents: 124
diff changeset
   870
claus
parents: 124
diff changeset
   871
    s notNil ifTrue:[
claus
parents: 124
diff changeset
   872
	^ resources string:s
claus
parents: 124
diff changeset
   873
    ].
claus
parents: 124
diff changeset
   874
    ^ nil
claus
parents: 124
diff changeset
   875
claus
parents: 124
diff changeset
   876
    "Modified: 29.8.1995 / 23:38:54 / claus"
claus
parents: 124
diff changeset
   877
! !
claus
parents: 124
diff changeset
   878
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   879
!DebugView methodsFor:'basic'!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   880
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   881
enter:aContext
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   882
    "enter the debugger - get and display the context, then start an
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   883
     exclusive event loop on top of eveything else"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   884
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   885
    |con selection m idx retval s|
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   886
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   887
    busy := true.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   888
    inspecting := false.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   889
    inspectedProcess := Processor activeProcess.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   890
    stepping := false.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   891
    bigStep := false.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   892
    nChainShown := 50.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   893
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   894
    "if debugger is entered while a box has grabbed the
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   895
     pointer, we must ungrab - otherwise X wont talk to
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   896
     us here
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   897
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   898
    (grabber := device activePointerGrab) notNil ifTrue:[
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   899
	device ungrabPointer
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   900
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   901
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   902
    terminateButton enable.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   903
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   904
    drawableId notNil ifTrue:[
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   905
	"not the first time - realize at old position"
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   906
	terminateButton turnOffWithoutRedraw.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   907
	continueButton turnOffWithoutRedraw.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   908
	returnButton turnOffWithoutRedraw.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   909
	restartButton turnOffWithoutRedraw.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   910
	abortButton turnOffWithoutRedraw.
78
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
   911
	nextButton turnOffWithoutRedraw.
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   912
	stepButton turnOffWithoutRedraw.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   913
	sendButton turnOffWithoutRedraw.
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   914
    ] ifFalse:[
132
claus
parents: 127
diff changeset
   915
	self iconLabel:'Debugger'.
claus
parents: 127
diff changeset
   916
    ].
claus
parents: 127
diff changeset
   917
claus
parents: 127
diff changeset
   918
    exclusive ifFalse:[
claus
parents: 127
diff changeset
   919
	"/ create a (modal) windowGroup for myself
claus
parents: 127
diff changeset
   920
claus
parents: 127
diff changeset
   921
	windowGroup isNil ifTrue:[
claus
parents: 127
diff changeset
   922
	    windowGroup := WindowGroup new.
claus
parents: 127
diff changeset
   923
	    windowGroup addTopView:self.
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   924
	].
132
claus
parents: 127
diff changeset
   925
	windowGroup setProcess:Processor activeProcess.
claus
parents: 127
diff changeset
   926
	windowGroup setModal:true.
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   927
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   928
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   929
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   930
     get the walkback list
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   931
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   932
    self setContext:aContext.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   933
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   934
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   935
     and find the one context to show initially
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   936
     - if we came here by a send (single step), its the top context;
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   937
     - if we came here by a step (i.e. bigStep), its the top context
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   938
       (for ifs and whiles) or the sender (for regular sends).
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   939
     - otherwise, we came here by some signal raise, and we are interrested
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   940
       in the context where the raise actually occured.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   941
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   942
    exitAction == #step ifTrue:[
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   943
	selection := 1.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   944
	steppedContextAddress notNil ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   945
	    "
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   946
	     if we came here by a big-step, show the method where we are
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   947
	    "
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   948
	    (ObjectMemory addressOf:aContext) == steppedContextAddress ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   949
		selection := 1
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   950
	    ] ifFalse:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   951
		(ObjectMemory addressOf:aContext sender) == steppedContextAddress ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   952
		    selection := 2
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   953
		]
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   954
	    ].
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   955
	    "
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   956
	     for bigStep, we could also be in a block below the actual method ...
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   957
	    "
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   958
	    (aContext home notNil and:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   959
	    (ObjectMemory addressOf:aContext home) == steppedContextAddress]) ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   960
		selection := 1
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   961
	    ] ifFalse:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   962
		(aContext sender home notNil and:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   963
		(ObjectMemory addressOf:aContext sender home) == steppedContextAddress]) ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   964
		    selection := 2
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   965
		]
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   966
	    ].
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   967
	]
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   968
    ] ifFalse:[
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   969
	steppedContextAddress isNil ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   970
	    "
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   971
	     preselect a more interresting context, (where halt/raise was ...)
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   972
	    "
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   973
	    selection := self interrestingContextFrom:aContext.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   974
	] ifFalse:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   975
	    "
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   976
	     if we came here by a big-step, show the method where we are
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   977
	    "
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   978
	    (ObjectMemory addressOf:aContext) == steppedContextAddress ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   979
		selection := 1
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   980
	    ] ifFalse:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   981
		(ObjectMemory addressOf:aContext sender) == steppedContextAddress ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   982
		    selection := 2
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   983
		]
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   984
	    ]
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   985
	]
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   986
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   987
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   988
    selection notNil ifTrue:[
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   989
	self showSelection:selection.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   990
	contextView selection:selection.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   991
	selection > 1 ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   992
	    contextView scrollToLine:(selection - 1)
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   993
	]
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   994
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   995
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   996
    m := contextView middleButtonMenu.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
   997
    m notNil ifTrue:[
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   998
	canAbort := inspecting or:[Object abortSignal isHandled].
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
   999
	canAbort ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1000
	    abortButton enable.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1001
	    m enable:#doAbort.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1002
	] ifFalse:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1003
	    abortButton disable.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1004
	    m disable:#doAbort.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1005
	].
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1006
	exclusive ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1007
	    terminateButton disable.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1008
	    m disable:#doTerminate.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1009
	] ifFalse:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1010
	    terminateButton enable.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1011
	    m enable:#doTerminate.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1012
	]
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1013
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1014
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1015
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1016
     drawableId is nil, if this is a new debugger. Then do a realize.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1017
     Otherwise, its probably better to do a rerealize, which shows the
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1018
     view at the previous position, without a need for the user to set the
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1019
     position again
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1020
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1021
    drawableId notNil ifTrue:[
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1022
	self rerealize
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1023
    ] ifFalse:[
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1024
	self realize.
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1025
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1026
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1027
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1028
     bring us to the top
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1029
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1030
    self raise.
105
claus
parents: 101
diff changeset
  1031
    device flush.
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1032
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1033
    canContinue := true.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1034
    exitAction := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1035
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1036
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1037
     enter private event handling loop. This is left (and we come back here again)
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1038
     when any button was pressed which requires continuation of the debuggee or
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1039
     closedown of the debugger.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1040
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1041
132
claus
parents: 127
diff changeset
  1042
    [self controlLoop] valueOnUnwindDo:[
claus
parents: 127
diff changeset
  1043
	windowGroup notNil ifTrue:[
claus
parents: 127
diff changeset
  1044
	    windowGroup setProcess:nil.
claus
parents: 127
diff changeset
  1045
	].
claus
parents: 127
diff changeset
  1046
	self destroy
claus
parents: 127
diff changeset
  1047
    ].
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1048
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1049
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1050
     release all context stuff.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1051
     This is required to avoid keeping references to the debuggees objects
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1052
     forever. (since the debugger is reused for faster startup next time)
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1053
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1054
    contextArray := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1055
    codeView acceptAction:nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1056
    contextView contents:nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1057
    receiverInspector release.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1058
    contextInspector release.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1059
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1060
    (exitAction ~~ #step) ifTrue:[
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1061
	self unrealize.
105
claus
parents: 101
diff changeset
  1062
	device flush.
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1063
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1064
	(exitAction == #abort) ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1065
	    self cacheMyself.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1066
	    "
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1067
	     have to catch errors occuring in unwind-blocks
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1068
	    "
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1069
	    Object errorSignal handle:[:ex |
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1070
		'ignored error while unwinding: ' errorPrint.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1071
		ex errorString errorPrintNL.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1072
		ex proceed
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1073
	    ] do:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1074
		Object abortSignal raise.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1075
	    ].
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1076
	    'abort failed' errorPrintNL
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1077
	].
61
cb5e3560bd82 *** empty log message ***
claus
parents: 58
diff changeset
  1078
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1079
	(exitAction == #return) ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1080
	    selectedContext notNil ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1081
		"
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1082
		 if there is a selection in the codeView,
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1083
		 evaluate it and use the result as return value
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1084
		"
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1085
"/ disabled for now, there is almost always a selection (the current line)
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1086
"/ and that is syntactically incorrect ...
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1087
"/ ... leading to a popup warning from the codeView
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1088
"/
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1089
"/                codeView hasSelection ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1090
"/                    s := codeView selection asString.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1091
"/                    Object errorSignal handle:[:ex |
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1092
"/                        'DEBUGGER: error - returning nil' printNL.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1093
"/                        retval := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1094
"/                        ex return
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1095
"/                    ] do:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1096
"/                        retval := codeView doItAction value:s.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1097
"/                    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1098
"/                ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1099
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1100
		con := selectedContext.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1101
		self cacheMyself.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1102
		"
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1103
		 have to catch errors occuring in unwind-blocks
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1104
		"
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1105
		Object errorSignal handle:[:ex |
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1106
		    'ignored error while unwinding: ' errorPrint.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1107
		    ex errorString errorPrintNL.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1108
		    ex proceed
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1109
		] do:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1110
		    con unwind:retval.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1111
		].
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1112
		'cannot return from selected context' errorPrintNL
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1113
	    ]
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1114
	].
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1115
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1116
	(exitAction == #restart) ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1117
	    selectedContext notNil ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1118
		con := selectedContext.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1119
		self cacheMyself.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1120
		"
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1121
		 have to catch errors occuring in unwind-blocks
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1122
		"
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1123
		Object errorSignal handle:[:ex |
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1124
		    'ignored error while unwinding: ' errorPrint.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1125
		    ex errorString errorPrintNL.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1126
		    ex proceed
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1127
		] do:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1128
		    con unwindAndRestart.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1129
		].
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1130
		'cannot restart selected context' errorPrintNL
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1131
	    ]
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1132
	].
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1133
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1134
	(exitAction == #quickTerminate) ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1135
	    self cacheMyself.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1136
	    Processor activeProcess terminateNoSignal
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1137
	].
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1138
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1139
	(exitAction == #terminate) ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1140
	    self cacheMyself.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1141
	    "
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1142
	     have to catch errors occuring in unwind-blocks
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1143
	    "
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1144
	    Object errorSignal handle:[:ex |
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1145
		'ignored error while unwinding: ' errorPrint.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1146
		ex errorString errorPrintNL.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1147
		ex proceed
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1148
	    ] do:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1149
		Processor activeProcess terminate.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1150
	    ].
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1151
	    'cannot terminate process' errorPrintNL
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1152
	]
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1153
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1154
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1155
    selectedContext := actualContext := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1156
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1157
    grabber notNil ifTrue:[
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1158
	device grabPointerInView:grabber.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1159
	grabber := nil.
61
cb5e3560bd82 *** empty log message ***
claus
parents: 58
diff changeset
  1160
    ].
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1161
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1162
    (exitAction == #step) ifTrue:[
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1163
	"
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1164
	 schedule another stepInterrupt
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1165
	 - must enter myself into the collection of open debuggers,
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1166
	   in case the stepping process comes back again via a halt or signal
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1167
	   before the step is finished. In this case, the stepping debugger should
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1168
	   come up (instead of a new one)
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1169
	 - must flush caches since optimized methods not always
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1170
	   look for pending interrupts
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1171
	"
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1172
	OpenDebuggers isNil ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1173
	    OpenDebuggers := WeakArray with:self
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1174
	] ifFalse:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1175
	    (OpenDebuggers includes:self) ifFalse:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1176
		idx := OpenDebuggers identityIndexOf:nil.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1177
		idx ~~ 0 ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1178
		    OpenDebuggers at:idx put:self
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1179
		] ifFalse:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1180
		    OpenDebuggers := OpenDebuggers copyWith:self
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1181
		]
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1182
	    ]
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1183
	].
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1184
	self label:'single stepping - please wait ...'.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1185
	stepping := true.
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1186
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1187
	ObjectMemory stepInterruptHandler:self.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1188
	ObjectMemory flushInlineCaches.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1189
	StepInterruptPending := 1.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1190
	InterruptPending := 1.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1191
	InStepInterrupt := nil
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1192
    ] ifFalse:[
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1193
	OpenDebuggers notNil ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1194
	    idx := OpenDebuggers identityIndexOf:self.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1195
	    idx ~~ 0 ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1196
		OpenDebuggers at:idx put:nil
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1197
	    ]
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1198
	].
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1199
	self cacheMyself.
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1200
    ]
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1201
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1202
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1203
openOn:aProcess
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1204
    "enter the debugger on a process - 
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1205
     in this case, we are just inspecting the context chain of the process,
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1206
     not running on top of the debugged process, but as a separate
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1207
     one. (think of it as an inspector showing more detail, and offering
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1208
     some more control operations)"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1209
127
claus
parents: 126
diff changeset
  1210
    |bpanel dummy|
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1211
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1212
    busy := true.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1213
    bigStep := false.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1214
    inspecting := true.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1215
    inspectedProcess := aProcess.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1216
    nChainShown := 50.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1217
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1218
    bpanel := abortButton superView.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1219
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1220
    stopButton := Button new.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1221
    stopButton label:(resources at:'stop');
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1222
	       action:[self doStop].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1223
    bpanel addSubView:stopButton after:continueButton.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1224
92
claus
parents: 90
diff changeset
  1225
    dummy := View extent:(10 @ 5) in:bpanel.
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1226
    dummy borderWidth:0; level:0.
61
cb5e3560bd82 *** empty log message ***
claus
parents: 58
diff changeset
  1227
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1228
"/    stepButton destroy.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1229
"/    sendButton destroy.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1230
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1231
    updateButton := Button
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1232
			label:(resources at:'update')
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1233
			action:[self updateContext]
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1234
			in:bpanel.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1235
    monitorToggle := Toggle in:bpanel.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1236
    monitorToggle label:(resources at:'monitor').
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1237
    monitorToggle pressAction:[self autoUpdateOn].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1238
    monitorToggle releaseAction:[self autoUpdateOff].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1239
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1240
    "can only look into process - context chain is not active"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1241
    canContinue := true.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1242
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1243
    terminateButton enable.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1244
    abortButton enable.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1245
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1246
    sendButton disable.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1247
    stepButton disable.
78
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  1248
    nextButton disable.
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1249
"/    continueButton disable.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1250
"/    returnButton disable.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1251
"/    restartButton disable.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1252
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1253
    aProcess isNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1254
	terminateButton disable.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1255
	abortButton disable.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1256
	continueButton disable.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1257
	returnButton disable.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1258
	restartButton disable.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1259
    ] ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1260
	aProcess suspendedContext isNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1261
	    terminateButton disable.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1262
	].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1263
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1264
	self setContext:aProcess suspendedContext.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1265
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1266
	catchBlock := [
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1267
	    catchBlock := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1268
	    contextArray := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1269
	    selectedContext := actualContext := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1270
	    (exitAction == #terminate) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1271
		aProcess terminate.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1272
	    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1273
	    (exitAction == #quickTerminate) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1274
		aProcess terminateNoSignal.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1275
	    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1276
	    super destroy
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1277
	].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1278
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1279
    self open
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1280
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1281
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1282
enter
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1283
    "enter the debugger - on the sending context"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1284
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1285
    |where|
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1286
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1287
    busy := true.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1288
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1289
    where := thisContext.      "enter"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1290
    where := where sender.     "the calling context"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1291
    where notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1292
	(where receiver == DebugView) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1293
	    where := where sender
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1294
	]
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1295
	"where is now interrupted methods context"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1296
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1297
    ^ self enter:where
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1298
! !
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1299
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1300
!DebugView methodsFor:'interrupt handling'!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1301
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1302
stepInterrupt
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1303
    |where here s isWrap method lastWrappedConAddr wrappedMethod inBlock left ignore|
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1304
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1305
    Processor activeProcess ~~ inspectedProcess ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1306
	'stray step interrupt' errorPrintNL.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1307
	^ self
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1308
    ].
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1309
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1310
    "
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1311
     kludge to hide breakpoint wrappers in the context list: 
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1312
	 check if we are in a wrapper methods hidden setup-sequence
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1313
	 if so, ignore the interrupt and continue single sending
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1314
    "
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1315
    here := thisContext.        "stepInterrupt"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1316
    here := here sender.        "the interrupted context"  
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1317
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1318
"/ '*******' printNL.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1319
"/ 'here in ' print.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1320
"/  ((ObjectMemory addressOf:here) printStringRadix:16)print. '' printNL.
10
46e0d4f2079f *** empty log message ***
claus
parents: 7
diff changeset
  1321
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1322
    where := here.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1323
    isWrap := false.
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1324
    left := false.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1325
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1326
    inWrap ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1327
	wrappedMethod := nil.
58
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1328
	5 timesRepeat:[
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1329
"/ where selector printNL.
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1330
	    (where notNil and:[where isBlockContext not]) ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1331
		method := where method.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1332
		(method notNil and:[method isWrapped]) ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1333
		    "
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1334
		     in a wrapper method
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1335
		    "
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1336
		    wrappedMethod ~~ method ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1337
			wrappedMethod := method.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1338
			lastWrappedConAddr := ObjectMemory addressOf:where.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1339
			where sender receiver == method originalMethod ifFalse:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1340
			    isWrap := true.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1341
			]
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1342
		    ] ifFalse:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1343
			(ObjectMemory addressOf:where) == steppedContextAddress ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1344
"/ 'change stepCon from: ' print.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1345
"/ (steppedContextAddress printStringRadix:16)print.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1346
"/ ' to: ' print.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1347
"/ (lastWrappedConAddr printStringRadix:16)printNL.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1348
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1349
			    inWrap := false.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1350
			    steppedContextAddress := lastWrappedConAddr
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1351
			]
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1352
		    ]
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1353
		].
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1354
		where := where sender
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1355
	    ]
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1356
	].
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1357
    ].
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1358
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1359
    isWrap ifTrue:[
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1360
"/ 'ignore wrap' printNL.
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1361
"/ ' ' printNL.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1362
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1363
	  ignore, while in wrappers hidden setup
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1364
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1365
	where := nil. here := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1366
	ObjectMemory flushInlineCaches.
58
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1367
	StepInterruptPending := 1.
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1368
	InterruptPending := 1.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1369
	InStepInterrupt := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1370
	^ nil
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1371
    ].
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1372
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1373
    inBlock := false.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1374
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1375
    "
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1376
     is this for a send or a step ?
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1377
    "
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1378
    bigStep ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1379
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1380
	 a step - ignore all contexts below the interresting one
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1381
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1382
	where := here.      "the interrupted context"
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1383
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1384
	where home notNil ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1385
	    (ObjectMemory addressOf:where home) == steppedContextAddress ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1386
"/ '*block*' printNL.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1387
		inBlock := true
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1388
	    ]
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1389
	].
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1390
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1391
	(ObjectMemory addressOf:where) == steppedContextAddress ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1392
	    where := where sender.
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1393
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1394
	    where home notNil ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1395
		(ObjectMemory addressOf:where home) == steppedContextAddress ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1396
"/ '*block*' printNL.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1397
		    inBlock := true.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1398
		]
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1399
	    ].
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1400
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1401
"/ 'looking for ' print.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1402
"/  (steppedContextAddress printStringRadix:16)print. '' printNL.
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1403
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1404
	    (ObjectMemory addressOf:where) == steppedContextAddress ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1405
		"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1406
		 check if we are in a context below steppedContext
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1407
		 (i.e. if steppedContext can be reached from
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1408
		  interrupted context. Not using context-ref but its
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1409
		  address to avoid creation of many useless contexts.)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1410
		"
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1411
		inBlock ifFalse:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1412
		    [where notNil] whileTrue:[
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1413
"/  ((ObjectMemory addressOf:where) printStringRadix:16)print. ' ' print.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1414
"/  where selector printNL.
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1415
			(ObjectMemory addressOf:where) == steppedContextAddress ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1416
"/ 'found it - below; ignore' printNL.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1417
			    "
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1418
			     found the interresting context somwehere up in the
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1419
			     chain. We seem to be still below the interresting one ...
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1420
			    "
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1421
			    tracing == true ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1422
				here printString printNewline
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1423
			    ].
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1424
			    where := nil. here := nil.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1425
			    "
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1426
			      yes, a context below
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1427
			      - continue and schedule another stepInterrupt.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1428
			      Must flush caches since optimized methods not always
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1429
			      look for pending interrupts
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1430
			    "
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1431
			    ObjectMemory flushInlineCaches.
58
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1432
			    StepInterruptPending := 1.
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1433
			    InterruptPending := 1.
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1434
			    InStepInterrupt := nil.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1435
			    ^ nil
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1436
			].
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1437
			where := where sender
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1438
		    ].
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1439
		    s := 'left stepped method'.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1440
		    left := true.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1441
		].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1442
	    ] ifTrue:[
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1443
"/ 'found it right in sender' printNL.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1444
		s := 'after step'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1445
	    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1446
	] ifTrue:[
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1447
"/ 'found it right away' printNL.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1448
	    s := 'after step'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1449
	].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1450
    ] ifFalse:[
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1451
"/ ' send' printNL.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1452
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1453
	 a send
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1454
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1455
	steppedContextAddress := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1456
	s := 'after send'
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1457
    ].
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  1458
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1459
    inBlock ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1460
"/ 'inBlock' printNL.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1461
	s := 'in block'.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1462
    ].
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1463
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1464
"/    where notNil ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1465
"/        '(' print. steppedContextLineno print. ') ' print.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1466
"/        where print.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1467
"/        '[' print. where lineNumber print. ']' printNL.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1468
"/    ].
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1469
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1470
    ignore := false.
78
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  1471
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1472
    (bigStep 
78
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  1473
    and:[steppedContextLineno notNil 
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1474
    and:[where notNil 
78
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  1475
    and:[where lineNumber == steppedContextLineno]]]) ifTrue:[
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1476
"/ 'same line - ignored' printNL.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1477
	ignore := true
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1478
    ].
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1479
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1480
    (left not 
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1481
    and:[skipLineNr notNil 
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1482
    and:[where lineNumber ~~ skipLineNr]]) ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1483
"/ 'skip (' print. skipLineNr print. ' unreached - ignored' printNL.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1484
	ignore := true
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1485
    ].
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1486
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1487
    ignore ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1488
"/' ' printNL.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1489
	where := nil. here := nil.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1490
	"
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1491
	 yes, a context below
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1492
	  - continue and schedule another stepInterrupt.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1493
	  Must flush caches since optimized methods not always
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1494
	  look for pending interrupts
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1495
	"
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1496
	ObjectMemory flushInlineCaches.
58
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1497
	StepInterruptPending := 1.
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1498
	InterruptPending := 1.
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1499
	InStepInterrupt := nil.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1500
	^ nil
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1501
    ].
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1502
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1503
"/ ' ' printNL.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1504
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1505
    name := Processor activeProcess nameOrId.
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  1506
    self label:(s , ' (process: ' , name , ')').
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  1507
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1508
    tracing := false.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1509
    bigStep := false.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1510
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1511
    "release refs to context"
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1512
    where := nil. here := nil.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1513
    self enter:thisContext sender 
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1514
! !
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1515
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1516
!DebugView methodsFor:'user interaction'!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1517
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1518
showSelection:lineNr
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1519
    "user clicked on a header line - show selected code in textView"
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1520
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1521
    |con homeContext sel method code canAccept
105
claus
parents: 101
diff changeset
  1522
     implementorClass lineNrInMethod rec m line
124
claus
parents: 111
diff changeset
  1523
     sender selSender tryVars possibleBlocks errMsg|
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1524
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1525
    contextArray notNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1526
	lineNr <= contextArray size ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1527
	    con := contextArray at:lineNr.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1528
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1529
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1530
	 clicking on the '** ...'-line shows more ...
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1531
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1532
	con isNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1533
	    line := contextView list at:lineNr.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1534
	    (line startsWith:'**') ifTrue:[
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1535
		self showMore.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1536
		contextView selection:lineNr.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1537
		con := contextArray at:lineNr
108
claus
parents: 107
diff changeset
  1538
	    ].
claus
parents: 107
diff changeset
  1539
	    con isNil ifTrue:[^ self].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1540
	].
105
claus
parents: 101
diff changeset
  1541
claus
parents: 101
diff changeset
  1542
	"
claus
parents: 101
diff changeset
  1543
	 give it to the (lower right) inspector
claus
parents: 101
diff changeset
  1544
	"
claus
parents: 101
diff changeset
  1545
	contextInspector inspect:con.
claus
parents: 101
diff changeset
  1546
claus
parents: 101
diff changeset
  1547
	"
claus
parents: 101
diff changeset
  1548
	 get the home context
claus
parents: 101
diff changeset
  1549
	"
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1550
	con isBlockContext ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1551
	    homeContext := con methodHome
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1552
	] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1553
	    homeContext := con
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1554
	].
107
claus
parents: 106
diff changeset
  1555
	con canReturn ifTrue:[
claus
parents: 106
diff changeset
  1556
	    returnButton enable. restartButton enable.
claus
parents: 106
diff changeset
  1557
	] ifFalse:[
claus
parents: 106
diff changeset
  1558
	    returnButton disable. restartButton disable.
claus
parents: 106
diff changeset
  1559
	].
105
claus
parents: 101
diff changeset
  1560
claus
parents: 101
diff changeset
  1561
	lineNrInMethod := con lineNumber.
claus
parents: 101
diff changeset
  1562
claus
parents: 101
diff changeset
  1563
	canAccept := false.
claus
parents: 101
diff changeset
  1564
55
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1565
	homeContext isNil ifTrue:[
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1566
	    "
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1567
	     mhmh - an optimized block
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1568
	     should get the block here, and get the method from
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1569
	     that one ...
105
claus
parents: 101
diff changeset
  1570
	     But in 2.10.x, there is no easy way to get to the block
claus
parents: 101
diff changeset
  1571
	     since that one is not in the context.
claus
parents: 101
diff changeset
  1572
	     Starting with 2.11, the new block calling scheme will fix this.
55
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1573
	    "
105
claus
parents: 101
diff changeset
  1574
claus
parents: 101
diff changeset
  1575
	    "temporary kludge - peek into the sender context.
claus
parents: 101
diff changeset
  1576
	     If its a do-like method and there is a single block variable 
claus
parents: 101
diff changeset
  1577
	     in the args or temporaries, that must be the one.
claus
parents: 101
diff changeset
  1578
	     This helps in some cases.
claus
parents: 101
diff changeset
  1579
	    "
claus
parents: 101
diff changeset
  1580
	    (sender := con sender) notNil ifTrue:[
claus
parents: 101
diff changeset
  1581
		tryVars := false.
claus
parents: 101
diff changeset
  1582
		(selSender := sender selector) notNil ifTrue:[
claus
parents: 101
diff changeset
  1583
		    (selSender endsWith:'do:') ifTrue:[
claus
parents: 101
diff changeset
  1584
			tryVars := true.
claus
parents: 101
diff changeset
  1585
		    ] ifFalse:[
claus
parents: 101
diff changeset
  1586
			(selSender endsWith:'Do:') ifTrue:[
claus
parents: 101
diff changeset
  1587
			    tryVars := true.
claus
parents: 101
diff changeset
  1588
			]
claus
parents: 101
diff changeset
  1589
		    ]
claus
parents: 101
diff changeset
  1590
		].
claus
parents: 101
diff changeset
  1591
		tryVars ifTrue:[
claus
parents: 101
diff changeset
  1592
		    possibleBlocks := sender argsAndVars select:[:v | v isBlock].
claus
parents: 101
diff changeset
  1593
		    possibleBlocks := possibleBlocks select:[:b | b home isNil].
claus
parents: 101
diff changeset
  1594
		    possibleBlocks size == 1 ifTrue:[
claus
parents: 101
diff changeset
  1595
			method := possibleBlocks first method.
claus
parents: 101
diff changeset
  1596
		    ].
claus
parents: 101
diff changeset
  1597
		]
claus
parents: 101
diff changeset
  1598
	    ].
claus
parents: 101
diff changeset
  1599
55
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1600
	] ifFalse:[
105
claus
parents: 101
diff changeset
  1601
	    "fetch rec here - so we wont need context in doItAction"
claus
parents: 101
diff changeset
  1602
	    rec := homeContext receiver.
claus
parents: 101
diff changeset
  1603
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1604
	    sel := homeContext selector.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1605
	    sel notNil ifTrue:[
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1606
		canAccept := true.
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1607
55
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1608
		implementorClass := homeContext methodClass.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1609
		implementorClass isNil ifTrue:[
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1610
		    "
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1611
		     special: look if this context was created by
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1612
		     valueWithReceiver kind of method invocation;
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1613
		     if so, grab the method from the sender and show it
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1614
		    "
124
claus
parents: 111
diff changeset
  1615
		    ((sender := con sender) notNil
claus
parents: 111
diff changeset
  1616
		    and:[(sender selector startsWith:'valueWithReceiver:')
claus
parents: 111
diff changeset
  1617
		    and:[sender receiver isMethod]]) ifTrue:[
claus
parents: 111
diff changeset
  1618
			method := sender receiver.
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1619
			code := method source.
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1620
			canAccept := false.
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1621
		    ] ifFalse:[
105
claus
parents: 101
diff changeset
  1622
			(method := con method) notNil ifTrue:[
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1623
			    code := method source.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1624
			    canAccept := false.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1625
			]
56
d0cb937cbcaa *** empty log message ***
claus
parents: 55
diff changeset
  1626
		    ]
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1627
		] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1628
		    method := implementorClass compiledMethodAt:sel.
105
claus
parents: 101
diff changeset
  1629
		].
claus
parents: 101
diff changeset
  1630
	    ]
claus
parents: 101
diff changeset
  1631
	].
claus
parents: 101
diff changeset
  1632
claus
parents: 101
diff changeset
  1633
	code isNil ifTrue:[
124
claus
parents: 111
diff changeset
  1634
	    errMsg := nil.
105
claus
parents: 101
diff changeset
  1635
	    method notNil ifTrue:[
claus
parents: 101
diff changeset
  1636
		code := method source.
claus
parents: 101
diff changeset
  1637
		code isNil ifTrue:[
claus
parents: 101
diff changeset
  1638
		    method sourceFilename notNil ifTrue:[
claus
parents: 101
diff changeset
  1639
			codeView contents:(resources 
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1640
						   string:'** no sourcefile: %1 **'
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1641
						   with:method sourceFilename).
105
claus
parents: 101
diff changeset
  1642
			codeView flash
claus
parents: 101
diff changeset
  1643
		    ] ifFalse:[
124
claus
parents: 111
diff changeset
  1644
			errMsg := '** no source **'
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1645
		    ]
105
claus
parents: 101
diff changeset
  1646
		]
claus
parents: 101
diff changeset
  1647
	    ] ifFalse:[
claus
parents: 101
diff changeset
  1648
		homeContext isNil ifTrue:[
124
claus
parents: 111
diff changeset
  1649
		    errMsg := '** sorry; cannot show code of all optimized blocks (yet) **'.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1650
		] ifFalse:[
124
claus
parents: 111
diff changeset
  1651
		    errMsg := '** no method - no source **'
105
claus
parents: 101
diff changeset
  1652
		]
124
claus
parents: 111
diff changeset
  1653
	    ].
claus
parents: 111
diff changeset
  1654
	    errMsg notNil ifTrue:[
claus
parents: 111
diff changeset
  1655
	       self showError:errMsg
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1656
	    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1657
	].
105
claus
parents: 101
diff changeset
  1658
claus
parents: 101
diff changeset
  1659
	code isNil ifTrue:[
claus
parents: 101
diff changeset
  1660
	    canAccept := false.
claus
parents: 101
diff changeset
  1661
	] ifFalse:[
claus
parents: 101
diff changeset
  1662
	    codeView contents:code.
claus
parents: 101
diff changeset
  1663
	    (lineNrInMethod notNil and:[lineNrInMethod ~~ 0]) ifTrue:[
110
claus
parents: 108
diff changeset
  1664
"/                lineNrInMethod > codeView list size ifTrue:[
claus
parents: 108
diff changeset
  1665
"/                    lineNrInMethod := codeView list size + 1
claus
parents: 108
diff changeset
  1666
"/                ].
claus
parents: 108
diff changeset
  1667
"/                codeView selectLine:lineNrInMethod.
claus
parents: 108
diff changeset
  1668
"/                codeView makeSelectionVisible
132
claus
parents: 127
diff changeset
  1669
110
claus
parents: 108
diff changeset
  1670
		lineNrInMethod <= codeView list size ifTrue:[
132
claus
parents: 127
diff changeset
  1671
		    (lineNrInMethod == 255 
claus
parents: 127
diff changeset
  1672
		    and:[method notNil
claus
parents: 127
diff changeset
  1673
		    and:[method code isNil]]) ifTrue:[
claus
parents: 127
diff changeset
  1674
			"/ means: do not really know in interpreted methods
claus
parents: 127
diff changeset
  1675
			codeView selectFromLine:255 col:1 toLine:codeView list size + 1 col:0.
claus
parents: 127
diff changeset
  1676
		    ] ifFalse:[
claus
parents: 127
diff changeset
  1677
			codeView selectLine:lineNrInMethod.
claus
parents: 127
diff changeset
  1678
		    ].
110
claus
parents: 108
diff changeset
  1679
		    codeView makeSelectionVisible
claus
parents: 108
diff changeset
  1680
		]
105
claus
parents: 101
diff changeset
  1681
	    ].
claus
parents: 101
diff changeset
  1682
	].
claus
parents: 101
diff changeset
  1683
claus
parents: 101
diff changeset
  1684
	canAccept ifTrue:[
claus
parents: 101
diff changeset
  1685
	    codeView acceptAction:[:code | self codeAccept:code asString]
claus
parents: 101
diff changeset
  1686
	] ifFalse:[
claus
parents: 101
diff changeset
  1687
	    codeView acceptAction:nil.
claus
parents: 101
diff changeset
  1688
	].
claus
parents: 101
diff changeset
  1689
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1690
	receiverInspector inspect:rec.
105
claus
parents: 101
diff changeset
  1691
claus
parents: 101
diff changeset
  1692
	"
claus
parents: 101
diff changeset
  1693
	 the one below is wrong: currently, the
claus
parents: 101
diff changeset
  1694
	 evaluator cannot handle passed contexts.
claus
parents: 101
diff changeset
  1695
	 Once it does, pass con as in:-arg
claus
parents: 101
diff changeset
  1696
	"
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1697
	codeView doItAction:[:theCode |
100
claus
parents: 99
diff changeset
  1698
			 rec class evaluatorClass 
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1699
			     evaluate:theCode 
105
claus
parents: 101
diff changeset
  1700
			     in:nil            "/ *** con
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1701
			     receiver:rec 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1702
			     notifying:codeView 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1703
			     logged:true 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1704
			     ifFail:nil 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1705
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1706
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1707
	selectedContext := homeContext.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1708
	actualContext := con
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1709
    ].
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1710
105
claus
parents: 101
diff changeset
  1711
    "clear out locals to prevent keeping around unneeded contexts 
claus
parents: 101
diff changeset
  1712
     (due to the block held in codeView).
claus
parents: 101
diff changeset
  1713
     (not really needed, since stuff gets collected away sooner or later ...
claus
parents: 101
diff changeset
  1714
      ... but this makes it a bit sooner)
claus
parents: 101
diff changeset
  1715
    "
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1716
    con := nil.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1717
    homeContext := nil.
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1718
105
claus
parents: 101
diff changeset
  1719
    "
claus
parents: 101
diff changeset
  1720
     enable/disable some menu items
claus
parents: 101
diff changeset
  1721
    "
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1722
    m := contextView middleButtonMenu.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1723
    m notNil ifTrue:[
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1724
	m enable:#implementors.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1725
	m enable:#senders.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1726
	m enable:#inspectContext.
99
claus
parents: 93
diff changeset
  1727
	m enable:#browseClass.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1728
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1729
	(method notNil and:[method isWrapped]) ifTrue:[
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1730
	    m enable:#removeBreakpoint.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1731
	] ifFalse:[
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1732
	    m disable:#removeBreakpoint.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1733
	]
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1734
    ]
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1735
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1736
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1737
destroy
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1738
    "closing the debugger implies an abort or continue"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1739
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1740
    contextView middleButtonMenu hide.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1741
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1742
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1743
     we manually release all private data, since the Debugger
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1744
     is cached for reuse - thus the memory would not be collectable
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1745
     otherwise.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1746
    "
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1747
    codeView acceptAction:nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1748
    codeView doItAction:nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1749
    codeView contents:nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1750
    catchBlock := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1751
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1752
    receiverInspector release.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1753
    contextInspector release.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1754
    inspectedProcess := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1755
    exitAction := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1756
    contextArray := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1757
    selectedContext := actualContext := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1758
    grabber := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1759
    self autoUpdateOff.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1760
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1761
    inspecting ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1762
	exclusive ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1763
	    CachedExclusive == self ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1764
		CachedExclusive := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1765
	    ]
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1766
	] ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1767
	    CachedDebugger == self ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1768
		CachedDebugger := nil
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1769
	    ]
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1770
	].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1771
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1772
	inspecting ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1773
	    canAbort ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1774
		self doAbort.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1775
	    ] ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1776
		self doContinue
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1777
	    ]
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1778
	].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1779
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1780
    super destroy    "/ 1.12.94
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1781
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1782
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1783
codeAccept:someCode
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1784
    "user wants some code to be recompiled - must unwind stack since everything above
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1785
     and including selected method cannot be continued."
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1786
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1787
    "
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1788
     actually, this is not true, since the active methods will still be
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1789
     executed correctly - however, the code shown in the debugger is no
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1790
     longer in sync (showing the new code) with the executed code.
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1791
     Therefore, we hide those contexts to avoid confusion ....
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1792
     If you dont like this behavior, remove the 'inspecting ifFalse:' check below"
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1793
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1794
    "walk up context chain and find highest context which is either the selected context,
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1795
     or - if its a block-context - whose home is the selected context"
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1796
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1797
    |con top sel implementorClass method newMethod|
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1798
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1799
    codeView cursor:Cursor execute.
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1800
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1801
    "
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1802
     find the method-home context for this one
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1803
    "
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1804
    con := selectedContext.
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1805
    top := con.
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1806
    [con notNil] whileTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1807
	(con methodHome == selectedContext) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1808
	    top := con
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1809
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1810
	con := con sender
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1811
    ].
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1812
    "
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1813
     use class&selector to find the method for the compilation
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1814
     and compile.
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1815
    "
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1816
    sel := selectedContext selector.
55
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1817
    implementorClass := selectedContext methodClass.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1818
    method := implementorClass compiledMethodAt:sel.
61
cb5e3560bd82 *** empty log message ***
claus
parents: 58
diff changeset
  1819
    newMethod := implementorClass compilerClass
cb5e3560bd82 *** empty log message ***
claus
parents: 58
diff changeset
  1820
			 compile:someCode
cb5e3560bd82 *** empty log message ***
claus
parents: 58
diff changeset
  1821
			 forClass:implementorClass
cb5e3560bd82 *** empty log message ***
claus
parents: 58
diff changeset
  1822
			 inCategory:(method category)
cb5e3560bd82 *** empty log message ***
claus
parents: 58
diff changeset
  1823
			 notifying:codeView.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1824
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1825
    inspecting ifFalse:[
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1826
	"
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1827
	 if it worked, remove everything up to and including top
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1828
	 from context chain
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1829
	"
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1830
	(newMethod notNil and:[newMethod ~~ #Error]) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1831
	    self setContext:(top sender).
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1832
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1833
	    "
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1834
	     continue/step is no longer possible
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1835
	    "
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1836
	    canContinue := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1837
	    self showSelection:1.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1838
	    exitAction := #return
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1839
	].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1840
    ].
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1841
    codeView cursor:Cursor normal
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1842
! !
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1843
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1844
!DebugView methodsFor:'menu / button actions'!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1845
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1846
doAbort
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1847
    "abort - send Object>>abortSignal, which is usually cought
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1848
     at save places (for example: in the event loop) and returns back
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1849
     from whatever the process is doing, but does not terminate it."
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1850
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1851
    inspecting ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1852
	inspectedProcess isDead ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1853
	    self showTerminated.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1854
	    ^ self
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1855
	].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1856
	(Object abortSignal isHandledIn:inspectedProcess suspendedContext) ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1857
	    self showError:'** the process does not handle the abort signal **'
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1858
	] ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1859
	    self interruptProcessWith:[Object abortSignal raise].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1860
	].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1861
	^ self
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1862
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1863
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1864
    steppedContextAddress := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1865
    haveControl := false.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1866
    exitAction := #abort.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1867
    ProcessorScheduler isPureEventDriven ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1868
	"exit private event-loop"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1869
	catchBlock notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1870
	    abortButton turnOff.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1871
	    catchBlock value.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1872
	    'DEBUGGER: oops, abort failed' errorPrintNL.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1873
	]
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1874
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1875
    ^ self.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1876
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1877
"obsolete ..."
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1878
"/    Processor activeProcess id == 0 ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1879
"/        "dont allow termination of main-thread"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1880
"/        exitAction := #abort
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1881
"/    ] ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1882
"/        exitAction := #terminate 
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1883
"/    ]
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1884
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1885
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1886
exit
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1887
    "exit from menu: immediate exit from smalltalk"
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1888
132
claus
parents: 127
diff changeset
  1889
    OperatingSystem exit
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1890
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1891
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1892
removeBreakpoint
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1893
    "remove breakpoint on the selected contexts method - if any"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1894
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1895
    |implementorClass method|
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1896
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1897
    selectedContext isNil ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1898
	^ self showError:'** select a context first **'
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1899
    ].
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1900
55
abfd613f95d9 *** empty log message ***
claus
parents: 53
diff changeset
  1901
    implementorClass := selectedContext methodClass. 
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1902
    implementorClass notNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1903
	method := implementorClass compiledMethodAt:selectedContext selector.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1904
	(method notNil and:[method isWrapped]) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1905
	    MessageTracer unwrapMethod:method
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1906
	]
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1907
    ].
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1908
    contextView middleButtonMenu disable:#removeBreakpoint.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1909
!
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1910
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1911
removeAllBreakpoints
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1912
    "remove all trace & breakpoints - if any"
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1913
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1914
    MessageTracer unwrapAllMethods
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1915
!
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  1916
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1917
browseClass
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1918
    selectedContext isNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1919
	^ self showError:'** select a context first **'
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1920
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1921
    SystemBrowser browseClass:(selectedContext method who at:1).
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1922
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1923
108
claus
parents: 107
diff changeset
  1924
browseClassHierarchy
claus
parents: 107
diff changeset
  1925
    selectedContext isNil ifTrue:[
claus
parents: 107
diff changeset
  1926
	^ self showError:'** select a context first **'
claus
parents: 107
diff changeset
  1927
    ].
claus
parents: 107
diff changeset
  1928
    SystemBrowser browseClassHierarchy:(selectedContext method who at:1).
claus
parents: 107
diff changeset
  1929
!
claus
parents: 107
diff changeset
  1930
claus
parents: 107
diff changeset
  1931
browseFullClassProtocol
claus
parents: 107
diff changeset
  1932
    selectedContext isNil ifTrue:[
claus
parents: 107
diff changeset
  1933
	^ self showError:'** select a context first **'
claus
parents: 107
diff changeset
  1934
    ].
claus
parents: 107
diff changeset
  1935
    SystemBrowser browseFullClassProtocol:(selectedContext method who at:1).
claus
parents: 107
diff changeset
  1936
!
claus
parents: 107
diff changeset
  1937
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1938
autoUpdateOff
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1939
    "stop the update process"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1940
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1941
    updateProcess notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1942
	monitorToggle lampColor:(Color yellow).
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1943
	updateProcess terminate.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1944
	updateProcess := nil
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1945
    ]
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1946
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1947
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1948
senders
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1949
    "open a browser on the senders"
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
  1950
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1951
    selectedContext isNil ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1952
	^ self showError:'** select a context first **'
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1953
    ].
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1954
    SystemBrowser browseAllCallsOn:selectedContext selector.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1955
!
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1956
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1957
implementors
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1958
    "open a browser on the implementors"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1959
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1960
    selectedContext isNil ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1961
	^ self showError:'** select a context first **'
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1962
    ].
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1963
    SystemBrowser browseImplementorsOf:selectedContext selector.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1964
!
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1965
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  1966
showMore
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1967
    "double number of contexts shown"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1968
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1969
    |oldSelection con|
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1970
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1971
    contextArray notNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1972
	oldSelection := contextView selection.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1973
	nChainShown := nChainShown * 2.
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1974
	con := contextArray at:1.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1975
	contextArray at:1 put:nil.
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  1976
	self setContext:con.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1977
	contextView selection:oldSelection.
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1978
    ]
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1979
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1980
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1981
doSend
78
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  1982
    "single send; reenter with next message send"
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1983
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1984
    inspecting ifTrue:[^ self].
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  1985
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1986
    canContinue ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1987
	steppedContextAddress := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1988
	haveControl := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1989
	exitAction := #step.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1990
	ProcessorScheduler isPureEventDriven ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1991
	    "exit private event-loop"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1992
	    catchBlock notNil ifTrue:[catchBlock value].
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1993
	    'DEBUGGER: oops, send failed' errorPrintNL.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1994
	    sendButton turnOff.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1995
	].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1996
    ]
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1997
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1998
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  1999
doStep:lineNr
78
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2000
    "step until we pass lineNr (if nonNil) or to next line (if nil)
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2001
     or to next send (if -1)"
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2002
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2003
    |con method|
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2004
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  2005
    inspecting ifTrue:[^ self].
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  2006
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2007
    canContinue ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2008
	selectedContext notNil ifTrue:[
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2009
	    con := selectedContext.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2010
	    steppedContextLineno := actualContext lineNumber.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2011
	] ifFalse:[
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2012
	    con := contextArray at:2.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2013
	    steppedContextLineno := con lineNumber.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2014
	].
78
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2015
	skipLineNr := lineNr.
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2016
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2017
	lineNr == -1 ifTrue:[
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2018
	    steppedContextLineno := skipLineNr := nil.
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2019
	].
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2020
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2021
	steppedContextAddress := ObjectMemory addressOf:con.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2022
	"
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2023
	 if we step in a wrapped method,
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2024
	 prepare to skip the prolog ...
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2025
	"
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2026
"/ ' step con:' print. steppedContextAddress printHex. ' ' printNL.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2027
	inWrap := false.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2028
	method := con method.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2029
	(method notNil and:[method isWrapped]) ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2030
	    inWrap := true
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2031
	].
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2032
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2033
	con := nil.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2034
	bigStep := true.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2035
	haveControl := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2036
	exitAction := #step.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2037
	ProcessorScheduler isPureEventDriven ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2038
	    "exit private event-loop"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2039
	    catchBlock notNil ifTrue:[catchBlock value].
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  2040
	    'DEBUGGER: oops, step failed' errorPrintNL.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  2041
	    stepButton turnOff.
78
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2042
	    nextButton turnOff.
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2043
	    sendButton turnOff.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2044
	].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2045
    ]
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2046
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2047
78
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2048
doNext
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2049
    "skip for next source-code line"
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  2050
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  2051
    self doStep:nil
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  2052
!
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  2053
78
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2054
doStep
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2055
    "skip for next send in selected method"
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  2056
78
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2057
    self doStep:-1 
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2058
!
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2059
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2060
skip
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2061
    "skip for cursor line in selected method"
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2062
037323660c45 *** empty log message ***
claus
parents: 75
diff changeset
  2063
    self doStep:codeView cursorLine.
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  2064
!
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  2065
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2066
doReturn
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2067
    "return - the selected context will do a ^nil"
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2068
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2069
    inspecting ifTrue:[
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  2070
	selectedContext isNil ifTrue:[
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  2071
	    ^ self showError:'** select a context first **'
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  2072
	].
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  2073
	self interruptProcessWith:[selectedContext unwind].
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  2074
	^ self
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2075
    ].
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  2076
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2077
    steppedContextAddress := nil.
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2078
    haveControl := false.
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2079
    exitAction := #return.
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
  2080
    ProcessorScheduler isPureEventDriven ifFalse:[
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  2081
	"exit private event-loop"
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  2082
	catchBlock notNil ifTrue:[catchBlock value].
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  2083
	'DEBUGGER: oops, return failed' errorPrintNL.
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  2084
	returnButton turnOff.
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
  2085
    ].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2086
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2087
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  2088
doTerminate
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  2089
    "terminate - the process has a chance for cleanup"
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  2090
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2091
    inspecting ifTrue:[
92
claus
parents: 90
diff changeset
  2092
	self processPerform:#terminate.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2093
	^ self
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2094
    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2095
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  2096
    steppedContextAddress := nil.
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  2097
    haveControl := false.
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
  2098
    exitAction := #terminate. 
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
  2099
    ProcessorScheduler isPureEventDriven ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2100
	"exit private event-loop"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2101
	catchBlock notNil ifTrue:[catchBlock value].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2102
	inspecting ifFalse:[
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  2103
	    'DEBUGGER: oops, terminate failed' errorPrintNL.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2104
	    self warn:'terminate failed'.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2105
	].
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  2106
	terminateButton turnOff.
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
  2107
    ].
7
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  2108
!
92b82578c88c *** empty log message ***
claus
parents: 4
diff changeset
  2109
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2110
doTraceStep
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2111
    "tracestep - not implemented yet"
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2112
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2113
    canContinue ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2114
	tracing := true.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2115
	self doStep
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2116
    ]
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2117
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2118
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2119
doRestart
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  2120
    "restart - the selected context will be restarted"
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2121
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2122
    inspecting ifTrue:[
52
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  2123
	selectedContext isNil ifTrue:[
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  2124
	    ^ self showError:'** select a context first **'
7b48409ae088 *** empty log message ***
claus
parents: 48
diff changeset
  2125
	].
61
cb5e3560bd82 *** empty log message ***
claus
parents: 58
diff changeset
  2126
	self interruptProcessWith:[selectedContext unwindAndRestart].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2127
	^ self
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2128
    ].
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  2129
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2130
    steppedContextAddress := nil.
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2131
    haveControl := false.
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
  2132
    exitAction := #restart.
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
  2133
    ProcessorScheduler isPureEventDriven ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2134
	"exit private event-loop"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2135
	catchBlock notNil ifTrue:[catchBlock value].
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  2136
	'DEBUGGER: oops, restart failed' errorPrintNL.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  2137
	restartButton turnOff.
13
145a9461122e *** empty log message ***
claus
parents: 10
diff changeset
  2138
    ].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2139
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2140
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2141
quickTerminate
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2142
    "quick terminate - the process will get no chance for cleanup actions"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2143
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2144
    inspecting ifTrue:[
92
claus
parents: 90
diff changeset
  2145
	self processPerform:#terminateNoSignal.
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2146
	^ self
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2147
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2148
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2149
    steppedContextAddress := nil.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2150
    haveControl := false.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2151
    exitAction := #quickTerminate.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2152
    ProcessorScheduler isPureEventDriven ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2153
	"exit private event-loop"
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2154
	catchBlock notNil ifTrue:[catchBlock value].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2155
	inspecting ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2156
	    'DEBUGGER: oops, terminate failed' errorPrintNL.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2157
	    self warn:'terminate failed'.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2158
	].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2159
	terminateButton turnOff.
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2160
    ].
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2161
!
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2162
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2163
doTrace
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
  2164
    "tracing - not really implemented ..."
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
  2165
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
  2166
    self warn:'this function is not yet implemented'.
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
  2167
107
claus
parents: 106
diff changeset
  2168
"/    |v b|
claus
parents: 106
diff changeset
  2169
"/
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2170
"/    traceView isNil ifTrue:[
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2171
"/        v := StandardSystemView on:Display.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2172
"/        v label:'Debugger-Trace'.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2173
"/        v icon:icon.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2174
"/
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2175
"/        b := Button label:'untrace' in:v.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2176
"/        b origin:(0 @ 0) extent:(1.0 @ (b height)).
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2177
"/        b action:[
58
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  2178
"/            StepInterruptPending := nil.
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2179
"/            tracing := false.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2180
"/            v unrealize.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2181
"/            traceView := nil
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2182
"/        ].
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2183
"/        traceView := ScrollableView for:TextCollector in:v.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2184
"/        traceView origin:(0 @ (b height))
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2185
"/                  extent:[v width @ (v height - b height)]
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2186
"/    ].
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2187
"/    v realize.
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2188
"/
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  2189
"/    tracing := true.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2190
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2191
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2192
doNoTrace
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2193
    traceView notNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2194
	traceView topView destroy.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2195
	traceView := nil.
22
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
  2196
    ].
8b81fea5212b *** empty log message ***
claus
parents: 20
diff changeset
  2197
    tracing := false
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2198
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2199
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2200
doStop
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2201
    "stop the process (if its running, otherwise this is a no-op)"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2202
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2203
    inspecting ifTrue:[
92
claus
parents: 90
diff changeset
  2204
	self processPerform:#stop.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2205
	^ self
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2206
    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2207
!
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2208
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2209
doContinue
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2210
    "continue from menu"
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2211
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2212
    inspecting ifTrue:[
92
claus
parents: 90
diff changeset
  2213
	self processPerform:#resume.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2214
	^ self
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2215
    ].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2216
    canContinue ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2217
	steppedContextAddress := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2218
	tracing := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2219
	haveControl := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2220
	exitAction := #continue.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2221
	ProcessorScheduler isPureEventDriven ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2222
	    "exit private event-loop"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2223
	    catchBlock notNil ifTrue:[catchBlock value].
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  2224
	    'DEBUGGER: oops, continue failed' errorPrintNL.
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  2225
	    continueButton turnOff.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2226
	].
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 14
diff changeset
  2227
    ] ifFalse:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2228
	inspecting ifFalse:[
53
2fc78a0165e7 *** empty log message ***
claus
parents: 52
diff changeset
  2229
	    'resuming top context' errorPrintNL.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2230
	    self showSelection:1.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2231
	    self doReturn
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2232
	]
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  2233
    ]
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  2234
!
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  2235
73
e332d9c71624 *** empty log message ***
claus
parents: 69
diff changeset
  2236
inspectContext
29
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  2237
    "launch an inspector on the currently selected context"
8a72e10043f6 *** empty log message ***
claus
parents: 22
diff changeset
  2238
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2239
    contextView selection notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2240
	(contextView selectionValue startsWith:'**') ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2241
	    (contextArray at:(contextView selection)) inspect.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2242
	]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2243
    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2244
!
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2245
124
claus
parents: 111
diff changeset
  2246
copyWalkbackText
claus
parents: 111
diff changeset
  2247
    "place the contents of the walkback view into the copy-paste buffer.
claus
parents: 111
diff changeset
  2248
     This allows pasting it into some other view for printing ..."
claus
parents: 111
diff changeset
  2249
claus
parents: 111
diff changeset
  2250
    self setTextSelection:(contextArray collect:[:con | con fullPrintString]) asStringCollection
claus
parents: 111
diff changeset
  2251
claus
parents: 111
diff changeset
  2252
    "Modified: 28.8.1995 / 15:31:59 / claus"
claus
parents: 111
diff changeset
  2253
!
claus
parents: 111
diff changeset
  2254
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2255
autoUpdateOn
48
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  2256
    "fork a subprocess which updates the contextList in regular intervals"
f007285a17ba much better process debugging
claus
parents: 46
diff changeset
  2257
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2258
    updateProcess isNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2259
	updateProcess := 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2260
	    [
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2261
		[true] whileTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2262
		    monitorToggle showLamp ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2263
			monitorToggle lampColor:(Color yellow).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2264
		    ] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2265
			monitorToggle activeForegroundColor:Color black.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2266
		    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2267
		    (Delay forSeconds:0.25) wait.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2268
		    self updateContext.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2269
		    monitorToggle showLamp ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2270
			monitorToggle lampColor:(Color red).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2271
		    ] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2272
			monitorToggle activeForegroundColor:Color red.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2273
		    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2274
		    (Delay forSeconds:0.25) wait.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2275
		    self updateContext.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2276
		]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2277
	    ] forkAt:(Processor activePriority - 1)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2278
    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  2279
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  2280
! !