- if (ctxt) {
- refn = (struct user_ref_number *)malloc(sizeof(struct user_ref_number));
- memset (refn, 0, sizeof(struct user_ref_number));
- refn->value = strdup(GEDCOM_STRING(parsed_value));
-
- switch (ctxt->ctxt_type) {
- case REC_FAM:
- family_add_user_ref(ctxt, refn); break;
- case REC_INDI:
- individual_add_user_ref(ctxt, refn); break;
- case REC_OBJE:
- multimedia_add_user_ref(ctxt, refn); break;
- case REC_NOTE:
- note_add_user_ref(ctxt, refn); break;
- case REC_REPO:
- repository_add_user_ref(ctxt, refn); break;
- case REC_SOUR:
- source_add_user_ref(ctxt, refn); break;
- default:
- UNEXPECTED_CONTEXT(ctxt->ctxt_type);
+ if (! ctxt)
+ NO_CONTEXT;
+ else {
+ struct user_ref_number *refn = SUB_MAKEFUNC(user_ref_number)();
+ if (refn) {
+ refn->value = strdup(GEDCOM_STRING(parsed_value));
+ if (! refn->value) {
+ MEMORY_ERROR;
+ free(refn);
+ }
+ else {
+ switch (ctxt->ctxt_type) {
+ case REC_FAM:
+ ADDFUNC2(family,user_ref_number)(ctxt, refn); break;
+ case REC_INDI:
+ ADDFUNC2(individual,user_ref_number)(ctxt, refn); break;
+ case REC_OBJE:
+ ADDFUNC2(multimedia,user_ref_number)(ctxt, refn); break;
+ case REC_NOTE:
+ ADDFUNC2(note,user_ref_number)(ctxt, refn); break;
+ case REC_REPO:
+ ADDFUNC2(repository,user_ref_number)(ctxt, refn); break;
+ case REC_SOUR:
+ ADDFUNC2(source,user_ref_number)(ctxt, refn); break;
+ default:
+ UNEXPECTED_CONTEXT(ctxt->ctxt_type);
+ }
+
+ result = MAKE_GOM_CTXT(elt, user_ref_number, refn);
+ }