SignalSet.st
author Claus Gittinger <cg@exept.de>
Tue, 07 Jan 1997 12:02:05 +0100
changeset 2072 e84dbf5e5424
parent 1292 89497fff7f87
child 2283 a1b388277558
permissions -rw-r--r--
removed package-change info message
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: 95
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
IdentitySet subclass:#SignalSet
1275
2079f4776628 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 697
diff changeset
    14
	instanceVariableNames:''
2079f4776628 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 697
diff changeset
    15
	classVariableNames:'SetOfAnySignal'
2079f4776628 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 697
diff changeset
    16
	poolDictionaries:''
2079f4776628 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 697
diff changeset
    17
	category:'Kernel-Exceptions'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
44
b262907c93ea *** empty log message ***
claus
parents: 41
diff changeset
    20
!SignalSet class methodsFor:'documentation'!
b262907c93ea *** empty log message ***
claus
parents: 41
diff changeset
    21
88
81dacba7a63a *** empty log message ***
claus
parents: 71
diff changeset
    22
copyright
81dacba7a63a *** empty log message ***
claus
parents: 71
diff changeset
    23
"
81dacba7a63a *** empty log message ***
claus
parents: 71
diff changeset
    24
 COPYRIGHT (c) 1993 by Claus Gittinger
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
    25
	      All Rights Reserved
88
81dacba7a63a *** empty log message ***
claus
parents: 71
diff changeset
    26
81dacba7a63a *** empty log message ***
claus
parents: 71
diff changeset
    27
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 71
diff changeset
    28
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 71
diff changeset
    29
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 71
diff changeset
    30
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 71
diff changeset
    31
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 71
diff changeset
    32
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 71
diff changeset
    33
"
81dacba7a63a *** empty log message ***
claus
parents: 71
diff changeset
    34
!
81dacba7a63a *** empty log message ***
claus
parents: 71
diff changeset
    35
44
b262907c93ea *** empty log message ***
claus
parents: 41
diff changeset
    36
documentation
b262907c93ea *** empty log message ***
claus
parents: 41
diff changeset
    37
"
71
a42874820e27 *** empty log message ***
claus
parents: 44
diff changeset
    38
    SignalSet allows catching of multiple signals. A SignalSet consists of
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
    39
    a number of signals and also implements the #handle:do: and #catch: methods
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
    40
    just as signals do. 
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
    41
    However, any signal from the SignalSet will, if signalled, lead into the handler.
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
    42
71
a42874820e27 *** empty log message ***
claus
parents: 44
diff changeset
    43
    There is also a special signalSet, which can be used to catch any
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
    44
    signal in the system - but this should no longer be used, since catching
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
    45
    Object>>errorSignal has now the same effect.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    46
71
a42874820e27 *** empty log message ***
claus
parents: 44
diff changeset
    47
    For more detail, see comment in Signal and examples in doc/coding.
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
    48
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
    49
    Notice: SignalSets are not needed when a group of children of a common signal
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
    50
    (such as arithmeticSignal) is to be handled; the parent signal of those will
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
    51
    also handle all children.
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
    52
    Use signalSets if totally unrelated signals should be handled by one common
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
    53
    handler.
1275
2079f4776628 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 697
diff changeset
    54
2079f4776628 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 697
diff changeset
    55
1292
89497fff7f87 documentation
Claus Gittinger <cg@exept.de>
parents: 1275
diff changeset
    56
    [author:]
89497fff7f87 documentation
Claus Gittinger <cg@exept.de>
parents: 1275
diff changeset
    57
        Claus Gittinger
89497fff7f87 documentation
Claus Gittinger <cg@exept.de>
parents: 1275
diff changeset
    58
1275
2079f4776628 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 697
diff changeset
    59
    [see also:]
2079f4776628 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 697
diff changeset
    60
        Exception 
2079f4776628 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 697
diff changeset
    61
        Signal QuerySignal
2079f4776628 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 697
diff changeset
    62
        Object
44
b262907c93ea *** empty log message ***
claus
parents: 41
diff changeset
    63
"
b262907c93ea *** empty log message ***
claus
parents: 41
diff changeset
    64
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    65
a27a279701f8 Initial revision
claus
parents:
diff changeset
    66
!SignalSet class methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    67
a27a279701f8 Initial revision
claus
parents:
diff changeset
    68
anySignal
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
    69
    "return a special signalSet for catching any signal.
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
    70
     Obsolete; use Object>>errorSignal for that purpose."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    71
44
b262907c93ea *** empty log message ***
claus
parents: 41
diff changeset
    72
    SetOfAnySignal isNil ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
    73
	SetOfAnySignal := self basicNew
44
b262907c93ea *** empty log message ***
claus
parents: 41
diff changeset
    74
    ].
b262907c93ea *** empty log message ***
claus
parents: 41
diff changeset
    75
    ^ SetOfAnySignal
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    76
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
    77
