theKernel 10.0
Loading...
Searching...
No Matches
MkKernel_Setup_libmkkernel_RB_API

MkKernel PACKAGE - Setup und Cleanup the rbmkkernelMore...

+ Collaboration diagram for MkKernel_Setup_libmkkernel_RB_API:

Functions

static OT_ProcRet rbmkkernel_MkKernel_Cleanup (OtClass_ARGS)
  Ruby: (static) MkKernel.Cleanup() C-API
cleanup rbmkkernel internal memory …
 
static OT_ProcRet rbmkkernel_MkKernel_Setup (OtClass_ARGS)
  Ruby: (static) MkKernel.Setup() C-API
setup rbmkkernel internal memory …
 

Detailed Description

MkKernel PACKAGE - Setup und Cleanup the rbmkkernel

Initializing a rbmkkernel library depends on the Target-Programming-Language (TPL) and the specific nature of the Programming-Language-Micro-Kernel (PLMK).

In general it is required to call a Setup style funtion as FIRST command because of:

If more than one META library is called only the toplevel Setup is required:

shared library detail

A new rbmkkernel library is initialized with Setup and released again with Cleanup. Both functions are automatically called upon loading and unloading of the shared library.

Example: Definition (C) of the rbmkkernel library startup functions

MK_EXTERN void MK_DECL MkSetup (void) __attribute__ ((constructor(200)));
MK_EXTERN void MK_DECL MkCleanup (void) __attribute__ ((destructor(200)));
#define MK_DECL
#define MK_EXTERN
static library
void MkSetup(void)
setup rbmkkernel internal memory …
void MkCleanup(void)
cleanup rbmkkernel internal memory …

In the Programming-Language-Micro-Kernel (PLMK), a type is defined for each thread, which means that the new rbmkkernel library must be known when the thread starts. This is not a problem as long as the external rbmkkernel library is linked to the application. However, if dlopen is used to load the rbmkkernel library, the current restriction is that the new data type from the rbmkkernel library has not been defined in all existing threads.

The point in time when a library is loaded depends heavily on the programming language used.

‍To avoid all the problems call the Setup directly at the start of the main program.

Example: Start of the LcConfigServer application from the example/cs directory

static void Main(string[] argv) {
LcConfig.Setup();
var srv = MqFactoryCT<LcConfigServer>.Add().New();
try {
srv.LinkCreate(argv);
srv.ProcessEvent(MqWaitOnEventE.FOREVER);
} catch (Exception e) {
srv.ErrorCatch(e);
}
srv.Exit();
}

Function Documentation

◆ rbmkkernel_MkKernel_Cleanup()

static OT_ProcRet rbmkkernel_MkKernel_Cleanup ( OtClass_ARGS )
static

Ruby: (static) MkKernel.Cleanup() C-API
cleanup rbmkkernel internal memory …

Definition at line 526 of file LibMkKernel_rb.c.

526 {
530 MkCleanupTmpl ();
532 end: MK_UNUSED /* LONG JUMP on error */
534}
#define MkCleanupTmpl()
#define OT_SETUP_hdl_static
#define Cleanup_doc
#define OT_SETUP_NOARG(d)
#define OT_retObj_SET_None
#define OT_retObj_RETURN
#define OT_CHECK_NOARGS
#define MK_UNUSED
mark unnused variables and functions

◆ rbmkkernel_MkKernel_Setup()

static OT_ProcRet rbmkkernel_MkKernel_Setup ( OtClass_ARGS )
static

Ruby: (static) MkKernel.Setup() C-API
setup rbmkkernel internal memory …

Definition at line 537 of file LibMkKernel_rb.c.

537 {
541 MkSetupTmpl ();
543 end: MK_UNUSED /* LONG JUMP on error */
545}
#define MkSetupTmpl()
#define Setup_doc