Description
Current state
For now only recent linux on amd64 and macos on intel and apple silicon are supported.
It is done by dirty hacks: configuration is half hard-coded and a few generated headers are provided pre-generated.
Benefit of change
Not hard-coding configuration and generated headers would allow finally allow cross-compiling libpq on many more targets, and also make building the server code much easier.
Note that each PostgreSQL version has a different list of variable to provide for its configuration, so not hard-coding it would allow building more versions with less effort.
What should be done to get there
1. Generate configuration from the target
ALIGNOF_
TYPE
For now i've used @alignOf
.
For cross-compiling we need to switch to std.Target.cTypeAlignment
. Problem: it was called c_type_alignment
up to zig 0.13.
I'll wait for 0.14 to release before doing that change.
SIZEOF_
TYPE
Same thing: i'll change from @sizeOf
to std.Target.cTypeByteSize
upon 0.14 release
HAVE_
FUNCTION
A mix of options for optional dependencies and writing a big switch.
There is also a need to know which GLIBC version is targeted.
In the case of a version explicitely queried, it will appear in std.Build.ResolvedTarget
's query
, but in the other case, I don't know how to proceed yet, help would be welcomed
HAVE_
HEADER
Idem
DLSUFFIX
Not needed to set correctly as it it not used when building statically I guess
BLCKSZ
ENABLE_THREAD_SAFETY
...
I haven't spent time understanding that, leaving it hard-coded until it breaks something
2. Generate headers at build-time
Certain headers are generated by perl scripts.
They are not a function of the target OS and arch, but may change for each PostgreSQL version, so it is more about supporting different PostgreSQL versions and building the server code than about cross-compilation.
include/catalog/pg_tablespace_d.h
Generated by src/backend/catalog/genbki.pl
, see src/include/catalog/Makefile
.
Not sure exactly what it does and what it depends on.
include/kwlist_d.h
Generated by src/tools/gen_keywordlist.pl
, using module src/tools/PerfectHash.pm
(see src/common/Makefile
).
include/utils/errcodes.h
Generated by src/backend/utils/generate-errcodes.pl
using src/backend/utils/errcodes.txt
TODO list
-
ALIGNOF_
TYPE -
SIZEOF_
TYPE -
include/catalog/pg_tablespace_d.h
-
include/kwlist_d.h
-
include/utils/errcodes.h