1 /* Note sub-structure in the gedcom object model.
2 Copyright (C) 2002 The Genes Development Team
3 This file is part of the Gedcom parser library.
4 Contributed by Peter Verthez <Peter.Verthez@advalvas.be>, 2002.
6 The Gedcom parser library is free software; you can redistribute it
7 and/or modify it under the terms of the GNU Lesser General Public
8 License as published by the Free Software Foundation; either
9 version 2.1 of the License, or (at your option) any later version.
11 The Gedcom parser library is distributed in the hope that it will be
12 useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 Lesser General Public License for more details.
16 You should have received a copy of the GNU Lesser General Public
17 License along with the Gedcom parser library; if not, write to the
18 Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
27 #include "source_citation.h"
31 #include "change_date.h"
36 #include "gom_internal.h"
38 struct note* gom_first_note = NULL;
40 Gedcom_ctxt note_start(_REC_PARAMS_)
42 struct xref_value* xr = GEDCOM_XREF_PTR(xref);
43 struct note* note = (struct note*) xr->object;
45 note = make_note_record(xr->string);
46 xr->object = (Gedcom_ctxt) note;
48 note->text = strdup(GEDCOM_STRING(parsed_value));
49 return (Gedcom_ctxt) MAKE_GOM_CTXT(rec, note, xr->object);
52 GET_REC_BY_XREF(note, XREF_NOTE, gom_get_note_by_xref)
54 Gedcom_ctxt sub_cont_conc_start(_ELT_PARAMS_)
56 Gom_ctxt ctxt = (Gom_ctxt)parent;
59 char *str = GEDCOM_STRING(parsed_value);
60 NL_TYPE type = (elt == ELT_SUB_CONT ? WITH_NL : WITHOUT_NL);
61 switch (ctxt->ctxt_type) {
63 header_add_to_note(type, ctxt, str); break;
65 citation_add_to_desc(type, ctxt, str); break;
66 case ELT_SUB_SOUR_TEXT:
67 citation_add_to_text(type, ctxt, str); break;
69 note_sub_add_to_note(type, ctxt, str); break;
71 note_add_to_note(type, ctxt, str); break;
76 source_add_to_value(type, ctxt, str); break;
78 UNEXPECTED_CONTEXT(ctxt->ctxt_type);
80 return (Gedcom_ctxt) make_gom_ctxt(elt, ctxt->obj_type, ctxt->ctxt_ptr);
83 return (Gedcom_ctxt) MAKE_GOM_CTXT(elt, NULL, NULL);
89 gedcom_subscribe_to_record(REC_NOTE, note_start, def_rec_end);
90 gedcom_subscribe_to_element(ELT_SUB_CONT, sub_cont_conc_start, def_elt_end);
91 gedcom_subscribe_to_element(ELT_SUB_CONC, sub_cont_conc_start, def_elt_end);
94 void note_add_to_note(NL_TYPE type, Gom_ctxt ctxt, char* str)
96 struct note *note = SAFE_CTXT_CAST(note, ctxt);
97 note->text = concat_strings (type, note->text, str);
100 void note_add_citation(Gom_ctxt ctxt, struct source_citation* cit)
102 struct note *note = SAFE_CTXT_CAST(note, ctxt);
103 LINK_CHAIN_ELT(source_citation, note->citation, cit)
106 void note_add_user_ref(Gom_ctxt ctxt, struct user_ref_number* ref)
108 struct note *note = SAFE_CTXT_CAST(note, ctxt);
109 LINK_CHAIN_ELT(user_ref_number, note->ref, ref)
112 void note_set_record_id(Gom_ctxt ctxt, char *rin)
114 struct note *note = SAFE_CTXT_CAST(note, ctxt);
115 note->record_id = strdup(rin);
118 void note_set_change_date(Gom_ctxt ctxt, struct change_date* chan)
120 struct note *note = SAFE_CTXT_CAST(note, ctxt);
121 note->change_date = chan;
124 void note_add_user_data(Gom_ctxt ctxt, struct user_data* data)
126 struct note *obj = SAFE_CTXT_CAST(note, ctxt);
127 LINK_CHAIN_ELT(user_data, obj->extra, data)
130 void note_cleanup(struct note* note)
132 SAFE_FREE(note->xrefstr);
133 SAFE_FREE(note->text);
134 DESTROY_CHAIN_ELTS(source_citation, note->citation, citation_cleanup)
135 DESTROY_CHAIN_ELTS(user_ref_number, note->ref, user_ref_cleanup)
136 SAFE_FREE(note->record_id);
137 change_date_cleanup(note->change_date);
138 DESTROY_CHAIN_ELTS(user_data, note->extra, user_data_cleanup)
143 DESTROY_CHAIN_ELTS(note, gom_first_note, note_cleanup);
146 struct note* gom_get_first_note()
148 return gom_first_note;
151 struct note* make_note_record(char* xrefstr)
154 MAKE_CHAIN_ELT(note, gom_first_note, note);
155 note->xrefstr = strdup(xrefstr);