Skip to content
This repository has been archived by the owner on Dec 15, 2023. It is now read-only.
/ ezic Public archive

a set of erlang utilities for the Olson timezone database files

Notifications You must be signed in to change notification settings

drfloob/ezic

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

75 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ezic

ezic is a native erlang library for working with timezones. It parses the Olson timezone database files, allowing native erlang timezone lookup and zone conversions without the use of shell commands or a UNIX system.

See the tz database page for more information about the Olson database.

Purpose

Erlang/OTP didn't have a native timezone library, so I wrote ezic to fill that void.

The recommended way of handling timezones in erlang involves setting the system environment variable TZ to the desired timezone, then calling erlang time functions. As far as I can tell, this technique has a few key issues:

  • it only works on *nix systems,
  • it depends on your system's timezone data (preventing custom timezone hackery), and
  • you can create race conditions if you aren't careful about it

ezic doesn't have these problems. ezic is, however, a young project with who-knows-how-many problems of its own.

API

  • ezic:localtime(TimeZone) -> datetime()
  • ezic:utc_to_local(universal_datetime(), TimeZone) -> local_datetime()
  • ezic:local_to_utc(local_datetime(), TimeZone) -> universal_datetime()

Example Setup

# setup your local environment
mkdir -p priv/tzdata

# download the timezone data files
wget 'ftp://ftp.iana.org/tz/tzdata-latest.tar.gz'
tar -xvzf tzdata-latest.tar.gz -C priv/tzdata

# remove a few troublesome files
cd priv/tzdata
LC_COLLATE=C
rm *.sh *.gz *.tab factory *.pl *.awk *.list [A-Z]*

# build and run ezic
cd -
make all run
1> application:start(ezic).
2> ezic:localtime("Australia/Adelaide").

License

This project is in the public domain. Anyone is free to copy, modify, publish, use, compile, sell, or distribute the original code, either in source code form or as a compiled binary, for any purpose, commercial or non-commercial, and by any means.

Contributed Code

To maintain ezic's status as a public domain work, all contributions must also be dedicated to the public domain.

Acknowledgements

A big thanks to ezic's contributors:

The decision to release this into the public domain was inspired by the (anti-) license of the SQLite project.

About

a set of erlang utilities for the Olson timezone database files

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •