Mir 1.0
Mir application programming interface
Optional functions

Macros

#define MIR_OPTIONAL_FN_TYPE(name)   mir_OFN_##name##_t
 
#define MIR_DECLARE_OPTIONAL_FN(ret, name, args)   typedef ret (MIR_OPTIONAL_FN_TYPE(name)) args
 
#define MIR_REGISTER_OPTIONAL_FN(name, error)
 
#define MIR_DEREGISTER_OPTIONAL_FN(name)    mir_optfn_deregister(#name);
 
#define MIR_RETRIEVE_OPTIONAL_FN(name)    (MIR_OPTIONAL_FN_TYPE(name) *)mir_optfn_retrieve(#name)
 

Typedefs

typedef void() mir_opt_fn_t(void)
 

Functions

mirkl_error_tmir_optfn_register (const char *szName, mir_opt_fn_t *pfn)
 
void mir_optfn_deregister (const char *szName)
 
mir_opt_fn_tmir_optfn_retrieve (const char *szName)
 

Detailed Description

Macro Definition Documentation

◆ MIR_DECLARE_OPTIONAL_FN

#define MIR_DECLARE_OPTIONAL_FN (   ret,
  name,
  args 
)    typedef ret (MIR_OPTIONAL_FN_TYPE(name)) args

Declare an optional function.

Parameters
retThe return type of the function
nameThe name of the function
argsThe function arguments (including brackets)

◆ MIR_OPTIONAL_FN_TYPE

#define MIR_OPTIONAL_FN_TYPE (   name)    mir_OFN_##name##_t

The type of an optional function.

Parameters
nameThe name of the function

◆ MIR_REGISTER_OPTIONAL_FN

#define MIR_REGISTER_OPTIONAL_FN (   name,
  error 
)
Value:
do { \
MIR_OPTIONAL_FN_TYPE(name) *mirnex__opt = name; \
error = mir_optfn_register(#name,(mir_opt_fn_t *)mir__opt); \
} while (0)
void() mir_opt_fn_t(void)
Definition: mir_optionalfn.h:44

Register an optional function. This can be later retrieved, type-safely, by name. Like all global functions, the name must be unique. Note that, confusingly but correctly, the function itself can be static!

Parameters
nameThe name of the function

◆ MIR_RETRIEVE_OPTIONAL_FN

#define MIR_RETRIEVE_OPTIONAL_FN (   name)     (MIR_OPTIONAL_FN_TYPE(name) *)mir_optfn_retrieve(#name)

Retrieve an optional function. Returns NULL if the function is not present.

Parameters
nameThe name of the function

Typedef Documentation

◆ mir_opt_fn_t

typedef void() mir_opt_fn_t(void)

Private function! DO NOT USE!