go-geos
uses libgeos
's stable C API,
geos_c.h
. Only the thread-safe
*_r
functions are used.
Wherever possible, go-geos
uses code generation to generate wrappers for
*Geom
methods. The generated code is in
geommethods.go
.
There are five parts to this:
geommethods.yaml
contains the high-level definitions of the methods.geommethods.go.tmpl
is atext/template
template that is executed with the data fromgeommethods.yaml
.internal/cmds/execute-template/
executes a template with data and includes custom template functions.go generate
runsinternal/cmds/execute-template/
withgeommethods.yaml
andgeommethods.go.tmpl
as inputs and writesgeommethods.go
.geom_test.go
contains unit tests to ensure that the method is wrapped correctly.
Adding a method to *Geom
consists of one or more steps, depending on how
similar the method is to existing methods:
- In simple cases, adding a few lines to
geommethods.yaml
and runninggo generate
is sufficient. You will need to add a test togeom_test.go
. - For more complex cases, you might have to modify or extend
geommethods.go.tmpl
. - If you need to add or modify a template function, you will need to modify
internal/cmds/execute-template/
.
go-geos
supports the libgeos version using in the latest Ubuntu LTS
release, which is currently GEOS
3.10.2.
As libgeos
is under active development, bugs are fixed and new features are
added over time. This causes problems when versions might behave incorrectly or
miss newly-added features. In these cases:
- In general, it is the user's responsibility to ensure that they are using a
sufficiently recent version of
libgeos
for their needs.go-geos
can forward incorrect results fromlibgeos
and behave in an undefined manner (including crashing the program) when missing features are invoked. - For features not present in GEOS 3.10.2, you will need to add stubs in
geos.c
andgeos.h
to provide the function when it is not provided.
go-geos
uses clang-format
to
format C code. You can run this with:
$ clang-format -i *.c *.h