xref: /freebsd/contrib/tzcode/tz-link.html (revision 7aa1dba6b00ccfb7d66627badc8a7aaa06b02946)
1<!DOCTYPE html>
2<html lang="en">
3<head>
4<title>Time zone and daylight saving time data</title>
5<meta charset="UTF-8">
6<meta name="viewport" content="width=device-width, initial-scale=1">
7<style>
8dd {margin-left: 1.3rem;}
9pre {margin-left: 1.3rem; overflow: auto;}
10ul {padding-left: 1.3rem;}
11</style>
12</head>
13<body>
14<h1>Time zone and daylight saving time data</h1>
15<p>
16<a href="https://en.wikipedia.org/wiki/Time_zone">Time zone</a> and
17<a href="https://en.wikipedia.org/wiki/Daylight_saving_time">daylight-saving</a>
18rules are controlled by individual
19governments. They are sometimes changed with little notice, and their
20histories and planned futures are often recorded only fitfully. Here
21is a summary of attempts to organize and record relevant data in this
22area.
23</p>
24  <nav>
25    <ul>
26      <li>The <code><abbr>tz</abbr></code> database product and process
27	<ul>
28	  <li><a href="#tzdb">The <code><abbr>tz</abbr></code> database</a></li>
29	  <li><a href="#download">Downloading the <code><abbr>tz</abbr></code> database</a></li>
30	  <li><a href="#changes">Changes to the <code><abbr>tz</abbr></code> database</a></li>
31	  <li><a href="#coordinating">Coordinating with governments and distributors</a></li>
32	  <li><a href="#commentary">Commentary on the <code><abbr>tz</abbr></code> database</a></li>
33	</ul>
34      </li>
35      <li>Uses of the <code><abbr>tz</abbr></code> database
36	<ul>
37	  <li><a href="#web">Web sites using recent versions of the <code><abbr>tz</abbr></code> database</a></li>
38	  <li><a href="#protocols">Network protocols for <code><abbr>tz</abbr></code> data</a></li>
39	  <li><a href="#compilers">Other <code><abbr>tz</abbr></code> compilers</a></li>
40	  <li><a href="#TZif">Other <abbr>TZif</abbr> readers</a></li>
41	  <li><a href="#software">Other <code><abbr>tz</abbr></code>-based time zone software</a></li>
42	</ul>
43      </li>
44      <li>Related data
45	<ul>
46	  <li><a href="#other-dbs">Other time zone databases</a></li>
47	  <li><a href="#maps">Maps</a></li>
48	  <li><a href="#boundaries">Time zone boundaries</a></li>
49	</ul>
50      </li>
51      <li>Timekeeping concepts
52	<ul>
53	  <li><a href="#civil">Civil time concepts and history</a></li>
54	  <li><a href="#national">National histories of legal time</a></li>
55	  <li><a href="#costs">Costs and benefits of time shifts</a></li>
56	  <li><a href="#precision">Precision timekeeping</a></li>
57	  <li><a href="#notation">Time notation</a></li>
58	</ul>
59      </li>
60      <li><a href="#see-also">See also</a></li>
61    </ul>
62  </nav>
63
64<section>
65<h2 id="tzdb">The <code><abbr title="time zone">tz</abbr></code> database</h2>
66<p>
67The <a href="https://en.wikipedia.org/wiki/Public_domain">public-domain</a>
68time zone database contains code and data
69that represent the history of local time
70for many representative locations around the globe.
71It is updated periodically to reflect changes made by political bodies
72to time zone boundaries and daylight saving rules.
73This database (known as <code><abbr>tz</abbr></code>,
74<code><abbr>tzdb</abbr></code>, or <code>zoneinfo</code>)
75is used by several implementations,
76including
77<a href="https://www.gnu.org/software/libc/">the
78<abbr title="GNU’s Not Unix">GNU</abbr>
79C Library</a> (used in
80<a href="https://en.wikipedia.org/wiki/Linux"><abbr>GNU</abbr>/Linux</a>),
81<a href="https://www.android.com">Android</a>,
82<a href="https://www.freebsd.org">Free<abbr
83title="Berkeley Software Distribution">BSD</abbr></a>,
84<a href="https://netbsd.org">Net<abbr>BSD</abbr></a>,
85<a href="https://www.openbsd.org">Open<abbr>BSD</abbr></a>,
86<a href="https://www.chromium.org/chromium-os/">ChromiumOS</a>,
87<a href="https://cygwin.com">Cygwin</a>,
88<a href="https://mariadb.org">MariaDB</a>,
89<a href="https://musl.libc.org">musl libc</a>,
90<a href="https://www.mysql.com">MySQL</a>,
91<a href="https://en.wikipedia.org/wiki/WebOS"><abbr
92title="Web Operating System">webOS</abbr></a>,
93<a href="https://en.wikipedia.org/wiki/IBM_AIX"><abbr
94title="Advanced Interactive eXecutive">AIX</abbr></a>,
95<a href="https://www.apple.com/os/ios/"><abbr
96title="iPhone OS">iOS</abbr></a>,
97<a href="https://www.apple.com/os/macos/">macOS</a>,
98<a href="https://www.microsoft.com/en-us/windows">Microsoft Windows</a>,
99<a href="https://vmssoftware.com">Open<abbr
100title="Virtual Memory System">VMS</abbr></a>,
101<a href="https://www.oracle.com/database/">Oracle Database</a>,
102<a href="https://www.oracle.com/solaris/solaris11/">Oracle Solaris</a>,
103and <a href="https://qnx.software/en">QNX</a>.</p>
104<p>
105Each main entry in the database represents a <dfn>timezone</dfn>
106for a set of civil-time clocks that have all agreed since 1970.
107Timezones are typically identified by continent or ocean and then by the
108name of the largest city within the region containing the clocks.
109For example, <code>America/New_York</code>
110represents most of the <abbr title="United States">US</abbr> eastern time zone;
111<code>America/Phoenix</code> represents most of Arizona, which
112uses mountain time without daylight saving time (<abbr>DST</abbr>);
113<code>America/Detroit</code> represents most of Michigan, which uses
114eastern time but with different <abbr>DST</abbr> rules in 1975;
115and other entries represent smaller regions like Starke County,
116Indiana, which switched from central to eastern time in 1991
117and switched back in 2006.
118To use the database on a <a
119href="https://en.wikipedia.org/wiki/POSIX"><abbr
120title="Portable Operating System Interface">POSIX</abbr>.1-2024</a>
121implementation set the <code><abbr>TZ</abbr></code>
122environment variable to the location’s full name,
123e.g., <code><abbr>TZ</abbr>="America/New_York"</code>.</p>
124<p>
125Associated with each timezone is a history of offsets from
126<a href="https://en.wikipedia.org/wiki/Universal_Time">Universal
127Time</a> (<abbr>UT</abbr>), which is <a
128href="https://en.wikipedia.org/wiki/Greenwich_Mean_Time">Greenwich Mean
129Time</a> (<abbr>GMT</abbr>) with days beginning at midnight;
130for timestamps after 1960 this is more precisely <a
131href="https://en.wikipedia.org/wiki/Coordinated_Universal_Time">Coordinated
132Universal Time</a> (<abbr>UTC</abbr>).
133The database also records when daylight saving time was in use,
134along with some time zone abbreviations such as <abbr>EST</abbr>
135for Eastern Standard Time in the <abbr>US</abbr>.</p>
136</section>
137
138<section>
139<h2 id="download">Downloading the <code><abbr>tz</abbr></code> database</h2>
140<p>
141The following <a
142href="https://en.wikipedia.org/wiki/Unix_shell">shell</a> commands download
143the latest release’s two
144<a href="https://en.wikipedia.org/wiki/Tar_(computing)">tarballs</a>
145to a <abbr>GNU</abbr>/Linux or similar host.</p>
146<pre><code>mkdir tzdb
147cd tzdb
148<a href="https://www.gnu.org/software/wget/">wget</a> https://www.iana.org/time-zones/repository/tzcode-latest.tar.gz
149wget https://www.iana.org/time-zones/repository/tzdata-latest.tar.gz
150<a href="https://www.gnu.org/software/gzip/">gzip</a> -dc tzcode-latest.tar.gz | <a href="https://www.gnu.org/software/tar/">tar</a> -xf -
151gzip -dc tzdata-latest.tar.gz | tar -xf -
152</code></pre>
153<p>Alternatively, the following shell commands download the same
154release in a single-tarball format containing extra data
155useful for regression testing:</p>
156<pre><code>wget <a href="https://www.iana.org/time-zones/repository/tzdb-latest.tar.lz">https://www.iana.org/time-zones/repository/tzdb-latest.tar.lz</a>
157<a href="https://www.nongnu.org/lzip/">lzip</a> -dc tzdb-latest.tar.lz | tar -xf -
158</code></pre>
159<p>These commands use convenience links to the latest release
160of the <code><abbr>tz</abbr></code> database hosted by the
161<a href="https://www.iana.org/time-zones">Time Zone Database website</a>
162of the <a href="https://www.iana.org">Internet Assigned Numbers
163Authority (IANA)</a>.
164Older releases are in files named
165<code>tzcode<var>V</var>.tar.gz</code>,
166<code>tzdata<var>V</var>.tar.gz</code>, and
167<code>tzdb-<var>V</var>.tar.lz</code>,
168where <code><var>V</var></code> is the version.
169Since 1996, each version has been a four-digit year followed by
170lower-case letter (<samp>a</samp> through <samp>z</samp>,
171then <samp>za</samp> through <samp>zz</samp>, then <samp>zza</samp>
172through <samp>zzz</samp>, and so on).
173Since version 2022a, each release has been distributed in
174<a href="https://pubs.opengroup.org/onlinepubs/9799919799/utilities/pax.html#tag_20_94_13_06">POSIX
175ustar interchange format</a>, compressed as described above;
176older releases use a nearly compatible format.
177Since version 2016h, each release has contained a text file named
178“<code>version</code>” whose first (and currently only) line is the version.
179<a href="https://ftp.iana.org/tz/releases/">Older archived releases are
180available</a> via
181<a href="https://en.wikipedia.org/wiki/HTTPS"><abbr
182title="Hypertext Transfer Protocol Secure">HTTPS</abbr></a>,
183<a href="https://en.wikipedia.org/wiki/Rsync"><abbr
184title="remote sync">rsync</abbr></a>, and
185<a href="https://en.wikipedia.org/wiki/FTP"><abbr
186title="File Transfer Protocol">FTP</abbr></a>.
187<p>Alternatively, a development repository of code and data can be
188retrieved from <a href="https://github.com">GitHub</a> via the shell
189command:</p>
190<pre><code><a href="https://git-scm.com">git</a> clone <a href="https://github.com/eggert/tz">https://github.com/eggert/tz</a>
191</code></pre>
192<p>
193Since version 2012e, each release has been tagged in development repositories.
194Untagged commits are less well tested and probably contain
195more errors.</p>
196<p>
197After obtaining the code and data files, see the
198<code>README</code> file for what to do next.
199The code lets you compile the <code><abbr>tz</abbr></code> source files into
200machine-readable binary files, one for each location. The binary files
201are in a special format specified by
202<a href="https://www.rfc-editor.org/rfc/rfc9636">The
203Time Zone Information Format (<abbr>TZif</abbr>)</a>
204(Internet <abbr title="Request For Comments">RFC</abbr> 9636).
205The code also lets
206you read a <abbr>TZif</abbr> file and interpret timestamps for that
207location.</p>
208</section>
209
210<section>
211<h2 id="changes">Changes to the <code><abbr>tz</abbr></code> database</h2>
212<p>
213The <code><abbr>tz</abbr></code> code and data
214are by no means authoritative. If you find errors, please
215email changes to <a href="mailto:tz@iana.org"><code>tz@iana.org</code></a>,
216the time zone mailing list.
217The mailing list and its archives are public,
218so please do not send confidential information.
219See
220<a href="https://lists.iana.org/postorius/lists/tz.iana.org/">the mailing
221list’s main page</a> to subscribe or to browse its archive of old messages.
222<a href="https://tzdata-meta.timtimeonline.com">Metadata for mailing list
223discussions</a> and corresponding data changes can be
224generated <a href="https://github.com/timparenti/tzdata-meta">automatically</a>.
225</p>
226<p>
227Changes to the <code><abbr>tz</abbr></code> code and data are often
228propagated to clients via operating system updates, so
229client <code><abbr>tz</abbr></code> data can often be corrected by
230applying these updates. With GNU/Linux and similar systems, if your
231maintenance provider has not yet adopted the
232latest <code><abbr>tz</abbr></code> data, you can often short-circuit
233the process by tailoring the generic instructions in
234the <code><abbr>tz</abbr> README</code> file and installing the latest
235data yourself. System-specific instructions for installing the
236latest <code><abbr>tz</abbr></code> data have also been published
237for <a href="https://www.ibm.com/support/pages/aix-time-zone-olson-tzdata-updates"><abbr>AIX</abbr></a>,
238<a
239href="https://source.android.com/docs/core/permissions/timezone-rules">Android</a>,
240<a
241href="https://unicode-org.github.io/icu/userguide/datetime/timezone/"><abbr
242title="International Components for Unicode">ICU</abbr></a>,
243<a href="https://www.ibm.com/support/pages/java-sdk-time-zone-update-utility"><abbr>IBM</abbr>
244JDK</a>,
245<a href="https://www.joda.org/joda-time/tz_update.html">Joda-Time</a>, <a
246href="https://dev.mysql.com/doc/refman/en/time-zone-support.html">MySQL</a>,
247<a href="https://nodatime.org/userguide/tzdb">Noda Time</a>, and <a
248href="https://www.oracle.com/java/technologies/javase/tzupdater-readme.html">OpenJDK/Oracle JDK</a>.
249</p>
250<p>Since version 2013a,
251sources for the <code><abbr>tz</abbr></code> database have been
252<a href="https://en.wikipedia.org/wiki/UTF-8"><abbr
253title="Unicode Transformation Format 8-bit">UTF-8</abbr></a>
254<a href="https://en.wikipedia.org/wiki/Text_file">text files</a>
255with lines terminated by <a href="https://en.wikipedia.org/wiki/Newline"><abbr
256title="linefeed">LF</abbr></a>,
257which can be modified by common text editors such
258as <a href="https://www.gnu.org/software/emacs/">GNU Emacs</a>,
259<a href="https://gedit-text-editor.org">gedit</a>, and
260<a href="https://www.vim.org">vim</a>.
261Specialized source-file editing can be done via the
262<a href="https://packagecontrol.io/packages/zoneinfo">Sublime
263zoneinfo</a> package for <a
264href="https://www.sublimetext.com">Sublime Text</a> and the <a
265href="https://marketplace.visualstudio.com/items?itemName=gilmoreorless.vscode-zoneinfo">VSCode
266zoneinfo</a> extension for <a href="https://code.visualstudio.com">Visual
267Studio Code</a>.
268</p>
269<p>
270For further information about updates, please see
271<a href="https://www.rfc-editor.org/rfc/rfc6557">Procedures for
272Maintaining the Time Zone Database</a> (Internet <abbr>RFC</abbr> 6557).
273More detail can be
274found in <a href="theory.html">Theory and pragmatics of the
275<code><abbr>tz</abbr></code> code and data</a>.
276<a href="https://a0.github.io/a0-tzmigration/">A0 TimeZone Migration</a>
277displays changes between recent <code><abbr>tzdb</abbr></code> versions.
278</p>
279</section>
280
281<section>
282<h2 id="coordinating">Coordinating with governments and distributors</h2>
283<p>
284As discussed in
285“<a href="https://www.icann.org/en/blogs/details/how-time-zones-are-coordinated-13-03-2023-en">How
286Time Zones Are Coordinated</a>”, the time zone database relies on
287collaboration among governments, the time zone database volunteer
288community, and data distributors downstream.
289<p>
290If your government plans to change its time zone boundaries or
291daylight saving rules, please send email as described in
292“<a href="#changes">Changes to the <code><abbr>tz</abbr></code> database</a>”.
293Do this well in advance,
294as this will lessen confusion and will coordinate updates to many cell phones,
295computers, and other devices around the world.
296In your email, please cite the legislation or regulation that specifies
297the change, so that it can be checked for details such as the exact times
298when clock transitions occur.
299It is OK if a rule change is planned to affect clocks
300far into the future, as a long-planned change can easily be reverted
301or otherwise altered with a year’s notice before the change would have
302affected clocks.</p>
303<p>
304There is no fixed schedule for <code><abbr>tzdb</abbr></code> releases.
305However, typically a release occurs every few months.
306Many downstream timezone data distributors wait for
307a <code><abbr>tzdb</abbr></code> release before they produce an update
308to time zone behavior in consumer devices and software products.
309After a release, various parties must integrate, test,
310and roll out an update before <a
311href="https://en.wikipedia.org/wiki/End_user">end users</a> see changes.
312These updates can be expensive, for both the <a
313href="https://en.wikipedia.org/wiki/Quality_assurance">quality
314assurance</a> process and the overall cost of shipping and installing
315updates to each device’s copy of <code><abbr>tzdb</abbr></code>.
316Updates may be batched with other updates and may take substantial
317time to reach end users after a release.
318Older devices may no longer be supported and thus may never be updated,
319which means they will continue to use out-of-date rules.</p>
320<p>
321For these reasons any rule change should be promulgated at least a
322year before it affects how clocks operate; otherwise, there is a good
323chance that many clocks will be wrong due to delays in propagating updates,
324and that residents will be confused or even actively resist the change.
325The shorter the notice, the more likely clock problems will arise; see “<a
326href="https://codeofmatt.com/on-the-timing-of-time-zone-changes/">On
327the Timing of Time Zone Changes</a>” for examples.
328</p>
329</section>
330
331<section>
332<h2 id="commentary">Commentary on the <code><abbr>tz</abbr></code> database</h2>
333<ul>
334<li>The article
335<a href="https://en.wikipedia.org/wiki/Tz_database">tz database</a> is
336an encyclopedic summary.</li>
337<li><a href="tz-how-to.html">How to Read the
338tz Database Source Files</a> explains the <code><abbr>tz</abbr></code>
339database format.</li>
340<li><a
341href="https://blog.jonudell.net/2009/10/23/a-literary-appreciation-of-the-olsonzoneinfotz-database/">A
342literary appreciation of the Olson/Zoneinfo/tz database</a> comments on the
343database’s style.</li>
344<li><a href="https://doi.org/10.1145/3340301.3341125">What time is it:
345managing time in the internet</a> analyzes the database longitudinally.</li>
346</ul>
347</section>
348
349<section>
350<h2 id="web">Web sites using recent versions of the
351<code><abbr>tz</abbr></code> database</h2>
352<p>
353These are listed roughly in ascending order of complexity and fanciness.
354</p>
355<ul>
356<li><a href="https://time.is">Time.is</a> shows locations’
357time and zones.</li>
358<li><a href="https://www.timejones.com">TimeJones.com</a>,
359<a href="https://timezoneconverterapp.com">Time Zone Converter</a> and
360<a href="https://www.worldclock.com">The World Clock</a>
361are time zone converters.</li>
362<li><a href="https://timezonedb.com/download">TimeZoneDB Database</a>
363publishes <code><abbr>tzdb</abbr></code>-derived data in
364<a href="https://en.wikipedia.org/wiki/Comma-separated_values"><abbr
365title="comma-separated values">CSV</abbr></a> and
366in <a href="https://en.wikipedia.org/wiki/SQL"><abbr
367title="Structured Query Language">SQL</abbr></a> form.</li>
368<li><a
369href="https://twiki.org/cgi-bin/xtra/tzdatepick.html">Date and Time Gateway</a>
370lets you see the <code><abbr>TZ</abbr></code> values directly.</li>
371<li><a
372href="https://www.convertit.com/Go/ConvertIt/World_Time/Current_Time.ASP">Current
373Time in 1000 Places</a> uses descriptions of the values.</li>
374<li><a href="https://www.timeanddate.com/worldclock/">The World Clock –
375Worldwide</a> lets you sort zone names and convert times.</li>
376<li><a href="https://24timezones.com">24TimeZones</a> has a world
377time map and a time converter.</li>
378<li><a href="https://www.zeitverschiebung.net/en/">Time Difference</a>
379calculates the current time difference between locations.</li>
380<li><a href="https://www.wx-now.com">Weather Now</a> and
381<a href="https://www.thetimenow.com">The Time Now</a> list the weather too.</li>
382</ul>
383</section>
384
385<section>
386<h2 id="protocols">Network protocols for <code><abbr>tz</abbr></code> data</h2>
387<ul>
388<li><a href="https://www.rfc-editor.org/rfc/rfc7808">Time Zone
389Data Distribution Service</a> (TZDIST, Internet <abbr>RFC</abbr> 7808)
390is associated with
391<a href="https://www.rfc-editor.org/rfc/rfc7809">CalDAV</a>
392(Internet <abbr>RFC</abbr> 7809), a calendar access protocol for
393transferring time zone data by reference.
394<a href="https://devguide.calconnect.org/Time-Zones/TZDS/">TZDIST
395implementations</a> are available.</li>
396<li>The <a href="https://www.rfc-editor.org/rfc/rfc5545">iCalendar format</a>
397(Internet <abbr>RFC</abbr> 5445)
398covers time zone
399data; see its VTIMEZONE calendar component.
400The iCalendar format requires specialized parsers and generators; a
401variant <a href="https://www.rfc-editor.org/rfc/rfc6321">xCal</a>
402(Internet <abbr>RFC</abbr> 6321) uses
403<a href="https://www.w3.org/XML/"><abbr
404title="Extensible Markup Language">XML</abbr></a> format, and a variant
405<a href="https://www.rfc-editor.org/rfc/rfc7265">jCal</a>
406(Internet <abbr>RFC</abbr> 7265)
407uses <a href="https://www.json.org/json-en.html"><abbr
408title="JavaScript Object Notation">JSON</abbr></a> format.</li>
409</ul>
410</section>
411
412<section>
413<h2 id="compilers">Other <code><abbr>tz</abbr></code> compilers</h2>
414<p>Although some of these do not fully support
415<code><abbr>tz</abbr></code> data, in recent <code><abbr>tzdb</abbr></code>
416distributions you can generally work around compatibility problems by
417running the command <code>make rearguard_tarballs</code> and compiling
418from the resulting tarballs instead.</p>
419<ul>
420<li><a href="https://github.com/libical/vzic">Vzic</a> is a <a
421href="https://en.wikipedia.org/wiki/C_(programming_language)">C</a>
422program that compiles
423<code><abbr>tz</abbr></code> source into iCalendar-compatible VTIMEZONE files.
424Vzic is freely
425available under the <a
426href="https://www.gnu.org/copyleft/gpl.html"><abbr>GNU</abbr>
427General Public License (<abbr
428title="General Public License">GPL</abbr>)</a>.</li>
429<li><a
430href="https://metacpan.org/release/DateTime-TimeZone">DateTime::TimeZone</a>
431contains a script <code>parse_olson</code> that compiles
432<code><abbr>tz</abbr></code> source into <a href="https://www.perl.org">Perl</a>
433modules. It is part of the Perl <a
434href="https://github.com/houseabsolute/DateTime.pm/wiki">DateTime Project</a>,
435which is freely
436available under both the <abbr>GPL</abbr> and the Perl Artistic
437License. DateTime::TimeZone also contains a script
438<code>tests_from_zdump</code> that generates test cases for each clock
439transition in the <code><abbr>tz</abbr></code> database.</li>
440<li>The <a href="https://howardhinnant.github.io/date/tz.html">Time Zone
441Database Parser</a> is a
442<a href="https://en.wikipedia.org/wiki/C++">C++</a> parser and
443runtime library with a <a
444href="https://en.cppreference.com/w/cpp/chrono.html"><code>std::chrono</code> API</a>
445that is a standard part of C++.
446It is freely available under the
447<abbr title="Massachusetts Institute of Technology">MIT</abbr> license.</li>
448<li><a id="ICU" href="https://icu.unicode.org">International Components for
449Unicode (<abbr>ICU</abbr>)</a> contains C/C++ and <a
450href="https://en.wikipedia.org/wiki/Java_(programming_language)">Java</a>
451libraries for internationalization that
452has a compiler from <code><abbr>tz</abbr></code> source
453and from <abbr title="Common Locale Data Repository">CLDR</abbr> data
454(mentioned <a href="#CLDR">below</a>)
455into an <abbr>ICU</abbr>-specific format.
456<abbr>ICU</abbr> is freely available under a
457<abbr>BSD</abbr>-style license.</li>
458<li>The <a href="https://github.com/lau/tzdata">Tzdata</a> package for
459the <a href="https://elixir-lang.org">Elixir</a> language downloads
460and compiles <code><abbr>tz</abbr></code> source and exposes <abbr
461title="Application Program Interface">API</abbr>s for use. It is
462freely available under the <abbr>MIT</abbr> license.</li>
463<li>Java-based compilers and libraries include:
464<ul>
465<li>The <a
466href="https://www.oracle.com/java/technologies/javase/tzupdater-readme.html">TZUpdater
467tool</a> compiles <code><abbr>tz</abbr></code> source into the format used by
468<a href="https://openjdk.org">OpenJDK</a> and
469<a href="https://jdk.java.net">Oracle JDK</a>.
470Although its source code is proprietary, its executable is available under the
471<a href="https://www.oracle.com/a/tech/docs/tzupdater-lic.html">Java SE
472Timezone Updater License Agreement</a>.</li>
473<li>The <a
474href="https://www.oracle.com/technical-resources/articles/java/jf14-date-time.html">Java
475SE 8 Date and Time</a> <abbr>API</abbr> can be supplemented by <a
476href="https://www.threeten.org/threeten-extra/">ThreeTen-Extra</a>,
477which is freely available under a <abbr>BSD</abbr>-style license.</li>
478<li><a href="https://www.joda.org/joda-time/">Joda-Time – Java date
479and time <abbr>API</abbr></a> contains a class
480<code>org.joda.time.tz.ZoneInfoCompiler</code> that compiles
481<code><abbr>tz</abbr></code> source into a binary format. It inspired
482Java 8 <code>java.time</code>, which its users should migrate to once
483they can assume Java 8 or later. It is available under the <a
484href="https://www.apache.org/licenses/LICENSE-2.0">Apache License</a>.</li>
485<li><a href="https://bell-sw.com/pages/iana-updater/">IANA Updater</a> and <a
486href="https://www.azul.com/products/components/ziupdater-time-zone-tool/">ZIUpdater</a>
487are alternatives to TZUpdater. IANA Updater’s license is unclear;
488ZIUpdater is licensed under the <abbr>GPL</abbr>.</li>
489<li><a href="https://github.com/MenoData/Time4A">Time4A: Advanced date and
490time library for Android</a> and
491<a href="https://github.com/MenoData/Time4J">Time4J: Advanced date,
492time and interval library for Java</a> compile
493<code><abbr>tz</abbr></code> source into a binary format.
494Time4A is available under the Apache License and Time4J is
495available under the <a
496href="https://www.gnu.org/copyleft/lesser.html"><abbr>GNU</abbr> Lesser
497General Public License (<abbr title="Lesser General Public
498License">LGPL</abbr>)</a>.</li>
499<li><abbr>ICU</abbr> (mentioned <a href="#ICU">above</a>) contains compilers and
500Java-based libraries.</li>
501</ul>
502<li><a href="https://nodatime.org">Noda Time – Date and
503time <abbr>API</abbr> for .NET</a>
504is like Joda-Time and Time4J, but for the .NET framework instead of Java.
505It is freely available under the Apache License.</li>
506<li>Many modern
507<a href="https://en.wikipedia.org/wiki/JavaScript">JavaScript</a>
508runtimes support <code><abbr>tz</abbr></code> natively via the
509<code>timeZone</code> option of <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/DateTimeFormat"><code>Intl.DateTimeFormat</code></a>.
510This can be used as-is or with most of the following libraries,
511many of which also support runtimes lacking the <code>timeZone</code> option.
512<ul>
513<li>The <a
514href="https://github.com/formatjs/date-time-format-timezone"><code>Intl.DateTimeFormat</code>
515timezone polyfill</a>
516is freely available under a <abbr>BSD</abbr>-style license.</li>
517<li>The <a href="https://date-fns.org">date-fns</a>
518library manipulates timezone-aware timestamps in browsers and
519in <a href="https://nodejs.org/en/">Node.js</a>.
520It is freely available under the <abbr>MIT</abbr> license.</li>
521<li><a href="https://github.com/iamkun/dayjs">Day.js</a> is a
522minimalist replacement for the date and time API of
523the <a href="https://momentjs.com/docs/">now-legacy Moment.js</a> date
524manipulation library.
525It is freely available under the <abbr>MIT</abbr> license.</li>
526<li><a href="https://moment.github.io/luxon/">Luxon</a> improves
527timezone support for the <code>Intl</code> API.
528It is freely available under the <abbr>MIT</abbr> license.</li>
529<li><a href="https://momentjs.com/timezone/">Moment Timezone</a> is a
530Moment.js plugin.
531It is freely available under the <abbr>MIT</abbr> license.</li>
532<li><a href="https://github.com/bigeasy/timezone">Timezone</a> is a
533JavaScript library that supports date arithmetic that is time zone
534aware. It is freely available under the <abbr>MIT</abbr> license.</li>
535<li><a href="https://www.npmjs.com/package/@tubular/time">@tubular/time</a>
536supports live <code><abbr>tzdb</abbr></code> updates,
537astronomical and atomic time, a command-line interface,
538and full <a
539href="https://en.wikipedia.org/wiki/TypeScript">TypeScript</a>.
540Its companion <a
541href="https://www.npmjs.com/package/@tubular/time-tzdb">@tubular/time-tzdb</a>
542can generate <abbr>TZif</abbr> and other files, and a companion website
543<a href="https://tzexplorer.org">Timezone Database Explorer</a> lets you
544convert timestamps, view transition histories, and download code and data.
545It is freely available under the <abbr>MIT</abbr> license.</li>
546</ul>
547The proposed <a
548href="https://github.com/tc39/proposal-temporal"><code>Temporal</code>
549objects</a> let programs access an abstract view of
550<code><abbr>tzdb</abbr></code> data, and are designed to replace <a
551href="https://codeofmatt.com/javascript-date-type-is-horribly-broken/">JavaScript’s
552problematic <code>Date</code> objects</a> when working with dates and times.
553<li><a href="https://github.com/JuliaTime">JuliaTime</a> contains a
554compiler from <code><abbr>tz</abbr></code> source into
555<a href="https://julialang.org">Julia</a>. It is freely available
556under the <abbr>MIT</abbr> license.</li>
557<li><a href="https://github.com/pavkam/tzdb"><abbr>TZDB</abbr> –
558<abbr>IANA</abbr> Time Zone Database for Delphi/<abbr
559title="Free Pascal Compiler">FPC</abbr></a>
560compiles from <code><abbr>tz</abbr></code> source into
561<a href="https://en.wikipedia.org/wiki/Object_Pascal">Object Pascal</a>
562as compiled by <a href="https://en.wikipedia.org/wiki/Delphi_(IDE)">Delphi</a>
563and <a
564href="https://en.wikipedia.org/wiki/Free_Pascal"><abbr>FPC</abbr></a>.
565It is freely available under a <abbr>BSD</abbr>-style license.</li>
566<li><a href="https://pythonhosted.org/pytz/">pytz – World Timezone
567Definitions for Python</a> compiles <code><abbr>tz</abbr></code> source into
568<a href="https://www.python.org">Python</a>.
569It is freely available under a <abbr>BSD</abbr>-style license.
570In code that can assume Python 3.6 or later it is largely superseded; see <a
571href="https://blog.ganssle.io/articles/2018/03/pytz-fastest-footgun.html">pytz:
572The Fastest Footgun in the West</a>.</li>
573<li><a href="https://tzinfo.github.io">TZInfo –
574Ruby Timezone Library</a>
575compiles <code><abbr>tz</abbr></code> source into
576<a href="https://www.ruby-lang.org/en/">Ruby</a>.
577It is freely available under the <abbr>MIT</abbr> license.</li>
578<li>The <a href="https://www.squeaksource.com/Chronos/">Chronos Date/Time
579Library</a> is
580a <a href="https://en.wikipedia.org/wiki/Smalltalk">Smalltalk</a> class
581library that compiles <code><abbr>tz</abbr></code> source into a time
582zone repository whose format
583is either proprietary or an <abbr>XML</abbr>-encoded
584representation.</li>
585<li><a id="Tcl" href="https://www.tcl-lang.org">Tcl</a>
586contains a developer-oriented parser that compiles <code><abbr>tz</abbr></code>
587source into text files, along with a runtime that can read those
588files. Tcl is freely available under a <abbr>BSD</abbr>-style
589license.</li>
590</ul>
591</section>
592
593<section>
594<h2 id="TZif">Other <abbr>TZif</abbr> readers</h2>
595<ul>
596<li>The <a
597href="https://www.gnu.org/software/libc/"><abbr>GNU</abbr> C
598Library</a>
599has an independent, thread-safe implementation of
600a <abbr>TZif</abbr> file reader.
601This library is freely available under the LGPL
602and is widely used in <abbr>GNU</abbr>/Linux systems.</li>
603<li><a href="https://www.gnome.org">GNOME</a>’s
604<a href="https://docs.gtk.org/glib/">GLib</a> has
605a <abbr>TZif</abbr> file reader written in C that
606creates a <code>GTimeZone</code> object representing sets
607of <abbr>UT</abbr> offsets.
608It is freely available under the <abbr>LGPL</abbr>.</li>
609<li>The
610<a href="https://github.com/bloomberg/bde/wiki">BDE Standard Library</a>’s
611<code>baltzo::TimeZoneUtil</code> component contains a C++
612implementation of a <abbr>TZif</abbr> file reader. It is freely available under
613the Apache License.</li>
614<li><a href="https://github.com/google/cctz">CCTZ</a> is a simple C++
615library that translates between <abbr>UT</abbr> and civil time and
616can read <abbr>TZif</abbr> files. It is freely available under the Apache
617License.</li>
618<li>The <a href="https://go.dev">Go programming language</a>
619has a <abbr>TZif</abbr> file reader <a
620href="https://pkg.go.dev/time#LoadLocationFromTZData"><code>LoadLocationFromTZData</code></a>.</li>
621<li>The
622<a href="https://github.com/nayarsystems/posix_tz_db"><code>posix_tz_db</code>
623package</a> contains Python code
624to generate <abbr>CSV</abbr> and <abbr>JSON</abbr> tables that map
625<code><abbr>tz</abbr></code> settings to proleptic TZ approximations.
626For example, it maps <code>"Africa/Cairo"</code>
627to <code>"EET-2EEST,M4.5.5/0,M10.5.4/24"</code>,
628an approximation valid for Cairo timestamps from 2023 on.
629This can help porting to platforms that support only proleptic TZ.
630The package is freely available under the MIT license.</li>
631<li><a href="https://github.com/derickr/timelib">Timelib</a> is a C
632library that reads <abbr>TZif</abbr> files and converts
633timestamps from one time zone or format to another.
634It is used by <a href="https://www.php.net"><abbr
635title="PHP: Hypertext Preprocessor">PHP</abbr></a>,
636<a href="https://hhvm.com"><abbr title="HipHop Virtual Machine">HHVM</abbr></a>,
637and <a href="https://www.mongodb.com">MongoDB</a>.
638It is freely available under the <abbr>MIT</abbr> license.</li>
639<li>Tcl, mentioned <a href="#Tcl">above</a>, also contains a
640<abbr>TZif</abbr> file reader.</li>
641<li><a href="https://metacpan.org/pod/DateTime::TimeZone::Tzfile">
642DateTime::TimeZone::Tzfile</a>
643is a <abbr>TZif</abbr> file reader written in Perl.
644It is freely available under the same terms as Perl
645(dual <abbr>GPL</abbr> and Artistic license).</li>
646<li>Python has a <a id="python-zoneinfo"
647href="https://docs.python.org/3/library/zoneinfo.html"><code>zoneinfo.ZoneInfo</code>
648class</a> that reads <abbr>TZif</abbr> data and creates objects
649that represent <code><abbr>tzdb</abbr></code> timezones.
650Python is freely available under the
651<a href="https://docs.python.org/3/license.html">Python Software Foundation
652License</a>.
653A companion <a id="pypi-tzdata" href="https://pypi.org">PyPI</a> module
654<a href="https://pypi.org/project/tzdata/"><code>tzdata</code></a>
655supplies TZif data if the underlying system data cannot be found;
656it is freely available under the Apache License.</li>
657<li>The
658public-domain <a href="https://github.com/dbaron/tz.js">tz.js</a>
659library contains a Python tool that
660converts <abbr>TZif</abbr> data into
661<abbr>JSON</abbr>-format data suitable for use
662in its JavaScript library for time zone conversion. Dates before 1970
663are not supported.</li>
664<li>The <a
665href="https://hackage.haskell.org/package/timezone-olson">timezone-olson</a>
666package contains <a href="https://www.haskell.org">Haskell</a> code that
667parses and uses <abbr>TZif</abbr> data. It is freely
668available under a <abbr>BSD</abbr>-style license.</li>
669</ul>
670</section>
671
672<section>
673<h2 id="software">Other <code><abbr>tz</abbr></code>-based time zone software</h2>
674<ul>
675<li><a href="https://foxclocks.org">FoxClocks</a>
676is an extension for <a href="https://www.google.com/chrome/">Google
677Chrome</a>, <a
678href="https://www.firefox.com/en-US/">Firefox</a> and <a
679href="https://www.thunderbird.net/en-US/">Thunderbird</a>.
680It displays multiple clocks in the application window, and has a mapping
681interface to <a href="https://earth.google.com/web/">Google Earth</a>.
682It is freely available under the <abbr>GPL</abbr>.</li>
683<li>Microsoft Windows 8.1
684and later has <code><abbr>tz</abbr></code> data and <abbr>CLDR</abbr>
685data (mentioned <a href="#CLDR">below</a>) used by the
686<a href="https://en.wikipedia.org/wiki/Windows_Runtime">Windows Runtime</a> /
687<a href="https://en.wikipedia.org/wiki/Universal_Windows_Platform">Universal Windows Platform</a> classes
688<a href="https://learn.microsoft.com/en-us/uwp/api/Windows.Globalization.DateTimeFormatting.DateTimeFormatter"><code>DateTimeFormatter</code></a> and
689<a href="https://learn.microsoft.com/en-us/uwp/api/windows.globalization.calendar"><code>Calendar</code></a>.
690<a id="System.TimeZoneInfo"
691href="https://learn.microsoft.com/en-us/archive/blogs/bclteam/exploring-windows-time-zones-with-system-timezoneinfo-josh-free">Exploring
692Windows Time Zones with <code>System.TimeZoneInfo</code></a> describes
693the older, proprietary method of Microsoft Windows 2000 and later,
694which stores time zone data in the
695<a href="https://en.wikipedia.org/wiki/Windows_Registry">Windows Registry</a>. The
696<a
697href="https://unicode.org/cldr/charts/latest/supplemental/zone_tzid.html">Zone
698→ Tzid table</a> or <a
699href="https://github.com/unicode-org/cldr/blob/main/common/supplemental/windowsZones.xml"><abbr>XML</abbr>
700file</a> of the <abbr>CLDR</abbr> data maps proprietary zone IDs
701to <code><abbr>tz</abbr></code> names.
702These mappings can be performed programmatically via the
703<a href="https://github.com/mattjohnsonpint/TimeZoneConverter">TimeZoneConverter</a>
704.NET library,
705or the ICU Java and C++ libraries mentioned <a href="#ICU">above</a>.
706<li><a
707href="https://www.oracle.com/java/">Oracle
708Java</a> contains a copy of a subset of a recent
709<code><abbr>tz</abbr></code> database in a
710Java-specific format.</li>
711</ul>
712</section>
713
714<section>
715<h2 id="other-dbs">Other time zone databases</h2>
716<ul>
717<li><a href="https://www.astro.com/atlas">Time-zone Atlas</a>
718is Astrodienst’s Web version of Shanks and Pottenger’s out-of-print
719time zone history atlases
720<a href="https://search.worldcat.org/title/468828649">for the US</a> and
721<a href="https://search.worldcat.org/title/76950459">for the world</a>.
722Although these extensive atlases
723<a href="https://astrologynewsservice.com/opinion/how-astrologers-contributed-to-the-information-age-a-brief-history-of-time/">were
724sources for much of the older <code><abbr>tz</abbr></code> data</a>,
725they are unreliable as Shanks appears to have
726guessed many <abbr>UT</abbr> offsets and transitions. The atlases cite no
727sources and do not indicate which entries are guesswork.</li>
728<li><a href="https://en.wikipedia.org/wiki/HP-UX">HP-UX</a> has a database in
729its own <code>tztab</code>(4) format.</li>
730<li>Microsoft Windows has proprietary data mentioned
731<a href="#System.TimeZoneInfo">above</a>.</li>
732<li><a href="https://www.worldtimeserver.com">World Time Server</a>
733is another time zone database.</li>
734<li>The <a
735href="https://www.iata.org/en/publications/manuals/standard-schedules-information">Standard
736Schedules Information Manual</a> of the
737International Air Transport Association
738gives current time zone rules for airports served by commercial aviation.</li>
739</ul>
740</section>
741
742<section>
743<h2 id="maps">Maps</h2>
744<ul>
745<li><a href="https://www.worldtimezone.com">World Time Zone Map
746with current time</a>
747has several fancy time zone maps; it covers Russia particularly well.</li>
748<li><a
749href="https://blog.poormansmath.net/how-much-is-time-wrong-around-the-world/">How
750much is time wrong around the world?</a> maps the difference between
751mean solar and standard time, highlighting areas such as western China
752where the two differ greatly. It’s a bit out of date, unfortunately.</li>
753<li>The
754<a
755href="https://maps.lib.utexas.edu/maps/world.html">Perry–Castañeda
756Library Map Collection</a> of the University of Texas at Austin has
757copies of old maps taken from <a
758href="https://en.wikipedia.org/wiki/The_World_Factbook"><em>The
759World Factbook</em></a>, formerly published by the
760<a href="https://www.cia.gov">US Central Intelligence Agency</a>.
761Although the maps’ pictorial quality is good,
762the maps do not indicate daylight saving time.</li>
763</ul>
764</section>
765
766<section>
767<h2 id="boundaries">Time zone boundaries</h2>
768<p>Geographical boundaries between timezones are available
769from several <a
770href="https://en.wikipedia.org/wiki/Internet_geolocation">Internet
771geolocation</a>
772services and other sources.</p>
773<ul>
774<li><a href="https://github.com/evansiroky/timezone-boundary-builder">Timezone
775Boundary Builder</a> extracts
776<a href="https://www.openstreetmap.org">Open Street Map</a> data to build
777boundaries of <code><abbr>tzdb</abbr></code> timezones.
778Its code is freely available under the <abbr>MIT</abbr> license, and
779its data entries are freely available under the
780<a href="https://opendatacommons.org/licenses/odbl/">Open Data Commons
781Open Database License</a>. The borders appear to be quite accurate.
782Its main web page lists more than twenty libraries
783for looking up a timezone name from a GPS coordinate.</li>
784<li>Free access via a network API, if you register a key, is provided by
785the <a
786href="https://www.geonames.org/export/web-services.html#timezone">GeoNames
787Timezone web service</a>, the <a
788href="https://developers.google.com/maps/documentation/timezone/overview">Google
789Maps Time Zone API</a>, and
790the <a href="https://timezonedb.com/api">TimeZoneDB API</a>.
791Commercial network API access is provided
792by <a href="https://askgeo.com">AskGeo</a>
793and <a href="https://www.geogarage.com/blog/news-1/post/geogarage-time-zone-api-31">GeoGarage</a>.
794</li>
795<li>“<a
796href="https://stackoverflow.com/questions/16086962/how-to-get-a-time-zone-from-a-location-using-latitude-and-longitude-coordinates/16086964">How
797to get a time zone from a location using latitude and longitude
798coordinates?</a>” discusses other geolocation possibilities.</li>
799<li><a href="https://statoids.com/statoids.html">Administrative
800Divisions of Countries (“Statoids”)</a> lists
801political subdivision data related to time zones.</li>
802<li><a href="https://manifold.net/info/freestuff.shtml">Manifold Software
803– GIS and Database Tools</a> includes a Manifold-format map of
804world time zone boundaries circa 2007, distributed under the
805<abbr>GPL</abbr>.</li>
806<li>A ship within the <a
807href="https://en.wikipedia.org/wiki/Territorial_waters">territorial
808waters</a> of any nation uses that nation’s time. In international
809waters, time zone boundaries are meridians 15° apart, except that
810<abbr>UT</abbr>−12 and <abbr>UT</abbr>+12 are each 7.5°
811wide and are separated by
812the 180° meridian (not by the International Date Line, which is
813for land and territorial waters only). A captain can change ship’s
814clocks any time after entering a new time zone; midnight changes are
815common.</li>
816</ul>
817</section>
818
819<section>
820<h2 id="civil">Civil time concepts and history</h2>
821<ul>
822<li><a href="https://www.nist.gov/pml/time-and-frequency-division/popular-links/walk-through-time">A
823Walk through Time</a>
824surveys the evolution of timekeeping.</li>
825<li>The history of daylight saving time is surveyed in <a
826href="https://www.webexhibits.org/daylightsaving/">About Daylight
827Saving Time – History, rationale, laws &amp; dates</a> and summarized in
828<a href="http://seizethedaylight.com/dst/">A Brief
829History of Daylight Saving Time</a>.</li>
830<li><a href="https://www.laphamsquarterly.org/roundtable/time-lords">Time
831Lords</a> discusses how authoritarians manipulate civil time.</li>
832<li><a href="https://www.w3.org/TR/timezone/">Working with Time
833and Time Zones</a>
834contains guidelines and best practices for software applications that
835deal with civil time.</li>
836<li><a href="https://webspace.science.uu.nl/~gent0113/idl/idl.htm">A History of
837the International Date Line</a> tells the story of the most important
838time zone boundary.</li>
839<li><a href="https://statoids.com/tconcept.html">Basic Time
840Zone Concepts</a> discusses terminological issues behind time zones.</li>
841</ul>
842</section>
843
844<section>
845<h2 id="national">National histories of legal time</h2>
846<dl>
847<dt>Australia</dt>
848<dd>The Bureau of Meteorology publishes a list of <a
849href="http://www.bom.gov.au/climate/averages/tables/dst_times.shtml">Implementation
850Dates of Daylight Savings Time within Australia</a>.</dd>
851<dt>Belgium</dt>
852<dd>The Royal Observatory of Belgium maintains a table of time in
853Belgium (in
854<a href="https://robinfo.oma.be/nl/astro-info/tijd/"
855hreflang="nl">Dutch</a> and <a
856href="https://robinfo.oma.be/fr/astro-info/heure/"
857hreflang="fr">French</a>).</dd>
858<dt>Brazil</dt>
859<dd>The Time Service Department of the National Observatory
860records <a href="http://pcdsh01.on.br/DecHV.html"
861hreflang="pt-BR">Brazil’s daylight saving time decrees (in
862Portuguese)</a>.</dd>
863<dt>Canada</dt>
864<dd>National Research Council Canada publishes current
865and some older information about <a
866href="https://nrc.canada.ca/en/certifications-evaluations-standards/canadas-official-time/time-zones-daylight-saving-time">time
867zones and daylight saving time</a>.</dd>
868<dt>Chile</dt>
869<dd>The Hydrographic and Oceanographic Service of the Chilean Navy publishes a
870<a href="https://www.horaoficial.cl/historia_hora.php" hreflang="es">history of
871Chile’s official time (in Spanish)</a>.</dd>
872<dt>China</dt>
873<dd>The Hong Kong Observatory maintains a
874<a href="https://www.hko.gov.hk/en/gts/time/Summertime.htm">history of
875 summer time in Hong Kong</a>,
876and Macau’s Meteorological and Geophysical Bureau maintains a <a
877href="https://www.smg.gov.mo/en/subpage/224/page/174">similar
878history for Macau</a>.
879Unfortunately the latter is incomplete and has errors.</dd>
880<dt>Czech Republic</dt>
881<dd><a href="https://kalendar.beda.cz/kdy-zacina-a-konci-letni-cas"
882hreflang="cs">When daylight saving time starts and ends (in Czech)</a>
883summarizes and cites historical <abbr>DST</abbr> regulations.</dd>
884<dt>Germany</dt>
885<dd>The National Institute for Science and Technology maintains the <a
886href="https://www.ptb.de/cms/en/ptb/fachabteilungen/abt4/fb-44/ag-441/realisation-of-legal-time-in-germany.html">Realisation
887of Legal Time in Germany</a>.</dd>
888<dt>Israel</dt>
889<dd><a
890href="https://tz.cs.huji.ac.il">Israel Timezone Files</a>
891lists official time-change announcements and laws since 1940,
892almost all in Hebrew.</dd>
893<dt>Malaysia</dt>
894<dd>See Singapore <a href="#Singapore">below</a>.</dd>
895<dt>Mexico</dt>
896<dd>The Investigation and Analysis Service of the Mexican Library of
897Congress has published a <a
898href="https://www.diputados.gob.mx/bibliot/publica/inveyana/polisoc/horver/index.htm"
899hreflang="es">history of Mexican local time (in Spanish)</a>.</dd>
900<dt>Netherlands</dt>
901<dd><a href="https://webspace.science.uu.nl/~gent0113/wettijd/wettijd.htm"
902hreflang="nl">Legal time in the Netherlands (in Dutch)</a>
903covers the history of local time in the Netherlands from ancient times.</dd>
904<dt>New Zealand</dt>
905<dd>The Department of Internal Affairs maintains a brief <a
906href="https://www.govt.nz/browse/recreation-and-the-environment/daylight-saving/history-of-daylight-saving-in-nz/">History
907of Daylight Saving in NZ</a>.</dd>
908<dt>Palestine</dt>
909<dd>The Ministry of Telecom and Digital Economy publishes a <a
910href="https://mtde.gov.ps/home/TimeZone"
911hreflang="ar">history of clock changes (in Arabic)</a>.</dd>
912<dt>Portugal</dt>
913<dd>The Lisbon Astronomical Observatory publishes a
914<a href="https://oal.ul.pt/hora-legal/" hreflang="pt">history of
915legal time (in Portuguese)</a>.</dd>
916<dt>Singapore</dt>
917<dd><a id="Singapore"
918href="https://web.archive.org/web/20190822231045/http://www.math.nus.edu.sg/~mathelmr/teaching/timezone.html">Why
919is Singapore in the “Wrong” Time Zone?</a> details the
920history of legal time in Singapore and Malaysia.</dd>
921<dt>United Kingdom</dt>
922<dd><a
923href="https://www.polyomino.org.uk/british-time/">History of
924legal time in Britain</a> discusses in detail the country
925with perhaps the best-documented history of clock adjustments.</dd>
926<dt>United States</dt>
927<dd>The Department of Transportation’s <a
928href="https://www.transportation.gov/regulations/recent-time-zone-proceedings">Recent
929Time Zone Proceedings</a> lists changes to
930official written time zone boundaries, and its <a
931href="https://geodata.bts.gov/datasets/usdot::time-zones/about">Time
932Zones dataset</a> maps current boundaries.
933These boundaries are only for standard time, so the current map puts
934all of Arizona in one time zone even though part of Arizona
935observes <abbr>DST</abbr> and part does not.</dd>
936<dt>Uruguay</dt>
937<dd>The Oceanography, Hydrography, and Meteorology Service of the Uruguayan
938Navy (SOHMA) publishes an annual <a
939href="https://sohma.armada.mil.uy/index.php/servicios/datos-astronomicos" hreflang="es">almanac
940(in Spanish)</a>.</dd>
941</dl>
942</section>
943
944<section>
945<h2 id="costs">Costs and benefits of time shifts</h2>
946<p>Various sources argue for and against daylight saving time and time
947zone shifts, and many scientific studies have been conducted. This
948section summarizes reviews and position statements based on
949scientific literature in the area.</p>
950<ul>
951<li>Carey RN, Sarma KM.
952<a href="https://bmjopen.bmj.com/content/7/6/e014319.long">Impact of
953daylight saving time on road traffic collision risk: a systematic
954review</a>.
955<em>BMJ Open.</em> 2017;7(6):e014319. doi:<a href="https://doi.org/10.1136/bmjopen-2016-014319">10.1136/bmjopen-2016-014319</a>.
956This reviews research literature and concludes that the evidence
957neither supports nor refutes road safety benefits from
958shifts in time zones.</li>
959<li>Havranek T, Herman D, Irsova D.
960Does daylight saving save electricity? A meta-analysis.
961<em>Energy J.</em> 2018;39(2):35–61.
962doi:<a href="https://doi.org/10.5547/01956574.39.2.thav">10.5547/01956574.39.2.thav</a>.
963This analyzes research literature and concludes, “Electricity savings
964are larger for countries farther away from the equator, while
965subtropical regions consume more electricity because of <abbr>DST</abbr>.”</li>
966<li>Neumann P, von Blanckenburg K. <a
967href="https://journals.sagepub.com/doi/full/10.1177/0961463X241310562">What
968time will it be? A comprehensive literature review on daylight saving time</a>.
969<em>Time Soc</em>. 2025;34(4):684–745.
970doi:<a href="https://doi.org/10.1177/0961463X241310562">10.1177/0961463X241310562</a>.
971This reviews <abbr>DST</abbr>’s effects on electricity, health, crime, road
972safety, and the economy, focusing on research since 2010, and concludes that
973year-round standard time is preferable overall.</li>
974<li>Romigi A, Franco V, Scoditti E <em>et al</em>.
975The effects of daylight saving time and clock time transitions on sleep and
976sleepiness: a systematic review. <em>Sleep Med Rev.</em> 2025;84:102161. doi:<a
977href="https://doi.org/10.1016/j.smrv.2025.102161">10.1016/j.smrv.2025.102161</a>.
978This reviews <abbr>DST</abbr> and <abbr>DST</abbr> transitions,
979and concludes that they both harm sleep, health and behavior.</li>
980</ul>
981
982<p>The following medical societies have taken positions on the
983advisability of clock shifts:</p>
984
985<ul>
986<li>In 2022 the American Medical Association issued a
987<a href="https://www.ama-assn.org/press-center/ama-press-releases/ama-calls-permanent-standard-time">statement
988supporting permanent standard time</a> on health grounds.</li>
989<li>Crawford MR, Winnebeck EC, von Schantz M <em>et al</em>.
990<a href="https://onlinelibrary.wiley.com/doi/10.1111/jsr.14352">The
991British Sleep Society position statement on Daylight Saving Time in the UK</a>.
992<em>J Sleep Res.</em> 2025;34(3):e14352.
993doi:<a href="https://doi.org/10.1111/jsr.14352">10.1111/jsr.14352</a>.
994This recommends that the UK abolish <abbr>DST</abbr> for health reasons.</li>
995<li>Malow BA. <a
996href="https://academic.oup.com/sleep/article/45/12/zsac236/6717940">It is time
997to abolish the clock change and adopt permanent
998standard time in the United States:
999a Sleep Research Society position statement</a>.
1000<em>Sleep.</em> 2022;45(12):zsac236.
1001doi:<a href="https://doi.org/10.1093/sleep/zsac236">10.1093/sleep/zsac236</a>.
1002The Sleep Research Society
1003advocates permanent standard time due to its health benefits.</li>
1004<li>Rishi MA, Cheng JY, Strang AR <em>et al</em>.
1005<a href="https://jcsm.aasm.org/doi/10.5664/jcsm.10898">Permanent standard time
1006is the optimal choice for health and safety:
1007an American Academy of Sleep Medicine position statement</a>.
1008<em>J Clin Sleep Med.</em> 2024;20(1):121–125.
1009doi:<a href="https://doi.org/10.5664/jcsm.10898">10.5664/jcsm.10898</a>.
1010The AASM argues for permanent standard time due to health and safety risks
1011and economic costs of both <abbr>DST</abbr> transitions and
1012permanent <abbr>DST</abbr>.</li>
1013<li>Roenneberg T, Wirz-Justice A, Skene DJ <em>et al</em>.
1014<a href="https://journals.sagepub.com/doi/10.1177/0748730419854197">Why
1015should we abolish Daylight Saving Time?</a>
1016<em>J Biol Rhythms.</em> 2019;34(3):227–230.
1017doi:<a href="https://doi.org/10.1177/0748730419854197">10.1177/0748730419854197</a>.
1018The Society for Research on Biological Rhythms
1019opposes <abbr>DST</abbr> changes and permanent <abbr>DST</abbr>,
1020and advocates that governments adopt
1021“permanent Standard Time for the health and safety of their citizens”.</li>
1022</ul>
1023</section>
1024
1025<section>
1026<h2 id="precision">Precision timekeeping</h2>
1027<ul>
1028<li><a
1029href="http://leapsecond.com/hpan/an1289.pdf">The
1030Science of Timekeeping</a> is a thorough introduction
1031to the theory and practice of precision timekeeping.</li>
1032<li><a href="https://doi.org/10.1007/978-3-319-59909-0">The Science of
1033Time 2016</a> contains several freely readable papers.</li>
1034<li><a href="https://www.ntp.org"><abbr
1035title="Network Time Protocol">NTP</abbr>: The Network
1036Time Protocol</a> (Internet <abbr>RFC</abbr> 5905)
1037discusses how to synchronize clocks of
1038Internet hosts.</li>
1039<li>The <a href="https://www.usenix.org/system/files/conference/nsdi18/nsdi18-geng.pdf"><span style="font-variant: small-caps">Huygens</span></a>
1040family of software algorithms can achieve accuracy to a few tens of
1041nanoseconds in scalable server farms without special hardware.</li>
1042<li>The <a
1043href="https://www.nist.gov/el/intelligent-systems-division-73500/ieee-1588">Precision
1044Time Protocol</a> (<abbr
1045title="Institute of Electrical and Electronics Engineers">IEEE</abbr> 1588)
1046can achieve submicrosecond clock accuracy on a local area network
1047with special-purpose hardware.</li>
1048<li><a
1049href="https://www.rfc-editor.org/rfc/rfc4833">Timezone
1050Options for <abbr title="Dynamic Host Configuration Protocol">DHCP</abbr></a>
1051(Internet <abbr>RFC</abbr> 4833)
1052specifies a <a
1053href="https://en.wikipedia.org/wiki/Dynamic_Host_Configuration_Protocol"><abbr>DHCP</abbr></a>
1054option for a server to configure
1055a client’s time zone and daylight saving settings automatically.</li>
1056<li><a href="https://www.ucolick.org/~sla/leapsecs/timescales.html">Time
1057Scales</a> describes astronomical time scales like
1058<abbr title="Terrestrial Dynamic Time">TDT</abbr>,
1059<abbr title="Geocentric Coordinate Time">TCG</abbr>, and
1060<abbr title="Barycentric Dynamic Time">TDB</abbr>.
1061<li>The <a href="https://www.iau.org"><abbr
1062title="International Astronomical Union">IAU</abbr></a>’s <a
1063href="https://www.iausofa.org"><abbr
1064title="Standards Of Fundamental Astronomy">SOFA</abbr></a>
1065collection contains C and <a
1066href="https://en.wikipedia.org/wiki/Fortran">Fortran</a>
1067code for converting among time scales like
1068<abbr title="International Atomic Time">TAI</abbr>,
1069<abbr>TDB</abbr>, <abbr>TDT</abbr> and
1070<abbr>UTC</abbr>. It is freely available under the
1071<a href="https://www.iausofa.org/terms-and-conditions">SOFA license</a>.</li>
1072<li><a
1073href="https://www.giss.nasa.gov/tools/mars24/help/notes.html">Mars24 Sunclock
1074– Time on Mars</a> describes Airy Mean Time (<abbr>AMT</abbr>) and the
1075diverse local time
1076scales used by each landed mission on Mars.</li>
1077<li><a href="http://leapsecond.com">LeapSecond.com</a> is
1078dedicated not only to leap seconds but to precise time and frequency
1079in general. It covers the state of the art in amateur timekeeping, and
1080how the art has progressed over the past few decades.</li>
1081<li>The rules for leap seconds are specified in Annex 1 (Time scales) of <a
1082href="https://www.itu.int/rec/R-REC-TF.460-6-200202-I/">Standard-frequency
1083and time-signal emissions</a>, International Telecommunication Union –
1084Radiocommunication Sector (ITU-R) Recommendation TF.460-6 (02/2002).</li>
1085<li><a
1086href="https://www.iers.org/IERS/EN/Publications/Bulletins/bulletins.html"><abbr
1087title="International Earth Rotation and Reference Systems Service">IERS</abbr>
1088Bulletins</a> contains official publications of the International
1089Earth Rotation and Reference Systems Service, which decides when leap
1090seconds occur.
1091The <code><abbr>tz</abbr></code> code and data support leap seconds
1092via an optional <code>"right"</code> configuration where a computer’s internal
1093<code>time_t</code> integer clock counts every <abbr>TAI</abbr> second,
1094as opposed to the default <code>"posix"</code> configuration
1095where the internal clock ignores leap seconds.
1096The two configurations agree for timestamps starting with 1972-01-01 00:00:00
1097<abbr>UTC</abbr> (<code>time_t</code> 63&thinsp;072&thinsp;000) and diverge for
1098timestamps starting with <code>time_t</code> 78&thinsp;796&thinsp;800,
1099which corresponds to the first leap second
11001972-06-30 23:59:60 <abbr>UTC</abbr> in the <code>"right"</code> configuration,
1101and to
11021972-07-01 00:00:00 <abbr>UTC</abbr> in the <code>"posix"</code> configuration.
1103In practice the two configurations also agree for timestamps before
11041972 even though the historical situation is messy, partly because
1105neither <abbr>UTC</abbr> nor <abbr>TAI</abbr>
1106is well-defined for sufficiently old timestamps.</li>
1107<li><a href="https://kb.meinbergglobal.com/kb/time_sync/ntp/configuration/ntp_leap_second_file">The
1108<abbr>NTP</abbr> Leap Second File</a> covers the text file
1109<code>leap-seconds.list</code>, which lists the currently known leap seconds.
1110The <abbr>IERS</abbr> maintains this file, and a copy is distributed by
1111<code><abbr>tzdb</abbr></code> for use by <abbr>NTP</abbr> implementations like
1112<a href="https://www.ntp.org">classic
1113<code><abbr title="Network Time Protocol Daemon">ntpd</abbr></code></a>
1114and <a href="https://ntpsec.org">NTPsec</a>.
1115The <code><abbr>tz</abbr></code> database also distributes leap second
1116information in a differently-formatted <code>leapseconds</code> text file,
1117as well as in the <code>"right"</code> configuration in binary form; for
1118example, <code>right/UTC</code> can be used
1119by <a href="https://chrony-project.org"><code>chrony</code></a>,
1120another <abbr>NTP</abbr> implementation.</li>
1121<li><a href="https://developers.google.com/time/smear">Leap Smear</a>
1122discusses how to gradually adjust <abbr>POSIX</abbr> clocks near a
1123leap second so that they disagree with <abbr>UTC</abbr> by at most a
1124half second, even though every <abbr>POSIX</abbr> minute has exactly
1125sixty seconds. This approach works with the default <code><abbr>tz</abbr></code>
1126<code>"posix"</code> configuration, is <a
1127href="https://gitlab.com/NTPsec/ntpsec/-/blob/master/docs/leapsmear.adoc">supported</a>
1128by the abovementioned <abbr>NTP</abbr> implementations, <a
1129href="https://github.com/google/unsmear">supports</a> conversion between
1130<abbr>UTC</abbr> and smeared <abbr>POSIX</abbr> timestamps, and is used by major
1131cloud service providers. However, according to
1132<a href="https://www.rfc-editor.org/rfc/rfc8633#section-3.7.1">§3.7.1 of
1133Network Time Protocol Best Current Practices</a>
1134(Internet <abbr>RFC</abbr> 8633), leap smearing is not suitable for
1135applications requiring accurate <abbr>UTC</abbr> or civil time,
1136and is intended for use only in single, well-controlled environments.</li>
1137<li>The <a
1138href="https://pairlist6.pair.net/mailman/listinfo/leapsecs">Leap
1139Second Discussion List</a> covers <a
1140href="https://gge.ext.unb.ca/Resources/gpsworld.november99.pdf">McCarthy
1141and Klepczynski’s 1999 proposal to discontinue leap seconds</a>,
1142discussed further in
1143<a href="https://www.cl.cam.ac.uk/~mgk25/time/metrologia-leapsecond.pdf">The
1144leap second: its history and possible future</a>.
1145<a href="https://www.ucolick.org/~sla/leapsecs/"><abbr>UTC</abbr>
1146might be redefined
1147without Leap Seconds</a> gives pointers on this
1148contentious issue.
1149The General Conference on Weights and Measures
1150<a href="https://www.bipm.org/en/cgpm-2022/resolution-4">decided in 2022</a>
1151to discontinue the use of leap seconds by 2035, and requested that no
1152discontinuous adjustments be made to UTC for at least a century.
1153The World Radiocommunication Conference <a
1154href="https://www.itu.int/dms_pub/itu-r/opb/act/R-ACT-WRC.15-2023-PDF-E.pdf">resolved
1155in 2023</a> to cooperate with this process. One proposal to implement this
1156would replace leap seconds with seven 13-second leap smears occurring once per
1157decade until 2100, with leap smears after that gradually increasing in size.
1158See:
1159<ul>
1160<li>Levine J. <a href="https://www.preprints.org/manuscript/202406.0043">A
1161proposal to change the leap-second adjustments to
1162coordinated universal time</a>. <em>Metrologia.</em> 2024;61(5):055002. doi:<a
1163href="https://doi.org/10.1088/1681-7575/ad6266">10.1088/1681-7575/ad6266</a>.</li>
1164</ul>
1165However, there is still no consensus on whether this is the best way
1166to replace leap seconds.
1167</li>
1168</ul>
1169</section>
1170
1171<section>
1172<h2 id="notation">Time notation</h2>
1173<ul>
1174<li>The <a id="CLDR" href="https://cldr.unicode.org">Unicode Common Locale Data
1175Repository (<abbr>CLDR</abbr>) Project</a> has localizations for time
1176zone names, abbreviations, identifiers, and formats. For example, it
1177contains French translations for “Eastern European Summer Time”,
1178“<abbr title="Eastern European Summer Time">EEST</abbr>”, and “Bucharest”. Its
1179<a href="https://unicode.org/cldr/charts/latest/by_type/">by-type
1180charts</a> show these values for many locales. Data values are available in
1181both <abbr title="Locale Data Markup Language">LDML</abbr>
1182(an <abbr>XML</abbr> format) and <abbr>JSON</abbr>.
1183<li>
1184<a href="https://www.cl.cam.ac.uk/~mgk25/iso-time.html">A summary of
1185the international standard date and time notation</a> covers
1186<a
1187href="https://www.iso.org/standard/70907.html"><em><abbr
1188title="International Organization for Standardization">ISO</abbr>
11898601-1:2019 – Date and time – Representations for information
1190interchange – Part 1: Basic rules</em></a>.</li>
1191<li>
1192<a href="https://www.w3.org/TR/xmlschema/#dateTime"><abbr>XML</abbr>
1193Schema: Datatypes – dateTime</a> specifies a format inspired by
1194<abbr>ISO</abbr> 8601 that is in common use in <abbr>XML</abbr> data.</li>
1195<li><a href="https://www.rfc-editor.org/rfc/rfc5322#section-3.3">§3.3 of
1196Internet Message Format</a> (Internet <abbr>RFC</abbr> 5322)
1197specifies the time notation used in email and <a
1198href="https://en.wikipedia.org/wiki/Hypertext_Transfer_Protocol"><abbr>HTTP</abbr></a>
1199headers.</li>
1200<li>
1201<a href="https://www.rfc-editor.org/rfc/rfc3339">Date and Time
1202on the Internet: Timestamps</a> (Internet <abbr>RFC</abbr> 3339)
1203specifies an <abbr>ISO</abbr> 8601 profile for use in new Internet protocols.
1204An extension, <a href="https://www.rfc-editor.org/rfc/rfc9557">Date
1205and Time on the Internet: Timestamps with Additional Information</a>
1206(Internet <abbr>RFC</abbr> 9557) extends this profile
1207to let you specify the <code><abbr>tzdb</abbr></code> timezone of a timestamp
1208via suffixes like <code>[Asia/Tokyo]</code>.
1209<li>
1210<a href="https://web.archive.org/web/20190130042457/https://www.hackcraft.net/web/datetime/">Date &amp; Time
1211Formats on the Web</a> surveys web- and Internet-oriented date and time
1212formats.</li>
1213<li>Alphabetic time zone abbreviations should not be used as unique
1214identifiers for <abbr>UT</abbr> offsets as they are ambiguous in
1215practice. For example, in English-speaking North America
1216“<abbr>CST</abbr>” denotes 6 hours behind <abbr>UT</abbr>,
1217but in China it denotes 8 hours ahead of <abbr>UT</abbr>,
1218and French-speaking North Americans prefer
1219“<abbr title="Heure Normale du Centre">HNC</abbr>” to
1220“<abbr>CST</abbr>”. The <code><abbr>tz</abbr></code>
1221database contains English abbreviations for many timestamps;
1222unfortunately some of these abbreviations were merely the database maintainers’
1223inventions, and these have been removed when possible.</li>
1224<li>Numeric time zone abbreviations typically count hours east of
1225<abbr>UT</abbr>, e.g., +09 for Japan and
1226−10 for Hawaii. However, <abbr>POSIX</abbr> proleptic
1227<code><abbr>TZ</abbr></code> settings use the opposite convention.
1228For example, one might use <code><abbr>TZ</abbr>="<abbr
1229title="Japan Standard Time">JST</abbr>-9"</code> and
1230<code><abbr>TZ</abbr>="<abbr title="Hawaii Standard Time">HST</abbr>10"</code>
1231for Japan and Hawaii, respectively. If the
1232<code><abbr>tz</abbr></code> database is available, it is usually better to use
1233settings like <code><abbr>TZ</abbr>="Asia/Tokyo"</code> and
1234<code><abbr>TZ</abbr>="Pacific/Honolulu"</code> instead, as this should avoid
1235confusion, handle old timestamps better, and insulate you better from
1236any future changes to the rules. One should never set
1237<abbr>POSIX</abbr> <code><abbr>TZ</abbr></code> to a value like
1238<code>"GMT-9"</code>, though, since this would incorrectly imply that
1239local time is nine hours ahead of <abbr>UT</abbr> and the time zone
1240is called “<abbr>GMT</abbr>”.</li>
1241</ul>
1242</section>
1243
1244<section>
1245<h2 id="see-also">See also</h2>
1246<ul>
1247<li><a href="theory.html">Theory and pragmatics of the
1248<code><abbr>tz</abbr></code> code and data</a></li>
1249<li><a href="tz-art.html">Time and the Arts</a></li>
1250</ul>
1251</section>
1252
1253<footer>
1254<hr>
1255This web page is in the public domain, so clarified as of
12562009-05-17 by Arthur David Olson.
1257<br>
1258Please send corrections to this web page to the
1259<a href="mailto:tz@iana.org">time zone mailing list</a>.
1260The mailing list and its archives are public,
1261so please do not send confidential information.
1262</footer>
1263</body>
1264</html>
1265