summaryrefslogtreecommitdiff
path: root/gst/mxf/mxfaes-bwf.c
diff options
context:
space:
mode:
authorSebastian Dröge <slomo@circular-chaos.org>2008-12-15 17:27:00 +0000
committerSebastian Dröge <slomo@circular-chaos.org>2008-12-15 17:27:00 +0000
commitbc93b81dd56106f11d87f6a8ad9b6134f2817a57 (patch)
tree7c1d9ab165287ddff168bdde0d16579a1f95487c /gst/mxf/mxfaes-bwf.c
parent9cfbca8754cef7961cbfbfb1d7a66ab886efefc9 (diff)
downloadgstreamer-plugins-bad-bc93b81dd56106f11d87f6a8ad9b6134f2817a57.tar.gz
gst/mxf/: Convert the structural metadata to GstMiniObjects to make a lot of code easier and to make everything bette...
Original commit message from CVS: * gst/mxf/Makefile.am: * gst/mxf/mxf.c: (plugin_init): * gst/mxf/mxfaes-bwf.c: (mxf_metadata_wave_audio_essence_descriptor_handle_tag), (mxf_metadata_wave_audio_essence_descriptor_init), (mxf_metadata_wave_audio_essence_descriptor_class_init), (mxf_metadata_aes3_audio_essence_descriptor_finalize), (mxf_metadata_aes3_audio_essence_descriptor_handle_tag), (mxf_metadata_aes3_audio_essence_descriptor_init), (mxf_metadata_aes3_audio_essence_descriptor_class_init), (mxf_is_aes_bwf_essence_track), (mxf_bwf_create_caps), (mxf_aes3_create_caps), (mxf_aes_bwf_create_caps), (mxf_aes_bwf_init): * gst/mxf/mxfaes-bwf.h: * gst/mxf/mxfalaw.c: (mxf_is_alaw_essence_track), (mxf_alaw_create_caps), (mxf_alaw_init): * gst/mxf/mxfalaw.h: * gst/mxf/mxfd10.c: (mxf_is_d10_essence_track), (mxf_d10_create_caps), (mxf_d10_init): * gst/mxf/mxfd10.h: * gst/mxf/mxfdemux.c: (gst_mxf_demux_reset_metadata), (gst_mxf_demux_handle_header_metadata_resolve_references), (gst_mxf_demux_find_package), (gst_mxf_demux_choose_package), (gst_mxf_demux_handle_header_metadata_update_streams), (gst_mxf_demux_handle_metadata), (gst_mxf_demux_handle_generic_container_essence_element), (gst_mxf_demux_handle_klv_packet), (gst_mxf_demux_src_query): * gst/mxf/mxfdemux.h: * gst/mxf/mxfdv-dif.c: (mxf_is_dv_dif_essence_track), (mxf_dv_dif_create_caps), (mxf_dv_dif_init): * gst/mxf/mxfdv-dif.h: * gst/mxf/mxfjpeg2000.c: (mxf_is_jpeg2000_essence_track), (mxf_jpeg2000_create_caps), (mxf_jpeg2000_init): * gst/mxf/mxfjpeg2000.h: * gst/mxf/mxfmetadata.c: (mxf_metadata_base_finalize), (mxf_metadata_base_handle_tag), (mxf_metadata_base_resolve), (mxf_metadata_base_init), (mxf_metadata_base_class_init), (mxf_metadata_parse), (mxf_metadata_resolve), (mxf_metadata_handle_tag), (mxf_metadata_class_init), (mxf_metadata_init), (mxf_metadata_init_types), (mxf_metadata_register), (mxf_metadata_new), (mxf_metadata_preface_finalize), (mxf_metadata_preface_handle_tag), (mxf_metadata_preface_resolve), (mxf_metadata_preface_init), (mxf_metadata_preface_class_init), (mxf_metadata_identification_finalize), (mxf_metadata_identification_handle_tag), (mxf_metadata_identification_init), (mxf_metadata_identification_class_init), (mxf_metadata_content_storage_finalize), (mxf_metadata_content_storage_handle_tag), (mxf_metadata_content_storage_resolve), (mxf_metadata_content_storage_init), (mxf_metadata_content_storage_class_init), (mxf_metadata_essence_container_data_handle_tag), (mxf_metadata_essence_container_data_resolve), (mxf_metadata_essence_container_data_init), (mxf_metadata_essence_container_data_class_init), (mxf_metadata_generic_package_finalize), (mxf_metadata_generic_package_handle_tag), (mxf_metadata_generic_package_resolve), (mxf_metadata_generic_package_init), (mxf_metadata_generic_package_class_init), (mxf_metadata_material_package_resolve), (mxf_metadata_material_package_init), (mxf_metadata_material_package_class_init), (mxf_metadata_source_package_finalize), (mxf_metadata_source_package_handle_tag), (mxf_metadata_source_package_resolve), (mxf_metadata_source_package_init), (mxf_metadata_source_package_class_init), (mxf_metadata_track_finalize), (mxf_metadata_track_handle_tag), (mxf_metadata_track_resolve), (mxf_metadata_track_init), (mxf_metadata_track_class_init), (mxf_metadata_track_identifier_parse), (mxf_metadata_timeline_track_handle_tag), (mxf_metadata_timeline_track_init), (mxf_metadata_timeline_track_class_init), (mxf_metadata_event_track_handle_tag), (mxf_metadata_event_track_init), (mxf_metadata_event_track_class_init), (mxf_metadata_static_track_init), (mxf_metadata_static_track_class_init), (mxf_metadata_sequence_finalize), (mxf_metadata_sequence_handle_tag), (mxf_metadata_sequence_resolve), (mxf_metadata_sequence_init), (mxf_metadata_sequence_class_init), (mxf_metadata_structural_component_handle_tag), (mxf_metadata_structural_component_init), (mxf_metadata_structural_component_class_init), (mxf_metadata_timecode_component_handle_tag), (mxf_metadata_timecode_component_init), (mxf_metadata_timecode_component_class_init), (mxf_metadata_source_clip_handle_tag), (mxf_metadata_source_clip_resolve), (mxf_metadata_source_clip_init), (mxf_metadata_source_clip_class_init), (mxf_metadata_dm_source_clip_finalize), (mxf_metadata_dm_source_clip_handle_tag), (mxf_metadata_dm_source_clip_init), (mxf_metadata_dm_source_clip_class_init), (mxf_metadata_dm_segment_finalize), (mxf_metadata_dm_segment_handle_tag), (mxf_metadata_dm_segment_resolve), (mxf_metadata_dm_segment_init), (mxf_metadata_dm_segment_class_init), (mxf_metadata_generic_descriptor_finalize), (mxf_metadata_generic_descriptor_handle_tag), (mxf_metadata_generic_descriptor_resolve), (mxf_metadata_generic_descriptor_init), (mxf_metadata_generic_descriptor_class_init), (mxf_metadata_file_descriptor_handle_tag), (mxf_metadata_file_descriptor_init), (mxf_metadata_file_descriptor_class_init), (mxf_metadata_generic_picture_essence_descriptor_handle_tag), (mxf_metadata_generic_picture_essence_descriptor_init), (mxf_metadata_generic_picture_essence_descriptor_class_init), (mxf_metadata_generic_picture_essence_descriptor_set_caps), (mxf_metadata_generic_sound_essence_descriptor_handle_tag), (mxf_metadata_generic_sound_essence_descriptor_init), (mxf_metadata_generic_sound_essence_descriptor_class_init), (mxf_metadata_cdci_picture_essence_descriptor_handle_tag), (mxf_metadata_cdci_picture_essence_descriptor_init), (mxf_metadata_cdci_picture_essence_descriptor_class_init), (mxf_metadata_rgba_picture_essence_descriptor_finalize), (mxf_metadata_rgba_picture_essence_descriptor_handle_tag), (mxf_metadata_rgba_picture_essence_descriptor_init), (mxf_metadata_rgba_picture_essence_descriptor_class_init), (mxf_metadata_generic_data_essence_descriptor_handle_tag), (mxf_metadata_generic_data_essence_descriptor_init), (mxf_metadata_generic_data_essence_descriptor_class_init), (mxf_metadata_multiple_descriptor_finalize), (mxf_metadata_multiple_descriptor_handle_tag), (mxf_metadata_multiple_descriptor_resolve), (mxf_metadata_multiple_descriptor_init), (mxf_metadata_multiple_descriptor_class_init), (mxf_metadata_locator_init), (mxf_metadata_locator_class_init), (mxf_metadata_text_locator_finalize), (mxf_metadata_text_locator_handle_tag), (mxf_metadata_text_locator_init), (mxf_metadata_text_locator_class_init), (mxf_metadata_network_locator_finalize), (mxf_metadata_network_locator_handle_tag), (mxf_metadata_network_locator_init), (mxf_metadata_network_locator_class_init): * gst/mxf/mxfmetadata.h: * gst/mxf/mxfmpeg.c: (mxf_metadata_mpeg_video_descriptor_handle_tag), (mxf_metadata_mpeg_video_descriptor_init), (mxf_metadata_mpeg_video_descriptor_class_init), (mxf_is_mpeg_essence_track), (mxf_mpeg_es_create_caps), (mxf_mpeg_create_caps), (mxf_mpeg_init): * gst/mxf/mxfmpeg.h: * gst/mxf/mxfparse.c: (mxf_index_table_segment_parse), (mxf_local_tag_add_to_hash_table): * gst/mxf/mxfparse.h: * gst/mxf/mxftypes.h: * gst/mxf/mxfup.c: (mxf_is_up_essence_track), (mxf_up_create_caps), (mxf_up_init): * gst/mxf/mxfup.h: Convert the structural metadata to GstMiniObjects to make a lot of code easier and to make everything better extensible. Add a "registry" for metadata handlers to improve extensibility even more and to remove metadata type specifics from mxfdemux. Clean up a lot of parts and add some more NULL checks.
Diffstat (limited to 'gst/mxf/mxfaes-bwf.c')
-rw-r--r--gst/mxf/mxfaes-bwf.c389
1 files changed, 207 insertions, 182 deletions
diff --git a/gst/mxf/mxfaes-bwf.c b/gst/mxf/mxfaes-bwf.c
index 98e0f7247..6b297ef48 100644
--- a/gst/mxf/mxfaes-bwf.c
+++ b/gst/mxf/mxfaes-bwf.c
@@ -41,180 +41,199 @@ GST_DEBUG_CATEGORY_EXTERN (mxf_debug);
#define GST_CAT_DEFAULT mxf_debug
/* SMPTE 382M Annex 1 */
-gboolean
- mxf_metadata_wave_audio_essence_descriptor_handle_tag
- (MXFMetadataGenericDescriptor * d, const MXFPrimerPack * primer,
- guint16 tag, const guint8 * tag_data, guint16 tag_size)
+G_DEFINE_TYPE (MXFMetadataWaveAudioEssenceDescriptor,
+ mxf_metadata_wave_audio_essence_descriptor,
+ MXF_TYPE_METADATA_GENERIC_SOUND_ESSENCE_DESCRIPTOR);
+
+static gboolean
+mxf_metadata_wave_audio_essence_descriptor_handle_tag (MXFMetadataBase *
+ metadata, MXFPrimerPack * primer, guint16 tag, const guint8 * tag_data,
+ guint tag_size)
{
- MXFMetadataWaveAudioEssenceDescriptor *descriptor =
- (MXFMetadataWaveAudioEssenceDescriptor *) d;
- gboolean ret = FALSE;
+ MXFMetadataWaveAudioEssenceDescriptor *self =
+ MXF_METADATA_WAVE_AUDIO_ESSENCE_DESCRIPTOR (metadata);
+ gboolean ret = TRUE;
gchar str[48];
switch (tag) {
case 0x3d0a:
if (tag_size != 2)
goto error;
- descriptor->block_align = GST_READ_UINT16_BE (tag_data);
- GST_DEBUG (" block align = %u", descriptor->block_align);
- ret = TRUE;
+ self->block_align = GST_READ_UINT16_BE (tag_data);
+ GST_DEBUG (" block align = %u", self->block_align);
break;
case 0x3d0b:
if (tag_size != 1)
goto error;
- descriptor->sequence_offset = GST_READ_UINT8 (tag_data);
- GST_DEBUG (" sequence offset = %u", descriptor->sequence_offset);
- ret = TRUE;
+ self->sequence_offset = GST_READ_UINT8 (tag_data);
+ GST_DEBUG (" sequence offset = %u", self->sequence_offset);
break;
case 0x3d09:
if (tag_size != 4)
goto error;
- descriptor->avg_bps = GST_READ_UINT32_BE (tag_data);
- GST_DEBUG (" average bps = %u", descriptor->avg_bps);
- ret = TRUE;
+ self->avg_bps = GST_READ_UINT32_BE (tag_data);
+ GST_DEBUG (" average bps = %u", self->avg_bps);
break;
case 0x3d32:
if (tag_size != 16)
goto error;
- memcpy (&descriptor->channel_assignment, tag_data, 16);
+ memcpy (&self->channel_assignment, tag_data, 16);
GST_DEBUG (" channel assignment = %s",
- mxf_ul_to_string (&descriptor->channel_assignment, str));
- ret = TRUE;
+ mxf_ul_to_string (&self->channel_assignment, str));
break;
case 0x3d29:
if (tag_size != 4)
goto error;
- descriptor->peak_envelope_version = GST_READ_UINT32_BE (tag_data);
- GST_DEBUG (" peak envelope version = %u",
- descriptor->peak_envelope_version);
- ret = TRUE;
+ self->peak_envelope_version = GST_READ_UINT32_BE (tag_data);
+ GST_DEBUG (" peak envelope version = %u", self->peak_envelope_version);
break;
case 0x3d2a:
if (tag_size != 4)
goto error;
- descriptor->peak_envelope_format = GST_READ_UINT32_BE (tag_data);
- GST_DEBUG (" peak envelope format = %u",
- descriptor->peak_envelope_format);
- ret = TRUE;
+ self->peak_envelope_format = GST_READ_UINT32_BE (tag_data);
+ GST_DEBUG (" peak envelope format = %u", self->peak_envelope_format);
break;
case 0x3d2b:
if (tag_size != 4)
goto error;
- descriptor->points_per_peak_value = GST_READ_UINT32_BE (tag_data);
- GST_DEBUG (" points per peak value = %u",
- descriptor->points_per_peak_value);
- ret = TRUE;
+ self->points_per_peak_value = GST_READ_UINT32_BE (tag_data);
+ GST_DEBUG (" points per peak value = %u", self->points_per_peak_value);
break;
case 0x3d2c:
if (tag_size != 4)
goto error;
- descriptor->peak_envelope_block_size = GST_READ_UINT32_BE (tag_data);
+ self->peak_envelope_block_size = GST_READ_UINT32_BE (tag_data);
GST_DEBUG (" peak envelope block size = %u",
- descriptor->peak_envelope_block_size);
- ret = TRUE;
+ self->peak_envelope_block_size);
break;
case 0x3d2d:
if (tag_size != 4)
goto error;
- descriptor->peak_channels = GST_READ_UINT32_BE (tag_data);
- GST_DEBUG (" peak channels = %u", descriptor->peak_channels);
- ret = TRUE;
+ self->peak_channels = GST_READ_UINT32_BE (tag_data);
+ GST_DEBUG (" peak channels = %u", self->peak_channels);
break;
case 0x3d2e:
if (tag_size != 4)
goto error;
- descriptor->peak_frames = GST_READ_UINT32_BE (tag_data);
- GST_DEBUG (" peak frames = %u", descriptor->peak_frames);
- ret = TRUE;
+ self->peak_frames = GST_READ_UINT32_BE (tag_data);
+ GST_DEBUG (" peak frames = %u", self->peak_frames);
break;
case 0x3d2f:
if (tag_size != 8)
goto error;
- descriptor->peak_of_peaks_position = GST_READ_UINT64_BE (tag_data);
+ self->peak_of_peaks_position = GST_READ_UINT64_BE (tag_data);
GST_DEBUG (" peak of peaks position = %" G_GINT64_FORMAT,
- descriptor->peak_of_peaks_position);
- ret = TRUE;
+ self->peak_of_peaks_position);
break;
case 0x3d30:
- if (!mxf_timestamp_parse (&descriptor->peak_envelope_timestamp,
+ if (!mxf_timestamp_parse (&self->peak_envelope_timestamp,
tag_data, tag_size))
goto error;
GST_DEBUG (" peak envelope timestamp = %d/%u/%u %u:%u:%u.%u",
- descriptor->peak_envelope_timestamp.year,
- descriptor->peak_envelope_timestamp.month,
- descriptor->peak_envelope_timestamp.day,
- descriptor->peak_envelope_timestamp.hour,
- descriptor->peak_envelope_timestamp.minute,
- descriptor->peak_envelope_timestamp.second,
- (descriptor->peak_envelope_timestamp.quarter_msecond * 1000) / 256);
- ret = TRUE;
+ self->peak_envelope_timestamp.year,
+ self->peak_envelope_timestamp.month,
+ self->peak_envelope_timestamp.day,
+ self->peak_envelope_timestamp.hour,
+ self->peak_envelope_timestamp.minute,
+ self->peak_envelope_timestamp.second,
+ (self->peak_envelope_timestamp.quarter_msecond * 1000) / 256);
break;
case 0x3d31:
- descriptor->peak_envelope_data = g_memdup (tag_data, tag_size);
- descriptor->peak_envelope_data_length = tag_size;
+ self->peak_envelope_data = g_memdup (tag_data, tag_size);
+ self->peak_envelope_data_length = tag_size;
GST_DEBUG (" peak evelope data size = %u",
- descriptor->peak_envelope_data_length);
- ret = TRUE;
+ self->peak_envelope_data_length);
break;
default:
ret =
- mxf_metadata_generic_sound_essence_descriptor_handle_tag (d, primer,
- tag, tag_data, tag_size);
+ MXF_METADATA_BASE_CLASS
+ (mxf_metadata_wave_audio_essence_descriptor_parent_class)->
+ handle_tag (metadata, primer, tag, tag_data, tag_size);
break;
}
return ret;
error:
- GST_ERROR ("Invalid wave audio essence descriptor tag 0x%04x of size %u", tag,
+
+ GST_ERROR
+ ("Invalid wave audio essence descriptor local tag 0x%04x of size %u", tag,
tag_size);
return TRUE;
}
-void mxf_metadata_wave_audio_essence_descriptor_reset
- (MXFMetadataWaveAudioEssenceDescriptor * descriptor)
+static void
+ mxf_metadata_wave_audio_essence_descriptor_init
+ (MXFMetadataWaveAudioEssenceDescriptor * self)
{
- g_return_if_fail (descriptor != NULL);
- mxf_metadata_generic_sound_essence_descriptor_reset (
- (MXFMetadataGenericSoundEssenceDescriptor *) descriptor);
+}
+
+static void
+ mxf_metadata_wave_audio_essence_descriptor_class_init
+ (MXFMetadataWaveAudioEssenceDescriptorClass * klass)
+{
+ MXFMetadataBaseClass *metadata_base_class = (MXFMetadataBaseClass *) klass;
- MXF_METADATA_DESCRIPTOR_CLEAR (descriptor,
- MXFMetadataWaveAudioEssenceDescriptor,
- MXFMetadataGenericSoundEssenceDescriptor);
+ metadata_base_class->handle_tag =
+ mxf_metadata_wave_audio_essence_descriptor_handle_tag;
}
/* SMPTE 382M Annex 2 */
-gboolean
- mxf_metadata_aes3_audio_essence_descriptor_handle_tag
- (MXFMetadataGenericDescriptor * d, const MXFPrimerPack * primer,
- guint16 tag, const guint8 * tag_data, guint16 tag_size)
+G_DEFINE_TYPE (MXFMetadataAES3AudioEssenceDescriptor,
+ mxf_metadata_aes3_audio_essence_descriptor,
+ MXF_TYPE_METADATA_WAVE_AUDIO_ESSENCE_DESCRIPTOR);
+
+static void
+mxf_metadata_aes3_audio_essence_descriptor_finalize (GstMiniObject * object)
+{
+ MXFMetadataAES3AudioEssenceDescriptor *self =
+ MXF_METADATA_AES3_AUDIO_ESSENCE_DESCRIPTOR (object);
+
+ g_free (self->channel_status_mode);
+ self->channel_status_mode = NULL;
+ g_free (self->fixed_channel_status_data);
+ self->fixed_channel_status_data = NULL;
+ g_free (self->user_data_mode);
+ self->user_data_mode = NULL;
+ g_free (self->fixed_user_data);
+ self->fixed_user_data = NULL;
+
+ GST_MINI_OBJECT_CLASS
+ (mxf_metadata_aes3_audio_essence_descriptor_parent_class)->
+ finalize (object);
+}
+
+static gboolean
+mxf_metadata_aes3_audio_essence_descriptor_handle_tag (MXFMetadataBase *
+ metadata, MXFPrimerPack * primer, guint16 tag, const guint8 * tag_data,
+ guint tag_size)
{
- MXFMetadataAES3AudioEssenceDescriptor *descriptor =
- (MXFMetadataAES3AudioEssenceDescriptor *) d;
- gboolean ret = FALSE;
+ MXFMetadataAES3AudioEssenceDescriptor *self =
+ MXF_METADATA_AES3_AUDIO_ESSENCE_DESCRIPTOR (metadata);
+ gboolean ret = TRUE;
switch (tag) {
case 0x3d0d:
if (tag_size != 1)
goto error;
- descriptor->emphasis = GST_READ_UINT8 (tag_data);
- GST_DEBUG (" emphasis = %u", descriptor->emphasis);
+ self->emphasis = GST_READ_UINT8 (tag_data);
+ GST_DEBUG (" emphasis = %u", self->emphasis);
ret = TRUE;
break;
case 0x3d0f:
if (tag_size != 2)
goto error;
- descriptor->block_start_offset = GST_READ_UINT16_BE (tag_data);
- GST_DEBUG (" block start offset = %u", descriptor->block_start_offset);
+ self->block_start_offset = GST_READ_UINT16_BE (tag_data);
+ GST_DEBUG (" block start offset = %u", self->block_start_offset);
ret = TRUE;
break;
case 0x3d08:
if (tag_size != 1)
goto error;
- descriptor->auxiliary_bits_mode = GST_READ_UINT8 (tag_data);
- GST_DEBUG (" auxiliary bits mode = %u", descriptor->auxiliary_bits_mode);
+ self->auxiliary_bits_mode = GST_READ_UINT8 (tag_data);
+ GST_DEBUG (" auxiliary bits mode = %u", self->auxiliary_bits_mode);
ret = TRUE;
break;
case 0x3d10:{
@@ -225,7 +244,7 @@ gboolean
goto error;
len = GST_READ_UINT32_BE (tag_data);
GST_DEBUG (" number of channel status mode = %u", len);
- descriptor->n_channel_status_mode = len;
+ self->n_channel_status_mode = len;
if (len == 0)
return TRUE;
@@ -238,12 +257,12 @@ gboolean
if (tag_size != len)
goto error;
- descriptor->channel_status_mode = g_new0 (guint8, len);
+ self->channel_status_mode = g_new0 (guint8, len);
for (i = 0; i < len; i++) {
- descriptor->channel_status_mode[i] = GST_READ_UINT8 (tag_data);
+ self->channel_status_mode[i] = GST_READ_UINT8 (tag_data);
GST_DEBUG (" channel status mode %u = %u", i,
- descriptor->channel_status_mode[i]);
+ self->channel_status_mode[i]);
tag_data++;
tag_size--;
}
@@ -259,7 +278,7 @@ gboolean
goto error;
len = GST_READ_UINT32_BE (tag_data);
GST_DEBUG (" number of fixed channel status data = %u", len);
- descriptor->n_fixed_channel_status_data = len;
+ self->n_fixed_channel_status_data = len;
if (len == 0)
return TRUE;
@@ -272,41 +291,41 @@ gboolean
if (tag_size != len * 24)
goto error;
- descriptor->fixed_channel_status_data =
+ self->fixed_channel_status_data =
g_malloc0 (len * sizeof (guint8 *) + len * 24);
for (i = 0; i < len; i++) {
- descriptor->fixed_channel_status_data[i] =
- ((guint8 *) descriptor->fixed_channel_status_data) +
+ self->fixed_channel_status_data[i] =
+ ((guint8 *) self->fixed_channel_status_data) +
len * sizeof (guint8 *) + i * 24;
- memcpy (descriptor->fixed_channel_status_data[i], tag_data, 24);
+ memcpy (self->fixed_channel_status_data[i], tag_data, 24);
GST_DEBUG
(" fixed channel status data %u = 0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x",
- i, descriptor->fixed_channel_status_data[i][0],
- descriptor->fixed_channel_status_data[i][1],
- descriptor->fixed_channel_status_data[i][2],
- descriptor->fixed_channel_status_data[i][3],
- descriptor->fixed_channel_status_data[i][4],
- descriptor->fixed_channel_status_data[i][5],
- descriptor->fixed_channel_status_data[i][6],
- descriptor->fixed_channel_status_data[i][7],
- descriptor->fixed_channel_status_data[i][8],
- descriptor->fixed_channel_status_data[i][9],
- descriptor->fixed_channel_status_data[i][10],
- descriptor->fixed_channel_status_data[i][11],
- descriptor->fixed_channel_status_data[i][12],
- descriptor->fixed_channel_status_data[i][13],
- descriptor->fixed_channel_status_data[i][14],
- descriptor->fixed_channel_status_data[i][15],
- descriptor->fixed_channel_status_data[i][16],
- descriptor->fixed_channel_status_data[i][17],
- descriptor->fixed_channel_status_data[i][18],
- descriptor->fixed_channel_status_data[i][19],
- descriptor->fixed_channel_status_data[i][20],
- descriptor->fixed_channel_status_data[i][21],
- descriptor->fixed_channel_status_data[i][22],
- descriptor->fixed_channel_status_data[i][23]
+ i, self->fixed_channel_status_data[i][0],
+ self->fixed_channel_status_data[i][1],
+ self->fixed_channel_status_data[i][2],
+ self->fixed_channel_status_data[i][3],
+ self->fixed_channel_status_data[i][4],
+ self->fixed_channel_status_data[i][5],
+ self->fixed_channel_status_data[i][6],
+ self->fixed_channel_status_data[i][7],
+ self->fixed_channel_status_data[i][8],
+ self->fixed_channel_status_data[i][9],
+ self->fixed_channel_status_data[i][10],
+ self->fixed_channel_status_data[i][11],
+ self->fixed_channel_status_data[i][12],
+ self->fixed_channel_status_data[i][13],
+ self->fixed_channel_status_data[i][14],
+ self->fixed_channel_status_data[i][15],
+ self->fixed_channel_status_data[i][16],
+ self->fixed_channel_status_data[i][17],
+ self->fixed_channel_status_data[i][18],
+ self->fixed_channel_status_data[i][19],
+ self->fixed_channel_status_data[i][20],
+ self->fixed_channel_status_data[i][21],
+ self->fixed_channel_status_data[i][22],
+ self->fixed_channel_status_data[i][23]
);
tag_data += 24;
tag_size -= 24;
@@ -323,7 +342,7 @@ gboolean
goto error;
len = GST_READ_UINT32_BE (tag_data);
GST_DEBUG (" number of user data mode = %u", len);
- descriptor->n_user_data_mode = len;
+ self->n_user_data_mode = len;
if (len == 0)
return TRUE;
@@ -336,12 +355,11 @@ gboolean
if (tag_size != len)
goto error;
- descriptor->user_data_mode = g_new0 (guint8, len);
+ self->user_data_mode = g_new0 (guint8, len);
for (i = 0; i < len; i++) {
- descriptor->user_data_mode[i] = GST_READ_UINT8 (tag_data);
- GST_DEBUG (" user data mode %u = %u", i,
- descriptor->user_data_mode[i]);
+ self->user_data_mode[i] = GST_READ_UINT8 (tag_data);
+ GST_DEBUG (" user data mode %u = %u", i, self->user_data_mode[i]);
tag_data++;
tag_size--;
}
@@ -357,7 +375,7 @@ gboolean
goto error;
len = GST_READ_UINT32_BE (tag_data);
GST_DEBUG (" number of fixed user data = %u", len);
- descriptor->n_fixed_user_data = len;
+ self->n_fixed_user_data = len;
if (len == 0)
return TRUE;
@@ -370,41 +388,39 @@ gboolean
if (tag_size != len * 24)
goto error;
- descriptor->fixed_user_data =
- g_malloc0 (len * sizeof (guint8 *) + len * 24);
+ self->fixed_user_data = g_malloc0 (len * sizeof (guint8 *) + len * 24);
for (i = 0; i < len; i++) {
- descriptor->fixed_user_data[i] =
- ((guint8 *) descriptor->fixed_user_data) + len * sizeof (guint8 *) +
+ self->fixed_user_data[i] =
+ ((guint8 *) self->fixed_user_data) + len * sizeof (guint8 *) +
i * 24;
- memcpy (descriptor->fixed_user_data[i], tag_data, 24);
+ memcpy (self->fixed_user_data[i], tag_data, 24);
GST_DEBUG
(" fixed user data %u = 0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x.0x%02x",
- i, descriptor->fixed_user_data[i][0],
- descriptor->fixed_user_data[i][1],
- descriptor->fixed_user_data[i][2],
- descriptor->fixed_user_data[i][3],
- descriptor->fixed_user_data[i][4],
- descriptor->fixed_user_data[i][5],
- descriptor->fixed_user_data[i][6],
- descriptor->fixed_user_data[i][7],
- descriptor->fixed_user_data[i][8],
- descriptor->fixed_user_data[i][9],
- descriptor->fixed_user_data[i][10],
- descriptor->fixed_user_data[i][11],
- descriptor->fixed_user_data[i][12],
- descriptor->fixed_user_data[i][13],
- descriptor->fixed_user_data[i][14],
- descriptor->fixed_user_data[i][15],
- descriptor->fixed_user_data[i][16],
- descriptor->fixed_user_data[i][17],
- descriptor->fixed_user_data[i][18],
- descriptor->fixed_user_data[i][19],
- descriptor->fixed_user_data[i][20],
- descriptor->fixed_user_data[i][21],
- descriptor->fixed_user_data[i][22],
- descriptor->fixed_user_data[i][23]
+ i, self->fixed_user_data[i][0],
+ self->fixed_user_data[i][1],
+ self->fixed_user_data[i][2],
+ self->fixed_user_data[i][3],
+ self->fixed_user_data[i][4],
+ self->fixed_user_data[i][5],
+ self->fixed_user_data[i][6],
+ self->fixed_user_data[i][7],
+ self->fixed_user_data[i][8],
+ self->fixed_user_data[i][9],
+ self->fixed_user_data[i][10],
+ self->fixed_user_data[i][11],
+ self->fixed_user_data[i][12],
+ self->fixed_user_data[i][13],
+ self->fixed_user_data[i][14],
+ self->fixed_user_data[i][15],
+ self->fixed_user_data[i][16],
+ self->fixed_user_data[i][17],
+ self->fixed_user_data[i][18],
+ self->fixed_user_data[i][19],
+ self->fixed_user_data[i][20],
+ self->fixed_user_data[i][21],
+ self->fixed_user_data[i][22], self->fixed_user_data[i][23]
);
tag_data += 24;
tag_size -= 24;
@@ -417,39 +433,42 @@ gboolean
* SMPTE 382M Annex 2 */
default:
ret =
- mxf_metadata_wave_audio_essence_descriptor_handle_tag (d, primer,
- tag, tag_data, tag_size);
+ MXF_METADATA_BASE_CLASS
+ (mxf_metadata_aes3_audio_essence_descriptor_parent_class)->
+ handle_tag (metadata, primer, tag, tag_data, tag_size);
break;
}
return ret;
error:
- GST_ERROR ("Invalid AES3 audio essence descriptor tag 0x%04x of size %u", tag,
+
+ GST_ERROR
+ ("Invalid AES3 audio essence descriptor local tag 0x%04x of size %u", tag,
tag_size);
return TRUE;
}
-void mxf_metadata_aes3_audio_essence_descriptor_reset
- (MXFMetadataAES3AudioEssenceDescriptor * descriptor)
+static void
+ mxf_metadata_aes3_audio_essence_descriptor_init
+ (MXFMetadataAES3AudioEssenceDescriptor * self)
{
- g_return_if_fail (descriptor != NULL);
-
- mxf_metadata_wave_audio_essence_descriptor_reset (
- (MXFMetadataWaveAudioEssenceDescriptor *) descriptor);
-
- g_free (descriptor->channel_status_mode);
- g_free (descriptor->fixed_channel_status_data);
- g_free (descriptor->user_data_mode);
- g_free (descriptor->fixed_user_data);
- MXF_METADATA_DESCRIPTOR_CLEAR (descriptor,
- MXFMetadataAES3AudioEssenceDescriptor,
- MXFMetadataWaveAudioEssenceDescriptor);
}
+static void
+ mxf_metadata_aes3_audio_essence_descriptor_class_init
+ (MXFMetadataAES3AudioEssenceDescriptorClass * klass)
+{
+ MXFMetadataBaseClass *metadata_base_class = (MXFMetadataBaseClass *) klass;
+ GstMiniObjectClass *miniobject_class = (GstMiniObjectClass *) klass;
+ miniobject_class->finalize =
+ mxf_metadata_aes3_audio_essence_descriptor_finalize;
+ metadata_base_class->handle_tag =
+ mxf_metadata_aes3_audio_essence_descriptor_handle_tag;
+}
gboolean
mxf_is_aes_bwf_essence_track (const MXFMetadataTrack * track)
@@ -465,7 +484,12 @@ mxf_is_aes_bwf_essence_track (const MXFMetadataTrack * track)
for (i = 0; i < track->n_descriptor; i++) {
MXFMetadataFileDescriptor *d = track->descriptor[i];
- MXFUL *key = &d->essence_container;
+ MXFUL *key;
+
+ if (!d)
+ continue;
+
+ key = &d->essence_container;
/* SMPTE 382M 9 */
if (mxf_is_generic_container_essence_container_label (key) &&
key->u[12] == 0x02 &&
@@ -548,8 +572,7 @@ mxf_bwf_create_caps (MXFMetadataGenericPackage * package,
gchar str[48];
gchar *codec_name = NULL;
- if (((MXFMetadataGenericDescriptor *) descriptor)->type ==
- MXF_METADATA_WAVE_AUDIO_ESSENCE_DESCRIPTOR)
+ if (MXF_IS_METADATA_WAVE_AUDIO_ESSENCE_DESCRIPTOR (descriptor))
wa_descriptor = (MXFMetadataWaveAudioEssenceDescriptor *) descriptor;
/* TODO: Handle width=!depth, needs shifting of samples */
@@ -666,10 +689,7 @@ mxf_aes3_create_caps (MXFMetadataGenericPackage * package,
gchar *codec_name = NULL;
guint block_align;
- if (((MXFMetadataGenericDescriptor *) descriptor)->type ==
- MXF_METADATA_WAVE_AUDIO_ESSENCE_DESCRIPTOR ||
- ((MXFMetadataGenericDescriptor *) descriptor)->type ==
- MXF_METADATA_AES3_AUDIO_ESSENCE_DESCRIPTOR)
+ if (MXF_IS_METADATA_WAVE_AUDIO_ESSENCE_DESCRIPTOR (descriptor))
wa_descriptor = (MXFMetadataWaveAudioEssenceDescriptor *) descriptor;
/* FIXME: set a channel layout */
@@ -731,22 +751,18 @@ mxf_aes_bwf_create_caps (MXFMetadataGenericPackage * package,
}
for (i = 0; i < track->n_descriptor; i++) {
- if ((track->descriptor[i]->parent.type ==
- MXF_METADATA_WAVE_AUDIO_ESSENCE_DESCRIPTOR
- || track->descriptor[i]->parent.type ==
- MXF_METADATA_GENERIC_SOUND_ESSENCE_DESCRIPTOR)
+ if (!track->descriptor[i])
+ continue;
+
+ if (MXF_IS_METADATA_GENERIC_SOUND_ESSENCE_DESCRIPTOR (track->descriptor[i])
&& (track->descriptor[i]->essence_container.u[14] == 0x01
|| track->descriptor[i]->essence_container.u[14] == 0x02
|| track->descriptor[i]->essence_container.u[14] == 0x08)) {
s = (MXFMetadataGenericSoundEssenceDescriptor *) track->descriptor[i];
bwf = TRUE;
break;
- } else if ((track->descriptor[i]->parent.type ==
- MXF_METADATA_AES3_AUDIO_ESSENCE_DESCRIPTOR
- || track->descriptor[i]->parent.type ==
- MXF_METADATA_WAVE_AUDIO_ESSENCE_DESCRIPTOR
- || track->descriptor[i]->parent.type ==
- MXF_METADATA_GENERIC_SOUND_ESSENCE_DESCRIPTOR)
+ } else if (MXF_IS_METADATA_GENERIC_SOUND_ESSENCE_DESCRIPTOR (track->
+ descriptor[i])
&& (track->descriptor[i]->essence_container.u[14] == 0x03
|| track->descriptor[i]->essence_container.u[14] == 0x04
|| track->descriptor[i]->essence_container.u[14] == 0x09)) {
@@ -769,3 +785,12 @@ mxf_aes_bwf_create_caps (MXFMetadataGenericPackage * package,
return NULL;
}
+
+void
+mxf_aes_bwf_init (void)
+{
+ mxf_metadata_register (0x0148,
+ MXF_TYPE_METADATA_WAVE_AUDIO_ESSENCE_DESCRIPTOR);
+ mxf_metadata_register (0x0147,
+ MXF_TYPE_METADATA_AES3_AUDIO_ESSENCE_DESCRIPTOR);
+}