vorbistag: store DATE tag in GST_TAG_DATE_TIME instead of GST_TAG_DATE

The DATE field may contain dates, partial dates, or dates with
time. Store the result in GST_TAG_DATE_TIME, so we can express
properly which fields are present or not, and can store the
time if there is one, and can serialise and deserialise the
tag without loss of information and without making up
information that's not there.

Instead of using short YYYY-MM-DD form we will store
long YYYY-MM-DDTHH:MM:SS+TS date and time.

According to this documentation we can do it:
http://wiki.xiph.org/VorbisComment#Date_and_time

This datetime format is needed by apps where more information
is needed. For example voice, meeting recording, etc.

https://bugzilla.gnome.org/show_bug.cgi?id=677712
This commit is contained in:
Oleksij Rempel 2012-06-27 16:25:06 +02:00 committed by Tim-Philipp Müller
parent 044afd72eb
commit bc94374a8f

View file

@ -64,7 +64,7 @@ static const GstTagEntryMatch tag_matches[] = {
{GST_TAG_ORGANIZATION, "ORGANIZATION"}, {GST_TAG_ORGANIZATION, "ORGANIZATION"},
{GST_TAG_DESCRIPTION, "DESCRIPTION"}, {GST_TAG_DESCRIPTION, "DESCRIPTION"},
{GST_TAG_GENRE, "GENRE"}, {GST_TAG_GENRE, "GENRE"},
{GST_TAG_DATE, "DATE"}, {GST_TAG_DATE_TIME, "DATE"},
{GST_TAG_CONTACT, "CONTACT"}, {GST_TAG_CONTACT, "CONTACT"},
{GST_TAG_ISRC, "ISRC"}, {GST_TAG_ISRC, "ISRC"},
{GST_TAG_COMMENT, "COMMENT"}, {GST_TAG_COMMENT, "COMMENT"},
@ -272,38 +272,17 @@ gst_vorbis_tag_add (GstTagList * list, const gchar * tag, const gchar * value)
break; break;
} }
default:{ default:{
if (tag_type == G_TYPE_DATE) { if (tag_type == GST_TYPE_DATE_TIME) {
guint y, d = 1, m = 1; GstDateTime *datetime;
gchar *check = (gchar *) value;
y = strtoul (check, &check, 10); datetime = gst_date_time_new_from_iso8601_string (value);
if (*check == '-') {
check++;
m = strtoul (check, &check, 10);
if (*check == '-') {
check++;
d = strtoul (check, &check, 10);
}
}
/* accept dates like 2007-00-00 and 2007-05-00 */ if (datetime) {
if (y != 0) { gst_tag_list_add (list, GST_TAG_MERGE_APPEND, gst_tag, datetime,
if (m == 0 && d == 0) NULL);
m = d = 1; gst_date_time_unref (datetime);
else if (m != 0 && d == 0)
d = 1;
}
/* date might be followed by a time */
if ((*check == '\0' || g_ascii_isspace (*check)) && y != 0 &&
g_date_valid_dmy (d, m, y)) {
GDate *date;
date = g_date_new_dmy (d, m, y);
gst_tag_list_add (list, GST_TAG_MERGE_APPEND, gst_tag, date, NULL);
g_date_free (date);
} else { } else {
GST_DEBUG ("skipping invalid date '%s' (%u,%u,%u)", value, y, m, d); GST_WARNING ("could not parse datetime string '%s'", value);
} }
} else { } else {
GST_WARNING ("Unhandled tag of type '%s' (%d)", GST_WARNING ("Unhandled tag of type '%s' (%d)",
@ -728,18 +707,20 @@ gst_tag_to_vorbis_comments (const GstTagList * list, const gchar * tag)
break; break;
} }
default:{ default:{
if (tag_type == G_TYPE_DATE) { if (tag_type == GST_TYPE_DATE_TIME) {
GDate *date; GstDateTime *datetime;
if (!gst_tag_list_get_date_index (list, tag, i, &date)) if (gst_tag_list_get_date_time_index (list, tag, i, &datetime)) {
g_return_val_if_reached (NULL); gchar *string;
/* vorbis suggests using ISO date formats */ /* vorbis suggests using ISO date formats:
result = * http://wiki.xiph.org/VorbisComment#Date_and_time */
g_strdup_printf ("%s=%04d-%02d-%02d", vorbis_tag, string = gst_date_time_to_iso8601_string (datetime);
(gint) g_date_get_year (date), (gint) g_date_get_month (date), result = g_strdup_printf ("%s=%s", vorbis_tag, string);
(gint) g_date_get_day (date)); g_free (string);
g_date_free (date);
gst_date_time_unref (datetime);
}
} else { } else {
GST_DEBUG ("Couldn't write tag %s", tag); GST_DEBUG ("Couldn't write tag %s", tag);
continue; continue;