From owner-freebsd-emulation Fri Nov 28 19:15:56 1997 Return-Path: Received: (from root@localhost) by hub.freebsd.org (8.8.7/8.8.7) id TAA28324 for emulation-outgoing; Fri, 28 Nov 1997 19:15:56 -0800 (PST) (envelope-from owner-freebsd-emulation) Received: from word.smith.net.au (ppp4.portal.net.au [202.12.71.104]) by hub.freebsd.org (8.8.7/8.8.7) with ESMTP id TAA28317; Fri, 28 Nov 1997 19:15:29 -0800 (PST) (envelope-from mike@word.smith.net.au) Received: from word (localhost [127.0.0.1]) by word.smith.net.au (8.8.7/8.8.5) with ESMTP id NAA00495; Sat, 29 Nov 1997 13:39:33 +1030 (CST) Message-Id: <199711290309.NAA00495@word.smith.net.au> X-Mailer: exmh version 2.0zeta 7/24/97 To: Bruce Evans cc: emulation@freebsd.org, erich@freebsd.org Subject: Re: localtime under Linux-emu? In-reply-to: Your message of "Fri, 28 Nov 1997 21:45:33 +1100." <199711281045.VAA30008@godzilla.zeta.org.au> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Date: Sat, 29 Nov 1997 13:39:32 +1030 From: Mike Smith Sender: owner-freebsd-emulation@freebsd.org X-Loop: FreeBSD.org Precedence: bulk > >> It is probably actually necessary to link to or copy the whole > >> /usr/share/zoneinfo directory. If you link to it then you can't > >> have a symlink in the directory :-]. > > > >Heh. They actually put 'localtime' *inside* that directory? Bleugh. > > The search order is (omitting /compat/linux): > > /usr/lib/zoneinfo/localtime > /usr/share/zoneinfo/localtime Ok. Linking localtime into usr/lib/zoneinfo will work then. > and then for a zoneinfo data file: > > /usr/lib/zoneinfo/GMT > /usr/share/zoneinfo/GMT Er. That's sufficiently different from our POV that it's not going to work. (ie. we have it in /usr/share/zoneinfo/Etc/GMT) > Putting `localtime' in lib/zoneinfo is OK, especially if you don't > put the shareable zoneinfo files there. At least in glibc-2.0.3, > and in the timezone distribution, searching for `localtime' in the > same directory as the shareable zoneinfo files is caused by forming > the path from TZDIR and TZDEFAULT (unless TZDEFAULT is an absolute > pathname, as it is in FreeBSD). These distributions don't seem to > support multiple paths in TZDIR, but glibc supports overrinding it > using the TZDIR environment variable. I can't parse that. You've just said that the code searches the same places for both localtime and the shared data files, but now you are saying that putting them in the same directory would actually be bad, without explaining why. > >How about a more correct solution: > > > > mkdir /compat/linux/usr/lib/zoneinfo > > ln -s /usr/share/zoneinfo/* /compat/linux/usr/lib/zoneinfo > > ln -sf /etc/localtime /compat/linux/usr/lib/localtime > > This probably fails with glibc. Because it uses a diferent path layout for the shared datafiles? Would for i in find /usr/share/zoneinfo/ -type file; ln -s $i /compat/linux/usr/lib/zoneinfo/ get closer, or do they have their own, variant directory layout? > >I have no idea. I wouldn't know a locale if it walked up and bit me on > >the ass. 8) > > I don't know much about it either, but ktrace shows `date' attempting > to access locale files in the following order: > > /etc/locale/C/libc.cat > /usr/share/locale/C/libc.cat > /usr/share/locale/C > /usr/share/locale/C/libc.cat > /usr/local/share/locale/C/libc.cat > > None of these is found. This is probably just as well, since the format > seems to be less standard than that of timezone files. OK. Sounds like we need to add some more baggage to the linux-lib port. Eric H, are you still with us? mike