NoHandlerError.st
author Claus Gittinger <cg@exept.de>
Thu, 02 Sep 1999 23:44:11 +0200
changeset 4670 21eec331e1e9
parent 4586 22c84f7f9b85
child 4937 7e723f1daca7
permissions -rw-r--r--
checkin from browser
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
4554
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
     1
"
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
     2
 COPYRIGHT (c) 1999 by eXept Software AG
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
     3
              All Rights Reserved
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
     4
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
     5
 This software is furnished under a license and may be used
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
     6
 only in accordance with the terms of that license and with the
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
     8
 be provided or otherwise made available to, or used by, any
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
     9
 other person.  No title to or ownership of the software is
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    10
 hereby transferred.
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    11
"
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    12
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    13
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    14
4528
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    15
GenericException subclass:#NoHandlerError
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    16
	instanceVariableNames:''
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    17
	classVariableNames:'EmergencyHandler'
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    18
	poolDictionaries:''
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    19
	category:'Kernel-Exceptions'
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    20
!
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    21
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    22
!NoHandlerError class methodsFor:'documentation'!
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    23
4554
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    24
copyright
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    25
"
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    26
 COPYRIGHT (c) 1999 by eXept Software AG
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    27
              All Rights Reserved
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    28
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    29
 This software is furnished under a license and may be used
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    30
 only in accordance with the terms of that license and with the
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    31
 inclusion of the above copyright notice.   This software may not
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    32
 be provided or otherwise made available to, or used by, any
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    33
 other person.  No title to or ownership of the software is
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    34
 hereby transferred.
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    35
"
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    36
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    37
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    38
!
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    39
4528
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    40
documentation
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    41
"
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    42
    NoHandlerError is raised, if there is no exception handler
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    43
    or default action for an exception.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    44
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    45
    The parameter is the unhandled exception.
4554
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    46
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    47
    [Class variables:]
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    48
        EmergencyHandler <Block>    this block is evaluated, if no handler was defined
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    49
                                    for a signal (i.e. this one is responsible for the
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    50
                                    unhandled exception debugger).
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    51
                                    Having this being a block allows to globally catch
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    52
                                    these errors - even when no enclosing handler-scope
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    53
                                    around the erronous code exists.
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    54
                                    (as the catch/through does).
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    55
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    56
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    57
    [see also:]
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    58
        GenericException 
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    59
        (``Exception handling and signals'': programming/exceptions.html)
4528
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    60
"
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    61
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
    62
4554
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    63
!
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    64
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    65
examples
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    66
"
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    67
    The emergencyHandler stuff is very useful, to prevent endUser applications
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    68
    from entering the debugger.
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    69
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    70
    Some commonly used (useful) emergency handlers are provided in the
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    71
    'useful handlers' section; try them to learn more
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    72
    (especially, the mailingHandler is fun).
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    73
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    74
    Of course, these are only examples - you may define your own handler
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    75
    block and pass it to the #emergencyHandler: method.
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    76
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    77
    BTW: the Launchers 'source & debugger' settings menu allows you
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    78
         to install either a default or the notifying handler.
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    79
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    80
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    81
    A handler which shows a box, then aborts - (no more debuggers):
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    82
                                                                [exBegin]
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    83
        NoHandlerError emergencyHandler:(NoHandlerError abortingEmergencyHandler)
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    84
                                                                [exEnd]
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    85
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    86
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    87
    A handler which aborts - (no box, no debugger):
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    88
                                                                [exBegin]
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    89
        NoHandlerError emergencyHandler:[:ex | AbortSignal raise]
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    90
                                                                [exEnd]
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    91
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    92
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    93
    try some exception (for demonstration, in some other process):
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    94
                                                                [exBegin]
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    95
        [
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    96
            #(1 2 3) at:4
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    97
        ] fork.
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    98
                                                                [exEnd]
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
    99
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   100
    cleanup (switch back to the regular handler, which enters the debugger):
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   101
                                                                [exBegin]
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   102
        NoHandlerError emergencyHandler:nil
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   103
                                                                [exEnd]
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   104
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   105
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   106
    A handler which shows a warnBox and asks for debugging:
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   107
                                                                [exBegin]
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   108
        NoHandlerError emergencyHandler:(NoHandlerError notifyingEmergencyHandler)
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   109
                                                                [exEnd]
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   110
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   111
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   112
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   113
    A handler which dumps information to a file (watch the file 'errorTrace.stx'):
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   114
                                                                [exBegin]
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   115
        NoHandlerError emergencyHandler:(NoHandlerError dumpingEmergencyHandler)
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   116
                                                                [exEnd]
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   117
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   118
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   119
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   120
    A handler which sends you mail:
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   121
                                                                [exBegin]
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   122
        NoHandlerError emergencyHandler:(NoHandlerError mailingEmergencyHandler)
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   123
                                                                [exEnd]
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   124
"
db264efac2c0 Add copyright.
Stefan Vogel <sv@exept.de>
parents: 4539
diff changeset
   125
