summaryrefslogtreecommitdiffstats
path: root/source/l/glib2/glib2.slackware.localtime.diff
blob: 235632d125c19c2f37de902594325e6dda126c57 (about) (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
From 4ac2d88f3153d8cdaa003601363e71f46820a187 Mon Sep 17 00:00:00 2001
From: Patrick J. Volkerding <volkerdi@slackware.com>
Date: Tue, 20 Nov 2018 13:26:57 -0600
Subject: [PATCH] Also look at /etc/localtime-copied-from

In Slackware, /etc/localtime is a copy of the local timezone file, not a
symlink to it, but the latest glib expects a symlink (because that's been
demanded by systemd and guess-who). So, if we find that /etc/localtime is
not a symlink, consider /etc/localtime-copied-from next. On Slackware
systems this will be a symlink to the local timezone file under
/usr/share/zoneinfo. We still want to consider the possibility that
/etc/localtime *is* a symlink first though, since that's an acceptable
local system modification on Slackware.

--- ./glib/gtimezone.c.orig	2018-09-21 09:23:53.000000000 -0500
+++ ./glib/gtimezone.c	2018-11-20 13:11:31.601643410 -0600
@@ -440,6 +440,20 @@
 
       /* Resolve the actual timezone pointed to by /etc/localtime. */
       resolved_identifier = g_file_read_link (filename, &read_link_err);
+
+      /* If we didn't get the timezone here (probably because
+       * /etc/localtime is not a symlink), then we will try again using
+       * /etc/localtime-copied-from, which on Slackware is a symlink to
+       * the local timezone file. */
+      if (resolved_identifier == NULL)
+        {
+          filename = g_strdup ("/etc/localtime-copied-from");
+          g_clear_error (&read_link_err);
+          resolved_identifier = g_file_read_link (filename, &read_link_err);
+        }
+
+      /* Test that we got the resolved_identifier. If not, fall back on the
+       * last option (/var/db/zoneinfo file, as found on FreeBSD) */
       if (resolved_identifier == NULL)
         {
           gboolean not_a_symlink = g_error_matches (read_link_err,