X-Git-Url: https://git.dlugolecki.net.pl/?a=blobdiff_plain;f=gedcom%2Finterface.h;h=24a9e6475ca1ba2b2a0c2e7732927bb7124f9d5a;hb=9b4b646eafd90dcff38ab9ed9d89bba0a4a8c62d;hp=6eb0ed60ee46e5776ad1141a34d771c6aedf228a;hpb=8c92a223c34fbd674f26520fb990c64a7b2f9147;p=gedcom-parse.git diff --git a/gedcom/interface.h b/gedcom/interface.h index 6eb0ed6..24a9e64 100644 --- a/gedcom/interface.h +++ b/gedcom/interface.h @@ -27,7 +27,8 @@ #include "gedcom.h" Gedcom_ctxt start_record(Gedcom_rec rec, - int level, Gedcom_val xref, struct tag_struct tag); + int level, Gedcom_val xref, struct tag_struct tag, + char *raw_value, Gedcom_val parsed_value); void end_record(Gedcom_rec rec, Gedcom_ctxt self); Gedcom_ctxt start_element(Gedcom_elt elt, Gedcom_ctxt parent, @@ -36,24 +37,22 @@ Gedcom_ctxt start_element(Gedcom_elt elt, Gedcom_ctxt parent, void end_element(Gedcom_elt elt, Gedcom_ctxt parent, Gedcom_ctxt self, Gedcom_val parsed_value); -extern Gedcom_val_struct val; +extern Gedcom_val_struct val1; +extern Gedcom_val_struct val2; -#define GEDCOM_MAKE(VALUE, TYPE, MEMBER) \ - (val.type = TYPE, val.value.MEMBER = VALUE, &val) +#define GEDCOM_MAKE(VAR, VALUE, TYPE, MEMBER) \ + (VAR.type = TYPE, VAR.value.MEMBER = VALUE, &VAR) -#define GEDCOM_MAKE_NULL() \ - GEDCOM_MAKE(NULL, GV_NULL, string_val) +#define GEDCOM_MAKE_NULL(VAR) \ + GEDCOM_MAKE(VAR, NULL, GV_NULL, string_val) -#define GEDCOM_MAKE_STRING(STRING) \ - GEDCOM_MAKE(STRING, GV_CHAR_PTR, string_val) +#define GEDCOM_MAKE_STRING(VAR, STRING) \ + GEDCOM_MAKE(VAR, STRING, GV_CHAR_PTR, string_val) -#define GEDCOM_MAKE_NULL_OR_STRING(STRING) \ +#define GEDCOM_MAKE_NULL_OR_STRING(VAR, STRING) \ (STRING == NULL ? \ - GEDCOM_MAKE_NULL() : \ - GEDCOM_MAKE_STRING(STRING)) \ - -#define GEDCOM_MAKE_DATE(DATE) \ - GEDCOM_MAKE(DATE, GV_DATE_VALUE, date_val) + GEDCOM_MAKE_NULL(VAR) : \ + GEDCOM_MAKE_STRING(VAR, STRING)) #endif /* __INTERFACE_H */