93 lines
2.6 KiB
Python
93 lines
2.6 KiB
Python
#!/usr/bin/env python3
|
|
|
|
# Copyright (c) 2019, Ulf Magnusson
|
|
# SPDX-License-Identifier: ISC
|
|
|
|
"""
|
|
Simple utility for setting configuration values from the command line.
|
|
|
|
Sample usage:
|
|
|
|
$ setconfig FOO_SUPPORT=y BAR_BITS=8
|
|
|
|
Note: Symbol names should not be prefixed with 'CONFIG_'.
|
|
|
|
The exit status on errors is 1.
|
|
|
|
The default input/output configuration file is '.config'. A different filename
|
|
can be passed in the KCONFIG_CONFIG environment variable.
|
|
|
|
When overwriting a configuration file, the old version is saved to
|
|
<filename>.old (e.g. .config.old).
|
|
"""
|
|
import argparse
|
|
import sys
|
|
|
|
import kconfiglib
|
|
|
|
|
|
def main():
|
|
parser = argparse.ArgumentParser(
|
|
formatter_class=argparse.RawDescriptionHelpFormatter,
|
|
description=__doc__)
|
|
|
|
parser.add_argument(
|
|
"--kconfig",
|
|
default="Kconfig",
|
|
help="Top-level Kconfig file (default: Kconfig)")
|
|
|
|
parser.add_argument(
|
|
"--no-check-exists",
|
|
dest="check_exists",
|
|
action="store_false",
|
|
help="Ignore assignments to non-existent symbols instead of erroring "
|
|
"out")
|
|
|
|
parser.add_argument(
|
|
"--no-check-value",
|
|
dest="check_value",
|
|
action="store_false",
|
|
help="Ignore assignments that didn't \"take\" (where the symbol got a "
|
|
"different value, e.g. due to unsatisfied dependencies) instead "
|
|
"of erroring out")
|
|
|
|
parser.add_argument(
|
|
"assignments",
|
|
metavar="ASSIGNMENT",
|
|
nargs="*",
|
|
help="A 'NAME=value' assignment")
|
|
|
|
args = parser.parse_args()
|
|
|
|
kconf = kconfiglib.Kconfig(args.kconfig, suppress_traceback=True)
|
|
print(kconf.load_config())
|
|
|
|
for arg in args.assignments:
|
|
if "=" not in arg:
|
|
sys.exit("error: no '=' in assignment: '{}'".format(arg))
|
|
name, value = arg.split("=", 1)
|
|
|
|
if name not in kconf.syms:
|
|
if not args.check_exists:
|
|
continue
|
|
sys.exit("error: no symbol '{}' in configuration".format(name))
|
|
|
|
sym = kconf.syms[name]
|
|
|
|
if not sym.set_value(value):
|
|
sys.exit("error: '{}' is an invalid value for the {} symbol {}"
|
|
.format(value, kconfiglib.TYPE_TO_STR[sym.orig_type],
|
|
name))
|
|
|
|
if args.check_value and sym.str_value != value:
|
|
sys.exit("error: {} was assigned the value '{}', but got the "
|
|
"value '{}'. Check the symbol's dependencies, and make "
|
|
"sure that it has a prompt."
|
|
.format(name, value, sym.str_value))
|
|
|
|
print(kconf.write_config())
|
|
|
|
|
|
if __name__ == "__main__":
|
|
main()
|