- 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);
+ 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:
+ 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);
+ }
+ result = MAKE_GOM_CTXT(elt, change_date, chan);