Page MenuHomeFreeBSD

flua: support our flua modules in the bootstrap flua
ClosedPublic

Authored by kevans on Aug 14 2025, 6:09 AM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Oct 21, 8:26 PM
Unknown Object (File)
Sat, Oct 18, 2:08 PM
Unknown Object (File)
Fri, Oct 17, 11:29 PM
Unknown Object (File)
Wed, Oct 15, 12:23 PM
Unknown Object (File)
Sun, Oct 12, 8:20 PM
Unknown Object (File)
Sun, Oct 12, 8:20 PM
Unknown Object (File)
Sun, Oct 12, 8:20 PM
Unknown Object (File)
Sun, Oct 12, 8:44 AM
Subscribers
None

Details

Summary

This version builds every module into the flua binary itself, since all
of the bootstrap tools are built -DNO_SHARED. As a result, we also
cannot dlsym(), so we can't really discover the names of our newly
builtin modules. Instead, just build out a linker set with all of our
luaopen_*() functions to register everything up-front.

Building in all of the modules isn't strictly necessary, but it means
that we have an example of how to add a bootstrap module everywhere you
go and one doesn't need to consider whether bootstrap flua can use a
module when writing scripts. On my build machine, the consequence on
our binary size is an increase from around 1.6M -> 1.9M, which isn't
really that bad.

.lua modules can install into their usual path below $WORLDTMP/legacy
and we'll pick them up automagically by way of the ctor that sets up
LUA_PATH early on.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

kevans created this revision.
libexec/flua/libucl/Makefile.inc
1

intentional?

libexec/flua/libucl/Makefile.inc
1

Yes, I wanted to give us the option of raising the WARNS or excluding other modules that had an equal or lower WARNS without breaking the build

This revision is now accepted and ready to land.Sep 11 2025, 7:11 AM