if (!addr)
MEMORY_ERROR;
else {
- char *str = GEDCOM_STRING(parsed_value);
memset (addr, 0, sizeof(struct address));
- addr->full_label = strdup(str);
-
- if (! addr->full_label) {
- MEMORY_ERROR;
- free(addr);
- }
- else {
- switch (ctxt->ctxt_type) {
- case ELT_HEAD_SOUR_CORP:
- header_add_address(ctxt, addr); break;
- case ELT_SUB_FAM_EVT:
- case ELT_SUB_FAM_EVT_EVEN:
- case ELT_SUB_INDIV_ATTR:
- case ELT_SUB_INDIV_RESI:
- case ELT_SUB_INDIV_BIRT:
- case ELT_SUB_INDIV_GEN:
- case ELT_SUB_INDIV_ADOP:
- case ELT_SUB_INDIV_EVEN:
- event_add_address(ctxt, addr); break;
- case REC_REPO:
- repository_add_address(ctxt, addr); break;
- case REC_SUBM:
- submitter_add_address(ctxt, addr); break;
- default:
- UNEXPECTED_CONTEXT(ctxt->ctxt_type);
- }
- result = MAKE_GOM_CTXT(elt, address, addr);
+ switch (ctxt->ctxt_type) {
+ case ELT_HEAD_SOUR_CORP:
+ header_add_address(ctxt, addr); break;
+ case ELT_SUB_FAM_EVT:
+ case ELT_SUB_FAM_EVT_EVEN:
+ case ELT_SUB_INDIV_ATTR:
+ case ELT_SUB_INDIV_RESI:
+ case ELT_SUB_INDIV_BIRT:
+ case ELT_SUB_INDIV_GEN:
+ case ELT_SUB_INDIV_ADOP:
+ case ELT_SUB_INDIV_EVEN:
+ event_add_address(ctxt, addr); break;
+ case REC_REPO:
+ repository_add_address(ctxt, addr); break;
+ case REC_SUBM:
+ submitter_add_address(ctxt, addr); break;
+ default:
+ UNEXPECTED_CONTEXT(ctxt->ctxt_type);
}
+ result = MAKE_GOM_CTXT(elt, address, addr);
}
}
if (! ctxt)
NO_CONTEXT;
else {
- struct address *addr = SAFE_CTXT_CAST(address, ctxt);
- if (addr) {
- char *str = GEDCOM_STRING(parsed_value);
- char *newvalue = concat_strings (WITH_NL, addr->full_label, str);
- if (! newvalue)
- MEMORY_ERROR;
- else {
- addr->full_label = newvalue;
- result = MAKE_GOM_CTXT(elt, address, addr);
- }
- }
+ result = make_gom_ctxt(elt, ctxt->ctxt_type, ctxt->ctxt_ptr);
}
return (Gedcom_ctxt)result;
}
+STRING_END_CB(address, sub_addr_end, full_label)
STRING_CB(address, sub_addr_adr1_start, line1)
STRING_CB(address, sub_addr_adr2_start, line2)
STRING_CB(address, sub_addr_city_start, city)
void address_subscribe()
{
- gedcom_subscribe_to_element(ELT_SUB_ADDR, sub_addr_start, def_elt_end);
+ gedcom_subscribe_to_element(ELT_SUB_ADDR, sub_addr_start, sub_addr_end);
gedcom_subscribe_to_element(ELT_SUB_ADDR_CONT,
sub_addr_cont_start, def_elt_end);
gedcom_subscribe_to_element(ELT_SUB_ADDR_ADR1,
}
SAFE_FREE(address);
}
+
+int write_address(Gedcom_write_hndl hndl, int parent, struct address *address)
+{
+ int result = 0;
+
+ if (!address) return 1;
+
+ if (address->full_label)
+ result |= gedcom_write_element_str(hndl, ELT_SUB_ADDR, 0, parent,
+ address->full_label);
+ if (address->line1)
+ result |= gedcom_write_element_str(hndl, ELT_SUB_ADDR_ADR1, 0,
+ ELT_SUB_ADDR, address->line1);
+ if (address->line2)
+ result |= gedcom_write_element_str(hndl, ELT_SUB_ADDR_ADR2, 0,
+ ELT_SUB_ADDR, address->line2);
+ if (address->city)
+ result |= gedcom_write_element_str(hndl, ELT_SUB_ADDR_CITY, 0,
+ ELT_SUB_ADDR, address->city);
+ if (address->state)
+ result |= gedcom_write_element_str(hndl, ELT_SUB_ADDR_STAE, 0,
+ ELT_SUB_ADDR, address->state);
+ if (address->postal)
+ result |= gedcom_write_element_str(hndl, ELT_SUB_ADDR_POST, 0,
+ ELT_SUB_ADDR, address->postal);
+ if (address->country)
+ result |= gedcom_write_element_str(hndl, ELT_SUB_ADDR_CTRY, 0,
+ ELT_SUB_ADDR, address->country);
+ if (address->extra)
+ result |= write_user_data(hndl, address->extra);
+
+ return result;
+}