summaryrefslogtreecommitdiff
path: root/examples
diff options
context:
space:
mode:
authorsanine <sanine.not@pm.me>2021-09-04 12:39:29 -0500
committersanine <sanine.not@pm.me>2021-09-04 12:39:29 -0500
commitddc38c3e6524b27224b97faeb3abfc8663943d88 (patch)
treed228df0a5192d876703cfa6b6633e007220a7271 /examples
parent0b55e12f7f9fc98d22b2bead44d064af8c3f92c4 (diff)
add table processing demo
Diffstat (limited to 'examples')
-rw-r--r--examples/table_processing/table_processing.c60
1 files changed, 60 insertions, 0 deletions
diff --git a/examples/table_processing/table_processing.c b/examples/table_processing/table_processing.c
new file mode 100644
index 0000000..64c1f01
--- /dev/null
+++ b/examples/table_processing/table_processing.c
@@ -0,0 +1,60 @@
+#include <string.h>
+#include <stdlib.h>
+#include <honeysuckle.h>
+
+struct settings
+{
+ bool debug;
+ int debug_level;
+ char *logfile;
+} global_settings;
+
+void set_logfile(const char* filename, void *s)
+{
+ struct settings *settings = (struct settings *) s;
+ settings->logfile = malloc(sizeof(char) * strlen(filename));
+ strcpy(settings->logfile, filename);
+}
+
+int process(lua_State *L)
+{
+ int table_index;
+ hs_parse_args(L, hs_tbl(table_index));
+ hs_process_table(L, table_index,
+ hs_process_bool("debug",
+ hs_pt_set_boolean,
+ &(global_settings.debug)),
+ hs_process_int("level",
+ hs_pt_set_integer,
+ &(global_settings.debug_level)),
+ hs_process_str("logfile",
+ set_logfile,
+ &global_settings));
+ return 0;
+}
+
+int main()
+{
+ lua_State *L = luaL_newstate();
+ luaL_openlibs(L);
+
+ lua_pushcfunction(L, process);
+ lua_setglobal(L, "configure");
+
+ global_settings.debug = false;
+ global_settings.debug_level = 0;
+ global_settings.logfile = "nil";
+
+ printf("settings: [ %d, %d, '%s' ]\n",
+ global_settings.debug,
+ global_settings.debug_level,
+ global_settings.logfile);
+
+ luaL_dostring(L, "configure{debug=true, level=6, logfile='output.log'}");
+
+ printf("settings: [ %d, %d, '%s' ]\n",
+ global_settings.debug,
+ global_settings.debug_level,
+ global_settings.logfile);
+ return 0;
+}