Gedcom_ctxt note_start(_REC_PARAMS_)
{
+ Gom_ctxt result = NULL;
struct xref_value* xr = GEDCOM_XREF_PTR(xref);
struct note* note = (struct note*) xr->object;
- if (! xr->object) {
+ if (! note) {
note = make_note_record(xr->string);
xr->object = (Gedcom_ctxt) note;
}
- note->text = strdup(GEDCOM_STRING(parsed_value));
- return (Gedcom_ctxt) MAKE_GOM_CTXT(rec, note, xr->object);
+ if (note)
+ result = MAKE_GOM_CTXT(rec, note, xr->object);
+ return (Gedcom_ctxt)result;
}
+STRING_END_REC_CB(note, note_end, text)
GET_REC_BY_XREF(note, XREF_NOTE, gom_get_note_by_xref)
Gedcom_ctxt sub_cont_conc_start(_ELT_PARAMS_)
{
Gom_ctxt ctxt = (Gom_ctxt)parent;
-
- if (ctxt) {
- char *str = GEDCOM_STRING(parsed_value);
- NL_TYPE type = (elt == ELT_SUB_CONT ? WITH_NL : WITHOUT_NL);
- switch (ctxt->ctxt_type) {
- case ELT_HEAD_NOTE:
- header_add_to_note(type, ctxt, str); break;
- case ELT_SUB_SOUR:
- citation_add_to_desc(type, ctxt, str); break;
- case ELT_SUB_SOUR_TEXT:
- citation_add_to_text(type, ctxt, str); break;
- case ELT_SUB_NOTE:
- note_sub_add_to_note(type, ctxt, str); break;
- case REC_NOTE:
- note_add_to_note(type, ctxt, str); break;
- case ELT_SOUR_AUTH:
- case ELT_SOUR_TITL:
- case ELT_SOUR_PUBL:
- case ELT_SOUR_TEXT:
- source_add_to_value(type, ctxt, str); break;
- default:
- UNEXPECTED_CONTEXT(ctxt->ctxt_type);
- }
- return (Gedcom_ctxt) make_gom_ctxt(elt, ctxt->obj_type, ctxt->ctxt_ptr);
- }
- else {
- return (Gedcom_ctxt) MAKE_GOM_CTXT(elt, NULL, NULL);
- }
+ Gom_ctxt result = NULL;
+
+ if (! ctxt)
+ NO_CONTEXT;
+ else
+ result = make_gom_ctxt(elt, ctxt->obj_type, ctxt->ctxt_ptr);
+
+ return (Gedcom_ctxt)result;
}
void note_subscribe()
{
- gedcom_subscribe_to_record(REC_NOTE, note_start, def_rec_end);
+ gedcom_subscribe_to_record(REC_NOTE, note_start, note_end);
gedcom_subscribe_to_element(ELT_SUB_CONT, sub_cont_conc_start, def_elt_end);
gedcom_subscribe_to_element(ELT_SUB_CONC, sub_cont_conc_start, def_elt_end);
}
-void note_add_to_note(NL_TYPE type, Gom_ctxt ctxt, char* str)
-{
- struct note *note = SAFE_CTXT_CAST(note, ctxt);
- note->text = concat_strings (type, note->text, str);
-}
-
void note_add_citation(Gom_ctxt ctxt, struct source_citation* cit)
{
struct note *note = SAFE_CTXT_CAST(note, ctxt);
- LINK_CHAIN_ELT(source_citation, note->citation, cit)
+ if (note)
+ LINK_CHAIN_ELT(source_citation, note->citation, cit);
}
void note_add_user_ref(Gom_ctxt ctxt, struct user_ref_number* ref)
{
struct note *note = SAFE_CTXT_CAST(note, ctxt);
- LINK_CHAIN_ELT(user_ref_number, note->ref, ref)
+ if (note)
+ LINK_CHAIN_ELT(user_ref_number, note->ref, ref);
}
-void note_set_record_id(Gom_ctxt ctxt, char *rin)
+void note_set_record_id(Gom_ctxt ctxt, const char *rin)
{
struct note *note = SAFE_CTXT_CAST(note, ctxt);
- note->record_id = strdup(rin);
+ if (note) {
+ note->record_id = strdup(rin);
+ if (! note->record_id) MEMORY_ERROR;
+ }
}
void note_set_change_date(Gom_ctxt ctxt, struct change_date* chan)
{
struct note *note = SAFE_CTXT_CAST(note, ctxt);
- note->change_date = chan;
+ if (note)
+ note->change_date = chan;
}
void note_add_user_data(Gom_ctxt ctxt, struct user_data* data)
{
struct note *obj = SAFE_CTXT_CAST(note, ctxt);
- LINK_CHAIN_ELT(user_data, obj->extra, data)
+ if (obj)
+ LINK_CHAIN_ELT(user_data, obj->extra, data);
}
void note_cleanup(struct note* note)
{
- SAFE_FREE(note->xrefstr);
- SAFE_FREE(note->text);
- DESTROY_CHAIN_ELTS(source_citation, note->citation, citation_cleanup)
- DESTROY_CHAIN_ELTS(user_ref_number, note->ref, user_ref_cleanup)
- SAFE_FREE(note->record_id);
- change_date_cleanup(note->change_date);
- DESTROY_CHAIN_ELTS(user_data, note->extra, user_data_cleanup)
+ if (note) {
+ SAFE_FREE(note->xrefstr);
+ SAFE_FREE(note->text);
+ DESTROY_CHAIN_ELTS(source_citation, note->citation, citation_cleanup);
+ DESTROY_CHAIN_ELTS(user_ref_number, note->ref, user_ref_cleanup);
+ SAFE_FREE(note->record_id);
+ change_date_cleanup(note->change_date);
+ DESTROY_CHAIN_ELTS(user_data, note->extra, user_data_cleanup);
+ }
}
void notes_cleanup()
return gom_first_note;
}
-struct note* make_note_record(char* xrefstr)
+struct note* make_note_record(const char* xrefstr)
{
- struct note* note;
+ struct note* note = NULL;
MAKE_CHAIN_ELT(note, gom_first_note, note);
- note->xrefstr = strdup(xrefstr);
+ if (note) {
+ note->xrefstr = strdup(xrefstr);
+ if (! note->xrefstr) MEMORY_ERROR;
+ }
return note;
}
+
+int write_notes(Gedcom_write_hndl hndl)
+{
+ int result = 0;
+ struct note* obj;
+
+ for (obj = gom_first_note; obj; obj = obj->next) {
+ result |= gedcom_write_record_str(hndl, REC_NOTE, obj->xrefstr, obj->text);
+ if (obj->citation)
+ result |= write_citations(hndl, REC_NOTE, obj->citation);
+ if (obj->ref)
+ result |= write_user_refs(hndl, REC_NOTE, obj->ref);
+ if (obj->record_id)
+ result |= gedcom_write_element_str(hndl, ELT_SUB_IDENT_RIN, 0,
+ REC_NOTE, obj->record_id);
+ if (obj->change_date)
+ result |= write_change_date(hndl, REC_NOTE, obj->change_date);
+ if (obj->extra)
+ result |= write_user_data(hndl, obj->extra);
+ }
+
+ return result;
+}
+