- struct multimedia* obj = SAFE_CTXT_CAST(multimedia, ctxt);
- LINK_CHAIN_ELT(note_sub, obj->note, note)
-}
-
-void multimedia_add_user_ref(Gom_ctxt ctxt, struct user_ref_number* ref)
-{
- struct multimedia *obj = SAFE_CTXT_CAST(multimedia, ctxt);
- LINK_CHAIN_ELT(user_ref_number, obj->ref, ref)
-}
-
-void multimedia_set_record_id(Gom_ctxt ctxt, char *rin)
-{
- struct multimedia *obj = SAFE_CTXT_CAST(multimedia, ctxt);
- obj->record_id = strdup(rin);
-}
-
-void multimedia_set_change_date(Gom_ctxt ctxt, struct change_date* chan)
-{
- struct multimedia *obj = SAFE_CTXT_CAST(multimedia, ctxt);
- obj->change_date = chan;
-}
-
-void multimedia_add_user_data(Gom_ctxt ctxt, struct user_data* data)
-{
- struct multimedia *obj = SAFE_CTXT_CAST(multimedia, ctxt);
- LINK_CHAIN_ELT(user_data, obj->extra, data)
-}
-
-void multimedia_cleanup(struct multimedia* obj)
-{
- SAFE_FREE(obj->xrefstr);
- SAFE_FREE(obj->form);
- SAFE_FREE(obj->title);
- DESTROY_CHAIN_ELTS(note_sub, obj->note, note_sub_cleanup)
- SAFE_FREE(obj->data);
- DESTROY_CHAIN_ELTS(user_ref_number, obj->ref, user_ref_cleanup)
- SAFE_FREE(obj->record_id);
- change_date_cleanup(obj->change_date);
- DESTROY_CHAIN_ELTS(user_data, obj->extra, user_data_cleanup)
+ if (obj) {
+ SAFE_FREE(obj->xrefstr);
+ SAFE_FREE(obj->form);
+ SAFE_FREE(obj->title);
+ DESTROY_CHAIN_ELTS(note_sub, obj->note);
+ SAFE_FREE(obj->data);
+ DESTROY_CHAIN_ELTS(user_ref_number, obj->ref);
+ SAFE_FREE(obj->record_id);
+ CLEANFUNC(change_date)(obj->change_date);
+ DESTROY_CHAIN_ELTS(user_data, obj->extra);
+ }