- struct change_date *chan
- = (struct change_date *)malloc(sizeof(struct change_date));
- memset (chan, 0, sizeof(struct change_date));
-
- if (ctxt) {
- switch (ctxt->ctxt_type) {
- case REC_FAM:
- family_set_change_date(ctxt, chan); break;
- case REC_INDI:
- individual_set_change_date(ctxt, chan); break;
- case REC_OBJE:
- multimedia_set_change_date(ctxt, chan); break;
- case REC_NOTE:
- note_set_change_date(ctxt, chan); break;
- case REC_REPO:
- repository_set_change_date(ctxt, chan); break;
- case REC_SOUR:
- source_set_change_date(ctxt, chan); break;
- case REC_SUBM:
- submitter_set_change_date(ctxt, chan); break;
- default:
- UNEXPECTED_CONTEXT(ctxt->ctxt_type);
+ Gom_ctxt result = NULL;
+
+ if (! ctxt)
+ NO_CONTEXT;
+ else {
+ struct change_date *chan
+ = (struct change_date *)malloc(sizeof(struct change_date));
+ if (! chan)
+ MEMORY_ERROR;
+ else {
+ memset (chan, 0, sizeof(struct change_date));
+
+ switch (ctxt->ctxt_type) {
+ case REC_FAM:
+ ADDFUNC2_NOLIST(family,change_date)(ctxt, chan); break;
+ case REC_INDI:
+ ADDFUNC2_NOLIST(individual,change_date)(ctxt, chan); break;
+ case REC_OBJE:
+ ADDFUNC2_NOLIST(multimedia,change_date)(ctxt, chan); break;
+ case REC_NOTE:
+ ADDFUNC2_NOLIST(note,change_date)(ctxt, chan); break;
+ case REC_REPO:
+ ADDFUNC2_NOLIST(repository,change_date)(ctxt, chan); break;
+ case REC_SOUR:
+ ADDFUNC2_NOLIST(source,change_date)(ctxt, chan); break;
+ case REC_SUBM:
+ ADDFUNC2_NOLIST(submitter,change_date)(ctxt, chan); break;
+ default:
+ UNEXPECTED_CONTEXT(ctxt->ctxt_type);
+ }
+ result = MAKE_GOM_CTXT(elt, change_date, chan);