4528
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   126
! !
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   127
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   128
!NoHandlerError class methodsFor:'initialization'!
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   129
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   130
initialize
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   131
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   132
    NotifierString := 'unhandled exception'.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   133
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   134
    "
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   135
     self initialize
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   136
    "
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   137
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   138
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   139
! !
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   140
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   141
!NoHandlerError class methodsFor:'emergency handlers'!
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   142
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   143
emergencyHandler
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   144
    "return the handler used for unhandled exceptions.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   145
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   146
     If no EmergencyHandler has been set, a handler which enters the 
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   147
     debugger is returned.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   148
     The debugger is opened by asking the signal for a debug action,
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   149
     this allows to provide other debuggers in specialized (subclass-instances)
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   150
     of Signal (if that is ever needed)"
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   151
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   152
    "
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   153
     set it up, when called the first time
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   154
    "
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   155
    EmergencyHandler isNil ifTrue:[
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   156
        EmergencyHandler := [:ex |
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   157
            "
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   158
             sending it to the signal allows per-signal specific
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   159
             debuggers to be implemented in the future
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   160
             (for example, segv in primitive code could show things 
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   161
              on the C-level ..)
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   162
            "
4586
22c84f7f9b85 return nil from raise if proceeded in the debugger
Claus Gittinger <cg@exept.de>
parents: 4561
diff changeset
   163
            (ex signal) openDebuggerOnException:ex.
22c84f7f9b85 return nil from raise if proceeded in the debugger
Claus Gittinger <cg@exept.de>
parents: 4561
diff changeset
   164
            "/ if we arrive here, the debugger proceeded.
22c84f7f9b85 return nil from raise if proceeded in the debugger
Claus Gittinger <cg@exept.de>
parents: 4561
diff changeset
   165
            "/ the value below is the exceptions value ...
22c84f7f9b85 return nil from raise if proceeded in the debugger
Claus Gittinger <cg@exept.de>
parents: 4561
diff changeset
   166
            nil
4528
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   167
        ]
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   168
    ].
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   169
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   170
    ^ EmergencyHandler
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   171
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   172
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   173
!
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   174
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   175
emergencyHandler:aOneArgBlock
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   176
    "set the handler used for unhandled exceptions.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   177
     The default (a nil-handler) leads to a debugger to be shown."
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   178
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   179
    EmergencyHandler := aOneArgBlock
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   180
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   181
    "ST-80 behavior of first showing a notifier:
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   182
     (I prefer to get right into the debugger, though)
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   183
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   184
     Exception
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   185
        emergencyHandler:
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   186
            [:ex | self errorNotify:ex errorString ]
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   187
    "
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   188
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   189
    "ST-X behavior of going right into the debugger:
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   190
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   191
     Exception
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   192
        emergencyHandler:nil
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   193
    "
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   194
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   195
    "automatically aborting current operation, on error:
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   196
     (may be useful for end-user apps; make certain, 
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   197
      you have abortSignal handlers at appropriate places)
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   198
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   199
     Exception
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   200
        emergencyHandler:
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   201
            [:ex | Object abortSignal raise. ex return. ]
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   202
    "
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   203
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   204
    "finally, traditional language system behavior; dump core ;-)
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   205
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   206
     Exception
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   207
        emergencyHandler:
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   208
            [:ex | Smalltalk exitWithCoreDump. ]
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   209
    "
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   210
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   211
    "Modified: 15.1.1997 / 20:49:06 / cg"
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   212
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   213
! !
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   214
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   215
!NoHandlerError class methodsFor:'useful handlers'!
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   216
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   217
abortingEmergencyHandler
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   218
    "return a block (usable as an emergency handler), 
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   219
     which aborts after showing a warnBox.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   220
     This is useful for endUser applications"
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   221
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   222
    ^ [:ex | self warn:'Error: ' , ex errorString.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   223
             AbortSignal raise 
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   224
      ]
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   225
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   226
    "test with (try a few halts or CTRL-C's):
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   227
     NoHandlerError emergencyHandler:(NoHandlerError abortingEmergencyHandler)
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   228
    "
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   229
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   230
    "back with:
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   231
     NoHandlerError emergencyHandler:(NoHandlerError notifyingEmergencyHandler)
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   232
     NoHandlerError emergencyHandler:nil
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   233
    "
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   234
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   235
    "Created: 15.1.1997 / 20:13:06 / cg"
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   236
    "Modified: 15.1.1997 / 20:15:02 / cg"
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   237
!
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   238
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   239
dumpingEmergencyHandler
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   240
    "return a block (usable as an emergency handler), 
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   241
     which dumps the stackBacktrace to a trace file and
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   242
     aborts after showing a warnBox.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   243
     This is useful, for endUser application, which are still being
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   244
     debugged (i.e. the programmers may have a look at the traceFile
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   245
     from time to time).
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   246
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   247
     Notice:
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   248
         The code below is just an example; you may want to change the
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   249
         name of the error-file in your application
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   250
         (but please: copy the code; do not modify here)"
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   251
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   252
    ^ [:ex | 
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   253
             |str printedException|
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   254
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   255
             ex signal == NoHandlerError ifTrue:[
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   256
                printedException := ex parameter.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   257
             ] ifFalse:[
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   258
                printedException := ex
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   259
             ].
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   260
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   261
             "/ user interruption is handled specially:
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   262
             "/ allow user to choose between proceeding or aborting
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   263
             "/ but never dump that information to the file.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   264
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   265
             printedException signal == Object userInterruptSignal ifTrue:[
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   266
                  (self confirm:'abort current action ?') ifTrue:[
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   267
                      AbortSignal raise
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   268
                  ].
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   269
                  ex proceedWith:nil
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   270
             ].
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   271
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   272
             "/
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   273
             "/ dump it to 'errorTrace.stx'
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   274
             "/
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   275
             str := 'errorTrace.stx' asFilename appendingWriteStream.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   276
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   277
             str nextPutLine:('******************************* '
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   278
                              , AbsoluteTime now printString
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   279
                              , ' *******************************').
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   280
             str cr.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   281
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   282
             str nextPutLine:('** Error: ' , printedException errorString).
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   283
             str nextPutLine:('** Signal: ' , printedException signal printString).
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   284
             str nextPutLine:('** Parameter: ' , printedException parameter printString).
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   285
             str nextPutLine:('** Process: ' , Processor activeProcess printString).
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   286
             str nextPutLine:('** Backtrace:').
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   287
             str cr.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   288
        
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   289
             printedException suspendedContext fullPrintAllOn:str.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   290
             str cr.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   291
             str cr.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   292
             str close.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   293
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   294
             "/ send a line to stdErr
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   295
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   296
             ('[warning]: ignored error: ' , printedException errorString) errorPrintCR.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   297
             ('[warning]:    error information appended to ''errorTrace.stx''') errorPrintCR.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   298
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   299
             AbortSignal raise 
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   300
      ]
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   301
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   302
    "test with (try a few halts or CTRL-C's):
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   303
     NoHandlerError emergencyHandler:(NoHandlerError dumpingEmergencyHandler)
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   304
    "
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   305
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   306
    "back with:
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   307
     NoHandlerError emergencyHandler:(NoHandlerError notifyingEmergencyHandler)
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   308
     NoHandlerError emergencyHandler:nil
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   309
    "
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   310
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   311
    "Created: / 15.1.1997 / 20:14:52 / cg"
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   312
    "Modified: / 24.1.1997 / 20:36:21 / cg"
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   313
    "Modified: / 4.8.1999 / 08:11:20 / stefan"
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   314
!
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   315
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   316
mailingEmergencyHandler
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   317
    "return a block (usable as an emergency handler), 
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   318
     which shows a warnBox and optionally mails a stackBacktrace to a maintainer.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   319
     This is useful, for endUser application, which are still being
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   320
     debugged (i.e. the programmers may have a look at the errors).
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   321
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   322
     Notice: the stuff here is a demonstration only; it should be modified
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   323
             for your particular environment ...
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   324
             ... but please: copy the code and modify there;
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   325
             leave the stuff below as it is."
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   326
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   327
    ^ [:ex | 
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   328
            |str printedException doMail emergencyMailReceiver pipe|
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   329
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   330
            ex signal == NoHandlerError ifTrue:[
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   331
               printedException := ex parameter.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   332
            ] ifFalse:[
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   333
               printedException := ex
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   334
            ].
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   335
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   336
             "/ user interruption is handled specially:
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   337
             "/ allow user to choose between proceeding or aborting
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   338
             "/ but never dump that information to the file.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   339
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   340
             printedException signal == Object userInterruptSignal ifTrue:[
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   341
                  (self confirm:'abort current action ?') ifTrue:[
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   342
                      AbortSignal raise
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   343
                  ].
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   344
                  ex proceedWith:nil
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   345
             ].
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   346
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   347
            "/ somehow get the name of the guy to receive the mail
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   348
            "/ you have to implement that yourself.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   349
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   350
            "/ emergencyMailReceiver := OneOfYourClass getEmergencyMailReceiver.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   351
            emergencyMailReceiver := OperatingSystem getLoginName.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   352
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   353
            emergencyMailReceiver isNil ifTrue:[
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   354
                self warn:(printedException errorString 
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   355
                           , '\\No mailing to service people possible.') withCRs.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   356
                doMail := false.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   357
            ] ifFalse:[
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   358
                doMail := self confirm:(printedException errorString 
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   359
                                        , '\\Mail error information to the service people (' 
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   360
                                        , emergencyMailReceiver , ') ?') withCRs
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   361
            ].
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   362
            doMail ifTrue:[
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   363
                str := '' writeStream.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   364
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   365
                str nextPutLine:('Error notification from '
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   366
                                , OperatingSystem getLoginName
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   367
                                , '@'
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   368
                                , OperatingSystem getHostName).
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   369
                str cr.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   370
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   371
                str nextPutLine:('Time: ' , AbsoluteTime now printString).
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   372
                str nextPutLine:('Error: ', printedException errorString).
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   373
                str nextPutLine:('Signal: ', printedException signal printString).
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   374
                str nextPutLine:('Parameter: ', printedException parameter printString).
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   375
                str nextPutLine:('Process: ', Processor activeProcess printString).
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   376
                str nextPutLine:'Backtrace:'.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   377
                str cr.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   378
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   379
                printedException suspendedContext fullPrintAllOn:str.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   380
                str cr;cr.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   381
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   382
                str close.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   383
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   384
                pipe := PipeStream 
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   385
                            writingTo:'mail ', emergencyMailReceiver.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   386
                pipe notNil ifTrue:[
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   387
                    pipe nextPutLine:'Subject: automatic error report'.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   388
                    pipe nextPutAll:str contents.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   389
                    pipe cr.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   390
                    pipe close.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   391
                ]
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   392
             ].
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   393
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   394
             AbortSignal raise 
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   395
      ]
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   396
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   397
    "test with (try a few halts or CTRL-C's):
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   398
     NoHandlerError emergencyHandler:(Exception mailingEmergencyHandler)
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   399
    "
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   400
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   401
    "back with:
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   402
     NoHandlerError emergencyHandler:(Exception notifyingEmergencyHandler)
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   403
     NoHandlerError emergencyHandler:nil
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   404
    "
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   405
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   406
    "Created: / 15.1.1997 / 20:14:52 / cg"
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   407
    "Modified: / 15.1.1997 / 21:10:28 / cg"
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   408
    "Modified: / 4.8.1999 / 08:11:26 / stefan"
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   409
!
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   410
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   411
notifyingEmergencyHandler
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   412
    "return a block (usable as an emergency handler for exceptions), 
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   413
     which does errorNotification before going into the debugger."
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   414
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   415
    ^ [:ex | nil errorNotify:ex errorString from:ex suspendedContext ]
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   416
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   417
    "test with (try a few halts or CTRL-C's):
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   418
     Exception emergencyHandler:(Exception notifyingEmergencyHandler)
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   419
    "
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   420
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   421
    "back with:
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   422
     NoHandlerError emergencyHandler:nil
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   423
    "
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   424
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   425
    "Modified: 15.1.1997 / 20:15:12 / cg"
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   426
! !
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   427
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   428
!NoHandlerError methodsFor:'default actions'!
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   429
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   430
defaultAction
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   431
    "This action is performed, if nobody handles the NoHandlerError.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   432
     Look for either a per-process emergencyHandlerBlock 
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   433
     or the global emergencyHandler (from Exception) ..."
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   434
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   435
    |block|
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   436
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   437
    Processor notNil ifTrue:[ 
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   438
        "care for signal during startup (Processor not yet created)"
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   439
        block := Processor activeProcess emergencySignalHandler.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   440
    ].
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   441
    block isNil ifTrue:[
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   442
        block := self class emergencyHandler.
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   443
        block isNil ifTrue:[
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   444
            "care for error during startup (Exception not yet initialized)"
4539
7064506e8285 debugger entry protocol changed;
Claus Gittinger <cg@exept.de>
parents: 4528
diff changeset
   445
            ^ MiniDebugger 
7064506e8285 debugger entry protocol changed;
Claus Gittinger <cg@exept.de>
parents: 4528
diff changeset
   446
                enterWithMessage:self errorString 
7064506e8285 debugger entry protocol changed;
Claus Gittinger <cg@exept.de>
parents: 4528
diff changeset
   447
                mayProceed:self mayProceed
4528
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   448
        ].
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   449
    ].
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   450
4586
22c84f7f9b85 return nil from raise if proceeded in the debugger
Claus Gittinger <cg@exept.de>
parents: 4561
diff changeset
   451
    ^ block value:self
