|
|
--- |
|
|
short-description: Unstable kconfig module |
|
|
authors: |
|
|
- name: Mark Schulte, Paolo Bonzini |
|
|
years: [2017, 2019] |
|
|
has-copyright: false |
|
|
... |
|
|
|
|
|
# Unstable kconfig module |
|
|
|
|
|
This module parses Kconfig output files to allow use of kconfig |
|
|
configurations in meson projects. |
|
|
|
|
|
**Note**: this does not provide kconfig frontend tooling to generate a |
|
|
configuration. You still need something such as kconfig frontends (see |
|
|
link below) to parse your Kconfig files, and then (after you've |
|
|
chosen the configuration options), output a ".config" file. |
|
|
|
|
|
[kconfig-frontends]: http://ymorin.is-a-geek.org/projects/kconfig-frontends |
|
|
|
|
|
## Usage |
|
|
|
|
|
The module may be imported as follows: |
|
|
|
|
|
``` meson |
|
|
kconfig = import('unstable-kconfig') |
|
|
``` |
|
|
|
|
|
The following functions will then be available as methods on the object |
|
|
with the name `kconfig`. You can, of course, replace the name |
|
|
`kconfig` with anything else. |
|
|
|
|
|
### kconfig.load() |
|
|
|
|
|
This function loads a kconfig output file and returns a dictionary object. |
|
|
|
|
|
`kconfig.load()` makes no attempt at parsing the values in the |
|
|
file. Therefore, true boolean values will be represented as the string "y" |
|
|
and integer values will have to be converted with `.to_int()`. |
|
|
|
|
|
Kconfig frontends usually have ".config" as the default name for the |
|
|
configuration file. However, placing the configuration file in the source |
|
|
directory limits the user to one configuration per source directory. |
|
|
In order to allow separate configurations for each build directory, as is |
|
|
the Meson standard, `meson.build` should not hardcode ".config" as the |
|
|
argument to `kconfig.load()`, and should instead make the argument to |
|
|
`kconfig.load()` a [project build option](Build-options.md). |
|
|
|
|
|
* The first (and only) argument is the path to the configuration file to |
|
|
load (usually ".config"). |
|
|
|
|
|
**Returns**: a [dictionary object](Reference-manual.md#dictionary-object).
|
|
|
|