theKernel 10.0
Loading...
Searching...
No Matches
MkKernel_Setup_libmkkernel_PY_API

MkKernel PACKAGE - Setup und Cleanup the pymkkernelMore...

+ Collaboration diagram for MkKernel_Setup_libmkkernel_PY_API:

Functions

static OT_ProcRet pymkkernel_MkKernel_Cleanup (OtClass_ARGS)
  Python: [static] Cleanup() C-API
cleanup pymkkernel internal memory …
 
static OT_ProcRet pymkkernel_MkKernel_Setup (OtClass_ARGS)
  Python: [static] Setup() C-API
setup pymkkernel internal memory …
 

Detailed Description

MkKernel PACKAGE - Setup und Cleanup the pymkkernel

Initializing a pymkkernel 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 pymkkernel 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 pymkkernel 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 pymkkernel internal memory …
void MkCleanup(void)
cleanup pymkkernel internal memory …

In the Programming-Language-Micro-Kernel (PLMK), a type is defined for each thread, which means that the new pymkkernel library must be known when the thread starts. This is not a problem as long as the external pymkkernel library is linked to the application. However, if dlopen is used to load the pymkkernel library, the current restriction is that the new data type from the pymkkernel 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

◆ pymkkernel_MkKernel_Cleanup()

static OT_ProcRet pymkkernel_MkKernel_Cleanup ( OtClass_ARGS )
static

Python: [static] Cleanup() C-API
cleanup pymkkernel internal memory …

Definition at line 710 of file LibMkKernel_py.c.

710 {
714 MkCleanupTmpl ();
716 goto end;
717 error:
719 end:
721}
#define MkCleanupTmpl()
#define OT_SETUP_hdl_static
#define Cleanup_doc
#define OT_SETUP_NOARG(d)
#define OT_retObj_SET_Error
#define OT_retObj_SET_None
#define OT_retObj_RETURN
#define OT_CHECK_NOARGS

◆ pymkkernel_MkKernel_Setup()

static OT_ProcRet pymkkernel_MkKernel_Setup ( OtClass_ARGS )
static

Python: [static] Setup() C-API
setup pymkkernel internal memory …

Definition at line 724 of file LibMkKernel_py.c.

724 {
728 MkSetupTmpl ();
730 goto end;
731 error:
733 end:
735}
#define MkSetupTmpl()
#define Setup_doc