4528
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   452
4561
c82f8c848d4c Add #description, #creator
Stefan Vogel <sv@exept.de>
parents: 4554
diff changeset
   453
!
c82f8c848d4c Add #description, #creator
Stefan Vogel <sv@exept.de>
parents: 4554
diff changeset
   454
c82f8c848d4c Add #description, #creator
Stefan Vogel <sv@exept.de>
parents: 4554
diff changeset
   455
noHandler
c82f8c848d4c Add #description, #creator
Stefan Vogel <sv@exept.de>
parents: 4554
diff changeset
   456
    "redefined to avoid recursive invocations"
c82f8c848d4c Add #description, #creator
Stefan Vogel <sv@exept.de>
parents: 4554
diff changeset
   457
c82f8c848d4c Add #description, #creator
Stefan Vogel <sv@exept.de>
parents: 4554
diff changeset
   458
    ^ self
4528
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   459
! !
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   460
4539
7064506e8285 debugger entry protocol changed;
Claus Gittinger <cg@exept.de>
parents: 4528
diff changeset
   461
!NoHandlerError methodsFor:'queries'!
7064506e8285 debugger entry protocol changed;
Claus Gittinger <cg@exept.de>
parents: 4528
diff changeset
   462
7064506e8285 debugger entry protocol changed;
Claus Gittinger <cg@exept.de>
parents: 4528
diff changeset
   463
