bin/156019: Add a menu entry to tzsetup to select UTC
Daniel O'Connor
doconnor at gsoft.com.au
Tue Mar 29 06:50:09 UTC 2011
>Number: 156019
>Category: bin
>Synopsis: Add a menu entry to tzsetup to select UTC
>Confidential: no
>Severity: non-critical
>Priority: low
>Responsible: freebsd-bugs
>State: open
>Quarter:
>Keywords:
>Date-Required:
>Class: change-request
>Submitter-Id: current-users
>Arrival-Date: Tue Mar 29 06:50:08 UTC 2011
>Closed-Date:
>Last-Modified:
>Originator: Radar User
>Release: FreeBSD 9.0-CURRENT amd64
>Organization:
>Environment:
System: FreeBSD maarsy-acq.gsoft.com.au 9.0-CURRENT FreeBSD 9.0-CURRENT #0 r219926M: Sat Mar 26 02:15:22 UTC 2011 root at maarsy-acq.gsoft.com.au:/usr/obj/usr/src/sys/GENERIC amd64
>Description:
This patch allows you to select UTC as a time zone (which removes /etc/localtime)
Reviewed by: Garrett Cooper <gcooper at FreeBSD.org>
>How-To-Repeat:
>Fix:
http://www.gsoft.com.au/~doconnor/tzsetup-utc-menu.diff
# This is a shell archive. Save it in a file, remove anything before
# this line, and then unpack it by entering "sh file". Note, it may
# create directories; files and directories will be owned by you and
# have default permissions.
#
# This archive contains:
#
# tzsetup-utc-menu.diff
#
echo x - tzsetup-utc-menu.diff
sed 's/^X//' >tzsetup-utc-menu.diff << '25aa59230e4eb211a79aefc8fd34a91c'
X--- tzsetup.c.orig 2011-03-23 08:46:40.000000000 +0000
X+++ tzsetup.c 2011-03-29 06:43:48.000000000 +0000
X@@ -66,10 +66,13 @@
X static char *chrootenv = NULL;
X
X static void usage(void);
X+static int confirm_zone(const char *filename);
X static int continent_country_menu(dialogMenuItem *);
X+static int install_zoneinfo_file(const char *zoneinfo_file);
X static int set_zone_multi(dialogMenuItem *);
X static int set_zone_whole_country(dialogMenuItem *);
X static int set_zone_menu(dialogMenuItem *);
X+static int set_zone_utc(void);
X
X struct continent {
X dialogMenuItem *menu;
X@@ -79,7 +82,7 @@
X };
X
X static struct continent africa, america, antarctica, arctic, asia, atlantic;
X-static struct continent australia, europe, indian, pacific;
X+static struct continent australia, europe, indian, pacific, utc;
X
X static struct continent_names {
X const char *name;
X@@ -94,7 +97,8 @@
X { "Australia", &australia },
X { "Europe", &europe },
X { "Indian", &indian },
X- { "Pacific", &pacific }
X+ { "Pacific", &pacific },
X+ { "UTC", &utc }
X };
X
X static struct continent_items {
X@@ -110,7 +114,8 @@
X { "7", "Australia" },
X { "8", "Europe" },
X { "9", "Indian Ocean" },
X- { "0", "Pacific Ocean" }
X+ { "0", "Pacific Ocean" },
X+ { "a", "UTC" }
X };
X
X #define NCONTINENTS \
X@@ -128,6 +133,9 @@
X int menulen;
X int rv;
X
X+ if (!strcmp(continent->title, "UTC"))
X+ return set_zone_utc();
X+
X /* Short cut -- if there's only one country, don't post a menu. */
X if (contp->nitems == 1)
X return (contp->menu[0].fire(&contp->menu[0]));
X@@ -502,6 +510,15 @@
X return (DITEM_LEAVE_MENU);
X }
X
X+int
X+set_zone_utc(void)
X+{
X+ if (!confirm_zone(NULL))
X+ return (DITEM_FAILURE | DITEM_RECREATE);
X+
X+ return (install_zoneinfo_file(NULL));
X+}
X+
X static int
X install_zoneinfo_file(const char *zoneinfo_file)
X {
X@@ -526,7 +543,7 @@
X else
X snprintf(prompt, sizeof(prompt),
X "Creating symbolic link %s to %s",
X- path_localtime, zoneinfo_file);
X+ path_localtime, zoneinfo_file == NULL ? "(UTC)" : zoneinfo_file);
X if (usedialog)
X dialog_notify(prompt);
X else
X@@ -534,6 +551,22 @@
X #endif
X
X if (reallydoit) {
X+ if (zoneinfo_file == NULL) {
X+ if (unlink(path_localtime) < 0 && errno != ENOENT) {
X+ snprintf(title, sizeof(title), "Error");
X+ snprintf(prompt, sizeof(prompt),
X+ "Could not delete %s: %s", path_localtime,
X+ strerror(errno));
X+ if (usedialog)
X+ dialog_mesgbox(title, prompt, 8, 72);
X+ else
X+ fprintf(stderr, "%s\n", prompt);
X+
X+ return (DITEM_FAILURE | DITEM_RECREATE);
X+ }
X+ return (DITEM_LEAVE_MENU);
X+ }
X+
X if (copymode) {
X fd1 = open(zoneinfo_file, O_RDONLY, 0);
X if (fd1 < 0) {
X@@ -656,7 +689,7 @@
X struct tm *tm;
X int rv;
X
X- setenv("TZ", filename, 1);
X+ setenv("TZ", filename == NULL ? "" : filename, 1);
X tzset();
X tm = localtime(&t);
X
25aa59230e4eb211a79aefc8fd34a91c
exit
>Release-Note:
>Audit-Trail:
>Unformatted:
More information about the freebsd-bugs
mailing list