From f197c791489f1537db4aebc7ce29b6d4f9adc2b3 Mon Sep 17 00:00:00 2001 From: Peter Verthez Date: Sat, 25 Jan 2003 18:48:57 +0000 Subject: [PATCH] Correct sub_note_end callback: parsed value can be NULL. --- gom/note_sub.c | 23 +++++++++++++++++++++-- 1 file changed, 21 insertions(+), 2 deletions(-) diff --git a/gom/note_sub.c b/gom/note_sub.c index 2ff76db..e523b32 100644 --- a/gom/note_sub.c +++ b/gom/note_sub.c @@ -110,10 +110,29 @@ Gedcom_ctxt sub_note_start(_ELT_PARAMS_) return (Gedcom_ctxt)result; } +void sub_note_end(_ELT_END_PARAMS_) +{ + if (GEDCOM_IS_STRING(parsed_value)) { + Gom_ctxt ctxt = (Gom_ctxt)self; + if (! ctxt) + NO_CONTEXT; + else { + struct note_sub *obj = SAFE_CTXT_CAST(note_sub, ctxt); + if (obj) { + char *str = GEDCOM_STRING(parsed_value); + char *newvalue = strdup(str); + if (! newvalue) + MEMORY_ERROR; + else + obj->text = newvalue; + } + destroy_gom_ctxt(ctxt); + } + } +} + DEFINE_SUB_MAKEFUNC(note_sub) -DEFINE_STRING_END_CB(note_sub, sub_note_end, text) - DEFINE_ADDFUNC2(note_sub, source_citation, citation) DEFINE_ADDFUNC2(note_sub, user_data, extra) -- 2.30.2