NAME¶
libmawk_example - how to use the library
SYNOPSIS¶
#include <libmawk.h>
DESCRIPTION¶
Libmawk is a library that lets applications to embed awk scripts using the code
  of the popular implementation mawk. The normal process is to call
  libmawk_initialize() to set up a new mawk context (with script(s) loaded),
  then in the main loop feed it using libmawk_append_input(). For "out of
  band" communication, the program may also call functions implemented in
  awk and read (or modify) global variables of the awk script. The hos
  tapplication usally will also bind some of its functions to the context using
  libmawk_register_function, which allows the awk script to call the host
  applicaiton's functions directly as they were awk builtins or user defined
  functions. After the main loop, the application destroys the context freeing
  up all memory allocated for the script(s).
One context is for one awk program. One awk program may consist of
    multiple script files (just as with command line awk, with multiple -f
    filename arguments). Libmawk is instance safe, the host application may
    create multiple instances of contexts with the same or with different set of
    awk scripts loaded. These contexts are totally separate, no variables,
    functions or any sort of states are shared. However, the host application
    may provide means of communication between those scripts by custom functions
    or by copying variable contents between them.
Example application¶
The following example application creates a single context to demonstrate all
  the above mentioned functionality.