MkExceptionC - The default-exception of the Programming-Language-Micro-Kernel (PLMK) … More...
Functions | |
bool | MkExceptionCheck (MK_EXP exception) |
Checks if Exception is of type MkExceptionC and returns true or false … | |
void | MkExceptionRaise (MK_MNG const expobj, MK_STRN const callfunc, MK_I32 const callline) |
convert an MkErrorC into a Target-Programming-Language (TPL) exception … | |
MK_ERR | MkExceptionCatch (MK_MNG const expobj, MK_EXP const exception, MK_STRN const callfunc) |
convert an Target-Programming-Language (TPL) exception into an MkErrorC … | |
MkExceptionC - The default-exception of the Programming-Language-Micro-Kernel (PLMK) …
The Programming-Language-Micro-Kernel (PLMK) provide with MkErrorC a complete error-handling with focus to support the "C"
Programming-Language. The support include catch, raise, signal and attributes. In addition every Target-Programming-Language (TPL) add their own error-handling and the purpose of MkExceptionC is to integrate the MkErrorC into the Target-Programming-Language (TPL).
The default-exception MkExceptionC is used to connect the MkErrorC with the Target-Programming-Language (TPL) error-object.
The implementation of an exception depends heavily on the Target-Programming-Language (TPL), starting with no exception at all, for example. C
, an exception as a class object, or as an exception as a global attribute.
convert an Target-Programming-Language (TPL) exception into an MkErrorC …
[in] | expobj | The LibMsgqueObject used to personalize the exception/error (will be validated first) |
[in] | exception | the exception object from Atl, if "MK_NULL" the global exception object is used |
[in] | callfunc | a user-defined postfix to identify the calling-function or the environment (default = name-of-function, "MK_NULL" = resolve-own-name) |
bool MkExceptionCheck | ( | MK_EXP | exception | ) |
Checks if Exception is of type MkExceptionC and returns true
or false
…
Example: test case to check KILL and RECOVER feature, check on MkExceptionC
set VAL [ReadBUF $myNs] set cl [myooX::NewN ::Client] Client::myLinkCreate $cl [ConfigGetStartAs $myNs] Send $cl "W" "GPID@I" PID SysKill $myNs $PID 9 set RET 0 foreach num {1 2 3} { try { set RET [Send $cl "W" "ECOI:U@I" $VAL] } trap {MkExceptionC} "" { set err [ErrorCatch $cl] if {[MkErrorC::IsSOCKET $err]} { MkErrorC::Reset $err LinkConnect $cl continue } else { MkErrorC::Raise $err } myooX::DestroyN $err } break } SendSTART $myNs SendI32 $myNs $RET
true
or false
[in] | exception | the exception object from Atl, if "MK_NULL" the global exception object is used |
convert an MkErrorC into a Target-Programming-Language (TPL) exception …
[in] | expobj | The LibMsgqueObject used to personalize the exception/error (will be validated first) |
[in] | callfunc | a user-defined postfix to identify the calling-function or the environment (default = name-of-function, "MK_NULL" = resolve-own-name) |
[in] | callline | the number of the line the call take place (e.g. LINE) |