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