Signal.st
author Claus Gittinger <cg@exept.de>
Thu, 23 Nov 1995 02:21:27 +0100
changeset 607 a9a526c51233
parent 530 07d0bce293c9
child 622 a17084b7ac06
permissions -rw-r--r--
checkin from browser
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1993 by Claus Gittinger
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
     3
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     4
a27a279701f8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
a27a279701f8 Initial revision
claus
parents:
diff changeset
    13
Object subclass:#Signal
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
    14
	 instanceVariableNames:'mayProceed notifierString nameClass message
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
    15
				handlerBlock parent'
171
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
    16
	 classVariableNames:'NoHandlerSignal'
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
    17
	 poolDictionaries:''
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
    18
	 category:'Kernel-Exceptions'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
44
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
    21
!Signal class methodsFor:'documentation'!
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
    22
88
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    23
copyright
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    24
"
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    25
 COPYRIGHT (c) 1993 by Claus Gittinger
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
    26
	      All Rights Reserved
88
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    27
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    28
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    29
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    30
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    31
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    32
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    33
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    34
"
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    35
!
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    36
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    37
version
530
07d0bce293c9 uff - version methods changed to return stings
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
    38
    ^ '$Header: /cvs/stx/stx/libbasic/Signal.st,v 1.29 1995-11-11 15:26:50 cg Exp $'
88
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    39
!
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    40
44
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
    41
documentation
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
    42
"
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    43
    Signal and Exception provide a framework for exception handling.
44
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
    44
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    45
    A Signal object is usually defined somewhere up in the calling chain
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    46
    and associated with some abnormal event. Many signals are also
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    47
    created at startup time and reused.
44
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
    48
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    49
    When the event is raised (by Signal>>raise) the control will be either 
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    50
    given to a debugger or - if a handler was defined - to the handler. 
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    51
    The handler will get a description of what (and where) happened in an 
120
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
    52
    Exception object and can decide how to react on the situation (i.e. 
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
    53
    proceed, return or restart).
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    54
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    55
    There is also a companion class called SignalSet, which allows handling
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    56
    multiple signals with one handler (for example all arithmetic signals).
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    57
    And, finally there is a very special SignalSet which allows catching
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    58
    any signal (SignalSet>>anySignal).
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    59
171
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
    60
    Since there is no official documentation on signal handling (i.e. none
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
    61
    of the books describes it), this Signal implementation has been modeled
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
    62
    after what some PD programs seem to expect and what alpha/beta testers told
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
    63
    me it should look like.
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
    64
    It may not be perfect and undergo minor changes.
44
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
    65
120
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
    66
    special:
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
    67
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    68
    In addition to the nested catch & throw mechanism, signals can also be
120
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
    69
    used when no such handler scope exists. To support this, signals can be 
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
    70
    assigned a handlerBlock, which gets evaluated with the exception as argument 
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
    71
    in case no handler was found (on the stack).
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    72
171
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
    73
    If no handler was found (i.e. neither a handler context on the stack, nor
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
    74
    a static handler block), the NoHandlerSignal will be raised instead,
120
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
    75
    passing it the original exception in its exception-parameter.
