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 & 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 072 000) and diverge for 1098timestamps starting with <code>time_t</code> 78 796 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 & 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