%except(python) {
	try {
	$function
	}
	catch (RangeError) {
	 	PyErr_SetString(PyExc_IndexError,"index out-of-bounds");
		return NULL;
	}
}
As an argument, you need to specify the target language. The exception handling C/C++ code is then enclosed in braces. The symbol $function is replaced with the real C/C++ function call that SWIG would be ordinarily make in the wrapper code. The C code you specify inside the %except directive can be anything you like including custom C code and C++ exceptions.
To delete an exception handler, simply use the %except directive with no code. For example :
Exceptions can be redefined as necessary. The scope of an exception handler is from the point of definition to the end of the file, the definition of a new exception handler, or until the handler is deleted.%except(python); // Deletes any previously defined handler
/* File : except.c */
static char error_message[256];
static int error_status = 0;
void throw_exception(char *msg) {
	strncpy(error_message,msg,256);
	error_status = 1;
}
void clear_exception() {
	error_status = 0;
}
char *check_exception() {
	if (error_status) return error_message;
	else return NULL;
}
double inv(double x) {
	if (x != 0) return 1.0/x;
	else {
		throw_exception("Division by zero");
		return 0;
	}
}
%except(perl5) {
	char *err;
	clear_exception();
	$function
	if ((err = check_exception())) {
		croak(err);
	}
}
Now, when an error occurs, it will be translated into a Perl error. The downside to this approach is that it isn't particularly clean and it assumes that your C code is a willing participant in generating error messages. (This isn't going to magically add exceptions to a code that doesn't have them).
Now, within a C program, you can do the following :/* File : except.c Just the declaration of a few global variables we're going to use */ #include <setjmp.h> jmp_buf exception_buffer; int exception_status; /* File : except.h */ #include <setjmp.h> extern jmp_buf exception_buffer; extern int exception_status; #define try if ((exception_status = setjmp(exception_buffer)) == 0) #define catch(val) else if (exception_status == val) #define throw(val) longjmp(exception_buffer,val) #define finally else /* Exception codes */ #define RangeError 1 #define DivisionByZero 2 #define OutOfMemory 3
double inv(double x) {
	if (x) return 1.0/x;
	else {throw(DivisionByZero);
}
%{
#include "except.h"
%}
%except(perl5) {
	try {
		$function
	} catch(RangeError) {
		croak("Range Error");
	} catch(DivisionByZero) {
		croak("Division by zero");
	} catch(OutOfMemory) {
		croak("Out of memory");
	} finally {
		croak("Unknown exception");
	}
}
At this point, you're saying this sure looks alot like C++ and you'd be right (C++ exceptions are often implemented in a similar manner). As always, the usual disclaimers apply--your mileage may vary.
%except(perl5) {
	try {
		$function
	} catch(RangeError) {
		croak("Range Error");
	} catch(DivisionByZero) {
		croak("Division by zero");
	} catch(OutOfMemory) {
		croak("Out of memory");
	} catch(...) {
		croak("Unknown exception");
	}
}
class RangeError {};
class DivisionByZero {};
class OutOfMemory {};
double inv(double) throw(DivisionByZero);
%except(python) {
	... your exception handler ...
}
/* Define critical operations that can throw exceptions here */
%except(python);         // Clear the exception handler
/* Define non-critical operations that don't throw exceptions */
%typemap(python,except) void * {
	$function
	if (!$source) {
		PyExc_SetString(PyExc_MemoryError,"Out of memory in $name");
		return NULL;
	}
}
void *malloc(int size);
Python 1.4 (Jan 16 1997) [GCC 2.7.2] Copyright 1991-1995 Stichting Mathematisch Centrum, Amsterdam >>> from example import * >>> a = malloc(2048) >>> b = malloc(1500000000) Traceback (innermost last): File "<stdin>", line 1, in ? MemoryError: Out of memory in malloc >>>
Since typemaps can be named, you can define an exception handler for a specific function as follows :
%typemap(python,except) void *malloc {
	...
}
// Language independent exception handler
%include exception.i       
%except {
	try {
		$function
	} catch(RangeError) {
		SWIG_exception(SWIG_ValueError, "Range Error");
	} catch(DivisionByZero) {
		SWIG_exception(SWIG_DivisionByZero, "Division by zero");
	} catch(OutOfMemory) {
		SWIG_exception(SWIG_MemoryError, "Out of memory");
	} catch(...) {
		SWIG_exception(SWIG_RuntimeError,"Unknown exception");
	}
}
SWIG_MemoryError SWIG_IOError SWIG_RuntimeError SWIG_IndexError SWIG_TypeError SWIG_DivisionByZero SWIG_OverflowError SWIG_SyntaxError SWIG_ValueError SWIG_SystemError SWIG_UnknownError
Since the SWIG_exception() function is defined at the C-level it can be used elsewhere in SWIG. This includes typemaps and helper functions. The exception library provides a language-independent exception handling mechanism, so many of SWIG's library files now rely upon the library as well.
%except(tcl) {
	printf("Entering function : $name\n");
	$function
	printf("Leaving function : $name\n");
}
Exception handlers can also be chained. For example :
%except(tcl) {
	printf("Entering function : $name\n");
	$except
	printf("Leaving function : $name\n");
}