genTree generates a filesystem tree in a namespace using portage.
genTree-server serves the package cache and can be used to queue new builds using genTree.
genTree <config file> [--debug, -d]
ex. genTree nginx.toml
A seed must be imported before genTree can be used, whis is done with genTree-import-seed
:
`genTree-import-seed [conf_root]
system root
- The system root to import, can be a stage3 tarball or a directory.seed name
- The seed name to use.conf_root
- Alternate configuration root to use.
The
conf_root
is~/.local/share/genTree
by default
ex. genTree-import-seed stage3.tar.xz stage3-openrc .
By default, repos at ~/.local/share/genTree/repos
are used, and must be created with:
genTree-exec <seed_name> emerge --sync
Any sync method can be used.
System repos can be used by setting
bind_system_repos
to true in the config.
Seeds can be updated with genTree-update-seed <seed name> [alternate update arg string]
.
ex. genTree-update-seed stage3-openrc
By default, "--jobs 4 --update --deep --newuse --changed-use --with-bdeps=y --usepkg=y @world" is used. The update string can be defined with
seed_update_args
in the default config.
Commands can be execued in a seed using genTree-exec [--persistent] <seed name> <command>
.
By default, this will execute the command in an overlay, so it only persists in the upper dir. --persistent
can be used to execute the command directly in the seed root.
Crossdev support can be added to a seed with genTree-init-crossdev <seed name> <target-tuple>
.
ex. genTree-init-crossdev stage3-openrc aarch64-unknown-linux-gnu
The target tuple must be a valid crossdev target.
To remove old build tarballs, use genTree-clean-builds
.
~/.local/share/genTree/builds/
is use by default, but an alternate build dir can be passed with the first arg.
This is equivalent to
rm ~/.local/share/genTree/builds/*.tar
genTree can serve binpkgs using aiohttp
with genTree-server.
genTree-server <seed name> [--debug, -d] [-a --address <address>] [--port <port>] [--crossdev-target -c] [--profile -p] [--build-tag -t]
ex. genTree-server stage3-openrc -a 0.0.0.0
Builds can be added to a queue using /pkg?pkg=<pkg>
and viewed using /queue
.
Example build configuration file:
# nginx.toml
# name = "nginx" # The name is set to the filename without extension by default
# output_file = "nginx.tar" # The output file is set to the name with a .tar extension by default
# A seed must be defined
seed = "stage3-openrc"
# profile = "default/linux/amd64/23.0" # Set the profile
bases = ["tini", "gcc"]
packages = ["www-servers/nginx"]
unmerge = ["sys-devel/gcc"]
[env]
use = "nginx"
[clean_filter_options]
charmaps = true # Delete charmaps before packing
[tar_filter_options]
locales = true # Filter locales when packing
packages
(list) - The packages to emerge.unmerge
(list) - The packages to unmerge.deplean
(false) - Run depclean --with-bdeps=n after emerging.rebuild
(false) - Force a rebuild of the layer.
The default config is set in <module_path>/defaults.toml
, and is merged with:
/etc/genTree/config.toml
~/.config/genTree/config.toml
Values which are set to None will check DEFAULTS for a value.
The following defaults cannot be set:
name
- This must be set per build/layer.bases
- ''packages
/unmerge
- ''whiteouts
/opaques
- Handled by filtersconfig_file
- Doesn't make sense to have a default (for inheriting)build_tag
- Used for additional override profiles, as a key.parent
- Set by the parent when adding a base.
The following defaults inheritance can be configured:
env.features
- Toggled withinherit_features
env.use
- Toggled withinherit_use
env.common_flags
- as well as each common flag type, like cflags, cxxflags, etc.- When a
crossdev_target
is set, not used unlesscrossdev_use_env
is true.
- When a
crossdev_env
- Environment variables to set for crossdev, same as env.
The
env
dict is used to set environment variables including INHERITED_CONFIG, ENV_VARS, and DEF_ARGS
Crossdev profiles are set by key name, using the target tuple as the value.
# ~/.config/genTree/config.toml
seed = "openrc-hardened"
profile = "default/linux/amd64/23.0/no-multilib/hardened"
[crossdev_profile]
aarch64-unknown-linux-gnu = "default/linux/arm64/23.0"
[env]
cpu_flags_x86 = "aes avx avx2 f16c fma3 mmx mmxext pclmul popcnt rdrand sha sse sse2 sse3 sse4_1 sse4_2 sse4a ssse3 vpclmulqdq"
common_flags = "-march=native -flto -O3 -pipe"
[default.openrc-hardened.pi3]
crossdev_target = "aarch64-unknown-linux-gnu"
[default.openrc-hardened.pi3.crossdev_env]
common_flags = "-march=armv8-a+crc -mtune=cortex-a53 -flto -O3 -pipe"
[default.openrc-desktop]
profile = "default/linux/amd64/23.0/desktop"
[default.openrc-desktop-generic]
package_tag = "generic"
profile = "default/linux/amd64/23.0/desktop"
[default.openrc-desktop-generic.env]
common_flags = "-flto -O3 -pipe"
Bases are configurations used as a base for another config.
Bases layer contents are extracted to the lower_dir of the build layer's overlayfs mount.
Builtin bases such as
tini
,glibc
, andbase
can be specified without a suffix to be used
The path to a base file can be specified for custom bases.
inherit_use
(true) - Inherit USE flags from the parent.inherit_features
(true) - Inherit FEATURES from the parent.inherit_env
(true) - Inherit misc environment variables from the parent.inherit_config
(false) - Inherit the configuration root from the parent.
inherit_env
controls inheritance fromDEF_ARGS
(filter options and emerge args).
Several filters are available for cleaning and packing packing layer tarballs.
refilter
(true) - Reapply all filters to the final tarball.
Path filters are used to remove files and directories before packing.
These arguments are set under the clean_filter_options
dict.
man
(true) - Filters man pages.docs
(true) - Filters documentation.include
(true) - Filters headers/includes.charmaps
(true) - Filters charmaps.completions
(true) - Filters shell completions.locales
(false) - Filters locales.vardbpkg
(false) - Filters/var/db/pkg
.
refilter
can be used to reapply filters to the final tarball.
Tar filters are used to filter items added to the tarball.
They are set under the tar_filter_options
dict; any path filter can be used in addition to:
whiteouts
(true) - Handles OCI whiteouts. (.wh. files)dev
(true) - Filters character and block devices.
The profile can be set using:
profile
(default/linux/amd64/23.0) - The profile to use.profile_repos
(gentoo) - The repository source for the profile.
arguments with values can be set like:
[emerge_args]
jobs = 4
boolean operators to the emerge
commad can be set using:
[emerge_bools]
verbose = true
with_bdeps = false
Operators which cannot be set =n should be defined in PORTAGE_PLAIN_BOOLS
Environment variables can be set using the env
dict.
The following variables can be used as sets or strings:
use
(set) - USE flags to set.features
(set) - FEATURES to set.binpkg_format
(gpkg) - The binary package format to use.cpu_flags_{x86,arm,ppc}
(set) - CPU flags to set.common_flags
(set) - Common flags to set (appended to CFLAGS, CXXFLAGS, etc.)cflags
(str) - CFLAGS to set.cxxflags
(str) - CXXFLAGS to set.fcflags
(str) - FCFLAGS to set.fflags
(str) - FFLAGS to set.
The
use
andfeatures
variables are sets which can interpret adding and removing flags using+
and-
prefixes.
ex:
[env]
use = "-dracut ugrd" # The same as ["-dracut", "ugrd"]
features = ["test", "-test"] # Add and remove test (NOOP)
foo_arg = "bar" # Set the variable foo_arg to bar
common_flags = "-O3 -pipe -march=native -flto" # Set common flags
Several components are mounted into the build namespace as read-only bind mounts:
bind_system_repos
(false) - mounts the pathsystem_repos
to/var/db/repos
.
A seed must be defined in the top level config. Seeds are used as the lower layer in an overlay which is chrooted into.
This layer will persist between builds, and will not be cleaned unless clean_seed
is set to true.
clean_seed
(false) - Clean the seed overlay upper dir before building.ephemeral_seed
(false) - Mount the seed overlay on a tmpfs.
Configuration overrides to be mounted over /etc/portage
can be specified using:
config_overlay
(str) - The name of the configuration overlay to use (fromconfig_dir
).inherit_config
(false) - Inherit a config root from the seed.
The build are performed in overlays which are mounted over /builds
in the namespace, and under conf_root
/builds on the host.
conf_root
is ~/.local/share/genTree by default
The upper_dir is used to build layers between stages, and the mount point is used for the outermost layer.
clean_build
(true) - Clean the build overlay before building.