Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mamuesp/timezones
A Mongoose-OS library which will set the cryptic 'sys.tz_spec' from a human readable notation.
https://github.com/mamuesp/timezones
c library miniz mongoose-os olson timezone tzget tzset
Last synced: 3 months ago
JSON representation
A Mongoose-OS library which will set the cryptic 'sys.tz_spec' from a human readable notation.
- Host: GitHub
- URL: https://github.com/mamuesp/timezones
- Owner: mamuesp
- License: other
- Created: 2018-07-15T18:43:36.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2019-08-18T08:56:17.000Z (over 5 years ago)
- Last Synced: 2024-07-31T21:52:53.065Z (6 months ago)
- Topics: c, library, miniz, mongoose-os, olson, timezone, tzget, tzset
- Language: C
- Homepage:
- Size: 81.1 KB
- Stars: 6
- Watchers: 1
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-mongoose-os - timezones - Timezone related functions to get the correct settings of the tzData used by Mongoose-OS (Awesome Mongoose OS [![Awesome](https://awesome.re/badge.svg)](https://awesome.re) / Community Libraries)
README
# Timezones
Timezone related functions to get the correct settings of the tzData used by Mongoose-OS.
Inspired and based on a blog posting from Pavel Gurenko ["Getting POSIX TZ strings from Olson tzdata"](http://www.pavelgurenko.com/2017/05/getting-posix-tz-strings-from-olson.html). The library will only use the current timezone settings and is not able to track changes in timezone data.This is a library written in C which works in the background. Just add the lib, set your personal values in `mos.yml` and build the app.
**the setting 'Europe/Berlin' will result in 'CET-1CEST,M3.5.0,M10.5.0/3'**
# Usage:
## 1. Include library in `mos.yml`
## 2. Adapt you settings:
```YAML
- ["timezone.enable", true]
```
You may enable/disable the library though it is loaded.```YAML
- ["timezone.data_path", "/mnt"]
```
If you have mounted an additional file system with e.g. the name `/mnt`, you may move the ZIP file (~5KB) to the file system you entered here. It must by mounted before. This will only be executed after flashing a new version of the firmware. After this action the moved file will be used. Be aware that after moving the archive file you should not change this setting without a new build and flash, because this will lead to an error finding the file. **Be aware: if you want to let the data untouched and let it stay where it is, please set this value to an empty string "". In this case, the ZIP file will be in the standard file system**
```YAML
- ["timezone.arch_file", "tz-archive.zip"]
```
This is the filename of the timezone data archive, **should not be touched**.
```YAML
- ["timezone.olson", "UTC0"]```
Here you may enter the wished timezone in Olson notation you wish to be configured for your device.
For example: if you enter `America/New_York`, the `sys.tz_spec` will be set to `EST5EDT,M3.2.0,M11.1.0`
## 3. ToDo:
* comment the source code
* add update possibilities, because the timezone data changes from time to time
* implement some functions in MJS for information purposes
* implement a function which will retrieve the timezone from coordinates (longitude, latitude)
* implement a function which will get the timezone from a full address (e.g. via GoogleAPI)