From 7539f8c8804849294e100c5442e0397f4f4d2c40 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Hugo=20H=C3=B6rnquist?= Date: Tue, 1 Oct 2019 23:39:00 +0200 Subject: Disabled bunch of old stuff, new stuff kinda builds. --- src/struct.scm.c | 91 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 91 insertions(+) create mode 100644 src/struct.scm.c (limited to 'src/struct.scm.c') diff --git a/src/struct.scm.c b/src/struct.scm.c new file mode 100644 index 00000000..abbbba18 --- /dev/null +++ b/src/struct.scm.c @@ -0,0 +1,91 @@ +#include "struct.h" + +#include + +SCM vcomponent_vtable; +SCM vline_vtable; + +SCM_DEFINE(scm_make_vcomponent, "make-vcomponent", 0, 1, 0, + (SCM type), + "") +{ + + if (SCM_UNBNDP (type)) type = SCM_BOOL_F; + + if (scm_is_false(type)) type = scm_from_utf8_symbol("VIRTUAL"); + + return scm_c_make_struct (vcomponent_vtable, scm_from_int(0), + type, SCM_EOL, SCM_BOOL_F, + scm_make_hash_table(SCM_BOOL_F), + SCM_UNDEFINED); +} + + + +SCM_DEFINE(scm_parse_cal_path, "parse-path", 1, 0, 0, + (SCM path), + "") +{ + SCM root = scm_make_vcomponent(SCM_BOOL_F); + + char* p = scm_to_utf8_stringn(path, NULL); + scm_read_vcalendar(root, p); + free(p); +} + +SCM_DEFINE(scm_add_line_x, "add-line!", 3, 0, 0, + (SCM vcomponent, SCM key, SCM line), + "") +{ + scm_hash_set_x (scm_struct_ref(vcomponent, vcomponent_lines), key, line); + return SCM_UNSPECIFIED; +} + + +SCM_DEFINE(scm_add_child_x, "add-child!", 2, 0, 0, + (SCM vcomponent, SCM child), + "") +{ + scm_struct_set_x (child, vcomponent_parent, vcomponent); + scm_struct_set_x (vcomponent, vcomponent_children, + scm_cons (child, scm_struct_ref (vcomponent, vcomponent_children))); + + return SCM_UNSPECIFIED; +} + + +SCM_DEFINE(scm_make_vline, "make-vline", 0, 0, 0, + (), "") +{ + return scm_c_make_struct (vline_vtable, scm_from_int(0), + SCM_BOOL_F, scm_make_hash_table(SCM_BOOL_F), + SCM_UNDEFINED); +} + + +SCM_DEFINE(scm_add_attribute_x, "add-attribute!", 3, 0, 0, + (SCM vline, SCM key, SCM value), + "") +{ + SCM table = scm_struct_ref (vline, vline_attributes); + scm_hash_set_x (table, key, + scm_cons(value, scm_hash_ref(table, key, SCM_EOL))); + return SCM_UNSPECIFIED; +} + +void init_lib (void) { + // init_vcomponent_type(); + // content_set_lists = scm_make_weak_key_hash_table (scm_from_uint(0x100)); + SCM str = scm_from_utf8_string("pr" "pw" "pw" "pr"); + SCM vcomponent_vtable = scm_make_vtable(str, SCM_BOOL_F); + scm_set_struct_vtable_name_x (vcomponent_vtable, scm_from_utf8_symbol("vcomponent")); + + SCM vline_vtable = + scm_make_vtable(scm_from_utf8_string("pw" "pw"), + SCM_BOOL_F); + scm_set_struct_vtable_name_x (vline_vtable, scm_from_utf8_symbol("vline")); + +#ifndef SCM_MAGIC_SNARFER +#include "struct.x" +#endif +} -- cgit v1.2.3