Crates.io | zone-detect |
lib.rs | zone-detect |
version | 1.0.1 |
source | src |
created_at | 2020-01-25 00:35:04.793639 |
updated_at | 2024-03-17 20:32:08.578141 |
description | Rust version of the ZoneDetect C library. |
homepage | |
repository | https://github.com/nicholasbishop/zone-detect-rs |
max_upload_size | |
id | 201703 |
size | 4,305,877 |
This is a Rust version of the ZoneDetect C library. The initial conversion was done with c2rust, then manually cleaned up (it no longer contains any unsafe code).
This crate can be used to look up the country and timezone of any location on Earth.
$ cargo run --example demo data/timezone21.bin 35.0715 -82.5216
zone 0: ZoneMatch {
kind: InZone,
zone: Zone {
polygon_id: 1458,
meta_id: 3199,
fields: {
"CountryAlpha2": "US",
"CountryName": "United States",
"TimezoneIdPrefix": "America/",
"TimezoneId": "New_York",
},
},
}
The database containing the location and timezone data is in
data/timezone21.bin
. It can be updated as follows:
git clone https://github.com/BertoldVdb/ZoneDetect
cd ZoneDetect/database/builder
./makedb.sh
cp out_v1/timezone21.bin zone-detect-rs/data/timezone21.bin
There's a slow test that generates random values and compares the output between ZoneDetect and zone-detect-rs.
# Make sure the demo is built first; just run `make` in the ZoneDetect repo.
ZONEDETECT_DEMO=../ZoneDetect/demo cargo test -- --ignored