mirror of
https://github.com/xomboverlord/ldc.git
synced 2026-01-12 02:43:14 +01:00
277 lines
6.1 KiB
D
277 lines
6.1 KiB
D
/**
|
|
* The exception module defines all system-level exceptions and provides a
|
|
* mechanism to alter system-level error handling.
|
|
*
|
|
* Copyright: Copyright (c) 2005-2008, The D Runtime Project
|
|
* License: BSD Style, see LICENSE
|
|
* Authors: Sean Kelly
|
|
*/
|
|
module core.exception;
|
|
|
|
|
|
private
|
|
{
|
|
alias void function( string file, size_t line, string msg = null ) assertHandlerType;
|
|
|
|
assertHandlerType assertHandler = null;
|
|
}
|
|
|
|
|
|
/**
|
|
* Thrown on an array bounds error.
|
|
*/
|
|
class ArrayBoundsException : Exception
|
|
{
|
|
this( string file, size_t line )
|
|
{
|
|
super( "Array index out of bounds", file, line );
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Thrown on an assert error.
|
|
*/
|
|
class AssertException : Exception
|
|
{
|
|
this( string file, size_t line )
|
|
{
|
|
super( "Assertion failure", file, line );
|
|
}
|
|
|
|
this( string msg, string file, size_t line )
|
|
{
|
|
super( msg, file, line );
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Thrown on finalize error.
|
|
*/
|
|
class FinalizeException : Exception
|
|
{
|
|
ClassInfo info;
|
|
|
|
this( ClassInfo c, Exception e = null )
|
|
{
|
|
super( "Finalization error", e );
|
|
info = c;
|
|
}
|
|
|
|
override string toString()
|
|
{
|
|
return "An exception was thrown while finalizing an instance of class " ~ info.name;
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Thrown on hidden function error.
|
|
*/
|
|
class HiddenFuncException : Exception
|
|
{
|
|
this( ClassInfo ci )
|
|
{
|
|
super( "Hidden method called for " ~ ci.name );
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Thrown on an out of memory error.
|
|
*/
|
|
class OutOfMemoryException : Exception
|
|
{
|
|
this( string file, size_t line )
|
|
{
|
|
super( "Memory allocation failed", file, line );
|
|
}
|
|
|
|
override string toString()
|
|
{
|
|
return msg ? super.toString() : "Memory allocation failed";
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Thrown on a switch error.
|
|
*/
|
|
class SwitchException : Exception
|
|
{
|
|
this( string file, size_t line )
|
|
{
|
|
super( "No appropriate switch clause found", file, line );
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Thrown on a unicode conversion error.
|
|
*/
|
|
class UnicodeException : Exception
|
|
{
|
|
size_t idx;
|
|
|
|
this( string msg, size_t idx )
|
|
{
|
|
super( msg );
|
|
this.idx = idx;
|
|
}
|
|
}
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
// Overrides
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
/**
|
|
* Overrides the default assert hander with a user-supplied version.
|
|
*
|
|
* Params:
|
|
* h = The new assert handler. Set to null to use the default handler.
|
|
*/
|
|
void setAssertHandler( assertHandlerType h )
|
|
{
|
|
assertHandler = h;
|
|
}
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
// Overridable Callbacks
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
/**
|
|
* A callback for assert errors in D. The user-supplied assert handler will
|
|
* be called if one has been supplied, otherwise an AssertException will be
|
|
* thrown.
|
|
*
|
|
* Params:
|
|
* file = The name of the file that signaled this error.
|
|
* line = The line number on which this error occurred.
|
|
*/
|
|
extern (C) void onAssertError( string file, size_t line )
|
|
{
|
|
if( assertHandler is null )
|
|
throw new AssertException( file, line );
|
|
assertHandler( file, line );
|
|
}
|
|
|
|
|
|
/**
|
|
* A callback for assert errors in D. The user-supplied assert handler will
|
|
* be called if one has been supplied, otherwise an AssertException will be
|
|
* thrown.
|
|
*
|
|
* Params:
|
|
* file = The name of the file that signaled this error.
|
|
* line = The line number on which this error occurred.
|
|
* msg = An error message supplied by the user.
|
|
*/
|
|
extern (C) void onAssertErrorMsg( string file, size_t line, string msg )
|
|
{
|
|
if( assertHandler is null )
|
|
throw new AssertException( msg, file, line );
|
|
assertHandler( file, line, msg );
|
|
}
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
// Internal Error Callbacks
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
/**
|
|
* A callback for array bounds errors in D. An ArrayBoundsException will be
|
|
* thrown.
|
|
*
|
|
* Params:
|
|
* file = The name of the file that signaled this error.
|
|
* line = The line number on which this error occurred.
|
|
*
|
|
* Throws:
|
|
* ArrayBoundsException.
|
|
*/
|
|
extern (C) void onArrayBoundsError( string file, size_t line )
|
|
{
|
|
throw new ArrayBoundsException( file, line );
|
|
}
|
|
|
|
|
|
/**
|
|
* A callback for finalize errors in D. A FinalizeException will be thrown.
|
|
*
|
|
* Params:
|
|
* e = The exception thrown during finalization.
|
|
*
|
|
* Throws:
|
|
* FinalizeException.
|
|
*/
|
|
extern (C) void onFinalizeError( ClassInfo info, Exception ex )
|
|
{
|
|
throw new FinalizeException( info, ex );
|
|
}
|
|
|
|
|
|
/**
|
|
* A callback for hidden function errors in D. A HiddenFuncException will be
|
|
* thrown.
|
|
*
|
|
* Throws:
|
|
* HiddenFuncException.
|
|
*/
|
|
extern (C) void onHiddenFuncError( Object o )
|
|
{
|
|
throw new HiddenFuncException( o.classinfo );
|
|
}
|
|
|
|
|
|
/**
|
|
* A callback for out of memory errors in D. An OutOfMemoryException will be
|
|
* thrown.
|
|
*
|
|
* Throws:
|
|
* OutOfMemoryException.
|
|
*/
|
|
extern (C) void onOutOfMemoryError()
|
|
{
|
|
// NOTE: Since an out of memory condition exists, no allocation must occur
|
|
// while generating this object.
|
|
throw cast(OutOfMemoryException) cast(void*) OutOfMemoryException.classinfo.init;
|
|
}
|
|
|
|
|
|
/**
|
|
* A callback for switch errors in D. A SwitchException will be thrown.
|
|
*
|
|
* Params:
|
|
* file = The name of the file that signaled this error.
|
|
* line = The line number on which this error occurred.
|
|
*
|
|
* Throws:
|
|
* SwitchException.
|
|
*/
|
|
extern (C) void onSwitchError( string file, size_t line )
|
|
{
|
|
throw new SwitchException( file, line );
|
|
}
|
|
|
|
|
|
/**
|
|
* A callback for unicode errors in D. A UnicodeException will be thrown.
|
|
*
|
|
* Params:
|
|
* msg = Information about the error.
|
|
* idx = String index where this error was detected.
|
|
*
|
|
* Throws:
|
|
* UnicodeException.
|
|
*/
|
|
extern (C) void onUnicodeError( string msg, size_t idx )
|
|
{
|
|
throw new UnicodeException( msg, idx );
|
|
}
|