home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
OpenStep (Enterprise)
/
OpenStepENTCD.toast
/
OEDEV
/
DEV.Z
/
error.h
< prev
next >
Wrap
Text File
|
1996-09-11
|
4KB
|
120 lines
/*
error.h
This file defines the interface to the exception raising scheme.
Copyright (c) 1988-1996 NeXT Software, Inc. as an unpublished work.
All rights reserved.
*/
#ifndef _OBJC_ERROR_H_
#define _OBJC_ERROR_H_
#include <setjmp.h>
#import <objc/objc-api.h>
#if defined(__svr4__)
#define _setjmp setjmp
#define _longjmp longjmp
#endif
typedef struct _NXHandler { /* a node in the handler chain */
jmp_buf jumpState; /* place to longjmp to */
struct _NXHandler *next; /* ptr to next handler */
int code; /* error code of exception */
const void *data1, *data2; /* blind data for describing error */
} NXHandler;
/* Handles RAISE's with nowhere to longjmp to */
typedef void NXUncaughtExceptionHandler(int code, const void *data1,
const void *data2);
OBJC_EXPORT NXUncaughtExceptionHandler *_NXUncaughtExceptionHandler;
#define NXGetUncaughtExceptionHandler() _NXUncaughtExceptionHandler
#define NXSetUncaughtExceptionHandler(proc) \
(_NXUncaughtExceptionHandler = (proc))
/* NX_DURING, NX_HANDLER and NX_ENDHANDLER are always used like:
NX_DURING
some code which might raise an error
NX_HANDLER
code that will be jumped to if an error occurs
NX_ENDHANDLER
If any error is raised within the first block of code, the second block
of code will be jumped to. Typically, this code will clean up any
resources allocated in the routine, possibly case on the error code
and perform special processing, and default to RERAISE the error to
the next handler. Within the scope of the handler, a local variable
called NXLocalHandler of type NXHandler holds information about the
error raised.
It is illegal to exit the first block of code by any other means than
NX_VALRETURN, NX_VOIDRETURN, or just falling out the bottom.
*/
/* private support routines. Do not call directly. */
OBJC_EXPORT void _NXAddHandler( NXHandler *handler );
OBJC_EXPORT void _NXRemoveHandler( NXHandler *handler );
#define NX_DURING { NXHandler NXLocalHandler; \
_NXAddHandler(&NXLocalHandler); \
if( !_setjmp(NXLocalHandler.jumpState) ) {
#define NX_HANDLER _NXRemoveHandler(&NXLocalHandler); } else {
#define NX_ENDHANDLER }}
#define NX_VALRETURN(val) do { typeof(val) temp = (val); \
_NXRemoveHandler(&NXLocalHandler); \
return(temp); } while (0)
#define NX_VOIDRETURN do { _NXRemoveHandler(&NXLocalHandler); \
return; } while (0)
/* RAISE and RERAISE are called to indicate an error condition. They
initiate the process of jumping up the chain of handlers.
*/
OBJC_EXPORT
#if defined(__GNUC__)
#if !defined(__STRICT_ANSI__)
#if !defined(NeXT_PDO)
__volatile /* never returns */
#endif
#endif
#endif
void _NXRaiseError(int code, const void *data1, const void *data2)
#if defined(__GNUC__)
__attribute__ ((noreturn))
#endif
;
#define NX_RAISE( code, data1, data2 ) \
_NXRaiseError( (code), (data1), (data2) )
#define NX_RERAISE() _NXRaiseError( NXLocalHandler.code, \
NXLocalHandler.data1, NXLocalHandler.data2 )
/* These routines set and return the procedure which is called when
exceptions are raised. This procedure must NEVER return. It will
usually either longjmp, or call the uncaught exception handler.
The default exception raiser is also declared
*/
typedef volatile void NXExceptionRaiser(int code, const void *data1, const void *data2);
OBJC_EXPORT void NXSetExceptionRaiser(NXExceptionRaiser *proc);
OBJC_EXPORT NXExceptionRaiser *NXGetExceptionRaiser(void);
OBJC_EXPORT NXExceptionRaiser NXDefaultExceptionRaiser;
/* The error buffer is used to allocate data which is passed up to other
handlers. Clients should clear the error buffer in their top level
handler. The Application Kit does this.
*/
OBJC_EXPORT void NXAllocErrorData(int size, void **data);
OBJC_EXPORT void NXResetErrorData(void);
#endif /* _OBJC_ERROR_H_ */