[PATCH 2/6] core: changed type of date keys to GDateTime
- From: Guillaume Emont <guijemont igalia com>
- To: grilo-list gnome org
- Cc: Guillaume Emont <guijemont igalia com>
- Subject: [PATCH 2/6] core: changed type of date keys to GDateTime
- Date: Wed, 22 Jun 2011 19:07:52 +0200
Strings could be dangerous because errors in their formatting is likely to be
detected too late.
See also https://mail.gnome.org/archives/grilo-list/2011-June/msg00002.html.
---
src/data/grl-media.c | 26 +++++++++++++-------------
src/data/grl-media.h | 8 ++++----
src/grl-metadata-key.c | 14 +++++++-------
3 files changed, 24 insertions(+), 24 deletions(-)
diff --git a/src/data/grl-media.c b/src/data/grl-media.c
index 0757a06..eea3602 100644
--- a/src/data/grl-media.c
+++ b/src/data/grl-media.c
@@ -679,11 +679,11 @@ grl_media_set_duration (GrlMedia *media, gint duration)
* Set the media's date (TBD)
*/
void
-grl_media_set_date (GrlMedia *media, const gchar *date)
+grl_media_set_date (GrlMedia *media, const GDateTime *date)
{
- grl_data_set_string (GRL_DATA (media),
- GRL_METADATA_KEY_DATE,
- date);
+ grl_data_set_boxed (GRL_DATA (media),
+ GRL_METADATA_KEY_DATE,
+ date);
}
/**
@@ -697,11 +697,11 @@ grl_media_set_date (GrlMedia *media, const gchar *date)
*/
void
grl_media_set_creation_date (GrlMedia *media,
- const gchar * creation_date)
+ const GDateTime *creation_date)
{
- grl_data_set_string (GRL_DATA (media),
- GRL_METADATA_KEY_CREATION_DATE,
- creation_date);
+ grl_data_set_boxed (GRL_DATA (media),
+ GRL_METADATA_KEY_CREATION_DATE,
+ creation_date);
}
/**
@@ -1127,10 +1127,10 @@ grl_media_get_duration (GrlMedia *media)
*
* Since: 0.1.4
*/
-const gchar *
+const GDateTime *
grl_media_get_date (GrlMedia *media)
{
- return grl_data_get_string (GRL_DATA (media), GRL_METADATA_KEY_DATE);
+ return grl_data_get_boxed (GRL_DATA (media), GRL_METADATA_KEY_DATE);
}
/**
@@ -1141,11 +1141,11 @@ grl_media_get_date (GrlMedia *media)
*
* Since: 0.1.12
*/
-const gchar *
+const GDateTime *
grl_media_get_creation_date (GrlMedia *media)
{
- return grl_data_get_string (GRL_DATA (media),
- GRL_METADATA_KEY_CREATION_DATE);
+ return grl_data_get_boxed (GRL_DATA (media),
+ GRL_METADATA_KEY_CREATION_DATE);
}
/**
diff --git a/src/data/grl-media.h b/src/data/grl-media.h
index 242f16a..b23422e 100644
--- a/src/data/grl-media.h
+++ b/src/data/grl-media.h
@@ -119,9 +119,9 @@ void grl_media_set_site (GrlMedia *media, const gchar *site);
void grl_media_set_duration (GrlMedia *media, gint duration);
-void grl_media_set_date (GrlMedia *media, const gchar *date);
+void grl_media_set_date (GrlMedia *media, const GDateTime *date);
-void grl_media_set_creation_date (GrlMedia *media, const gchar *creation_date);
+void grl_media_set_creation_date (GrlMedia *media, const GDateTime *creation_date);
void grl_media_set_mime (GrlMedia *media, const gchar *mime);
@@ -187,9 +187,9 @@ const gchar *grl_media_get_site (GrlMedia *media);
gint grl_media_get_duration (GrlMedia *media);
-const gchar *grl_media_get_date (GrlMedia *media);
+const GDateTime *grl_media_get_date (GrlMedia *media);
-const gchar *grl_media_get_creation_date (GrlMedia *media);
+const GDateTime *grl_media_get_creation_date (GrlMedia *media);
const gchar *grl_media_get_mime (GrlMedia *media);
diff --git a/src/grl-metadata-key.c b/src/grl-metadata-key.c
index 977b77f..5b19ba6 100644
--- a/src/grl-metadata-key.c
+++ b/src/grl-metadata-key.c
@@ -67,10 +67,10 @@ grl_metadata_key_setup_system_keys (GrlPluginRegistry *registry)
NULL);
grl_plugin_registry_register_metadata_key_full (registry,
- g_param_spec_string ("date",
+ g_param_spec_boxed ("date",
"Date",
"Publishing or recording date",
- NULL,
+ G_TYPE_DATE_TIME,
G_PARAM_STATIC_STRINGS | G_PARAM_READWRITE),
GRL_METADATA_KEY_DATE,
NULL);
@@ -360,11 +360,11 @@ grl_metadata_key_setup_system_keys (GrlPluginRegistry *registry)
grl_plugin_registry_register_metadata_key_full (registry,
- g_param_spec_string ("creation-date",
- "Creation date",
- "Creation date",
- NULL,
- G_PARAM_STATIC_STRINGS | G_PARAM_READWRITE),
+ g_param_spec_boxed ("creation-date",
+ "Creation date",
+ "Creation date",
+ G_TYPE_DATE_TIME,
+ G_PARAM_STATIC_STRINGS | G_PARAM_READWRITE),
GRL_METADATA_KEY_CREATION_DATE,
NULL);
--
1.7.4.1
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]