Zig bindings for the GEOS C library (libgeos)
GEOS (Geometry Engine, Open Source) is a C/C++ library for spatial computational geometry of the sort generally used by “geographic information systems” software. GEOS is a core dependency of PostGIS, QGIS, GDAL, and Shapely.
3.13.0
0.13
Requires only zig
. Don't forget to clone/init the submodule!
git clone --recurse-submodules https://github.com/guidorice/libgeos.zig.git
cd libgeos.zig/
zig build
zig build test
$ zig build --help
$ zig build run-ex1
Geometry A: POLYGON((0 0, 10 0, 10 10, 0 10, 0 0))
Geometry B: POLYGON((5 5, 15 5, 15 15, 5 15, 5 5))
Intersection(A, B): POLYGON ((10 10, 10 5, 5 5, 5 10, 10 10))
- blocker: The libgeos library uses C++
std::runtime_error
, which is not currently captured by the Zig wrapper code. As a result, there is no way to recover from some error conditions, for example, failing to parse some WKT formatted string. see issue #9
- Minimal build.zig. Builds libgeos entirely using Zig compiler and build system.
- Create example exe using this package as a Zig library.
- Port libgeos C examples to Zig (from src/geos/examples)
- Ex 1 Reads two WKT representations and calculates the intersection, prints it out, and cleans up.
- Ex 1 (threadsafe)
- Ex 2 Reads one geometry and does high-performance prepared geometry operations to place "random" points inside it.
- Ex 3 Build a spatial index and search it for a nearest pair.
- Ex 4 Read and write geojson.
See also vendor/geos/README for how libgeos is updated within this repo.