GET_REC_BY_XREF(multimedia, XREF_OBJE, gom_get_multimedia_by_xref)
STRING_CB(multimedia, obje_form_start, form)
STRING_CB(multimedia, obje_titl_start, title)
-NULL_CB(multimedia, obje_blob_start)
+NULL_CB(multimedia, obje_blob_start)
+STRING_END_CB(multimedia, obje_blob_end, data)
XREF_CB(multimedia, obje_obje_start, continued, make_multimedia_record)
-void obje_blob_end(_ELT_END_PARAMS_)
-{
- Gom_ctxt ctxt = (Gom_ctxt)self;
-
- if (! ctxt)
- NO_CONTEXT;
- else {
- struct multimedia *obj = SAFE_CTXT_CAST(multimedia, ctxt);
- if (obj) {
- char *str = GEDCOM_STRING(parsed_value);
- char *newvalue = strdup(str);
- if (! newvalue)
- MEMORY_ERROR;
- else
- obj->data = newvalue;
- }
- }
-}
-
Gedcom_ctxt obje_blob_cont_start(_ELT_PARAMS_)
{
Gom_ctxt ctxt = (Gom_ctxt)parent;
}
return multi;
}
+
+int write_multimedia_recs(Gedcom_write_hndl hndl)
+{
+ int result = 0;
+ struct multimedia* obj;
+
+ for (obj = gom_first_multimedia; obj; obj = obj->next) {
+ result |= gedcom_write_record_str(hndl, REC_OBJE, obj->xrefstr, NULL);
+ if (obj->form)
+ result |= gedcom_write_element_str(hndl, ELT_OBJE_FORM, 0,
+ REC_OBJE, obj->form);
+ if (obj->title)
+ result |= gedcom_write_element_str(hndl, ELT_OBJE_TITL, 0,
+ REC_OBJE, obj->title);
+ if (obj->note)
+ result |= write_note_subs(hndl, REC_OBJE, obj->note);
+ if (obj->data)
+ result |= gedcom_write_element_str(hndl, ELT_OBJE_BLOB, 0,
+ REC_OBJE, obj->data);
+ if (obj->continued)
+ result |= gedcom_write_element_xref(hndl, ELT_OBJE_OBJE, 0,
+ REC_OBJE, obj->continued);
+ if (obj->ref)
+ result |= write_user_refs(hndl, REC_OBJE, obj->ref);
+ if (obj->record_id)
+ result |= gedcom_write_element_str(hndl, ELT_SUB_IDENT_RIN, 0,
+ REC_OBJE, obj->record_id);
+ if (obj->change_date)
+ result |= write_change_date(hndl, REC_OBJE, obj->change_date);
+ if (obj->extra)
+ result |= write_user_data(hndl, obj->extra);
+ }
+
+ return result;
+}
+