aboutsummaryrefslogtreecommitdiffstats
path: root/libical/src
diff options
context:
space:
mode:
authorDamon Chaplin <damon@ximian.com>2001-10-28 10:24:22 +0800
committerDamon Chaplin <damon@src.gnome.org>2001-10-28 10:24:22 +0800
commit27c2d8fee607bab0431bc5673d092d30bc9a4a76 (patch)
treedac29da866c75b345497e910cc5f8a097eb07fcf /libical/src
parent97bf6378069d105024d207ffa9f397a86b76bb21 (diff)
downloadgsoc2013-evolution-27c2d8fee607bab0431bc5673d092d30bc9a4a76.tar.gz
gsoc2013-evolution-27c2d8fee607bab0431bc5673d092d30bc9a4a76.tar.zst
gsoc2013-evolution-27c2d8fee607bab0431bc5673d092d30bc9a4a76.zip
added function to get a reasonable name to display for the timezone.
2001-10-27 Damon Chaplin <damon@ximian.com> * src/libical/icaltimezone.c (icaltimezone_get_display_name): added function to get a reasonable name to display for the timezone. (Though it won't be translated.) svn path=/trunk/; revision=14265
Diffstat (limited to 'libical/src')
-rw-r--r--libical/src/libical/icaltimezone.c22
-rw-r--r--libical/src/libical/icaltimezone.h4
2 files changed, 25 insertions, 1 deletions
diff --git a/libical/src/libical/icaltimezone.c b/libical/src/libical/icaltimezone.c
index 9e15fbf993..f7d62a3383 100644
--- a/libical/src/libical/icaltimezone.c
+++ b/libical/src/libical/icaltimezone.c
@@ -87,7 +87,8 @@ struct _icaltimezone {
/* If this is not NULL it points to the builtin icaltimezone that the
above TZID refers to. This icaltimezone should be used instead when
accessing the timezone changes data, so that the expanded timezone
- changes data is shared between calendar components. */
+ changes data is shared between calendar components. (I don't think
+ we actually use this at present.) */
icaltimezone *builtin_timezone;
/* This is the last year for which we have expanded the data to.
@@ -1208,6 +1209,25 @@ icaltimezone_set_component (icaltimezone *zone,
}
+/* Returns the timezone name to display to the user. We prefer to use the
+ Olson city name, but fall back on the TZNAME, or finally the TZID. We don't
+ want to use "" as it may be wrongly interpreted as a floating time.
+ Do not free the returned string. */
+char*
+icaltimezone_get_display_name (icaltimezone *zone)
+{
+ char *display_name;
+
+ display_name = icaltimezone_get_location (zone);
+ if (!display_name)
+ display_name = icaltimezone_get_tznames (zone);
+ if (!display_name)
+ display_name = icaltimezone_get_tzid (zone);
+
+ return display_name;
+}
+
+
icalarray*
icaltimezone_array_new (void)
{
diff --git a/libical/src/libical/icaltimezone.h b/libical/src/libical/icaltimezone.h
index b072f0dd9a..2a692c441b 100644
--- a/libical/src/libical/icaltimezone.h
+++ b/libical/src/libical/icaltimezone.h
@@ -74,6 +74,10 @@ char* icaltimezone_get_location (icaltimezone *zone);
may also return NULL. */
char* icaltimezone_get_tznames (icaltimezone *zone);
+/* Returns a string suitable for displaying to the user. If there is a
+ LOCATION property it returns that, else the TZNAMEs, else the TZID. */
+char* icaltimezone_get_display_name (icaltimezone *zone);
+
/* Returns the latitude of a builtin timezone. */
double icaltimezone_get_latitude (icaltimezone *zone);