171
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
    76
    This NoHandlerSignal can be handled just like any other signal.
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
    77
    (therefore, it is possible to catch any error by catching NoHandlerSignal.
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    78
120
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
    79
    When the NoHandler signal is raised, and neither a handler-context, nor 
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
    80
    a handler block is defined for it, an emergencyHandler(-block) is evaluated.
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
    81
    This block is either provided by the current process 
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
    82
    (see Process>>emergencySignalHandler) or as a global default by the Exception
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
    83
    class (see Exception>>emergencyHandler).
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
    84
    The default emergencyHandlerBlock (from Exception) will bring up a debugger.
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
    85
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
    86
    HandlerBlocks allow a global (if its the EmergencyHandler in Exception)
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
    87
    or per-process signal handling to be added. Even to code which was never
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
    88
    planned to handle signals.
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    89
171
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
    90
    See samples in 'doc/coding' and actual raise code in Exception.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    91
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    92
    Instance variables:
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    93
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
    94
	mayProceed      <Boolean>       hint for the debugger - program may 
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
    95
					proceed (currently not honored by the
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
    96
					debugger)
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
    97
171
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
    98
	notifierString  <String>        error message to be output 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    99
171
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   100
	nameClass       <Class>         for the printOn-implementation; nameClass
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   101
					is the class, to which message (below) 
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   102
					should be sent to create the receiver.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   103
171
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   104
	message         <Symbol>        for the printOn-implementation; message
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   105
					is the selector, which should be sent to 
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   106
					nameClass (above) to create the receiver.
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   107
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   108
	handlerBlock    <Block>         if nonNil, a 1-arg block to be 
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   109
					evaluated when no handler context is 
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   110
					found. The block gets the exception
171
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   111
					object as argument. This will play the role
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   112
					of an on-stack handler.
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   113
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   114
    Class variables:
120
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
   115
171
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   116
	NoHandlerSignal <Signal>        signal raised when no handler for a signal
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   117
					was found in raise.
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   118
					If this one is not handled either,
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   119
					Exceptions emergencyHandler will be evaluated
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   120
					instead (or a per-proces handler, if there
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   121
					is one).
44
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
   122
"
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
   123
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   124
a27a279701f8 Initial revision
claus
parents:
diff changeset
   125
!Signal class methodsFor:'initialization'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   126
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   127
initialize 
44
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
   128
    "setup the signal used to handle unhandled signals"
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
   129
61
claus
parents: 44
diff changeset
   130
    NoHandlerSignal isNil ifTrue:[
302
1f76060d58a4 *** empty log message ***
claus
parents: 259
diff changeset
   131
	NoHandlerSignal := ErrorSignal newSignalMayProceed:true.
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   132
	NoHandlerSignal nameClass:self message:#noHandlerSignal.
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   133
	NoHandlerSignal notifierString:'unhandled exception'.
61
claus
parents: 44
diff changeset
   134
    ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   135
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   136
a27a279701f8 Initial revision
claus
parents:
diff changeset
   137
!Signal class methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   138
a27a279701f8 Initial revision
claus
parents:
diff changeset
   139
new
a27a279701f8 Initial revision
claus
parents:
diff changeset
   140
    "return a new signal"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   141
419
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   142
    ^ (self basicNew) notifierString:'signal'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   143
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   144
345
claus
parents: 329
diff changeset
   145
!Signal class methodsFor:'Signal constants'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   146
a27a279701f8 Initial revision
claus
parents:
diff changeset
   147
noHandlerSignal
44
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
   148
    "return the signal used to handle unhandled signals"
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
   149
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   150
    ^ NoHandlerSignal
a27a279701f8 Initial revision
claus
parents:
diff changeset
   151
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   152
a27a279701f8 Initial revision
claus
parents:
diff changeset
   153
!Signal methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   154
a27a279701f8 Initial revision
claus
parents:
diff changeset
   155
newSignalMayProceed:aBoolean
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   156
    "create a new signal, using the receiver as a prototype and
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   157
     setting the parent of the new signal to the receiver."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   158
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   159
    |newSignal|
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   160
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   161
    newSignal := (self copy) mayProceed:aBoolean.
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   162
    newSignal parent:self.
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   163
    ^ newSignal
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   164
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   165
a27a279701f8 Initial revision
claus
parents:
diff changeset
   166
newSignal
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   167
    "create a new signal, using the receiver as a prototype and
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   168
     setting the parent of the new signal to the receiver."
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   169
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   170
    ^ (self copy) parent:self
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   171
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   172
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   173
!Signal methodsFor:'copying'!
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   174
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   175
deepCopy
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   176
    "raise an error - deepCopy is not allowed for signals"
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   177
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   178
    ^ self deepCopyError
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   179
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   180
a27a279701f8 Initial revision
claus
parents:
diff changeset
   181
!Signal methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   182
a27a279701f8 Initial revision
claus
parents:
diff changeset
   183
nameClass:aClass message:aSelector
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   184
    "this sets the class & selector of a method which returns
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   185
     that signal - this is simply for documentation purposes -
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   186
     see Signal>>printOn: implementation.
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   187
     (took me a while to find that one out ;-)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   188
a27a279701f8 Initial revision
claus
parents:
diff changeset
   189
    nameClass := aClass.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   190
    message := aSelector
a27a279701f8 Initial revision
claus
parents:
diff changeset
   191
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   192
a27a279701f8 Initial revision
claus
parents:
diff changeset
   193
mayProceed:aBoolean
44
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
   194
    "set/clear the signals ability to proceed.
419
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   195
     This flag is (currently) not checked by the system;
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   196
     be prepared for changes here, to eventually have nonProceedable
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   197
     signals refuse to let you continue execution."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   198
a27a279701f8 Initial revision
claus
parents:
diff changeset
   199
    mayProceed := aBoolean
a27a279701f8 Initial revision
claus
parents:
diff changeset
   200
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   201
419
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   202
mayProceed
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   203
    "return the signals ability to proceed.
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   204
     This flag is (currently) not checked by the system;
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   205
     be prepared for changes here, to eventually have nonProceedable
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   206
     signals refuse to let you continue execution."
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   207
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   208
    ^ mayProceed
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   209
!
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   210
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   211
parent:aSignal 
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   212
    "set the parent-signal of the receiver."
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   213
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   214
    parent := aSignal
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   215
!
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   216
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   217
parent
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   218
    "return the parent-signal of the receiver"
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   219
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   220
    ^ parent
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   221
!
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   222
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   223
notifierString:aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   224
    "set the notifier string"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   225
a27a279701f8 Initial revision
claus
parents:
diff changeset
   226
    notifierString := aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   227
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   228
a27a279701f8 Initial revision
claus
parents:
diff changeset
   229
notifierString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   230
    "return the notifier string"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   231
a27a279701f8 Initial revision
claus
parents:
diff changeset
   232
    ^ notifierString
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   233
!
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   234
362
claus
parents: 345
diff changeset
   235
errorString
claus
parents: 345
diff changeset
   236
    "return the notifier string"
claus
parents: 345
diff changeset
   237
claus
parents: 345
diff changeset
   238
    ^ notifierString
claus
parents: 345
diff changeset
   239
!
claus
parents: 345
diff changeset
   240
120
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
   241
handlerBlock:aOneArgBlock
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
   242
    "set the handlerblock - this will be evaluated with the exception 
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
   243
     object as argument, if no #handle:do: context was found on the stack."
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   244
120
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
   245
    handlerBlock := aOneArgBlock
171
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   246
!
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   247
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   248
handlerBlock
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   249
    "return the handlerblock - if non-nil, this will be evaluated with the exception 
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   250
     object as argument, if no #handle:do: context was found on the stack."
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   251
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   252
    ^ handlerBlock
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   253
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   254
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   255
!Signal methodsFor:'printing'!
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   256
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   257
printOn:aStream
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   258
    "append a printed representation of the receiver on aStream"
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   259
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   260
    nameClass notNil ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   261
	aStream nextPutAll:nameClass name.
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   262
	aStream space.
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   263
	aStream nextPutAll:message.
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   264
	^ self
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   265
    ].
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   266
    ^ super printOn:aStream
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   267
! !
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   268
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   269
!Signal methodsFor:'save evaluation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   270
a27a279701f8 Initial revision
claus
parents:
diff changeset
   271
handle:handleBlock do:aBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
   272
    "evaluate the argument, aBlock.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   273
     If the receiver-signal is raised during evaluation,
a27a279701f8 Initial revision
claus
parents:
diff changeset
   274
     evaluate the handleBlock passing it an Exception argument.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   275
     The handler may decide how to react to the signal by sending
a27a279701f8 Initial revision
claus
parents:
diff changeset
   276
     a corresponding message to the exception (see there).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   277
     If the signal is not raised, return the value of evaluating
a27a279701f8 Initial revision
claus
parents:
diff changeset
   278
     aBlock."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   279
a27a279701f8 Initial revision
claus
parents:
diff changeset
   280
     ^ aBlock value  "the real logic is in raise/Exception"
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   281
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   282
      "
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   283
       Object messageNotUnderstoodSignal handle:[:ex |
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   284
	  'oops' printNL.
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   285
	  ex return
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   286
       ] do:[
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   287
	  123 size open   
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   288
       ]
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   289
      "
120
9a2e74ed2f81 added per-process handler
claus
parents: 95
diff changeset
   290
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   291
      "
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   292
       |num|
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   293
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   294
       num := 0.
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   295
       Number divisionByZeroSignal handle:[:ex |
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   296
	  'oops' printNL.
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   297
	  ex return
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   298
       ] do:[
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   299
	  123 / num   
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   300
       ]
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   301
      "
44
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
   302
!
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
   303
362
claus
parents: 345
diff changeset
   304
handle:handleBlock from:anObject do:aBlock
claus
parents: 345
diff changeset
   305
    "evaluate the argument, aBlock.
claus
parents: 345
diff changeset
   306
     If the receiver-signal is raised during evaluation,
claus
parents: 345
diff changeset
   307
     and the exception originated from anObject,
claus
parents: 345
diff changeset
   308
     evaluate the handleBlock passing it an Exception argument.
claus
parents: 345
diff changeset
   309
     The handler may decide how to react to the signal by sending
claus
parents: 345
diff changeset
   310
     a corresponding message to the exception (see there).
claus
parents: 345
diff changeset
   311
     If the signal is not raised, return the value of evaluating
claus
parents: 345
diff changeset
   312
     aBlock."
claus
parents: 345
diff changeset
   313
claus
parents: 345
diff changeset
   314
     ^ aBlock value  "the real logic is in raise/Exception"
claus
parents: 345
diff changeset
   315
claus
parents: 345
diff changeset
   316
      "
claus
parents: 345
diff changeset
   317
       the first open will be cought; the second not:
claus
parents: 345
diff changeset
   318
claus
parents: 345
diff changeset
   319
       |o1 o2|
claus
parents: 345
diff changeset
   320
claus
parents: 345
diff changeset
   321
       o1 := 123.
claus
parents: 345
diff changeset
   322
       o2 := nil.
claus
parents: 345
diff changeset
   323
       Object messageNotUnderstoodSignal 
claus
parents: 345
diff changeset
   324
	   handle:
claus
parents: 345
diff changeset
   325
		[:ex |
claus
parents: 345
diff changeset
   326
		    'oops' printNL.
claus
parents: 345
diff changeset
   327
		    ex proceed
claus
parents: 345
diff changeset
   328
		] 
claus
parents: 345
diff changeset
   329
	   from:o1
claus
parents: 345
diff changeset
   330
	   do:
claus
parents: 345
diff changeset
   331
		[
claus
parents: 345
diff changeset
   332
		    o1 open.
claus
parents: 345
diff changeset
   333
		    o2 open
claus
parents: 345
diff changeset
   334
		]
claus
parents: 345
diff changeset
   335
      "
claus
parents: 345
diff changeset
   336
!
claus
parents: 345
diff changeset
   337
44
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
   338
catch:aBlock
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   339
     "evaluate the argument, aBlock.
44
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
   340
      If the receiver-signal is raised during evaluation, abort
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   341
      the evaluation and return true; otherwise return false. 
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   342
      This is the catch & throw mechanism found in other languages,
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   343
      where the returned value indicates if an exception occured."
44
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
   344
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   345
      |raiseOccurred|
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   346
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   347
      raiseOccurred := false.
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   348
      self handle:[:ex | raiseOccurred := true. ex return] do:aBlock.
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   349
      ^ raiseOccurred
44
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
   350
61
claus
parents: 44
diff changeset
   351
      "
claus
parents: 44
diff changeset
   352
       Object messageNotUnderstoodSignal catch:[
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   353
	  123 size open   
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   354
       ]
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   355
      "
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   356
!
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   357
419
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   358
ignoreIn:aBlock
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   359
     "evaluate the argument, aBlock.
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   360
      Ignore the receiver-signal during evaluation - i.e. simply
419
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   361
      continue. 
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   362
      This makes only sense for some signals, such as UserInterrupt
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   363
      or AbortSignal, because continuing after an exception without any cleanup
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   364
      often leads to followup-errors."
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   365
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   366
      ^ self handle:[:ex | ex proceed] do:aBlock.
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   367
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   368
      "
419
62f39bdfe99d *** empty log message ***
claus
parents: 406
diff changeset
   369
       Object messageNotUnderstoodSignal ignoreIn:[
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   370
	  123 size open   
61
claus
parents: 44
diff changeset
   371
       ]
claus
parents: 44
diff changeset
   372
      "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   373
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   374
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   375
!Signal methodsFor:'queries'!
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   376
406
claus
parents: 384
diff changeset
   377
inheritsFrom:anotherSignal
claus
parents: 384
diff changeset
   378
    "return true, if the receiver is a child of anotherSignal
claus
parents: 384
diff changeset
   379
     (i.e. if handling anotherSignal also handles the receiver)
claus
parents: 384
diff changeset
   380
     This is almost the same as accepts, but returns false, if
claus
parents: 384
diff changeset
   381
     the receiver is identical to anotherSignal."
claus
parents: 384
diff changeset
   382
claus
parents: 384
diff changeset
   383
    self == anotherSignal ifTrue:[^ false].
claus
parents: 384
diff changeset
   384
    ^ anotherSignal accepts:self
claus
parents: 384
diff changeset
   385
!
claus
parents: 384
diff changeset
   386
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   387
accepts:aSignal
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   388
    "return true, if the receiver accepts the argument, aSignal.
214
2e4defd713f9 *** empty log message ***
claus
parents: 171
diff changeset
   389
     (i.e. the receiver is aSignal or a parent of it). False otherwise."
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   390
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   391
    |s|
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   392
421
claus
parents: 419
diff changeset
   393
    aSignal isQuerySignal ifTrue:[^ false].
claus
parents: 419
diff changeset
   394
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   395
    s := aSignal.
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   396
    [s notNil] whileTrue:[
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   397
	self == s ifTrue:[^ true].
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   398
	s := s parent
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   399
    ].
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   400
    ^ false
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   401
!
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   402
259
   403
isSignal
   404
    "return true, if the receiver is some kind of signal;
   405
     true returned here - the method is redefined from Object."
   406
   407
    ^ true
   408
!
   409
421
claus
parents: 419
diff changeset
   410
isQuerySignal
claus
parents: 419
diff changeset
   411
    ^ false
claus
parents: 419
diff changeset
   412
!
claus
parents: 419
diff changeset
   413
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   414
isHandled
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   415
    "return true, if there is a handler for the receiver signal.
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   416
     Raising an unhandled signal will usually lead into the debugger,
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   417
     but can be cought globally by setting Exceptions EmergencyHandler."
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   418
171
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   419
    ^ self isHandledIn:(thisContext sender).
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   420
!
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   421
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   422
isHandledIn:aContext
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   423
    "return true, if there is a handler for the receiver signal in the 
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   424
     contextChain starting with aContext."
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   425
406
claus
parents: 384
diff changeset
   426
    |con sel|
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   427
171
129f0e2e23df handling now in Exception
claus
parents: 159
diff changeset
   428
    con := aContext.
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   429
    [con notNil] whileTrue:[
406
claus
parents: 384
diff changeset
   430
	(((sel := con selector) == #handle:do:) 
claus
parents: 384
diff changeset
   431
	or:[sel == #handle:from:do:]) ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   432
	    "
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   433
	     is this is the Signal>>handle:do: context
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   434
	     or a SignalSet>>handle:do: context with self in it ?
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   435
	    "
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   436
	    (con receiver accepts:self) ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   437
		"found a handler context"
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   438
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   439
		^ true
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   440
	    ].
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   441
	].
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   442
	con := con sender
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   443
    ].
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   444
    ^ false
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   445
! !
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   446
406
claus
parents: 384
diff changeset
   447
!Signal methodsFor:'private'!
claus
parents: 384
diff changeset
   448
claus
parents: 384
diff changeset
   449
errorStringFor:template
claus
parents: 384
diff changeset
   450
    "used when raising with a given error string; if the given
claus
parents: 384
diff changeset
   451
     errorString starts with a space, it is appended to the receivers
claus
parents: 384
diff changeset
   452
     notifier string; if it ends with a space, it is prepended.
claus
parents: 384
diff changeset
   453
     Otherwise, the errorString is returned."
claus
parents: 384
diff changeset
   454
claus
parents: 384
diff changeset
   455
    (template startsWith:' ') ifTrue:[
claus
parents: 384
diff changeset
   456
	^ notifierString , template
claus
parents: 384
diff changeset
   457
    ].
claus
parents: 384
diff changeset
   458
    (template endsWith:' ') ifTrue:[
claus
parents: 384
diff changeset
   459
	^ template , notifierString
claus
parents: 384
diff changeset
   460
    ].
claus
parents: 384
diff changeset
   461
    ^ template
claus
parents: 384
diff changeset
   462
! !
claus
parents: 384
diff changeset
   463
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   464
!Signal methodsFor:'raising'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   465
a27a279701f8 Initial revision
claus
parents:
diff changeset
   466
raise
a27a279701f8 Initial revision
claus
parents:
diff changeset
   467
    "raise a signal - create an Exception object
2
claus
parents: 1
diff changeset
   468
     and call the handler with this as argument.
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   469
     The signals notifierString is used as errorString."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   470
362
claus
parents: 345
diff changeset
   471
    ^ (Exception  
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   472
	      signal:self
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   473
	      parameter:nil 
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   474
	      errorString:notifierString
362
claus
parents: 345
diff changeset
   475
	      suspendedContext:thisContext sender) raise.
claus
parents: 345
diff changeset
   476
!
44
b262907c93ea *** empty log message ***
claus
parents: 27
diff changeset
   477
362
claus
parents: 345
diff changeset
   478
raiseErrorString:aString
claus
parents: 345
diff changeset
   479
    "raise a signal - create an Exception object
claus
parents: 345
diff changeset
   480
     and call the handler with this as argument.
claus
parents: 345
diff changeset
   481
     The argument is used as errorString."
claus
parents: 345
diff changeset
   482
claus
parents: 345
diff changeset
   483
    ^ (Exception  
claus
parents: 345
diff changeset
   484
	      signal:self
claus
parents: 345
diff changeset
   485
	      parameter:nil 
406
claus
parents: 384
diff changeset
   486
	      errorString:(self errorStringFor:aString)
362
claus
parents: 345
diff changeset
   487
	      suspendedContext:thisContext sender) raise.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   488
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   489
329
claus
parents: 326
diff changeset
   490
raiseFrom:something
claus
parents: 326
diff changeset
   491
    "raise a signal - create an Exception object with aParameter
claus
parents: 326
diff changeset
   492
     and call the handler with this as argument..
362
claus
parents: 345
diff changeset
   493
     The argument, something is passed both as parameter and originator.
329
claus
parents: 326
diff changeset
   494
     XXX: I am not certain, if this is the correct behavior (seen in remoteInvocation-goodie)"
claus
parents: 326
diff changeset
   495
362
claus
parents: 345
diff changeset
   496
    ^ (Exception 
329
claus
parents: 326
diff changeset
   497
	      signal:self
362
claus
parents: 345
diff changeset
   498
	      parameter:something 
claus
parents: 345
diff changeset
   499
	      errorString:notifierString
claus
parents: 345
diff changeset
   500
	      suspendedContext:thisContext sender
claus
parents: 345
diff changeset
   501
	      originator:something) raise.
329
claus
parents: 326
diff changeset
   502
!
claus
parents: 326
diff changeset
   503
255
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   504
raiseIn:aContext
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   505
    "raise a signal - create an Exception object
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   506
     and call the handler with this as argument.
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   507
     The signals notifierString is used as errorString.
362
claus
parents: 345
diff changeset
   508
     The additional context is passed as the context responsible for the raise,
claus
parents: 345
diff changeset
   509
     allowing a raise to mimicri the exception happened somewhere else."
255
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   510
362
claus
parents: 345
diff changeset
   511
    ^ (Exception 
255
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   512
	      signal:self
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   513
	      parameter:nil 
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   514
	      errorString:notifierString
362
claus
parents: 345
diff changeset
   515
	      suspendedContext:aContext) raise.
255
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   516
!
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   517
329
claus
parents: 326
diff changeset
   518
raiseWith:aParameter
claus
parents: 326
diff changeset
   519
    "raise a signal - create an Exception object with aParameter
claus
parents: 326
diff changeset
   520
     and call the handler with this as argument..
362
claus
parents: 345
diff changeset
   521
     The argument, aParameter is passed as parameter.
claus
parents: 345
diff changeset
   522
     XXX: I am not certain, if this is the correct behavior (seen in remoteInvocation-goodie)"
329
claus
parents: 326
diff changeset
   523
362
claus
parents: 345
diff changeset
   524
    ^ (Exception 
claus
parents: 345
diff changeset
   525
	      signal:self
claus
parents: 345
diff changeset
   526
	      parameter:aParameter 
claus
parents: 345
diff changeset
   527
	      errorString:notifierString
claus
parents: 345
diff changeset
   528
	      suspendedContext:thisContext sender) raise.
329
claus
parents: 326
diff changeset
   529
!
claus
parents: 326
diff changeset
   530
claus
parents: 326
diff changeset
   531
raiseWith:aParameter errorString:aString
claus
parents: 326
diff changeset
   532
    "raise a signal - create an Exception object with aParameter
claus
parents: 326
diff changeset
   533
     and call the handler with this as argument..
362
claus
parents: 345
diff changeset
   534
     The argument, aString is used as errorString, aParameter is passed
claus
parents: 345
diff changeset
   535
     as exception parameter."
claus
parents: 345
diff changeset
   536
claus
parents: 345
diff changeset
   537
    ^ (Exception 
claus
parents: 345
diff changeset
   538
	      signal:self
claus
parents: 345
diff changeset
   539
	      parameter:aParameter 
406
claus
parents: 384
diff changeset
   540
	      errorString:(self errorStringFor:aString)
362
claus
parents: 345
diff changeset
   541
	      suspendedContext:thisContext sender) raise.
claus
parents: 345
diff changeset
   542
!
329
claus
parents: 326
diff changeset
   543
362
claus
parents: 345
diff changeset
   544
raiseRequest
claus
parents: 345
diff changeset
   545
    "raise a signal - create an Exception object
claus
parents: 345
diff changeset
   546
     and call the handler with this as argument.
claus
parents: 345
diff changeset
   547
     The signals notifierString is used as errorString."
claus
parents: 345
diff changeset
   548
claus
parents: 345
diff changeset
   549
    ^ (Exception  
claus
parents: 345
diff changeset
   550
	      signal:self
claus
parents: 345
diff changeset
   551
	      parameter:nil 
claus
parents: 345
diff changeset
   552
	      errorString:notifierString
claus
parents: 345
diff changeset
   553
	      suspendedContext:thisContext sender) raiseRequest.
329
claus
parents: 326
diff changeset
   554
!
claus
parents: 326
diff changeset
   555
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   556
raiseRequestWith:aParameter
362
claus
parents: 345
diff changeset
   557
    "raise a signal - create a proceedable Exception object with aParameter
claus
parents: 345
diff changeset
   558
     and look for handlers .
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   559
     The signals notifierString is used as errorString."
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   560
362
claus
parents: 345
diff changeset
   561
    ^ (Exception 
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   562
	      signal:self
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   563
	      parameter:aParameter 
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   564
	      errorString:notifierString
362
claus
parents: 345
diff changeset
   565
	      suspendedContext:thisContext sender) raiseRequest.
2
claus
parents: 1
diff changeset
   566
!
claus
parents: 1
diff changeset
   567
255
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   568
raiseRequestWith:aParameter in:aContext
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   569
    "raise a signal - create an Exception object with aParameter
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   570
     and call the handler with this as argument..
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   571
     The signals notifierString is used as errorString.
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   572
     The additional context is passed as the context responsible for the raise."
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   573
362
claus
parents: 345
diff changeset
   574
    ^ (Exception 
255
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   575
	      signal:self
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   576
	      parameter:aParameter 
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   577
	      errorString:notifierString
362
claus
parents: 345
diff changeset
   578
	      suspendedContext:aContext) raiseRequest.
255
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   579
!
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   580
2
claus
parents: 1
diff changeset
   581
raiseRequestWith:aParameter errorString:aString
claus
parents: 1
diff changeset
   582
    "raise a signal - create an Exception object with aParameter
70
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   583
     and call the handler with this as argument..
73055652dd21 *** empty log message ***
claus
parents: 61
diff changeset
   584
     The argument, aString is used as errorString."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   585
362
claus
parents: 345
diff changeset
   586
    ^ (Exception 
159
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   587
	      signal:self
514c749165c3 *** empty log message ***
claus
parents: 145
diff changeset
   588
	      parameter:aParameter 
406
claus
parents: 384
diff changeset
   589
	      errorString:(self errorStringFor:aString)
362
claus
parents: 345
diff changeset
   590
	      suspendedContext:thisContext sender) raiseRequest
255
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   591
!
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   592
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   593
raiseRequestWith:aParameter errorString:aString in:aContext
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   594
    "raise a signal - create an Exception object with aParameter
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   595
     and call the handler with this as argument..
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   596
     The argument, aString is used as errorString.
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   597
     The additional context is passed as the context responsible for the raise."
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   598
362
claus
parents: 345
diff changeset
   599
    ^ (Exception 
255
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   600
	      signal:self
2b2c5c0facab *** empty log message ***
claus
parents: 214
diff changeset
   601
	      parameter:aParameter 
406
claus
parents: 384
diff changeset
   602
	      errorString:(self errorStringFor:aString)
362
claus
parents: 345
diff changeset
   603
	      suspendedContext:aContext) raiseRequest
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   604
! !