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