mayProceed
7064506e8285 debugger entry protocol changed;
Claus Gittinger <cg@exept.de>
parents: 4528
diff changeset
   464
    "return true, if the exception handler is allowed to proceed
7064506e8285 debugger entry protocol changed;
Claus Gittinger <cg@exept.de>
parents: 4528
diff changeset
   465
     the execution where the exception occured."
7064506e8285 debugger entry protocol changed;
Claus Gittinger <cg@exept.de>
parents: 4528
diff changeset
   466
7064506e8285 debugger entry protocol changed;
Claus Gittinger <cg@exept.de>
parents: 4528
diff changeset
   467
    parameter isNil ifTrue:[^ true].
7064506e8285 debugger entry protocol changed;
Claus Gittinger <cg@exept.de>
parents: 4528
diff changeset
   468
    ^ parameter mayProceed
7064506e8285 debugger entry protocol changed;
Claus Gittinger <cg@exept.de>
parents: 4528
diff changeset
   469
7064506e8285 debugger entry protocol changed;
Claus Gittinger <cg@exept.de>
parents: 4528
diff changeset
   470
7064506e8285 debugger entry protocol changed;
Claus Gittinger <cg@exept.de>
parents: 4528
diff changeset
   471
! !
7064506e8285 debugger entry protocol changed;
Claus Gittinger <cg@exept.de>
parents: 4528
diff changeset
   472
4528
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   473
!NoHandlerError class methodsFor:'documentation'!
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   474
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   475
version
4586
22c84f7f9b85 return nil from raise if proceeded in the debugger
Claus Gittinger <cg@exept.de>
parents: 4561
diff changeset
   476
    ^ '$Header: /cvs/stx/stx/libbasic/NoHandlerError.st,v 1.5 1999-08-10 18:41:49 cg Exp $'
4528
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   477
! !
5ef0de6abb50 initial checkin
Stefan Vogel <sv@exept.de>
parents:
diff changeset
   478
NoHandlerError initialize!