622
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    78
!SignalSet methodsFor:'queries'!
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    79
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    80
accepts:aSignal
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    81
    "return true, if the receiver accepts the argument, aSignal.
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    82
     (i.e. if any of the receivers elements is aSignal or a parent of it).
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    83
     False otherwise. The special anySet accepts any (non-query) signal."
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    84
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    85
    (self == SetOfAnySignal) ifTrue:[^ aSignal isQuerySignal not].
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    86
    self do:[:sig | (sig accepts:aSignal) ifTrue:[^ true]].
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    87
    ^ false
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    88
!
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    89
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    90
includes:aSignal
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    91
    "return true, if the receiver contains the argument, aSignal.
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    92
     The special any-Set includes every (non-query) signal."
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    93
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    94
    (self == SetOfAnySignal) ifTrue:[
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    95
	^ (aSignal isSignal and:[aSignal isQuerySignal not])
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    96
    ].
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    97
    ^ super includes:aSignal
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    98
! !
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
    99
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   100
!SignalSet methodsFor:'save evaluation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   101
622
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   102
catch:aBlock
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   103
     "evaluate the argument, aBlock.
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   104
      If any of the signals in the receiver is raised during evaluation, 
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   105
      abort the evaluation and return true; otherwise return false. 
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   106
      With the special anySignal, evaluation can be performed totally save 
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   107
      from signals 
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   108
      - but who (beside radical c++ fans) would do that ?"
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   109
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   110
      |raiseOccurred|
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   111
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   112
      raiseOccurred := false.
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   113
      self handle:[:ex | raiseOccurred := true. ex return] do:aBlock.
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   114
      ^ raiseOccurred
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   115
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   116
      "
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   117
       SignalSet anySignal catch:[
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   118
	  (#(1 2 3 4) at:5) / 0.0
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   119
       ]
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   120
      "
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   121
!
a17084b7ac06 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   122
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   123
handle:handleBlock do:aBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
   124
    "evaluate the argument, aBlock.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   125
     If any of the signals in the receiver is raised during evaluation,
a27a279701f8 Initial revision
claus
parents:
diff changeset
   126
     evaluate the handleBlock passing it an Exception argument.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   127
     The handler may decide how to react to the signal by sending
a27a279701f8 Initial revision
claus
parents:
diff changeset
   128
     a corresponding message to the exception (see there).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   129
     If the signal is not raised, return the value of evaluating
a27a279701f8 Initial revision
claus
parents:
diff changeset
   130
     aBlock."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   131
a27a279701f8 Initial revision
claus
parents:
diff changeset
   132
     ^ aBlock value  "the real logic is in raise/Exception"
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   133
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   134
      "
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   135
       SignalSet anySignal handle:[:ex |
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   136
	  ex errorString print. ' occured in: ' print. ex suspendedContext printNL.
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   137
	  ex return
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   138
       ] do:[
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   139
	  (#(1 2 3 4) at:5) / 0.0
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   140
       ]
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   141
      "
44
b262907c93ea *** empty log message ***
claus
parents: 41
diff changeset
   142
!
b262907c93ea *** empty log message ***
claus
parents: 41
diff changeset
   143
362
claus
parents: 259
diff changeset
   144
handle:handleBlock from:anObject do:aBlock
claus
parents: 259
diff changeset
   145
    "evaluate the argument, aBlock.
claus
parents: 259
diff changeset
   146
     If any of the signals in the receiver is raised during evaluation,
claus
parents: 259
diff changeset
   147
     and the exception originated from anObject,
claus
parents: 259
diff changeset
   148
     evaluate the handleBlock passing it an Exception argument.
claus
parents: 259
diff changeset
   149
     The handler may decide how to react to the signal by sending
claus
parents: 259
diff changeset
   150
     a corresponding message to the exception (see there).
claus
parents: 259
diff changeset
   151
     If the signal is not raised, return the value of evaluating
claus
parents: 259
diff changeset
   152
     aBlock."
claus
parents: 259
diff changeset
   153
claus
parents: 259
diff changeset
   154
     ^ aBlock value  "the real logic is in raise/Exception"
claus
parents: 259
diff changeset
   155
!
claus
parents: 259
diff changeset
   156
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   157
ignore:aBlock
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   158
     "evaluate the argument, aBlock.
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   159
      Ignore the receiver-signal during evaluation - i.e. simply
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   160
      continue. This makes only sense for some signals, such as UserInterrupt
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   161
      or AbortSignals, because continuing after an exception without any cleanup
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   162
      will often lead to followup-errors."
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   163
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   164
      ^ self handle:[:ex | ex proceed] do:aBlock.
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   165
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   166
      "
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   167
       SignalSet anySignal ignore:[
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   168
	  123 size open   
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   169
       ]
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   170
      "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   171
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   172
696
d11342e8b7ad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 622
diff changeset
   173
!SignalSet class methodsFor:'documentation'!
d11342e8b7ad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 622
diff changeset
   174
d11342e8b7ad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 622
diff changeset
   175
version
1292
89497fff7f87 documentation
Claus Gittinger <cg@exept.de>
parents: 1275
diff changeset
   176
    ^ '$Header: /cvs/stx/stx/libbasic/SignalSet.st,v 1.20 1996-04-25 16:46:55 cg Exp $'
696
d11342e8b7ad checkin from browser
Claus Gittinger <cg@exept.de>
parents: 622
diff changeset
   177
! !