X-Git-Url: https://git.dlugolecki.net.pl/?a=blobdiff_plain;f=include%2Fgedcom.h.in;h=6482c97edfe337a568e4b7c6143949c492faa431;hb=a989ed6b8feb891cbd7ef99eec26cdb65c6e442e;hp=8a2fb5abd4ee71d19435ac72a14613ec82e4cc11;hpb=f08bf1b4ba225219726e65ba65f41f11120933d8;p=gedcom-parse.git diff --git a/include/gedcom.h.in b/include/gedcom.h.in index 8a2fb5a..6482c97 100644 --- a/include/gedcom.h.in +++ b/include/gedcom.h.in @@ -25,6 +25,7 @@ #define __GEDCOM_H #include +#include __BEGIN_DECLS @@ -387,7 +388,7 @@ typedef struct _Gedcom_val_struct { union _Gedcom_val_union value; } Gedcom_val_struct; -void gedcom_cast_error(char* file, int line, +void gedcom_cast_error(const char* file, int line, Gedcom_val_type tried_type, Gedcom_val_type real_type); @@ -470,7 +471,8 @@ typedef void char *raw_value, int tag_value); void gedcom_init(); -int gedcom_parse_file(char* file_name); +int gedcom_parse_file(const char* file_name); +int gedcom_new_model(); void gedcom_set_debug_level(int level, FILE* trace_output); void gedcom_set_error_handling(Gedcom_err_mech mechanism); void gedcom_set_compat_handling(int enable_compat); @@ -485,9 +487,22 @@ void gedcom_subscribe_to_element(Gedcom_elt elt, Gedcom_elt_end_cb cb_end); /* Separate value parsing functions */ -struct date_value gedcom_parse_date(char* line_value); -struct age_value gedcom_parse_age(char* line_value); -struct xref_value *gedcom_get_by_xref(char *key); +struct date_value gedcom_parse_date(const char* line_value); +struct age_value gedcom_parse_age(const char* line_value); + +/* Handling cross-references */ +struct xref_value *gedcom_get_by_xref(const char *key); +struct xref_value *gedcom_add_xref(Xref_type type, const char* xrefstr, + Gedcom_ctxt object); +struct xref_value *gedcom_link_xref(Xref_type type, const char* xrefstr); +struct xref_value *gedcom_unlink_xref(Xref_type type, const char* xrefstr); +int gedcom_delete_xref(const char* xrefstr); + +/* For use in gom */ +int gedcom_error(const char* s, ...); +int gedcom_warning(const char* s, ...); +int gedcom_message(const char* s, ...); +int gedcom_debug_print(const char* s, ...); __END_DECLS