FreeBSD manual

download PDF document: config.lua.8.pdf

CONFIG.LUA(8) FreeBSD System Manager's Manual CONFIG.LUA(8)
NAME config.lua - FreeBSD config module
DESCRIPTION config.lua contains configuration and module loading functionality.
Before hooking into or using the functionality provided by config.lua, it must be included with a statement such as the following:
local config = require("config")
Exported functions The following functions are exported from config.lua:
config.getCarouselIndex(id) Returns the currently chosen index in the carousel menu entry described by id. See the definition of menu.lua(8) for a more in-depth explanation of carousels.
config.setCarouselIndex(id, idx) Set the chosen index for the carousel menu entry described by id to idx. A lookup will be done as needed to determine what value idx actually corresponds to.
config.readConf(file, loaded_files) Process file as a configuration file (e.g., as loader.conf) and then process files listed in the loader_conf_files variable. Additionnaly, the top-level call to readConf will process files listed in the loader_conf_dirs and local_loader_conf_files variables (see loader.conf(5)). The caller may optionally pass in a table as the loaded_files argument, which uses filenames as keys and any non-nil value to indicate that the file named by the key has already been loaded and should not be loaded again.
config.processFile(name, silent) Process and parse name as a configuration file. Returns true if name exists and parses without error, false otherwise. If silent is true, config.processFile() will not consider a failure to read the file as a failure.
config.parse(text) Parse text as a configuration file. This is used internally by config.processFile() to parse the
config.loadKernel(other_kernel) Attempts to load other_kernel as a kernel. If other_kernel is unset config.loadKernel() will attempt to load "kernel". Otherwise, it will try to load "kernel" first from /boot/{other_kernel}, then from {other_kernel}.
The latter is tried in case an absolute path has been specified to the kernel to use. module_path is amended to include the directory the kernel was found in if either of these paths result in a loaded kernel.
If no kernel was loaded from either of these paths, config.loadKernel() will attempt to load a kernel named "{other_kernel}" from module_path instead of attempting to load a kernel named "kernel".
Returns true if a kernel was loaded, false if no kernel was loaded.
config.selectKernel(kernel) Set kernel to the kernel that will be loaded when either autoboot or boot are invoked. This is usually called by the menu system as the kernel selector carousel is toggled through.
config.load(file, reload) Loads file as a configuration file. If file is not specified, /boot/defaults/loader.conf is used. config.load() will then silently attempt to process any files specified in loader_conf_files after file has been processed. nextboot(8) configuration will also be checked as part of config.load(). Before returning, all "config.loaded" hooks will be run if reload is not set to true.
config.reload(file) Reloads file as a configuration file. config.reload() will restore the environment to how it existed before the last config was loaded, then it will invoke config.load(file). Before returning, all "config.reloaded" hooks will be run. commands.
config.enableModule(modname) Marks a module named modname to be loaded during config.loadelf(). If the module was previously blacklisted, then it will be forcefully allowed to load.
config.disableModule(modname) Marks a module named modname to not be loaded during config.loadelf().
config.isModuleEnabled(modname) Checks if the module named modname will be loaded during config.loadelf(). It checks both that the module is marked for loading and that it is either forced or not blacklisted.
config.getModuleInfo() Returns a table with "modules" and "blacklist" tables describing the modules that the config module has been made aware of via loader.conf(5) as well as a representation of module_blacklist.
Defined Hooks The following hooks are defined in config.lua:
config.buildenv(env)
config.loaded()
config.reloaded()
kernel.loaded()
modules.loaded()
Note that the config.buildenv() hook is only invoked when an environment needs to be built to execute a lua configuration file that has been specified in loader_conf_files. It will be invoked for each configuration file encountered.
SEE ALSO loader.conf(5), loader(8), menu.lua(8), nextboot(8)
AUTHORS The config.lua file was originally written by Pedro Souza <pedrosouza@FreeBSD.org>. Later work and this manual page was done by Kyle Evans <kevans@FreeBSD.org>.
FreeBSD 14.2-RELEASE December 17, 2020 FreeBSD 14.2-RELEASE