mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-09 07:23:14 +00:00
Kconfig updates for v4.18
Kconfig now supports new functionality to perform textual substitution. It has been a while since Linus suggested to move compiler option tests from makefiles to Kconfig. Finally, here it is. The implementation has been generalized into a Make-like macro language. Some built-in functions such as 'shell' are provided. Variables and user-defined functions are also supported so that 'cc-option', 'ld-option', etc. are implemented as macros. Summary: - refactor package checks for building {m,n,q,g}conf - remove unused/unmaintained localization support - remove Kbuild cache - drop CONFIG_CROSS_COMPILE support - replace 'option env=' with direct variable expansion - add built-in functions such as 'shell' - support variables and user-defined functions - add helper macros as as 'cc-option' - add unit tests and a document of the new macro language - add 'testconfig' to help - fix warnings from GCC 8.1 -----BEGIN PGP SIGNATURE----- Version: GnuPG v1 iQIcBAABAgAGBQJbGBJPAAoJED2LAQed4NsG9QEP/24saP6Q3uF68yOsXcyE7yL0 VW6acNpCXFjyQZQuHB9JntD9oftSfPuY73mjVKPRvL29NopbFbe7O7wAOYSRvsZT cTZ5KF0FpG0enP6qUUiVpGZPGiSXKu21Lr/WrCdS889O2g5NxCB6OameQLjXkz5P EZb+QZD6drzYkXjipLJoliFJAhsbaACxmuCgO1gpg+qAEOm/fCnRk1qVwKffH21Z YlKMpw0FR3IdZA/cYp5Bh/WiICaCXs8lmMupHb4BHL4SvJGXxMEnuyt1txXANJcv 3nTxsMPwjdCGboEgCavbcUnTaONnFK6IdGhdSntsf1aKRqHntiA/cwqmJl2RX/6v ObX85dRjvyKq+qh9wEGvUle0LQYxhvJJ4NyWX5+wiRB6wzPCuqTPL0I1y6UPwAkQ JveUswQ7u3+dCBwuHeXFHWvpviNFkWO+Gc8E2h1PKroG0Tz3HpoQclvcZjsOXrRt HX2+6EsuYK2LnabwQzk4TRkI7JnTKpLGG/YoM4H360bNHs5KUwgm6g5V9Oo4L3E+ A5Jbow5siKtn7lIR9TXDou6O6F7L+bMiK+PlydPiv085EqUfhP+rkiJu9sb18GPD dsMXeTN51cJYLtDNiZ9tnPBtTB6Wvk7K1Dcmf3/t3rWVy35tjgl0RdxEySU153Pk n62ftyGGyUldBSzWcGWR =o37+ -----END PGP SIGNATURE----- Merge tag 'kconfig-v4.18' of git://git.kernel.org/pub/scm/linux/kernel/git/masahiroy/linux-kbuild Pull Kconfig updates from Masahiro Yamada: "Kconfig now supports new functionality to perform textual substitution. It has been a while since Linus suggested to move compiler option tests from makefiles to Kconfig. Finally, here it is. The implementation has been generalized into a Make-like macro language. Some built-in functions such as 'shell' are provided. Variables and user-defined functions are also supported so that 'cc-option', 'ld-option', etc. are implemented as macros. Summary: - refactor package checks for building {m,n,q,g}conf - remove unused/unmaintained localization support - remove Kbuild cache - drop CONFIG_CROSS_COMPILE support - replace 'option env=' with direct variable expansion - add built-in functions such as 'shell' - support variables and user-defined functions - add helper macros as as 'cc-option' - add unit tests and a document of the new macro language - add 'testconfig' to help - fix warnings from GCC 8.1" * tag 'kconfig-v4.18' of git://git.kernel.org/pub/scm/linux/kernel/git/masahiroy/linux-kbuild: (30 commits) kconfig: Avoid format overflow warning from GCC 8.1 kbuild: Move last word of nconfig help to the previous line kconfig: Add testconfig into make help output kconfig: add basic helper macros to scripts/Kconfig.include kconfig: show compiler version text in the top comment kconfig: test: add Kconfig macro language tests Documentation: kconfig: document a new Kconfig macro language kconfig: error out if a recursive variable references itself kconfig: add 'filename' and 'lineno' built-in variables kconfig: add 'info', 'warning-if', and 'error-if' built-in functions kconfig: expand lefthand side of assignment statement kconfig: support append assignment operator kconfig: support simply expanded variable kconfig: support user-defined function and recursively expanded variable kconfig: begin PARAM state only when seeing a command keyword kconfig: replace $(UNAME_RELEASE) with function call kconfig: add 'shell' built-in function kconfig: add built-in function support kconfig: make default prompt of mainmenu less specific kconfig: remove sym_expand_string_value() ...
This commit is contained in:
commit
0ad39cb3d7
@ -198,14 +198,6 @@ applicable everywhere (see syntax).
|
|||||||
enables the third modular state for all config symbols.
|
enables the third modular state for all config symbols.
|
||||||
At most one symbol may have the "modules" option set.
|
At most one symbol may have the "modules" option set.
|
||||||
|
|
||||||
- "env"=<value>
|
|
||||||
This imports the environment variable into Kconfig. It behaves like
|
|
||||||
a default, except that the value comes from the environment, this
|
|
||||||
also means that the behaviour when mixing it with normal defaults is
|
|
||||||
undefined at this point. The symbol is currently not exported back
|
|
||||||
to the build environment (if this is desired, it can be done via
|
|
||||||
another symbol).
|
|
||||||
|
|
||||||
- "allnoconfig_y"
|
- "allnoconfig_y"
|
||||||
This declares the symbol as one that should have the value y when
|
This declares the symbol as one that should have the value y when
|
||||||
using "allnoconfig". Used for symbols that hide other symbols.
|
using "allnoconfig". Used for symbols that hide other symbols.
|
||||||
|
242
Documentation/kbuild/kconfig-macro-language.txt
Normal file
242
Documentation/kbuild/kconfig-macro-language.txt
Normal file
@ -0,0 +1,242 @@
|
|||||||
|
Concept
|
||||||
|
-------
|
||||||
|
|
||||||
|
The basic idea was inspired by Make. When we look at Make, we notice sort of
|
||||||
|
two languages in one. One language describes dependency graphs consisting of
|
||||||
|
targets and prerequisites. The other is a macro language for performing textual
|
||||||
|
substitution.
|
||||||
|
|
||||||
|
There is clear distinction between the two language stages. For example, you
|
||||||
|
can write a makefile like follows:
|
||||||
|
|
||||||
|
APP := foo
|
||||||
|
SRC := foo.c
|
||||||
|
CC := gcc
|
||||||
|
|
||||||
|
$(APP): $(SRC)
|
||||||
|
$(CC) -o $(APP) $(SRC)
|
||||||
|
|
||||||
|
The macro language replaces the variable references with their expanded form,
|
||||||
|
and handles as if the source file were input like follows:
|
||||||
|
|
||||||
|
foo: foo.c
|
||||||
|
gcc -o foo foo.c
|
||||||
|
|
||||||
|
Then, Make analyzes the dependency graph and determines the targets to be
|
||||||
|
updated.
|
||||||
|
|
||||||
|
The idea is quite similar in Kconfig - it is possible to describe a Kconfig
|
||||||
|
file like this:
|
||||||
|
|
||||||
|
CC := gcc
|
||||||
|
|
||||||
|
config CC_HAS_FOO
|
||||||
|
def_bool $(shell, $(srctree)/scripts/gcc-check-foo.sh $(CC))
|
||||||
|
|
||||||
|
The macro language in Kconfig processes the source file into the following
|
||||||
|
intermediate:
|
||||||
|
|
||||||
|
config CC_HAS_FOO
|
||||||
|
def_bool y
|
||||||
|
|
||||||
|
Then, Kconfig moves onto the evaluation stage to resolve inter-symbol
|
||||||
|
dependency as explained in kconfig-language.txt.
|
||||||
|
|
||||||
|
|
||||||
|
Variables
|
||||||
|
---------
|
||||||
|
|
||||||
|
Like in Make, a variable in Kconfig works as a macro variable. A macro
|
||||||
|
variable is expanded "in place" to yield a text string that may then be
|
||||||
|
expanded further. To get the value of a variable, enclose the variable name in
|
||||||
|
$( ). The parentheses are required even for single-letter variable names; $X is
|
||||||
|
a syntax error. The curly brace form as in ${CC} is not supported either.
|
||||||
|
|
||||||
|
There are two types of variables: simply expanded variables and recursively
|
||||||
|
expanded variables.
|
||||||
|
|
||||||
|
A simply expanded variable is defined using the := assignment operator. Its
|
||||||
|
righthand side is expanded immediately upon reading the line from the Kconfig
|
||||||
|
file.
|
||||||
|
|
||||||
|
A recursively expanded variable is defined using the = assignment operator.
|
||||||
|
Its righthand side is simply stored as the value of the variable without
|
||||||
|
expanding it in any way. Instead, the expansion is performed when the variable
|
||||||
|
is used.
|
||||||
|
|
||||||
|
There is another type of assignment operator; += is used to append text to a
|
||||||
|
variable. The righthand side of += is expanded immediately if the lefthand
|
||||||
|
side was originally defined as a simple variable. Otherwise, its evaluation is
|
||||||
|
deferred.
|
||||||
|
|
||||||
|
The variable reference can take parameters, in the following form:
|
||||||
|
|
||||||
|
$(name,arg1,arg2,arg3)
|
||||||
|
|
||||||
|
You can consider the parameterized reference as a function. (more precisely,
|
||||||
|
"user-defined function" in contrast to "built-in function" listed below).
|
||||||
|
|
||||||
|
Useful functions must be expanded when they are used since the same function is
|
||||||
|
expanded differently if different parameters are passed. Hence, a user-defined
|
||||||
|
function is defined using the = assignment operator. The parameters are
|
||||||
|
referenced within the body definition with $(1), $(2), etc.
|
||||||
|
|
||||||
|
In fact, recursively expanded variables and user-defined functions are the same
|
||||||
|
internally. (In other words, "variable" is "function with zero argument".)
|
||||||
|
When we say "variable" in a broad sense, it includes "user-defined function".
|
||||||
|
|
||||||
|
|
||||||
|
Built-in functions
|
||||||
|
------------------
|
||||||
|
|
||||||
|
Like Make, Kconfig provides several built-in functions. Every function takes a
|
||||||
|
particular number of arguments.
|
||||||
|
|
||||||
|
In Make, every built-in function takes at least one argument. Kconfig allows
|
||||||
|
zero argument for built-in functions, such as $(fileno), $(lineno). You could
|
||||||
|
consider those as "built-in variable", but it is just a matter of how we call
|
||||||
|
it after all. Let's say "built-in function" here to refer to natively supported
|
||||||
|
functionality.
|
||||||
|
|
||||||
|
Kconfig currently supports the following built-in functions.
|
||||||
|
|
||||||
|
- $(shell,command)
|
||||||
|
|
||||||
|
The "shell" function accepts a single argument that is expanded and passed
|
||||||
|
to a subshell for execution. The standard output of the command is then read
|
||||||
|
and returned as the value of the function. Every newline in the output is
|
||||||
|
replaced with a space. Any trailing newlines are deleted. The standard error
|
||||||
|
is not returned, nor is any program exit status.
|
||||||
|
|
||||||
|
- $(info,text)
|
||||||
|
|
||||||
|
The "info" function takes a single argument and prints it to stdout.
|
||||||
|
It evaluates to an empty string.
|
||||||
|
|
||||||
|
- $(warning-if,condition,text)
|
||||||
|
|
||||||
|
The "warning-if" function takes two arguments. If the condition part is "y",
|
||||||
|
the text part is sent to stderr. The text is prefixed with the name of the
|
||||||
|
current Kconfig file and the current line number.
|
||||||
|
|
||||||
|
- $(error-if,condition,text)
|
||||||
|
|
||||||
|
The "error-if" function is similar to "warning-if", but it terminates the
|
||||||
|
parsing immediately if the condition part is "y".
|
||||||
|
|
||||||
|
- $(filename)
|
||||||
|
|
||||||
|
The 'filename' takes no argument, and $(filename) is expanded to the file
|
||||||
|
name being parsed.
|
||||||
|
|
||||||
|
- $(lineno)
|
||||||
|
|
||||||
|
The 'lineno' takes no argument, and $(lineno) is expanded to the line number
|
||||||
|
being parsed.
|
||||||
|
|
||||||
|
|
||||||
|
Make vs Kconfig
|
||||||
|
---------------
|
||||||
|
|
||||||
|
Kconfig adopts Make-like macro language, but the function call syntax is
|
||||||
|
slightly different.
|
||||||
|
|
||||||
|
A function call in Make looks like this:
|
||||||
|
|
||||||
|
$(func-name arg1,arg2,arg3)
|
||||||
|
|
||||||
|
The function name and the first argument are separated by at least one
|
||||||
|
whitespace. Then, leading whitespaces are trimmed from the first argument,
|
||||||
|
while whitespaces in the other arguments are kept. You need to use a kind of
|
||||||
|
trick to start the first parameter with spaces. For example, if you want
|
||||||
|
to make "info" function print " hello", you can write like follows:
|
||||||
|
|
||||||
|
empty :=
|
||||||
|
space := $(empty) $(empty)
|
||||||
|
$(info $(space)$(space)hello)
|
||||||
|
|
||||||
|
Kconfig uses only commas for delimiters, and keeps all whitespaces in the
|
||||||
|
function call. Some people prefer putting a space after each comma delimiter:
|
||||||
|
|
||||||
|
$(func-name, arg1, arg2, arg3)
|
||||||
|
|
||||||
|
In this case, "func-name" will receive " arg1", " arg2", " arg3". The presence
|
||||||
|
of leading spaces may matter depending on the function. The same applies to
|
||||||
|
Make - for example, $(subst .c, .o, $(sources)) is a typical mistake; it
|
||||||
|
replaces ".c" with " .o".
|
||||||
|
|
||||||
|
In Make, a user-defined function is referenced by using a built-in function,
|
||||||
|
'call', like this:
|
||||||
|
|
||||||
|
$(call my-func,arg1,arg2,arg3)
|
||||||
|
|
||||||
|
Kconfig invokes user-defined functions and built-in functions in the same way.
|
||||||
|
The omission of 'call' makes the syntax shorter.
|
||||||
|
|
||||||
|
In Make, some functions treat commas verbatim instead of argument separators.
|
||||||
|
For example, $(shell echo hello, world) runs the command "echo hello, world".
|
||||||
|
Likewise, $(info hello, world) prints "hello, world" to stdout. You could say
|
||||||
|
this is _useful_ inconsistency.
|
||||||
|
|
||||||
|
In Kconfig, for simpler implementation and grammatical consistency, commas that
|
||||||
|
appear in the $( ) context are always delimiters. It means
|
||||||
|
|
||||||
|
$(shell, echo hello, world)
|
||||||
|
|
||||||
|
is an error because it is passing two parameters where the 'shell' function
|
||||||
|
accepts only one. To pass commas in arguments, you can use the following trick:
|
||||||
|
|
||||||
|
comma := ,
|
||||||
|
$(shell, echo hello$(comma) world)
|
||||||
|
|
||||||
|
|
||||||
|
Caveats
|
||||||
|
-------
|
||||||
|
|
||||||
|
A variable (or function) cannot be expanded across tokens. So, you cannot use
|
||||||
|
a variable as a shorthand for an expression that consists of multiple tokens.
|
||||||
|
The following works:
|
||||||
|
|
||||||
|
RANGE_MIN := 1
|
||||||
|
RANGE_MAX := 3
|
||||||
|
|
||||||
|
config FOO
|
||||||
|
int "foo"
|
||||||
|
range $(RANGE_MIN) $(RANGE_MAX)
|
||||||
|
|
||||||
|
But, the following does not work:
|
||||||
|
|
||||||
|
RANGES := 1 3
|
||||||
|
|
||||||
|
config FOO
|
||||||
|
int "foo"
|
||||||
|
range $(RANGES)
|
||||||
|
|
||||||
|
A variable cannot be expanded to any keyword in Kconfig. The following does
|
||||||
|
not work:
|
||||||
|
|
||||||
|
MY_TYPE := tristate
|
||||||
|
|
||||||
|
config FOO
|
||||||
|
$(MY_TYPE) "foo"
|
||||||
|
default y
|
||||||
|
|
||||||
|
Obviously from the design, $(shell command) is expanded in the textual
|
||||||
|
substitution phase. You cannot pass symbols to the 'shell' function.
|
||||||
|
The following does not work as expected.
|
||||||
|
|
||||||
|
config ENDIAN_FLAG
|
||||||
|
string
|
||||||
|
default "-mbig-endian" if CPU_BIG_ENDIAN
|
||||||
|
default "-mlittle-endian" if CPU_LITTLE_ENDIAN
|
||||||
|
|
||||||
|
config CC_HAS_ENDIAN_FLAG
|
||||||
|
def_bool $(shell $(srctree)/scripts/gcc-check-flag ENDIAN_FLAG)
|
||||||
|
|
||||||
|
Instead, you can do like follows so that any function call is statically
|
||||||
|
expanded.
|
||||||
|
|
||||||
|
config CC_HAS_ENDIAN_FLAG
|
||||||
|
bool
|
||||||
|
default $(shell $(srctree)/scripts/gcc-check-flag -mbig-endian) if CPU_BIG_ENDIAN
|
||||||
|
default $(shell $(srctree)/scripts/gcc-check-flag -mlittle-endian) if CPU_LITTLE_ENDIAN
|
10
Kconfig
10
Kconfig
@ -3,10 +3,10 @@
|
|||||||
# For a description of the syntax of this configuration file,
|
# For a description of the syntax of this configuration file,
|
||||||
# see Documentation/kbuild/kconfig-language.txt.
|
# see Documentation/kbuild/kconfig-language.txt.
|
||||||
#
|
#
|
||||||
mainmenu "Linux/$ARCH $KERNELVERSION Kernel Configuration"
|
mainmenu "Linux/$(ARCH) $(KERNELVERSION) Kernel Configuration"
|
||||||
|
|
||||||
config SRCARCH
|
comment "Compiler: $(CC_VERSION_TEXT)"
|
||||||
string
|
|
||||||
option env="SRCARCH"
|
|
||||||
|
|
||||||
source "arch/$SRCARCH/Kconfig"
|
source "scripts/Kconfig.include"
|
||||||
|
|
||||||
|
source "arch/$(SRCARCH)/Kconfig"
|
||||||
|
@ -7684,8 +7684,9 @@ M: Masahiro Yamada <yamada.masahiro@socionext.com>
|
|||||||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/masahiroy/linux-kbuild.git kconfig
|
T: git git://git.kernel.org/pub/scm/linux/kernel/git/masahiroy/linux-kbuild.git kconfig
|
||||||
L: linux-kbuild@vger.kernel.org
|
L: linux-kbuild@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: Documentation/kbuild/kconfig-language.txt
|
F: Documentation/kbuild/kconfig*
|
||||||
F: scripts/kconfig/
|
F: scripts/kconfig/
|
||||||
|
F: scripts/Kconfig.include
|
||||||
|
|
||||||
KDUMP
|
KDUMP
|
||||||
M: Dave Young <dyoung@redhat.com>
|
M: Dave Young <dyoung@redhat.com>
|
||||||
|
10
Makefile
10
Makefile
@ -316,12 +316,9 @@ SUBARCH := $(shell uname -m | sed -e s/i.86/x86/ -e s/x86_64/x86/ \
|
|||||||
# CROSS_COMPILE can be set on the command line
|
# CROSS_COMPILE can be set on the command line
|
||||||
# make CROSS_COMPILE=ia64-linux-
|
# make CROSS_COMPILE=ia64-linux-
|
||||||
# Alternatively CROSS_COMPILE can be set in the environment.
|
# Alternatively CROSS_COMPILE can be set in the environment.
|
||||||
# A third alternative is to store a setting in .config so that plain
|
|
||||||
# "make" in the configured kernel build directory always uses that.
|
|
||||||
# Default value for CROSS_COMPILE is not to prefix executables
|
# Default value for CROSS_COMPILE is not to prefix executables
|
||||||
# Note: Some architectures assign CROSS_COMPILE in their arch/*/Makefile
|
# Note: Some architectures assign CROSS_COMPILE in their arch/*/Makefile
|
||||||
ARCH ?= $(SUBARCH)
|
ARCH ?= $(SUBARCH)
|
||||||
CROSS_COMPILE ?= $(CONFIG_CROSS_COMPILE:"%"=%)
|
|
||||||
|
|
||||||
# Architecture as present in compile.h
|
# Architecture as present in compile.h
|
||||||
UTS_MACHINE := $(ARCH)
|
UTS_MACHINE := $(ARCH)
|
||||||
@ -445,6 +442,8 @@ export KBUILD_AFLAGS_MODULE KBUILD_CFLAGS_MODULE KBUILD_LDFLAGS_MODULE
|
|||||||
export KBUILD_AFLAGS_KERNEL KBUILD_CFLAGS_KERNEL
|
export KBUILD_AFLAGS_KERNEL KBUILD_CFLAGS_KERNEL
|
||||||
export KBUILD_ARFLAGS
|
export KBUILD_ARFLAGS
|
||||||
|
|
||||||
|
export CC_VERSION_TEXT := $(shell $(CC) --version | head -n 1)
|
||||||
|
|
||||||
# When compiling out-of-tree modules, put MODVERDIR in the module
|
# When compiling out-of-tree modules, put MODVERDIR in the module
|
||||||
# tree rather than in the kernel tree. The kernel tree might
|
# tree rather than in the kernel tree. The kernel tree might
|
||||||
# even be read-only.
|
# even be read-only.
|
||||||
@ -504,7 +503,7 @@ KBUILD_CFLAGS += $(call cc-option,-fno-PIE)
|
|||||||
KBUILD_AFLAGS += $(call cc-option,-fno-PIE)
|
KBUILD_AFLAGS += $(call cc-option,-fno-PIE)
|
||||||
|
|
||||||
# check for 'asm goto'
|
# check for 'asm goto'
|
||||||
ifeq ($(call shell-cached,$(CONFIG_SHELL) $(srctree)/scripts/gcc-goto.sh $(CC) $(KBUILD_CFLAGS)), y)
|
ifeq ($(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-goto.sh $(CC) $(KBUILD_CFLAGS)), y)
|
||||||
CC_HAVE_ASM_GOTO := 1
|
CC_HAVE_ASM_GOTO := 1
|
||||||
KBUILD_CFLAGS += -DCC_HAVE_ASM_GOTO
|
KBUILD_CFLAGS += -DCC_HAVE_ASM_GOTO
|
||||||
KBUILD_AFLAGS += -DCC_HAVE_ASM_GOTO
|
KBUILD_AFLAGS += -DCC_HAVE_ASM_GOTO
|
||||||
@ -807,7 +806,7 @@ KBUILD_CFLAGS_KERNEL += $(call cc-option,-fdata-sections,)
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
# arch Makefile may override CC so keep this after arch Makefile is included
|
# arch Makefile may override CC so keep this after arch Makefile is included
|
||||||
NOSTDINC_FLAGS += -nostdinc -isystem $(call shell-cached,$(CC) -print-file-name=include)
|
NOSTDINC_FLAGS += -nostdinc -isystem $(shell $(CC) -print-file-name=include)
|
||||||
|
|
||||||
# warn about C99 declaration after statement
|
# warn about C99 declaration after statement
|
||||||
KBUILD_CFLAGS += $(call cc-option,-Wdeclaration-after-statement,)
|
KBUILD_CFLAGS += $(call cc-option,-Wdeclaration-after-statement,)
|
||||||
@ -1630,7 +1629,6 @@ clean: $(clean-dirs)
|
|||||||
-o -name '*.asn1.[ch]' \
|
-o -name '*.asn1.[ch]' \
|
||||||
-o -name '*.symtypes' -o -name 'modules.order' \
|
-o -name '*.symtypes' -o -name 'modules.order' \
|
||||||
-o -name modules.builtin -o -name '.tmp_*.o.*' \
|
-o -name modules.builtin -o -name '.tmp_*.o.*' \
|
||||||
-o -name .cache.mk \
|
|
||||||
-o -name '*.c.[012]*.*' \
|
-o -name '*.c.[012]*.*' \
|
||||||
-o -name '*.ll' \
|
-o -name '*.ll' \
|
||||||
-o -name '*.gcno' \) -type f -print | xargs rm -f
|
-o -name '*.gcno' \) -type f -print | xargs rm -f
|
||||||
|
@ -60,7 +60,7 @@ config SUPERH
|
|||||||
<http://www.linux-sh.org/>.
|
<http://www.linux-sh.org/>.
|
||||||
|
|
||||||
config SUPERH32
|
config SUPERH32
|
||||||
def_bool ARCH = "sh"
|
def_bool "$(ARCH)" = "sh"
|
||||||
select HAVE_KPROBES
|
select HAVE_KPROBES
|
||||||
select HAVE_KRETPROBES
|
select HAVE_KRETPROBES
|
||||||
select HAVE_IOREMAP_PROT if MMU && !X2TLB
|
select HAVE_IOREMAP_PROT if MMU && !X2TLB
|
||||||
@ -79,7 +79,7 @@ config SUPERH32
|
|||||||
select HAVE_CC_STACKPROTECTOR
|
select HAVE_CC_STACKPROTECTOR
|
||||||
|
|
||||||
config SUPERH64
|
config SUPERH64
|
||||||
def_bool ARCH = "sh64"
|
def_bool "$(ARCH)" = "sh64"
|
||||||
select HAVE_EXIT_THREAD
|
select HAVE_EXIT_THREAD
|
||||||
select KALLSYMS
|
select KALLSYMS
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
config 64BIT
|
config 64BIT
|
||||||
bool "64-bit kernel" if ARCH = "sparc"
|
bool "64-bit kernel" if "$(ARCH)" = "sparc"
|
||||||
default ARCH = "sparc64"
|
default "$(ARCH)" = "sparc64"
|
||||||
help
|
help
|
||||||
SPARC is a family of RISC microprocessors designed and marketed by
|
SPARC is a family of RISC microprocessors designed and marketed by
|
||||||
Sun Microsystems, incorporated. They are very widely found in Sun
|
Sun Microsystems, incorporated. They are very widely found in Sun
|
||||||
|
@ -54,10 +54,6 @@ config HZ
|
|||||||
int
|
int
|
||||||
default 100
|
default 100
|
||||||
|
|
||||||
config SUBARCH
|
|
||||||
string
|
|
||||||
option env="SUBARCH"
|
|
||||||
|
|
||||||
config NR_CPUS
|
config NR_CPUS
|
||||||
int
|
int
|
||||||
range 1 1
|
range 1 1
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
# SPDX-License-Identifier: GPL-2.0
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
# Select 32 or 64 bit
|
# Select 32 or 64 bit
|
||||||
config 64BIT
|
config 64BIT
|
||||||
bool "64-bit kernel" if ARCH = "x86"
|
bool "64-bit kernel" if "$(ARCH)" = "x86"
|
||||||
default ARCH != "i386"
|
default "$(ARCH)" != "i386"
|
||||||
---help---
|
---help---
|
||||||
Say yes to build a 64-bit kernel - formerly known as x86_64
|
Say yes to build a 64-bit kernel - formerly known as x86_64
|
||||||
Say no to build a 32-bit kernel - formerly known as i386
|
Say no to build a 32-bit kernel - formerly known as i386
|
||||||
|
@ -1,5 +1,9 @@
|
|||||||
# SPDX-License-Identifier: GPL-2.0
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
mainmenu "User Mode Linux/$SUBARCH $KERNELVERSION Kernel Configuration"
|
mainmenu "User Mode Linux/$(SUBARCH) $(KERNELVERSION) Kernel Configuration"
|
||||||
|
|
||||||
|
comment "Compiler: $(CC_VERSION_TEXT)"
|
||||||
|
|
||||||
|
source "scripts/Kconfig.include"
|
||||||
|
|
||||||
source "arch/um/Kconfig.common"
|
source "arch/um/Kconfig.common"
|
||||||
|
|
||||||
@ -16,8 +20,8 @@ config UML_X86
|
|||||||
select GENERIC_FIND_FIRST_BIT
|
select GENERIC_FIND_FIRST_BIT
|
||||||
|
|
||||||
config 64BIT
|
config 64BIT
|
||||||
bool "64-bit kernel" if SUBARCH = "x86"
|
bool "64-bit kernel" if "$(SUBARCH)" = "x86"
|
||||||
default SUBARCH != "i386"
|
default "$(SUBARCH)" != "i386"
|
||||||
|
|
||||||
config X86_32
|
config X86_32
|
||||||
def_bool !64BIT
|
def_bool !64BIT
|
||||||
|
25
init/Kconfig
25
init/Kconfig
@ -1,20 +1,12 @@
|
|||||||
config ARCH
|
|
||||||
string
|
|
||||||
option env="ARCH"
|
|
||||||
|
|
||||||
config KERNELVERSION
|
|
||||||
string
|
|
||||||
option env="KERNELVERSION"
|
|
||||||
|
|
||||||
config DEFCONFIG_LIST
|
config DEFCONFIG_LIST
|
||||||
string
|
string
|
||||||
depends on !UML
|
depends on !UML
|
||||||
option defconfig_list
|
option defconfig_list
|
||||||
default "/lib/modules/$UNAME_RELEASE/.config"
|
default "/lib/modules/$(shell,uname --release)/.config"
|
||||||
default "/etc/kernel-config"
|
default "/etc/kernel-config"
|
||||||
default "/boot/config-$UNAME_RELEASE"
|
default "/boot/config-$(shell,uname --release)"
|
||||||
default "$ARCH_DEFCONFIG"
|
default ARCH_DEFCONFIG
|
||||||
default "arch/$ARCH/defconfig"
|
default "arch/$(ARCH)/defconfig"
|
||||||
|
|
||||||
config CONSTRUCTORS
|
config CONSTRUCTORS
|
||||||
bool
|
bool
|
||||||
@ -54,15 +46,6 @@ config INIT_ENV_ARG_LIMIT
|
|||||||
Maximum of each of the number of arguments and environment
|
Maximum of each of the number of arguments and environment
|
||||||
variables passed to init from the kernel command line.
|
variables passed to init from the kernel command line.
|
||||||
|
|
||||||
|
|
||||||
config CROSS_COMPILE
|
|
||||||
string "Cross-compiler tool prefix"
|
|
||||||
help
|
|
||||||
Same as running 'make CROSS_COMPILE=prefix-' but stored for
|
|
||||||
default make runs in this kernel build directory. You don't
|
|
||||||
need to set this unless you want the configured kernel build
|
|
||||||
directory to select the cross-compiler automatically.
|
|
||||||
|
|
||||||
config COMPILE_TEST
|
config COMPILE_TEST
|
||||||
bool "Compile also drivers which will not load"
|
bool "Compile also drivers which will not load"
|
||||||
depends on !UML
|
depends on !UML
|
||||||
|
@ -8,8 +8,6 @@ squote := '
|
|||||||
empty :=
|
empty :=
|
||||||
space := $(empty) $(empty)
|
space := $(empty) $(empty)
|
||||||
space_escape := _-_SPACE_-_
|
space_escape := _-_SPACE_-_
|
||||||
right_paren := )
|
|
||||||
left_paren := (
|
|
||||||
pound := \#
|
pound := \#
|
||||||
|
|
||||||
###
|
###
|
||||||
@ -57,7 +55,6 @@ kecho := $($(quiet)kecho)
|
|||||||
# to specify a valid file as first prerequisite (often the kbuild file)
|
# to specify a valid file as first prerequisite (often the kbuild file)
|
||||||
define filechk
|
define filechk
|
||||||
$(Q)set -e; \
|
$(Q)set -e; \
|
||||||
$(kecho) ' CHK $@'; \
|
|
||||||
mkdir -p $(dir $@); \
|
mkdir -p $(dir $@); \
|
||||||
$(filechk_$(1)) < $< > $@.tmp; \
|
$(filechk_$(1)) < $< > $@.tmp; \
|
||||||
if [ -r $@ ] && cmp -s $@ $@.tmp; then \
|
if [ -r $@ ] && cmp -s $@ $@.tmp; then \
|
||||||
@ -83,71 +80,6 @@ cc-cross-prefix = \
|
|||||||
echo $(c); \
|
echo $(c); \
|
||||||
fi)))
|
fi)))
|
||||||
|
|
||||||
# Tools for caching Makefile variables that are "expensive" to compute.
|
|
||||||
#
|
|
||||||
# Here we want to help deal with variables that take a long time to compute
|
|
||||||
# by making it easy to store these variables in a cache.
|
|
||||||
#
|
|
||||||
# The canonical example here is testing for compiler flags. On a simple system
|
|
||||||
# each call to the compiler takes 10 ms, but on a system with a compiler that's
|
|
||||||
# called through various wrappers it can take upwards of 100 ms. If we have
|
|
||||||
# 100 calls to the compiler this can take 1 second (on a simple system) or 10
|
|
||||||
# seconds (on a complicated system).
|
|
||||||
#
|
|
||||||
# The "cache" will be in Makefile syntax and can be directly included.
|
|
||||||
# Any time we try to reference a variable that's not in the cache we'll
|
|
||||||
# calculate it and store it in the cache for next time.
|
|
||||||
|
|
||||||
# Include values from last time
|
|
||||||
make-cache := $(if $(KBUILD_EXTMOD),$(KBUILD_EXTMOD)/,$(if $(obj),$(obj)/)).cache.mk
|
|
||||||
$(make-cache): ;
|
|
||||||
-include $(make-cache)
|
|
||||||
|
|
||||||
cached-data := $(filter __cached_%, $(.VARIABLES))
|
|
||||||
|
|
||||||
# If cache exceeds 1000 lines, shrink it down to 500.
|
|
||||||
ifneq ($(word 1000,$(cached-data)),)
|
|
||||||
$(shell tail -n 500 $(make-cache) > $(make-cache).tmp; \
|
|
||||||
mv $(make-cache).tmp $(make-cache))
|
|
||||||
endif
|
|
||||||
|
|
||||||
create-cache-dir := $(if $(KBUILD_SRC),$(if $(cache-data),,1))
|
|
||||||
|
|
||||||
# Usage: $(call __sanitize-opt,Hello=Hola$(comma)Goodbye Adios)
|
|
||||||
#
|
|
||||||
# Convert all '$', ')', '(', '\', '=', ' ', ',', ':' to '_'
|
|
||||||
__sanitize-opt = $(subst $$,_,$(subst $(right_paren),_,$(subst $(left_paren),_,$(subst \,_,$(subst =,_,$(subst $(space),_,$(subst $(comma),_,$(subst :,_,$(1)))))))))
|
|
||||||
|
|
||||||
# Usage: $(call shell-cached,shell_command)
|
|
||||||
# Example: $(call shell-cached,md5sum /usr/bin/gcc)
|
|
||||||
#
|
|
||||||
# If we've already seen a call to this exact shell command (even in a
|
|
||||||
# previous invocation of make!) we'll return the value. If not, we'll
|
|
||||||
# compute it and store the result for future runs.
|
|
||||||
#
|
|
||||||
# This is a bit of voodoo, but basic explanation is that if the variable
|
|
||||||
# was undefined then we'll evaluate the shell command and store the result
|
|
||||||
# into the variable. We'll then store that value in the cache and finally
|
|
||||||
# output the value.
|
|
||||||
#
|
|
||||||
# NOTE: The $$(2) here isn't actually a parameter to __run-and-store. We
|
|
||||||
# happen to know that the caller will have their shell command in $(2) so the
|
|
||||||
# result of "call"ing this will produce a reference to that $(2). The reason
|
|
||||||
# for this strangeness is to avoid an extra level of eval (and escaping) of
|
|
||||||
# $(2).
|
|
||||||
define __run-and-store
|
|
||||||
ifeq ($(origin $(1)),undefined)
|
|
||||||
$$(eval $(1) := $$(shell $$(2)))
|
|
||||||
ifeq ($(create-cache-dir),1)
|
|
||||||
$$(shell mkdir -p $(dir $(make-cache)))
|
|
||||||
$$(eval create-cache-dir :=)
|
|
||||||
endif
|
|
||||||
$$(shell echo '$(1) := $$($(1))' >> $(make-cache))
|
|
||||||
endif
|
|
||||||
endef
|
|
||||||
__shell-cached = $(eval $(call __run-and-store,$(1)))$($(1))
|
|
||||||
shell-cached = $(call __shell-cached,__cached_$(call __sanitize-opt,$(1)),$(1))
|
|
||||||
|
|
||||||
# output directory for tests below
|
# output directory for tests below
|
||||||
TMPOUT := $(if $(KBUILD_EXTMOD),$(firstword $(KBUILD_EXTMOD))/)
|
TMPOUT := $(if $(KBUILD_EXTMOD),$(firstword $(KBUILD_EXTMOD))/)
|
||||||
|
|
||||||
@ -155,36 +87,30 @@ TMPOUT := $(if $(KBUILD_EXTMOD),$(firstword $(KBUILD_EXTMOD))/)
|
|||||||
# Usage: option = $(call try-run, $(CC)...-o "$$TMP",option-ok,otherwise)
|
# Usage: option = $(call try-run, $(CC)...-o "$$TMP",option-ok,otherwise)
|
||||||
# Exit code chooses option. "$$TMP" serves as a temporary file and is
|
# Exit code chooses option. "$$TMP" serves as a temporary file and is
|
||||||
# automatically cleaned up.
|
# automatically cleaned up.
|
||||||
__try-run = set -e; \
|
try-run = $(shell set -e; \
|
||||||
TMP="$(TMPOUT).$$$$.tmp"; \
|
TMP="$(TMPOUT).$$$$.tmp"; \
|
||||||
TMPO="$(TMPOUT).$$$$.o"; \
|
TMPO="$(TMPOUT).$$$$.o"; \
|
||||||
if ($(1)) >/dev/null 2>&1; \
|
if ($(1)) >/dev/null 2>&1; \
|
||||||
then echo "$(2)"; \
|
then echo "$(2)"; \
|
||||||
else echo "$(3)"; \
|
else echo "$(3)"; \
|
||||||
fi; \
|
fi; \
|
||||||
rm -f "$$TMP" "$$TMPO"
|
rm -f "$$TMP" "$$TMPO")
|
||||||
|
|
||||||
try-run = $(shell $(__try-run))
|
|
||||||
|
|
||||||
# try-run-cached
|
|
||||||
# This works like try-run, but the result is cached.
|
|
||||||
try-run-cached = $(call shell-cached,$(__try-run))
|
|
||||||
|
|
||||||
# as-option
|
# as-option
|
||||||
# Usage: cflags-y += $(call as-option,-Wa$(comma)-isa=foo,)
|
# Usage: cflags-y += $(call as-option,-Wa$(comma)-isa=foo,)
|
||||||
|
|
||||||
as-option = $(call try-run-cached,\
|
as-option = $(call try-run,\
|
||||||
$(CC) $(KBUILD_CFLAGS) $(1) -c -x assembler /dev/null -o "$$TMP",$(1),$(2))
|
$(CC) $(KBUILD_CFLAGS) $(1) -c -x assembler /dev/null -o "$$TMP",$(1),$(2))
|
||||||
|
|
||||||
# as-instr
|
# as-instr
|
||||||
# Usage: cflags-y += $(call as-instr,instr,option1,option2)
|
# Usage: cflags-y += $(call as-instr,instr,option1,option2)
|
||||||
|
|
||||||
as-instr = $(call try-run-cached,\
|
as-instr = $(call try-run,\
|
||||||
printf "%b\n" "$(1)" | $(CC) $(KBUILD_AFLAGS) -c -x assembler -o "$$TMP" -,$(2),$(3))
|
printf "%b\n" "$(1)" | $(CC) $(KBUILD_AFLAGS) -c -x assembler -o "$$TMP" -,$(2),$(3))
|
||||||
|
|
||||||
# __cc-option
|
# __cc-option
|
||||||
# Usage: MY_CFLAGS += $(call __cc-option,$(CC),$(MY_CFLAGS),-march=winchip-c6,-march=i586)
|
# Usage: MY_CFLAGS += $(call __cc-option,$(CC),$(MY_CFLAGS),-march=winchip-c6,-march=i586)
|
||||||
__cc-option = $(call try-run-cached,\
|
__cc-option = $(call try-run,\
|
||||||
$(1) -Werror $(2) $(3) -c -x c /dev/null -o "$$TMP",$(3),$(4))
|
$(1) -Werror $(2) $(3) -c -x c /dev/null -o "$$TMP",$(3),$(4))
|
||||||
|
|
||||||
# Do not attempt to build with gcc plugins during cc-option tests.
|
# Do not attempt to build with gcc plugins during cc-option tests.
|
||||||
@ -204,23 +130,23 @@ hostcc-option = $(call __cc-option, $(HOSTCC),\
|
|||||||
|
|
||||||
# cc-option-yn
|
# cc-option-yn
|
||||||
# Usage: flag := $(call cc-option-yn,-march=winchip-c6)
|
# Usage: flag := $(call cc-option-yn,-march=winchip-c6)
|
||||||
cc-option-yn = $(call try-run-cached,\
|
cc-option-yn = $(call try-run,\
|
||||||
$(CC) -Werror $(KBUILD_CPPFLAGS) $(CC_OPTION_CFLAGS) $(1) -c -x c /dev/null -o "$$TMP",y,n)
|
$(CC) -Werror $(KBUILD_CPPFLAGS) $(CC_OPTION_CFLAGS) $(1) -c -x c /dev/null -o "$$TMP",y,n)
|
||||||
|
|
||||||
# cc-disable-warning
|
# cc-disable-warning
|
||||||
# Usage: cflags-y += $(call cc-disable-warning,unused-but-set-variable)
|
# Usage: cflags-y += $(call cc-disable-warning,unused-but-set-variable)
|
||||||
cc-disable-warning = $(call try-run-cached,\
|
cc-disable-warning = $(call try-run,\
|
||||||
$(CC) -Werror $(KBUILD_CPPFLAGS) $(CC_OPTION_CFLAGS) -W$(strip $(1)) -c -x c /dev/null -o "$$TMP",-Wno-$(strip $(1)))
|
$(CC) -Werror $(KBUILD_CPPFLAGS) $(CC_OPTION_CFLAGS) -W$(strip $(1)) -c -x c /dev/null -o "$$TMP",-Wno-$(strip $(1)))
|
||||||
|
|
||||||
# cc-name
|
# cc-name
|
||||||
# Expands to either gcc or clang
|
# Expands to either gcc or clang
|
||||||
cc-name = $(call shell-cached,$(CC) -v 2>&1 | grep -q "clang version" && echo clang || echo gcc)
|
cc-name = $(shell $(CC) -v 2>&1 | grep -q "clang version" && echo clang || echo gcc)
|
||||||
|
|
||||||
# cc-version
|
# cc-version
|
||||||
cc-version = $(call shell-cached,$(CONFIG_SHELL) $(srctree)/scripts/gcc-version.sh $(CC))
|
cc-version = $(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-version.sh $(CC))
|
||||||
|
|
||||||
# cc-fullversion
|
# cc-fullversion
|
||||||
cc-fullversion = $(call shell-cached,$(CONFIG_SHELL) \
|
cc-fullversion = $(shell $(CONFIG_SHELL) \
|
||||||
$(srctree)/scripts/gcc-version.sh -p $(CC))
|
$(srctree)/scripts/gcc-version.sh -p $(CC))
|
||||||
|
|
||||||
# cc-ifversion
|
# cc-ifversion
|
||||||
@ -233,21 +159,21 @@ cc-if-fullversion = $(shell [ $(cc-fullversion) $(1) $(2) ] && echo $(3) || echo
|
|||||||
|
|
||||||
# cc-ldoption
|
# cc-ldoption
|
||||||
# Usage: ldflags += $(call cc-ldoption, -Wl$(comma)--hash-style=both)
|
# Usage: ldflags += $(call cc-ldoption, -Wl$(comma)--hash-style=both)
|
||||||
cc-ldoption = $(call try-run-cached,\
|
cc-ldoption = $(call try-run,\
|
||||||
$(CC) $(1) $(KBUILD_CPPFLAGS) $(CC_OPTION_CFLAGS) -nostdlib -x c /dev/null -o "$$TMP",$(1),$(2))
|
$(CC) $(1) $(KBUILD_CPPFLAGS) $(CC_OPTION_CFLAGS) -nostdlib -x c /dev/null -o "$$TMP",$(1),$(2))
|
||||||
|
|
||||||
# ld-option
|
# ld-option
|
||||||
# Usage: LDFLAGS += $(call ld-option, -X)
|
# Usage: LDFLAGS += $(call ld-option, -X)
|
||||||
ld-option = $(call try-run-cached, $(LD) $(LDFLAGS) $(1) -v,$(1),$(2))
|
ld-option = $(call try-run, $(LD) $(LDFLAGS) $(1) -v,$(1),$(2))
|
||||||
|
|
||||||
# ar-option
|
# ar-option
|
||||||
# Usage: KBUILD_ARFLAGS := $(call ar-option,D)
|
# Usage: KBUILD_ARFLAGS := $(call ar-option,D)
|
||||||
# Important: no spaces around options
|
# Important: no spaces around options
|
||||||
ar-option = $(call try-run-cached, $(AR) rc$(1) "$$TMP",$(1),$(2))
|
ar-option = $(call try-run, $(AR) rc$(1) "$$TMP",$(1),$(2))
|
||||||
|
|
||||||
# ld-version
|
# ld-version
|
||||||
# Note this is mainly for HJ Lu's 3 number binutil versions
|
# Note this is mainly for HJ Lu's 3 number binutil versions
|
||||||
ld-version = $(call shell-cached,$(LD) --version | $(srctree)/scripts/ld-version.sh)
|
ld-version = $(shell $(LD) --version | $(srctree)/scripts/ld-version.sh)
|
||||||
|
|
||||||
# ld-ifversion
|
# ld-ifversion
|
||||||
# Usage: $(call ld-ifversion, -ge, 22252, y)
|
# Usage: $(call ld-ifversion, -ge, 22252, y)
|
||||||
|
27
scripts/Kconfig.include
Normal file
27
scripts/Kconfig.include
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
# Kconfig helper macros
|
||||||
|
|
||||||
|
# Convenient variables
|
||||||
|
comma := ,
|
||||||
|
quote := "
|
||||||
|
squote := '
|
||||||
|
empty :=
|
||||||
|
space := $(empty) $(empty)
|
||||||
|
dollar := $
|
||||||
|
right_paren := )
|
||||||
|
left_paren := (
|
||||||
|
|
||||||
|
# $(if-success,<command>,<then>,<else>)
|
||||||
|
# Return <then> if <command> exits with 0, <else> otherwise.
|
||||||
|
if-success = $(shell,{ $(1); } >/dev/null 2>&1 && echo "$(2)" || echo "$(3)")
|
||||||
|
|
||||||
|
# $(success,<command>)
|
||||||
|
# Return y if <command> exits with 0, n otherwise
|
||||||
|
success = $(if-success,$(1),y,n)
|
||||||
|
|
||||||
|
# $(cc-option,<flag>)
|
||||||
|
# Return y if the compiler supports <flag>, n otherwise
|
||||||
|
cc-option = $(success,$(CC) -Werror $(1) -E -x c /dev/null -o /dev/null)
|
||||||
|
|
||||||
|
# $(ld-option,<flag>)
|
||||||
|
# Return y if the linker supports <flag>, n otherwise
|
||||||
|
ld-option = $(success,$(LD) -v $(1))
|
4
scripts/kconfig/.gitignore
vendored
4
scripts/kconfig/.gitignore
vendored
@ -2,9 +2,6 @@
|
|||||||
# Generated files
|
# Generated files
|
||||||
#
|
#
|
||||||
*.moc
|
*.moc
|
||||||
gconf.glade.h
|
|
||||||
*.pot
|
|
||||||
*.mo
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# configuration programs
|
# configuration programs
|
||||||
@ -14,4 +11,3 @@ mconf
|
|||||||
nconf
|
nconf
|
||||||
qconf
|
qconf
|
||||||
gconf
|
gconf
|
||||||
kxgettext
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
# Kernel configuration targets
|
# Kernel configuration targets
|
||||||
# These targets are used from top-level makefile
|
# These targets are used from top-level makefile
|
||||||
|
|
||||||
PHONY += xconfig gconfig menuconfig config syncconfig update-po-config \
|
PHONY += xconfig gconfig menuconfig config syncconfig \
|
||||||
localmodconfig localyesconfig
|
localmodconfig localyesconfig
|
||||||
|
|
||||||
ifdef KBUILD_KCONFIG
|
ifdef KBUILD_KCONFIG
|
||||||
@ -55,29 +55,6 @@ localyesconfig localmodconfig: $(obj)/conf
|
|||||||
fi
|
fi
|
||||||
$(Q)rm -f .tmp.config
|
$(Q)rm -f .tmp.config
|
||||||
|
|
||||||
# Create new linux.pot file
|
|
||||||
# Adjust charset to UTF-8 in .po file to accept UTF-8 in Kconfig files
|
|
||||||
update-po-config: $(obj)/kxgettext $(obj)/gconf.glade.h
|
|
||||||
$(Q)$(kecho) " GEN config.pot"
|
|
||||||
$(Q)xgettext --default-domain=linux \
|
|
||||||
--add-comments --keyword=_ --keyword=N_ \
|
|
||||||
--from-code=UTF-8 \
|
|
||||||
--files-from=$(srctree)/scripts/kconfig/POTFILES.in \
|
|
||||||
--directory=$(srctree) --directory=$(objtree) \
|
|
||||||
--output $(obj)/config.pot
|
|
||||||
$(Q)sed -i s/CHARSET/UTF-8/ $(obj)/config.pot
|
|
||||||
$(Q)(for i in `ls $(srctree)/arch/*/Kconfig \
|
|
||||||
$(srctree)/arch/*/um/Kconfig`; \
|
|
||||||
do \
|
|
||||||
$(kecho) " GEN $$i"; \
|
|
||||||
$(obj)/kxgettext $$i \
|
|
||||||
>> $(obj)/config.pot; \
|
|
||||||
done )
|
|
||||||
$(Q)$(kecho) " GEN linux.pot"
|
|
||||||
$(Q)msguniq --sort-by-file --to-code=UTF-8 $(obj)/config.pot \
|
|
||||||
--output $(obj)/linux.pot
|
|
||||||
$(Q)rm -f $(obj)/config.pot
|
|
||||||
|
|
||||||
# These targets map 1:1 to the commandline options of 'conf'
|
# These targets map 1:1 to the commandline options of 'conf'
|
||||||
simple-targets := oldconfig allnoconfig allyesconfig allmodconfig \
|
simple-targets := oldconfig allnoconfig allyesconfig allmodconfig \
|
||||||
alldefconfig randconfig listnewconfig olddefconfig
|
alldefconfig randconfig listnewconfig olddefconfig
|
||||||
@ -151,8 +128,7 @@ clean-dirs += tests/.cache
|
|||||||
# Help text used by make help
|
# Help text used by make help
|
||||||
help:
|
help:
|
||||||
@echo ' config - Update current config utilising a line-oriented program'
|
@echo ' config - Update current config utilising a line-oriented program'
|
||||||
@echo ' nconfig - Update current config utilising a ncurses menu based'
|
@echo ' nconfig - Update current config utilising a ncurses menu based program'
|
||||||
@echo ' program'
|
|
||||||
@echo ' menuconfig - Update current config utilising a menu based program'
|
@echo ' menuconfig - Update current config utilising a menu based program'
|
||||||
@echo ' xconfig - Update current config utilising a Qt based front-end'
|
@echo ' xconfig - Update current config utilising a Qt based front-end'
|
||||||
@echo ' gconfig - Update current config utilising a GTK+ based front-end'
|
@echo ' gconfig - Update current config utilising a GTK+ based front-end'
|
||||||
@ -172,141 +148,77 @@ help:
|
|||||||
@echo ' kvmconfig - Enable additional options for kvm guest kernel support'
|
@echo ' kvmconfig - Enable additional options for kvm guest kernel support'
|
||||||
@echo ' xenconfig - Enable additional options for xen dom0 and guest kernel support'
|
@echo ' xenconfig - Enable additional options for xen dom0 and guest kernel support'
|
||||||
@echo ' tinyconfig - Configure the tiniest possible kernel'
|
@echo ' tinyconfig - Configure the tiniest possible kernel'
|
||||||
|
@echo ' testconfig - Run Kconfig unit tests (requires python3 and pytest)'
|
||||||
# lxdialog stuff
|
|
||||||
check-lxdialog := $(srctree)/$(src)/lxdialog/check-lxdialog.sh
|
|
||||||
|
|
||||||
# Use recursively expanded variables so we do not call gcc unless
|
|
||||||
# we really need to do so. (Do not call gcc as part of make mrproper)
|
|
||||||
HOST_EXTRACFLAGS += $(shell $(CONFIG_SHELL) $(check-lxdialog) -ccflags) \
|
|
||||||
-DLOCALE
|
|
||||||
|
|
||||||
# ===========================================================================
|
# ===========================================================================
|
||||||
# Shared Makefile for the various kconfig executables:
|
# Shared Makefile for the various kconfig executables:
|
||||||
# conf: Used for defconfig, oldconfig and related targets
|
# conf: Used for defconfig, oldconfig and related targets
|
||||||
# nconf: Used for the nconfig target.
|
|
||||||
# Utilizes ncurses
|
|
||||||
# mconf: Used for the menuconfig target
|
|
||||||
# Utilizes the lxdialog package
|
|
||||||
# qconf: Used for the xconfig target
|
|
||||||
# Based on Qt which needs to be installed to compile it
|
|
||||||
# gconf: Used for the gconfig target
|
|
||||||
# Based on GTK+ which needs to be installed to compile it
|
|
||||||
# object files used by all kconfig flavours
|
# object files used by all kconfig flavours
|
||||||
|
|
||||||
lxdialog := lxdialog/checklist.o lxdialog/util.o lxdialog/inputbox.o
|
|
||||||
lxdialog += lxdialog/textbox.o lxdialog/yesno.o lxdialog/menubox.o
|
|
||||||
|
|
||||||
conf-objs := conf.o zconf.tab.o
|
conf-objs := conf.o zconf.tab.o
|
||||||
mconf-objs := mconf.o zconf.tab.o $(lxdialog)
|
|
||||||
nconf-objs := nconf.o zconf.tab.o nconf.gui.o
|
|
||||||
kxgettext-objs := kxgettext.o zconf.tab.o
|
|
||||||
qconf-cxxobjs := qconf.o
|
|
||||||
qconf-objs := zconf.tab.o
|
|
||||||
gconf-objs := gconf.o zconf.tab.o
|
|
||||||
|
|
||||||
hostprogs-y := conf nconf mconf kxgettext qconf gconf
|
hostprogs-y := conf
|
||||||
|
|
||||||
targets += zconf.lex.c
|
targets += zconf.lex.c
|
||||||
clean-files := qconf.moc .tmp_qtcheck .tmp_gtkcheck
|
|
||||||
clean-files += gconf.glade.h
|
|
||||||
clean-files += config.pot linux.pot
|
|
||||||
|
|
||||||
# Check that we have the required ncurses stuff installed for lxdialog (menuconfig)
|
|
||||||
PHONY += $(obj)/dochecklxdialog
|
|
||||||
$(addprefix $(obj)/, mconf.o $(lxdialog)): $(obj)/dochecklxdialog
|
|
||||||
$(obj)/dochecklxdialog:
|
|
||||||
$(Q)$(CONFIG_SHELL) $(check-lxdialog) -check $(HOSTCC) $(HOST_EXTRACFLAGS) $(HOSTLOADLIBES_mconf)
|
|
||||||
|
|
||||||
always := dochecklxdialog
|
|
||||||
|
|
||||||
# Add environment specific flags
|
|
||||||
HOST_EXTRACFLAGS += $(shell $(CONFIG_SHELL) $(srctree)/$(src)/check.sh $(HOSTCC) $(HOSTCFLAGS))
|
|
||||||
HOST_EXTRACXXFLAGS += $(shell $(CONFIG_SHELL) $(srctree)/$(src)/check.sh $(HOSTCXX) $(HOSTCXXFLAGS))
|
|
||||||
|
|
||||||
# generated files seem to need this to find local include files
|
# generated files seem to need this to find local include files
|
||||||
HOSTCFLAGS_zconf.lex.o := -I$(src)
|
HOSTCFLAGS_zconf.lex.o := -I$(src)
|
||||||
HOSTCFLAGS_zconf.tab.o := -I$(src)
|
HOSTCFLAGS_zconf.tab.o := -I$(src)
|
||||||
|
|
||||||
HOSTLOADLIBES_qconf = $(KC_QT_LIBS)
|
# nconf: Used for the nconfig target based on ncurses
|
||||||
HOSTCXXFLAGS_qconf.o = $(KC_QT_CFLAGS)
|
hostprogs-y += nconf
|
||||||
|
nconf-objs := nconf.o zconf.tab.o nconf.gui.o
|
||||||
|
|
||||||
HOSTLOADLIBES_gconf = `pkg-config --libs gtk+-2.0 gmodule-2.0 libglade-2.0`
|
HOSTLOADLIBES_nconf = $(shell . $(obj)/.nconf-cfg && echo $$libs)
|
||||||
HOSTCFLAGS_gconf.o = `pkg-config --cflags gtk+-2.0 gmodule-2.0 libglade-2.0` \
|
HOSTCFLAGS_nconf.o = $(shell . $(obj)/.nconf-cfg && echo $$cflags)
|
||||||
-Wno-missing-prototypes
|
HOSTCFLAGS_nconf.gui.o = $(shell . $(obj)/.nconf-cfg && echo $$cflags)
|
||||||
|
|
||||||
HOSTLOADLIBES_mconf = $(shell $(CONFIG_SHELL) $(check-lxdialog) -ldflags $(HOSTCC))
|
$(obj)/nconf.o: $(obj)/.nconf-cfg
|
||||||
|
|
||||||
HOSTLOADLIBES_nconf = $(shell \
|
# mconf: Used for the menuconfig target based on lxdialog
|
||||||
pkg-config --libs menuw panelw ncursesw 2>/dev/null \
|
hostprogs-y += mconf
|
||||||
|| pkg-config --libs menu panel ncurses 2>/dev/null \
|
lxdialog := checklist.o inputbox.o menubox.o textbox.o util.o yesno.o
|
||||||
|| echo "-lmenu -lpanel -lncurses" )
|
mconf-objs := mconf.o zconf.tab.o $(addprefix lxdialog/, $(lxdialog))
|
||||||
$(obj)/qconf.o: $(obj)/.tmp_qtcheck
|
|
||||||
|
|
||||||
ifeq ($(MAKECMDGOALS),xconfig)
|
HOSTLOADLIBES_mconf = $(shell . $(obj)/.mconf-cfg && echo $$libs)
|
||||||
$(obj)/.tmp_qtcheck: $(src)/Makefile
|
$(foreach f, mconf.o $(lxdialog), \
|
||||||
-include $(obj)/.tmp_qtcheck
|
$(eval HOSTCFLAGS_$f = $$(shell . $(obj)/.mconf-cfg && echo $$$$cflags)))
|
||||||
|
|
||||||
# Qt needs some extra effort...
|
$(addprefix $(obj)/, mconf.o $(lxdialog)): $(obj)/.mconf-cfg
|
||||||
$(obj)/.tmp_qtcheck:
|
|
||||||
@set -e; $(kecho) " CHECK qt"; \
|
|
||||||
if pkg-config --exists Qt5Core; then \
|
|
||||||
cflags="-std=c++11 -fPIC `pkg-config --cflags Qt5Core Qt5Gui Qt5Widgets`"; \
|
|
||||||
libs=`pkg-config --libs Qt5Core Qt5Gui Qt5Widgets`; \
|
|
||||||
moc=`pkg-config --variable=host_bins Qt5Core`/moc; \
|
|
||||||
elif pkg-config --exists QtCore; then \
|
|
||||||
cflags=`pkg-config --cflags QtCore QtGui`; \
|
|
||||||
libs=`pkg-config --libs QtCore QtGui`; \
|
|
||||||
moc=`pkg-config --variable=moc_location QtCore`; \
|
|
||||||
else \
|
|
||||||
echo >&2 "*"; \
|
|
||||||
echo >&2 "* Could not find Qt via pkg-config."; \
|
|
||||||
echo >&2 "* Please install either Qt 4.8 or 5.x. and make sure it's in PKG_CONFIG_PATH"; \
|
|
||||||
echo >&2 "*"; \
|
|
||||||
exit 1; \
|
|
||||||
fi; \
|
|
||||||
echo "KC_QT_CFLAGS=$$cflags" > $@; \
|
|
||||||
echo "KC_QT_LIBS=$$libs" >> $@; \
|
|
||||||
echo "KC_QT_MOC=$$moc" >> $@
|
|
||||||
endif
|
|
||||||
|
|
||||||
$(obj)/gconf.o: $(obj)/.tmp_gtkcheck
|
# qconf: Used for the xconfig target based on Qt
|
||||||
|
hostprogs-y += qconf
|
||||||
|
qconf-cxxobjs := qconf.o
|
||||||
|
qconf-objs := zconf.tab.o
|
||||||
|
|
||||||
ifeq ($(MAKECMDGOALS),gconfig)
|
HOSTLOADLIBES_qconf = $(shell . $(obj)/.qconf-cfg && echo $$libs)
|
||||||
-include $(obj)/.tmp_gtkcheck
|
HOSTCXXFLAGS_qconf.o = $(shell . $(obj)/.qconf-cfg && echo $$cflags)
|
||||||
|
|
||||||
# GTK+ needs some extra effort, too...
|
$(obj)/qconf.o: $(obj)/.qconf-cfg $(obj)/qconf.moc
|
||||||
$(obj)/.tmp_gtkcheck:
|
|
||||||
@if `pkg-config --exists gtk+-2.0 gmodule-2.0 libglade-2.0`; then \
|
quiet_cmd_moc = MOC $@
|
||||||
if `pkg-config --atleast-version=2.0.0 gtk+-2.0`; then \
|
cmd_moc = $(shell . $(obj)/.qconf-cfg && echo $$moc) -i $< -o $@
|
||||||
touch $@; \
|
|
||||||
else \
|
$(obj)/%.moc: $(src)/%.h $(obj)/.qconf-cfg
|
||||||
echo >&2 "*"; \
|
$(call cmd,moc)
|
||||||
echo >&2 "* GTK+ is present but version >= 2.0.0 is required."; \
|
|
||||||
echo >&2 "*"; \
|
# gconf: Used for the gconfig target based on GTK+
|
||||||
false; \
|
hostprogs-y += gconf
|
||||||
fi \
|
gconf-objs := gconf.o zconf.tab.o
|
||||||
else \
|
|
||||||
echo >&2 "*"; \
|
HOSTLOADLIBES_gconf = $(shell . $(obj)/.gconf-cfg && echo $$libs)
|
||||||
echo >&2 "* Unable to find the GTK+ installation. Please make sure that"; \
|
HOSTCFLAGS_gconf.o = $(shell . $(obj)/.gconf-cfg && echo $$cflags)
|
||||||
echo >&2 "* the GTK+ 2.0 development package is correctly installed..."; \
|
|
||||||
echo >&2 "* You need gtk+-2.0, glib-2.0 and libglade-2.0."; \
|
$(obj)/gconf.o: $(obj)/.gconf-cfg
|
||||||
echo >&2 "*"; \
|
|
||||||
false; \
|
|
||||||
fi
|
|
||||||
endif
|
|
||||||
|
|
||||||
$(obj)/zconf.tab.o: $(obj)/zconf.lex.c
|
$(obj)/zconf.tab.o: $(obj)/zconf.lex.c
|
||||||
|
|
||||||
$(obj)/qconf.o: $(obj)/qconf.moc
|
# check if necessary packages are available, and configure build flags
|
||||||
|
define filechk_conf_cfg
|
||||||
|
$(CONFIG_SHELL) $<
|
||||||
|
endef
|
||||||
|
|
||||||
quiet_cmd_moc = MOC $@
|
$(obj)/.%conf-cfg: $(src)/%conf-cfg.sh FORCE
|
||||||
cmd_moc = $(KC_QT_MOC) -i $< -o $@
|
$(call filechk,conf_cfg)
|
||||||
|
|
||||||
$(obj)/%.moc: $(src)/%.h $(obj)/.tmp_qtcheck
|
clean-files += .*conf-cfg
|
||||||
$(call cmd,moc)
|
|
||||||
|
|
||||||
# Extract gconf menu items for i18n support
|
|
||||||
$(obj)/gconf.glade.h: $(obj)/gconf.glade
|
|
||||||
$(Q)intltool-extract --type=gettext/glade --srcdir=$(srctree) \
|
|
||||||
$(obj)/gconf.glade
|
|
||||||
|
@ -1,12 +0,0 @@
|
|||||||
scripts/kconfig/lxdialog/checklist.c
|
|
||||||
scripts/kconfig/lxdialog/inputbox.c
|
|
||||||
scripts/kconfig/lxdialog/menubox.c
|
|
||||||
scripts/kconfig/lxdialog/textbox.c
|
|
||||||
scripts/kconfig/lxdialog/util.c
|
|
||||||
scripts/kconfig/lxdialog/yesno.c
|
|
||||||
scripts/kconfig/mconf.c
|
|
||||||
scripts/kconfig/conf.c
|
|
||||||
scripts/kconfig/confdata.c
|
|
||||||
scripts/kconfig/gconf.c
|
|
||||||
scripts/kconfig/gconf.glade.h
|
|
||||||
scripts/kconfig/qconf.cc
|
|
@ -1,14 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
# SPDX-License-Identifier: GPL-2.0
|
|
||||||
# Needed for systems without gettext
|
|
||||||
$* -x c -o /dev/null - > /dev/null 2>&1 << EOF
|
|
||||||
#include <libintl.h>
|
|
||||||
int main()
|
|
||||||
{
|
|
||||||
gettext("");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
EOF
|
|
||||||
if [ ! "$?" -eq "0" ]; then
|
|
||||||
echo -DKBUILD_NO_NLS;
|
|
||||||
fi
|
|
@ -3,7 +3,6 @@
|
|||||||
* Released under the terms of the GNU GPL v2.0.
|
* Released under the terms of the GNU GPL v2.0.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <locale.h>
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
@ -86,7 +85,7 @@ static int conf_askvalue(struct symbol *sym, const char *def)
|
|||||||
enum symbol_type type = sym_get_type(sym);
|
enum symbol_type type = sym_get_type(sym);
|
||||||
|
|
||||||
if (!sym_has_value(sym))
|
if (!sym_has_value(sym))
|
||||||
printf(_("(NEW) "));
|
printf("(NEW) ");
|
||||||
|
|
||||||
line[0] = '\n';
|
line[0] = '\n';
|
||||||
line[1] = 0;
|
line[1] = 0;
|
||||||
@ -133,7 +132,7 @@ static int conf_string(struct menu *menu)
|
|||||||
const char *def;
|
const char *def;
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
printf("%*s%s ", indent - 1, "", _(menu->prompt->text));
|
printf("%*s%s ", indent - 1, "", menu->prompt->text);
|
||||||
printf("(%s) ", sym->name);
|
printf("(%s) ", sym->name);
|
||||||
def = sym_get_string_value(sym);
|
def = sym_get_string_value(sym);
|
||||||
if (sym_get_string_value(sym))
|
if (sym_get_string_value(sym))
|
||||||
@ -166,7 +165,7 @@ static int conf_sym(struct menu *menu)
|
|||||||
tristate oldval, newval;
|
tristate oldval, newval;
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
printf("%*s%s ", indent - 1, "", _(menu->prompt->text));
|
printf("%*s%s ", indent - 1, "", menu->prompt->text);
|
||||||
if (sym->name)
|
if (sym->name)
|
||||||
printf("(%s) ", sym->name);
|
printf("(%s) ", sym->name);
|
||||||
putchar('[');
|
putchar('[');
|
||||||
@ -251,7 +250,7 @@ static int conf_choice(struct menu *menu)
|
|||||||
case no:
|
case no:
|
||||||
return 1;
|
return 1;
|
||||||
case mod:
|
case mod:
|
||||||
printf("%*s%s\n", indent - 1, "", _(menu_get_prompt(menu)));
|
printf("%*s%s\n", indent - 1, "", menu_get_prompt(menu));
|
||||||
return 0;
|
return 0;
|
||||||
case yes:
|
case yes:
|
||||||
break;
|
break;
|
||||||
@ -261,7 +260,7 @@ static int conf_choice(struct menu *menu)
|
|||||||
while (1) {
|
while (1) {
|
||||||
int cnt, def;
|
int cnt, def;
|
||||||
|
|
||||||
printf("%*s%s\n", indent - 1, "", _(menu_get_prompt(menu)));
|
printf("%*s%s\n", indent - 1, "", menu_get_prompt(menu));
|
||||||
def_sym = sym_get_choice_value(sym);
|
def_sym = sym_get_choice_value(sym);
|
||||||
cnt = def = 0;
|
cnt = def = 0;
|
||||||
line[0] = 0;
|
line[0] = 0;
|
||||||
@ -269,7 +268,7 @@ static int conf_choice(struct menu *menu)
|
|||||||
if (!menu_is_visible(child))
|
if (!menu_is_visible(child))
|
||||||
continue;
|
continue;
|
||||||
if (!child->sym) {
|
if (!child->sym) {
|
||||||
printf("%*c %s\n", indent, '*', _(menu_get_prompt(child)));
|
printf("%*c %s\n", indent, '*', menu_get_prompt(child));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
cnt++;
|
cnt++;
|
||||||
@ -278,14 +277,14 @@ static int conf_choice(struct menu *menu)
|
|||||||
printf("%*c", indent, '>');
|
printf("%*c", indent, '>');
|
||||||
} else
|
} else
|
||||||
printf("%*c", indent, ' ');
|
printf("%*c", indent, ' ');
|
||||||
printf(" %d. %s", cnt, _(menu_get_prompt(child)));
|
printf(" %d. %s", cnt, menu_get_prompt(child));
|
||||||
if (child->sym->name)
|
if (child->sym->name)
|
||||||
printf(" (%s)", child->sym->name);
|
printf(" (%s)", child->sym->name);
|
||||||
if (!sym_has_value(child->sym))
|
if (!sym_has_value(child->sym))
|
||||||
printf(_(" (NEW)"));
|
printf(" (NEW)");
|
||||||
printf("\n");
|
printf("\n");
|
||||||
}
|
}
|
||||||
printf(_("%*schoice"), indent - 1, "");
|
printf("%*schoice", indent - 1, "");
|
||||||
if (cnt == 1) {
|
if (cnt == 1) {
|
||||||
printf("[1]: 1\n");
|
printf("[1]: 1\n");
|
||||||
goto conf_childs;
|
goto conf_childs;
|
||||||
@ -372,7 +371,7 @@ static void conf(struct menu *menu)
|
|||||||
if (prompt)
|
if (prompt)
|
||||||
printf("%*c\n%*c %s\n%*c\n",
|
printf("%*c\n%*c %s\n%*c\n",
|
||||||
indent, '*',
|
indent, '*',
|
||||||
indent, '*', _(prompt),
|
indent, '*', prompt,
|
||||||
indent, '*');
|
indent, '*');
|
||||||
default:
|
default:
|
||||||
;
|
;
|
||||||
@ -437,7 +436,7 @@ static void check_conf(struct menu *menu)
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (!conf_cnt++)
|
if (!conf_cnt++)
|
||||||
printf(_("*\n* Restart config...\n*\n"));
|
printf("*\n* Restart config...\n*\n");
|
||||||
rootEntry = menu_get_parent_menu(menu);
|
rootEntry = menu_get_parent_menu(menu);
|
||||||
conf(rootEntry);
|
conf(rootEntry);
|
||||||
}
|
}
|
||||||
@ -498,10 +497,6 @@ int main(int ac, char **av)
|
|||||||
const char *name, *defconfig_file = NULL /* gcc uninit */;
|
const char *name, *defconfig_file = NULL /* gcc uninit */;
|
||||||
struct stat tmpstat;
|
struct stat tmpstat;
|
||||||
|
|
||||||
setlocale(LC_ALL, "");
|
|
||||||
bindtextdomain(PACKAGE, LOCALEDIR);
|
|
||||||
textdomain(PACKAGE);
|
|
||||||
|
|
||||||
tty_stdio = isatty(0) && isatty(1);
|
tty_stdio = isatty(0) && isatty(1);
|
||||||
|
|
||||||
while ((opt = getopt_long(ac, av, "s", long_opts, NULL)) != -1) {
|
while ((opt = getopt_long(ac, av, "s", long_opts, NULL)) != -1) {
|
||||||
@ -559,7 +554,7 @@ int main(int ac, char **av)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (ac == optind) {
|
if (ac == optind) {
|
||||||
fprintf(stderr, _("%s: Kconfig file missing\n"), av[0]);
|
fprintf(stderr, "%s: Kconfig file missing\n", av[0]);
|
||||||
conf_usage(progname);
|
conf_usage(progname);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
@ -569,12 +564,12 @@ int main(int ac, char **av)
|
|||||||
if (sync_kconfig) {
|
if (sync_kconfig) {
|
||||||
name = conf_get_configname();
|
name = conf_get_configname();
|
||||||
if (stat(name, &tmpstat)) {
|
if (stat(name, &tmpstat)) {
|
||||||
fprintf(stderr, _("***\n"
|
fprintf(stderr, "***\n"
|
||||||
"*** Configuration file \"%s\" not found!\n"
|
"*** Configuration file \"%s\" not found!\n"
|
||||||
"***\n"
|
"***\n"
|
||||||
"*** Please run some configurator (e.g. \"make oldconfig\" or\n"
|
"*** Please run some configurator (e.g. \"make oldconfig\" or\n"
|
||||||
"*** \"make menuconfig\" or \"make xconfig\").\n"
|
"*** \"make menuconfig\" or \"make xconfig\").\n"
|
||||||
"***\n"), name);
|
"***\n", name);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -585,9 +580,9 @@ int main(int ac, char **av)
|
|||||||
defconfig_file = conf_get_default_confname();
|
defconfig_file = conf_get_default_confname();
|
||||||
if (conf_read(defconfig_file)) {
|
if (conf_read(defconfig_file)) {
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
_("***\n"
|
"***\n"
|
||||||
"*** Can't find default configuration \"%s\"!\n"
|
"*** Can't find default configuration \"%s\"!\n"
|
||||||
"***\n"),
|
"***\n",
|
||||||
defconfig_file);
|
defconfig_file);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
@ -611,7 +606,7 @@ int main(int ac, char **av)
|
|||||||
if ((strcmp(name, "") != 0) && (strcmp(name, "1") != 0)) {
|
if ((strcmp(name, "") != 0) && (strcmp(name, "1") != 0)) {
|
||||||
if (conf_read_simple(name, S_DEF_USER)) {
|
if (conf_read_simple(name, S_DEF_USER)) {
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
_("*** Can't read seed configuration \"%s\"!\n"),
|
"*** Can't read seed configuration \"%s\"!\n",
|
||||||
name);
|
name);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
@ -628,7 +623,7 @@ int main(int ac, char **av)
|
|||||||
if (conf_read_simple(name, S_DEF_USER) &&
|
if (conf_read_simple(name, S_DEF_USER) &&
|
||||||
conf_read_simple("all.config", S_DEF_USER)) {
|
conf_read_simple("all.config", S_DEF_USER)) {
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
_("*** KCONFIG_ALLCONFIG set, but no \"%s\" or \"all.config\" file found\n"),
|
"*** KCONFIG_ALLCONFIG set, but no \"%s\" or \"all.config\" file found\n",
|
||||||
name);
|
name);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
@ -642,7 +637,7 @@ int main(int ac, char **av)
|
|||||||
name = getenv("KCONFIG_NOSILENTUPDATE");
|
name = getenv("KCONFIG_NOSILENTUPDATE");
|
||||||
if (name && *name) {
|
if (name && *name) {
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
_("\n*** The configuration requires explicit update.\n\n"));
|
"\n*** The configuration requires explicit update.\n\n");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -694,22 +689,22 @@ int main(int ac, char **av)
|
|||||||
* All other commands are only used to generate a config.
|
* All other commands are only used to generate a config.
|
||||||
*/
|
*/
|
||||||
if (conf_get_changed() && conf_write(NULL)) {
|
if (conf_get_changed() && conf_write(NULL)) {
|
||||||
fprintf(stderr, _("\n*** Error during writing of the configuration.\n\n"));
|
fprintf(stderr, "\n*** Error during writing of the configuration.\n\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
if (conf_write_autoconf()) {
|
if (conf_write_autoconf()) {
|
||||||
fprintf(stderr, _("\n*** Error during update of the configuration.\n\n"));
|
fprintf(stderr, "\n*** Error during update of the configuration.\n\n");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
} else if (input_mode == savedefconfig) {
|
} else if (input_mode == savedefconfig) {
|
||||||
if (conf_write_defconfig(defconfig_file)) {
|
if (conf_write_defconfig(defconfig_file)) {
|
||||||
fprintf(stderr, _("n*** Error while saving defconfig to: %s\n\n"),
|
fprintf(stderr, "n*** Error while saving defconfig to: %s\n\n",
|
||||||
defconfig_file);
|
defconfig_file);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
} else if (input_mode != listnewconfig) {
|
} else if (input_mode != listnewconfig) {
|
||||||
if (conf_write(NULL)) {
|
if (conf_write(NULL)) {
|
||||||
fprintf(stderr, _("\n*** Error during writing of the configuration.\n\n"));
|
fprintf(stderr, "\n*** Error during writing of the configuration.\n\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,7 +30,7 @@ static void conf_message(const char *fmt, ...)
|
|||||||
static const char *conf_filename;
|
static const char *conf_filename;
|
||||||
static int conf_lineno, conf_warnings;
|
static int conf_lineno, conf_warnings;
|
||||||
|
|
||||||
const char conf_defname[] = "arch/$ARCH/defconfig";
|
const char conf_defname[] = "arch/$(ARCH)/defconfig";
|
||||||
|
|
||||||
static void conf_warning(const char *fmt, ...)
|
static void conf_warning(const char *fmt, ...)
|
||||||
{
|
{
|
||||||
@ -81,39 +81,13 @@ const char *conf_get_autoconfig_name(void)
|
|||||||
return name ? name : "include/config/auto.conf";
|
return name ? name : "include/config/auto.conf";
|
||||||
}
|
}
|
||||||
|
|
||||||
static char *conf_expand_value(const char *in)
|
|
||||||
{
|
|
||||||
struct symbol *sym;
|
|
||||||
const char *src;
|
|
||||||
static char res_value[SYMBOL_MAXLENGTH];
|
|
||||||
char *dst, name[SYMBOL_MAXLENGTH];
|
|
||||||
|
|
||||||
res_value[0] = 0;
|
|
||||||
dst = name;
|
|
||||||
while ((src = strchr(in, '$'))) {
|
|
||||||
strncat(res_value, in, src - in);
|
|
||||||
src++;
|
|
||||||
dst = name;
|
|
||||||
while (isalnum(*src) || *src == '_')
|
|
||||||
*dst++ = *src++;
|
|
||||||
*dst = 0;
|
|
||||||
sym = sym_lookup(name, 0);
|
|
||||||
sym_calc_value(sym);
|
|
||||||
strcat(res_value, sym_get_string_value(sym));
|
|
||||||
in = src;
|
|
||||||
}
|
|
||||||
strcat(res_value, in);
|
|
||||||
|
|
||||||
return res_value;
|
|
||||||
}
|
|
||||||
|
|
||||||
char *conf_get_default_confname(void)
|
char *conf_get_default_confname(void)
|
||||||
{
|
{
|
||||||
struct stat buf;
|
struct stat buf;
|
||||||
static char fullname[PATH_MAX+1];
|
static char fullname[PATH_MAX+1];
|
||||||
char *env, *name;
|
char *env, *name;
|
||||||
|
|
||||||
name = conf_expand_value(conf_defname);
|
name = expand_string(conf_defname);
|
||||||
env = getenv(SRCTREE);
|
env = getenv(SRCTREE);
|
||||||
if (env) {
|
if (env) {
|
||||||
sprintf(fullname, "%s/%s", env, name);
|
sprintf(fullname, "%s/%s", env, name);
|
||||||
@ -274,10 +248,11 @@ int conf_read_simple(const char *name, int def)
|
|||||||
if (expr_calc_value(prop->visible.expr) == no ||
|
if (expr_calc_value(prop->visible.expr) == no ||
|
||||||
prop->expr->type != E_SYMBOL)
|
prop->expr->type != E_SYMBOL)
|
||||||
continue;
|
continue;
|
||||||
name = conf_expand_value(prop->expr->left.sym->name);
|
sym_calc_value(prop->expr->left.sym);
|
||||||
|
name = sym_get_string_value(prop->expr->left.sym);
|
||||||
in = zconf_fopen(name);
|
in = zconf_fopen(name);
|
||||||
if (in) {
|
if (in) {
|
||||||
conf_message(_("using defaults found in %s"),
|
conf_message("using defaults found in %s",
|
||||||
name);
|
name);
|
||||||
goto load;
|
goto load;
|
||||||
}
|
}
|
||||||
@ -745,7 +720,7 @@ int conf_write(const char *name)
|
|||||||
struct menu *menu;
|
struct menu *menu;
|
||||||
const char *basename;
|
const char *basename;
|
||||||
const char *str;
|
const char *str;
|
||||||
char dirname[PATH_MAX+1], tmpname[PATH_MAX+1], newname[PATH_MAX+1];
|
char dirname[PATH_MAX+1], tmpname[PATH_MAX+22], newname[PATH_MAX+8];
|
||||||
char *env;
|
char *env;
|
||||||
|
|
||||||
dirname[0] = 0;
|
dirname[0] = 0;
|
||||||
@ -831,7 +806,7 @@ int conf_write(const char *name)
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
conf_message(_("configuration written to %s"), newname);
|
conf_message("configuration written to %s", newname);
|
||||||
|
|
||||||
sym_set_change_count(0);
|
sym_set_change_count(0);
|
||||||
|
|
||||||
|
23
scripts/kconfig/gconf-cfg.sh
Executable file
23
scripts/kconfig/gconf-cfg.sh
Executable file
@ -0,0 +1,23 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
|
PKG="gtk+-2.0 gmodule-2.0 libglade-2.0"
|
||||||
|
|
||||||
|
if ! pkg-config --exists $PKG; then
|
||||||
|
echo >&2 "*"
|
||||||
|
echo >&2 "* Unable to find the GTK+ installation. Please make sure that"
|
||||||
|
echo >&2 "* the GTK+ 2.0 development package is correctly installed."
|
||||||
|
echo >&2 "* You need $PKG"
|
||||||
|
echo >&2 "*"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! pkg-config --atleast-version=2.0.0 gtk+-2.0; then
|
||||||
|
echo >&2 "*"
|
||||||
|
echo >&2 "* GTK+ is present but version >= 2.0.0 is required."
|
||||||
|
echo >&2 "*"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo cflags=\"$(pkg-config --cflags $PKG)\"
|
||||||
|
echo libs=\"$(pkg-config --libs $PKG)\"
|
@ -137,7 +137,7 @@ void init_main_window(const gchar * glade_file)
|
|||||||
|
|
||||||
xml = glade_xml_new(glade_file, "window1", NULL);
|
xml = glade_xml_new(glade_file, "window1", NULL);
|
||||||
if (!xml)
|
if (!xml)
|
||||||
g_error(_("GUI loading failed !\n"));
|
g_error("GUI loading failed !\n");
|
||||||
glade_xml_signal_autoconnect(xml);
|
glade_xml_signal_autoconnect(xml);
|
||||||
|
|
||||||
main_wnd = glade_xml_get_widget(xml, "window1");
|
main_wnd = glade_xml_get_widget(xml, "window1");
|
||||||
@ -233,7 +233,7 @@ void init_left_tree(void)
|
|||||||
|
|
||||||
column = gtk_tree_view_column_new();
|
column = gtk_tree_view_column_new();
|
||||||
gtk_tree_view_append_column(view, column);
|
gtk_tree_view_append_column(view, column);
|
||||||
gtk_tree_view_column_set_title(column, _("Options"));
|
gtk_tree_view_column_set_title(column, "Options");
|
||||||
|
|
||||||
renderer = gtk_cell_renderer_toggle_new();
|
renderer = gtk_cell_renderer_toggle_new();
|
||||||
gtk_tree_view_column_pack_start(GTK_TREE_VIEW_COLUMN(column),
|
gtk_tree_view_column_pack_start(GTK_TREE_VIEW_COLUMN(column),
|
||||||
@ -276,7 +276,7 @@ void init_right_tree(void)
|
|||||||
|
|
||||||
column = gtk_tree_view_column_new();
|
column = gtk_tree_view_column_new();
|
||||||
gtk_tree_view_append_column(view, column);
|
gtk_tree_view_append_column(view, column);
|
||||||
gtk_tree_view_column_set_title(column, _("Options"));
|
gtk_tree_view_column_set_title(column, "Options");
|
||||||
|
|
||||||
renderer = gtk_cell_renderer_pixbuf_new();
|
renderer = gtk_cell_renderer_pixbuf_new();
|
||||||
gtk_tree_view_column_pack_start(GTK_TREE_VIEW_COLUMN(column),
|
gtk_tree_view_column_pack_start(GTK_TREE_VIEW_COLUMN(column),
|
||||||
@ -305,7 +305,7 @@ void init_right_tree(void)
|
|||||||
|
|
||||||
renderer = gtk_cell_renderer_text_new();
|
renderer = gtk_cell_renderer_text_new();
|
||||||
gtk_tree_view_insert_column_with_attributes(view, -1,
|
gtk_tree_view_insert_column_with_attributes(view, -1,
|
||||||
_("Name"), renderer,
|
"Name", renderer,
|
||||||
"text", COL_NAME,
|
"text", COL_NAME,
|
||||||
"foreground-gdk",
|
"foreground-gdk",
|
||||||
COL_COLOR, NULL);
|
COL_COLOR, NULL);
|
||||||
@ -329,7 +329,7 @@ void init_right_tree(void)
|
|||||||
COL_COLOR, NULL);
|
COL_COLOR, NULL);
|
||||||
renderer = gtk_cell_renderer_text_new();
|
renderer = gtk_cell_renderer_text_new();
|
||||||
gtk_tree_view_insert_column_with_attributes(view, -1,
|
gtk_tree_view_insert_column_with_attributes(view, -1,
|
||||||
_("Value"), renderer,
|
"Value", renderer,
|
||||||
"text", COL_VALUE,
|
"text", COL_VALUE,
|
||||||
"editable",
|
"editable",
|
||||||
COL_EDIT,
|
COL_EDIT,
|
||||||
@ -368,7 +368,7 @@ static void text_insert_help(struct menu *menu)
|
|||||||
{
|
{
|
||||||
GtkTextBuffer *buffer;
|
GtkTextBuffer *buffer;
|
||||||
GtkTextIter start, end;
|
GtkTextIter start, end;
|
||||||
const char *prompt = _(menu_get_prompt(menu));
|
const char *prompt = menu_get_prompt(menu);
|
||||||
struct gstr help = str_new();
|
struct gstr help = str_new();
|
||||||
|
|
||||||
menu_get_ext_help(menu, &help);
|
menu_get_ext_help(menu, &help);
|
||||||
@ -422,7 +422,7 @@ gboolean on_window1_delete_event(GtkWidget * widget, GdkEvent * event,
|
|||||||
if (!conf_get_changed())
|
if (!conf_get_changed())
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
dialog = gtk_dialog_new_with_buttons(_("Warning !"),
|
dialog = gtk_dialog_new_with_buttons("Warning !",
|
||||||
GTK_WINDOW(main_wnd),
|
GTK_WINDOW(main_wnd),
|
||||||
(GtkDialogFlags)
|
(GtkDialogFlags)
|
||||||
(GTK_DIALOG_MODAL |
|
(GTK_DIALOG_MODAL |
|
||||||
@ -436,7 +436,7 @@ gboolean on_window1_delete_event(GtkWidget * widget, GdkEvent * event,
|
|||||||
gtk_dialog_set_default_response(GTK_DIALOG(dialog),
|
gtk_dialog_set_default_response(GTK_DIALOG(dialog),
|
||||||
GTK_RESPONSE_CANCEL);
|
GTK_RESPONSE_CANCEL);
|
||||||
|
|
||||||
label = gtk_label_new(_("\nSave configuration ?\n"));
|
label = gtk_label_new("\nSave configuration ?\n");
|
||||||
gtk_container_add(GTK_CONTAINER(GTK_DIALOG(dialog)->vbox), label);
|
gtk_container_add(GTK_CONTAINER(GTK_DIALOG(dialog)->vbox), label);
|
||||||
gtk_widget_show(label);
|
gtk_widget_show(label);
|
||||||
|
|
||||||
@ -496,7 +496,7 @@ load_filename(GtkFileSelection * file_selector, gpointer user_data)
|
|||||||
(user_data));
|
(user_data));
|
||||||
|
|
||||||
if (conf_read(fn))
|
if (conf_read(fn))
|
||||||
text_insert_msg(_("Error"), _("Unable to load configuration !"));
|
text_insert_msg("Error", "Unable to load configuration !");
|
||||||
else
|
else
|
||||||
display_tree(&rootmenu);
|
display_tree(&rootmenu);
|
||||||
}
|
}
|
||||||
@ -505,7 +505,7 @@ void on_load1_activate(GtkMenuItem * menuitem, gpointer user_data)
|
|||||||
{
|
{
|
||||||
GtkWidget *fs;
|
GtkWidget *fs;
|
||||||
|
|
||||||
fs = gtk_file_selection_new(_("Load file..."));
|
fs = gtk_file_selection_new("Load file...");
|
||||||
g_signal_connect(GTK_OBJECT(GTK_FILE_SELECTION(fs)->ok_button),
|
g_signal_connect(GTK_OBJECT(GTK_FILE_SELECTION(fs)->ok_button),
|
||||||
"clicked",
|
"clicked",
|
||||||
G_CALLBACK(load_filename), (gpointer) fs);
|
G_CALLBACK(load_filename), (gpointer) fs);
|
||||||
@ -524,7 +524,7 @@ void on_load1_activate(GtkMenuItem * menuitem, gpointer user_data)
|
|||||||
void on_save_activate(GtkMenuItem * menuitem, gpointer user_data)
|
void on_save_activate(GtkMenuItem * menuitem, gpointer user_data)
|
||||||
{
|
{
|
||||||
if (conf_write(NULL))
|
if (conf_write(NULL))
|
||||||
text_insert_msg(_("Error"), _("Unable to save configuration !"));
|
text_insert_msg("Error", "Unable to save configuration !");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -537,7 +537,7 @@ store_filename(GtkFileSelection * file_selector, gpointer user_data)
|
|||||||
(user_data));
|
(user_data));
|
||||||
|
|
||||||
if (conf_write(fn))
|
if (conf_write(fn))
|
||||||
text_insert_msg(_("Error"), _("Unable to save configuration !"));
|
text_insert_msg("Error", "Unable to save configuration !");
|
||||||
|
|
||||||
gtk_widget_destroy(GTK_WIDGET(user_data));
|
gtk_widget_destroy(GTK_WIDGET(user_data));
|
||||||
}
|
}
|
||||||
@ -546,7 +546,7 @@ void on_save_as1_activate(GtkMenuItem * menuitem, gpointer user_data)
|
|||||||
{
|
{
|
||||||
GtkWidget *fs;
|
GtkWidget *fs;
|
||||||
|
|
||||||
fs = gtk_file_selection_new(_("Save file as..."));
|
fs = gtk_file_selection_new("Save file as...");
|
||||||
g_signal_connect(GTK_OBJECT(GTK_FILE_SELECTION(fs)->ok_button),
|
g_signal_connect(GTK_OBJECT(GTK_FILE_SELECTION(fs)->ok_button),
|
||||||
"clicked",
|
"clicked",
|
||||||
G_CALLBACK(store_filename), (gpointer) fs);
|
G_CALLBACK(store_filename), (gpointer) fs);
|
||||||
@ -639,7 +639,7 @@ on_set_option_mode3_activate(GtkMenuItem *menuitem, gpointer user_data)
|
|||||||
void on_introduction1_activate(GtkMenuItem * menuitem, gpointer user_data)
|
void on_introduction1_activate(GtkMenuItem * menuitem, gpointer user_data)
|
||||||
{
|
{
|
||||||
GtkWidget *dialog;
|
GtkWidget *dialog;
|
||||||
const gchar *intro_text = _(
|
const gchar *intro_text =
|
||||||
"Welcome to gkc, the GTK+ graphical configuration tool\n"
|
"Welcome to gkc, the GTK+ graphical configuration tool\n"
|
||||||
"For each option, a blank box indicates the feature is disabled, a\n"
|
"For each option, a blank box indicates the feature is disabled, a\n"
|
||||||
"check indicates it is enabled, and a dot indicates that it is to\n"
|
"check indicates it is enabled, and a dot indicates that it is to\n"
|
||||||
@ -654,7 +654,7 @@ void on_introduction1_activate(GtkMenuItem * menuitem, gpointer user_data)
|
|||||||
"option.\n"
|
"option.\n"
|
||||||
"\n"
|
"\n"
|
||||||
"Toggling Show Debug Info under the Options menu will show \n"
|
"Toggling Show Debug Info under the Options menu will show \n"
|
||||||
"the dependencies, which you can then match by examining other options.");
|
"the dependencies, which you can then match by examining other options.";
|
||||||
|
|
||||||
dialog = gtk_message_dialog_new(GTK_WINDOW(main_wnd),
|
dialog = gtk_message_dialog_new(GTK_WINDOW(main_wnd),
|
||||||
GTK_DIALOG_DESTROY_WITH_PARENT,
|
GTK_DIALOG_DESTROY_WITH_PARENT,
|
||||||
@ -671,8 +671,8 @@ void on_about1_activate(GtkMenuItem * menuitem, gpointer user_data)
|
|||||||
{
|
{
|
||||||
GtkWidget *dialog;
|
GtkWidget *dialog;
|
||||||
const gchar *about_text =
|
const gchar *about_text =
|
||||||
_("gkc is copyright (c) 2002 Romain Lievin <roms@lpg.ticalc.org>.\n"
|
"gkc is copyright (c) 2002 Romain Lievin <roms@lpg.ticalc.org>.\n"
|
||||||
"Based on the source code from Roman Zippel.\n");
|
"Based on the source code from Roman Zippel.\n";
|
||||||
|
|
||||||
dialog = gtk_message_dialog_new(GTK_WINDOW(main_wnd),
|
dialog = gtk_message_dialog_new(GTK_WINDOW(main_wnd),
|
||||||
GTK_DIALOG_DESTROY_WITH_PARENT,
|
GTK_DIALOG_DESTROY_WITH_PARENT,
|
||||||
@ -689,9 +689,9 @@ void on_license1_activate(GtkMenuItem * menuitem, gpointer user_data)
|
|||||||
{
|
{
|
||||||
GtkWidget *dialog;
|
GtkWidget *dialog;
|
||||||
const gchar *license_text =
|
const gchar *license_text =
|
||||||
_("gkc is released under the terms of the GNU GPL v2.\n"
|
"gkc is released under the terms of the GNU GPL v2.\n"
|
||||||
"For more information, please see the source code or\n"
|
"For more information, please see the source code or\n"
|
||||||
"visit http://www.fsf.org/licenses/licenses.html\n");
|
"visit http://www.fsf.org/licenses/licenses.html\n";
|
||||||
|
|
||||||
dialog = gtk_message_dialog_new(GTK_WINDOW(main_wnd),
|
dialog = gtk_message_dialog_new(GTK_WINDOW(main_wnd),
|
||||||
GTK_DIALOG_DESTROY_WITH_PARENT,
|
GTK_DIALOG_DESTROY_WITH_PARENT,
|
||||||
@ -1049,7 +1049,7 @@ static gchar **fill_row(struct menu *menu)
|
|||||||
bzero(row, sizeof(row));
|
bzero(row, sizeof(row));
|
||||||
|
|
||||||
row[COL_OPTION] =
|
row[COL_OPTION] =
|
||||||
g_strdup_printf("%s %s", _(menu_get_prompt(menu)),
|
g_strdup_printf("%s %s", menu_get_prompt(menu),
|
||||||
sym && !sym_has_value(sym) ? "(NEW)" : "");
|
sym && !sym_has_value(sym) ? "(NEW)" : "");
|
||||||
|
|
||||||
if (opt_mode == OPT_ALL && !menu_is_visible(menu))
|
if (opt_mode == OPT_ALL && !menu_is_visible(menu))
|
||||||
@ -1102,7 +1102,7 @@ static gchar **fill_row(struct menu *menu)
|
|||||||
|
|
||||||
if (def_menu)
|
if (def_menu)
|
||||||
row[COL_VALUE] =
|
row[COL_VALUE] =
|
||||||
g_strdup(_(menu_get_prompt(def_menu)));
|
g_strdup(menu_get_prompt(def_menu));
|
||||||
}
|
}
|
||||||
if (sym->flags & SYMBOL_CHOICEVAL)
|
if (sym->flags & SYMBOL_CHOICEVAL)
|
||||||
row[COL_BTNRAD] = GINT_TO_POINTER(TRUE);
|
row[COL_BTNRAD] = GINT_TO_POINTER(TRUE);
|
||||||
@ -1447,10 +1447,6 @@ int main(int ac, char *av[])
|
|||||||
char *env;
|
char *env;
|
||||||
gchar *glade_file;
|
gchar *glade_file;
|
||||||
|
|
||||||
bindtextdomain(PACKAGE, LOCALEDIR);
|
|
||||||
bind_textdomain_codeset(PACKAGE, "UTF-8");
|
|
||||||
textdomain(PACKAGE);
|
|
||||||
|
|
||||||
/* GTK stuffs */
|
/* GTK stuffs */
|
||||||
gtk_set_locale();
|
gtk_set_locale();
|
||||||
gtk_init(&ac, &av);
|
gtk_init(&ac, &av);
|
||||||
|
@ -32,7 +32,6 @@ static struct kconf_id kconf_id_array[] = {
|
|||||||
{ "on", T_ON, TF_PARAM },
|
{ "on", T_ON, TF_PARAM },
|
||||||
{ "modules", T_OPT_MODULES, TF_OPTION },
|
{ "modules", T_OPT_MODULES, TF_OPTION },
|
||||||
{ "defconfig_list", T_OPT_DEFCONFIG_LIST, TF_OPTION },
|
{ "defconfig_list", T_OPT_DEFCONFIG_LIST, TF_OPTION },
|
||||||
{ "env", T_OPT_ENV, TF_OPTION },
|
|
||||||
{ "allnoconfig_y", T_OPT_ALLNOCONFIG_Y, TF_OPTION },
|
{ "allnoconfig_y", T_OPT_ALLNOCONFIG_Y, TF_OPTION },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1,235 +0,0 @@
|
|||||||
/*
|
|
||||||
* Arnaldo Carvalho de Melo <acme@conectiva.com.br>, 2005
|
|
||||||
*
|
|
||||||
* Released under the terms of the GNU GPL v2.0
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
#include "lkc.h"
|
|
||||||
|
|
||||||
static char *escape(const char* text, char *bf, int len)
|
|
||||||
{
|
|
||||||
char *bfp = bf;
|
|
||||||
int multiline = strchr(text, '\n') != NULL;
|
|
||||||
int eol = 0;
|
|
||||||
int textlen = strlen(text);
|
|
||||||
|
|
||||||
if ((textlen > 0) && (text[textlen-1] == '\n'))
|
|
||||||
eol = 1;
|
|
||||||
|
|
||||||
*bfp++ = '"';
|
|
||||||
--len;
|
|
||||||
|
|
||||||
if (multiline) {
|
|
||||||
*bfp++ = '"';
|
|
||||||
*bfp++ = '\n';
|
|
||||||
*bfp++ = '"';
|
|
||||||
len -= 3;
|
|
||||||
}
|
|
||||||
|
|
||||||
while (*text != '\0' && len > 1) {
|
|
||||||
if (*text == '"')
|
|
||||||
*bfp++ = '\\';
|
|
||||||
else if (*text == '\n') {
|
|
||||||
*bfp++ = '\\';
|
|
||||||
*bfp++ = 'n';
|
|
||||||
*bfp++ = '"';
|
|
||||||
*bfp++ = '\n';
|
|
||||||
*bfp++ = '"';
|
|
||||||
len -= 5;
|
|
||||||
++text;
|
|
||||||
goto next;
|
|
||||||
}
|
|
||||||
else if (*text == '\\') {
|
|
||||||
*bfp++ = '\\';
|
|
||||||
len--;
|
|
||||||
}
|
|
||||||
*bfp++ = *text++;
|
|
||||||
next:
|
|
||||||
--len;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (multiline && eol)
|
|
||||||
bfp -= 3;
|
|
||||||
|
|
||||||
*bfp++ = '"';
|
|
||||||
*bfp = '\0';
|
|
||||||
|
|
||||||
return bf;
|
|
||||||
}
|
|
||||||
|
|
||||||
struct file_line {
|
|
||||||
struct file_line *next;
|
|
||||||
const char *file;
|
|
||||||
int lineno;
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct file_line *file_line__new(const char *file, int lineno)
|
|
||||||
{
|
|
||||||
struct file_line *self = malloc(sizeof(*self));
|
|
||||||
|
|
||||||
if (self == NULL)
|
|
||||||
goto out;
|
|
||||||
|
|
||||||
self->file = file;
|
|
||||||
self->lineno = lineno;
|
|
||||||
self->next = NULL;
|
|
||||||
out:
|
|
||||||
return self;
|
|
||||||
}
|
|
||||||
|
|
||||||
struct message {
|
|
||||||
const char *msg;
|
|
||||||
const char *option;
|
|
||||||
struct message *next;
|
|
||||||
struct file_line *files;
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct message *message__list;
|
|
||||||
|
|
||||||
static struct message *message__new(const char *msg, char *option,
|
|
||||||
const char *file, int lineno)
|
|
||||||
{
|
|
||||||
struct message *self = malloc(sizeof(*self));
|
|
||||||
|
|
||||||
if (self == NULL)
|
|
||||||
goto out;
|
|
||||||
|
|
||||||
self->files = file_line__new(file, lineno);
|
|
||||||
if (self->files == NULL)
|
|
||||||
goto out_fail;
|
|
||||||
|
|
||||||
self->msg = xstrdup(msg);
|
|
||||||
if (self->msg == NULL)
|
|
||||||
goto out_fail_msg;
|
|
||||||
|
|
||||||
self->option = option;
|
|
||||||
self->next = NULL;
|
|
||||||
out:
|
|
||||||
return self;
|
|
||||||
out_fail_msg:
|
|
||||||
free(self->files);
|
|
||||||
out_fail:
|
|
||||||
free(self);
|
|
||||||
self = NULL;
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
|
|
||||||
static struct message *mesage__find(const char *msg)
|
|
||||||
{
|
|
||||||
struct message *m = message__list;
|
|
||||||
|
|
||||||
while (m != NULL) {
|
|
||||||
if (strcmp(m->msg, msg) == 0)
|
|
||||||
break;
|
|
||||||
m = m->next;
|
|
||||||
}
|
|
||||||
|
|
||||||
return m;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int message__add_file_line(struct message *self, const char *file,
|
|
||||||
int lineno)
|
|
||||||
{
|
|
||||||
int rc = -1;
|
|
||||||
struct file_line *fl = file_line__new(file, lineno);
|
|
||||||
|
|
||||||
if (fl == NULL)
|
|
||||||
goto out;
|
|
||||||
|
|
||||||
fl->next = self->files;
|
|
||||||
self->files = fl;
|
|
||||||
rc = 0;
|
|
||||||
out:
|
|
||||||
return rc;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int message__add(const char *msg, char *option, const char *file,
|
|
||||||
int lineno)
|
|
||||||
{
|
|
||||||
int rc = 0;
|
|
||||||
char bf[16384];
|
|
||||||
char *escaped = escape(msg, bf, sizeof(bf));
|
|
||||||
struct message *m = mesage__find(escaped);
|
|
||||||
|
|
||||||
if (m != NULL)
|
|
||||||
rc = message__add_file_line(m, file, lineno);
|
|
||||||
else {
|
|
||||||
m = message__new(escaped, option, file, lineno);
|
|
||||||
|
|
||||||
if (m != NULL) {
|
|
||||||
m->next = message__list;
|
|
||||||
message__list = m;
|
|
||||||
} else
|
|
||||||
rc = -1;
|
|
||||||
}
|
|
||||||
return rc;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void menu_build_message_list(struct menu *menu)
|
|
||||||
{
|
|
||||||
struct menu *child;
|
|
||||||
|
|
||||||
message__add(menu_get_prompt(menu), NULL,
|
|
||||||
menu->file == NULL ? "Root Menu" : menu->file->name,
|
|
||||||
menu->lineno);
|
|
||||||
|
|
||||||
if (menu->sym != NULL && menu_has_help(menu))
|
|
||||||
message__add(menu_get_help(menu), menu->sym->name,
|
|
||||||
menu->file == NULL ? "Root Menu" : menu->file->name,
|
|
||||||
menu->lineno);
|
|
||||||
|
|
||||||
for (child = menu->list; child != NULL; child = child->next)
|
|
||||||
if (child->prompt != NULL)
|
|
||||||
menu_build_message_list(child);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void message__print_file_lineno(struct message *self)
|
|
||||||
{
|
|
||||||
struct file_line *fl = self->files;
|
|
||||||
|
|
||||||
putchar('\n');
|
|
||||||
if (self->option != NULL)
|
|
||||||
printf("# %s:00000\n", self->option);
|
|
||||||
|
|
||||||
printf("#: %s:%d", fl->file, fl->lineno);
|
|
||||||
fl = fl->next;
|
|
||||||
|
|
||||||
while (fl != NULL) {
|
|
||||||
printf(", %s:%d", fl->file, fl->lineno);
|
|
||||||
fl = fl->next;
|
|
||||||
}
|
|
||||||
|
|
||||||
putchar('\n');
|
|
||||||
}
|
|
||||||
|
|
||||||
static void message__print_gettext_msgid_msgstr(struct message *self)
|
|
||||||
{
|
|
||||||
message__print_file_lineno(self);
|
|
||||||
|
|
||||||
printf("msgid %s\n"
|
|
||||||
"msgstr \"\"\n", self->msg);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void menu__xgettext(void)
|
|
||||||
{
|
|
||||||
struct message *m = message__list;
|
|
||||||
|
|
||||||
while (m != NULL) {
|
|
||||||
/* skip empty lines ("") */
|
|
||||||
if (strlen(m->msg) > sizeof("\"\""))
|
|
||||||
message__print_gettext_msgid_msgstr(m);
|
|
||||||
m = m->next;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int ac, char **av)
|
|
||||||
{
|
|
||||||
conf_parse(av[1]);
|
|
||||||
|
|
||||||
menu_build_message_list(menu_get_root_menu(NULL));
|
|
||||||
menu__xgettext();
|
|
||||||
return 0;
|
|
||||||
}
|
|
@ -8,15 +8,6 @@
|
|||||||
|
|
||||||
#include "expr.h"
|
#include "expr.h"
|
||||||
|
|
||||||
#ifndef KBUILD_NO_NLS
|
|
||||||
# include <libintl.h>
|
|
||||||
#else
|
|
||||||
static inline const char *gettext(const char *txt) { return txt; }
|
|
||||||
static inline void textdomain(const char *domainname) {}
|
|
||||||
static inline void bindtextdomain(const char *name, const char *dir) {}
|
|
||||||
static inline char *bind_textdomain_codeset(const char *dn, char *c) { return c; }
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
@ -29,11 +20,6 @@ extern "C" {
|
|||||||
#define PACKAGE "linux"
|
#define PACKAGE "linux"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define LOCALEDIR "/usr/share/locale"
|
|
||||||
|
|
||||||
#define _(text) gettext(text)
|
|
||||||
#define N_(text) (text)
|
|
||||||
|
|
||||||
#ifndef CONFIG_
|
#ifndef CONFIG_
|
||||||
#define CONFIG_ "CONFIG_"
|
#define CONFIG_ "CONFIG_"
|
||||||
#endif
|
#endif
|
||||||
@ -58,7 +44,6 @@ enum conf_def_mode {
|
|||||||
|
|
||||||
#define T_OPT_MODULES 1
|
#define T_OPT_MODULES 1
|
||||||
#define T_OPT_DEFCONFIG_LIST 2
|
#define T_OPT_DEFCONFIG_LIST 2
|
||||||
#define T_OPT_ENV 3
|
|
||||||
#define T_OPT_ALLNOCONFIG_Y 4
|
#define T_OPT_ALLNOCONFIG_Y 4
|
||||||
|
|
||||||
struct kconf_id {
|
struct kconf_id {
|
||||||
@ -117,6 +102,7 @@ void *xmalloc(size_t size);
|
|||||||
void *xcalloc(size_t nmemb, size_t size);
|
void *xcalloc(size_t nmemb, size_t size);
|
||||||
void *xrealloc(void *p, size_t size);
|
void *xrealloc(void *p, size_t size);
|
||||||
char *xstrdup(const char *s);
|
char *xstrdup(const char *s);
|
||||||
|
char *xstrndup(const char *s, size_t n);
|
||||||
|
|
||||||
struct gstr {
|
struct gstr {
|
||||||
size_t len;
|
size_t len;
|
||||||
@ -134,9 +120,6 @@ void str_printf(struct gstr *gs, const char *fmt, ...);
|
|||||||
const char *str_get(struct gstr *gs);
|
const char *str_get(struct gstr *gs);
|
||||||
|
|
||||||
/* symbol.c */
|
/* symbol.c */
|
||||||
extern struct expr *sym_env_list;
|
|
||||||
|
|
||||||
void sym_init(void);
|
|
||||||
void sym_clear_all_valid(void);
|
void sym_clear_all_valid(void);
|
||||||
struct symbol *sym_choice_default(struct symbol *sym);
|
struct symbol *sym_choice_default(struct symbol *sym);
|
||||||
const char *sym_get_string_default(struct symbol *sym);
|
const char *sym_get_string_default(struct symbol *sym);
|
||||||
|
@ -31,7 +31,6 @@ extern struct symbol * symbol_hash[SYMBOL_HASHSIZE];
|
|||||||
|
|
||||||
struct symbol * sym_lookup(const char *name, int flags);
|
struct symbol * sym_lookup(const char *name, int flags);
|
||||||
struct symbol * sym_find(const char *name);
|
struct symbol * sym_find(const char *name);
|
||||||
char *sym_expand_string_value(const char *in);
|
|
||||||
const char * sym_escape_string_value(const char *in);
|
const char * sym_escape_string_value(const char *in);
|
||||||
struct symbol ** sym_re_search(const char *pattern);
|
struct symbol ** sym_re_search(const char *pattern);
|
||||||
const char * sym_type_name(enum symbol_type type);
|
const char * sym_type_name(enum symbol_type type);
|
||||||
@ -49,5 +48,19 @@ const char * sym_get_string_value(struct symbol *sym);
|
|||||||
|
|
||||||
const char * prop_get_type_name(enum prop_type type);
|
const char * prop_get_type_name(enum prop_type type);
|
||||||
|
|
||||||
|
/* preprocess.c */
|
||||||
|
enum variable_flavor {
|
||||||
|
VAR_SIMPLE,
|
||||||
|
VAR_RECURSIVE,
|
||||||
|
VAR_APPEND,
|
||||||
|
};
|
||||||
|
void env_write_dep(FILE *f, const char *auto_conf_name);
|
||||||
|
void variable_add(const char *name, const char *value,
|
||||||
|
enum variable_flavor flavor);
|
||||||
|
void variable_all_del(void);
|
||||||
|
char *expand_string(const char *in);
|
||||||
|
char *expand_dollar(const char **str);
|
||||||
|
char *expand_one_token(const char **str);
|
||||||
|
|
||||||
/* expr.c */
|
/* expr.c */
|
||||||
void expr_print(struct expr *e, void (*fn)(void *, struct symbol *, const char *), void *data, int prevtoken);
|
void expr_print(struct expr *e, void (*fn)(void *, struct symbol *, const char *), void *data, int prevtoken);
|
||||||
|
@ -1,93 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
# SPDX-License-Identifier: GPL-2.0
|
|
||||||
# Check ncurses compatibility
|
|
||||||
|
|
||||||
# What library to link
|
|
||||||
ldflags()
|
|
||||||
{
|
|
||||||
pkg-config --libs ncursesw 2>/dev/null && exit
|
|
||||||
pkg-config --libs ncurses 2>/dev/null && exit
|
|
||||||
for ext in so a dll.a dylib ; do
|
|
||||||
for lib in ncursesw ncurses curses ; do
|
|
||||||
$cc -print-file-name=lib${lib}.${ext} | grep -q /
|
|
||||||
if [ $? -eq 0 ]; then
|
|
||||||
echo "-l${lib}"
|
|
||||||
exit
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
done
|
|
||||||
exit 1
|
|
||||||
}
|
|
||||||
|
|
||||||
# Where is ncurses.h?
|
|
||||||
ccflags()
|
|
||||||
{
|
|
||||||
if pkg-config --cflags ncursesw 2>/dev/null; then
|
|
||||||
echo '-DCURSES_LOC="<ncurses.h>" -DNCURSES_WIDECHAR=1'
|
|
||||||
elif pkg-config --cflags ncurses 2>/dev/null; then
|
|
||||||
echo '-DCURSES_LOC="<ncurses.h>"'
|
|
||||||
elif [ -f /usr/include/ncursesw/curses.h ]; then
|
|
||||||
echo '-I/usr/include/ncursesw -DCURSES_LOC="<curses.h>"'
|
|
||||||
echo ' -DNCURSES_WIDECHAR=1'
|
|
||||||
elif [ -f /usr/include/ncurses/ncurses.h ]; then
|
|
||||||
echo '-I/usr/include/ncurses -DCURSES_LOC="<ncurses.h>"'
|
|
||||||
elif [ -f /usr/include/ncurses/curses.h ]; then
|
|
||||||
echo '-I/usr/include/ncurses -DCURSES_LOC="<curses.h>"'
|
|
||||||
elif [ -f /usr/include/ncurses.h ]; then
|
|
||||||
echo '-DCURSES_LOC="<ncurses.h>"'
|
|
||||||
else
|
|
||||||
echo '-DCURSES_LOC="<curses.h>"'
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Temp file, try to clean up after us
|
|
||||||
tmp=.lxdialog.tmp
|
|
||||||
trap "rm -f $tmp" 0 1 2 3 15
|
|
||||||
|
|
||||||
# Check if we can link to ncurses
|
|
||||||
check() {
|
|
||||||
$cc -x c - -o $tmp 2>/dev/null <<'EOF'
|
|
||||||
#include CURSES_LOC
|
|
||||||
main() {}
|
|
||||||
EOF
|
|
||||||
if [ $? != 0 ]; then
|
|
||||||
echo " *** Unable to find the ncurses libraries or the" 1>&2
|
|
||||||
echo " *** required header files." 1>&2
|
|
||||||
echo " *** 'make menuconfig' requires the ncurses libraries." 1>&2
|
|
||||||
echo " *** " 1>&2
|
|
||||||
echo " *** Install ncurses (ncurses-devel or libncurses-dev " 1>&2
|
|
||||||
echo " *** depending on your distribution) and try again." 1>&2
|
|
||||||
echo " *** " 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
usage() {
|
|
||||||
printf "Usage: $0 [-check compiler options|-ccflags|-ldflags compiler options]\n"
|
|
||||||
}
|
|
||||||
|
|
||||||
if [ $# -eq 0 ]; then
|
|
||||||
usage
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
cc=""
|
|
||||||
case "$1" in
|
|
||||||
"-check")
|
|
||||||
shift
|
|
||||||
cc="$@"
|
|
||||||
check
|
|
||||||
;;
|
|
||||||
"-ccflags")
|
|
||||||
ccflags
|
|
||||||
;;
|
|
||||||
"-ldflags")
|
|
||||||
shift
|
|
||||||
cc="$@"
|
|
||||||
ldflags
|
|
||||||
;;
|
|
||||||
"*")
|
|
||||||
usage
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
|
@ -103,8 +103,8 @@ static void print_buttons(WINDOW * dialog, int height, int width, int selected)
|
|||||||
int x = width / 2 - 11;
|
int x = width / 2 - 11;
|
||||||
int y = height - 2;
|
int y = height - 2;
|
||||||
|
|
||||||
print_button(dialog, gettext("Select"), y, x, selected == 0);
|
print_button(dialog, "Select", y, x, selected == 0);
|
||||||
print_button(dialog, gettext(" Help "), y, x + 14, selected == 1);
|
print_button(dialog, " Help ", y, x + 14, selected == 1);
|
||||||
|
|
||||||
wmove(dialog, y, x + 1 + 14 * selected);
|
wmove(dialog, y, x + 1 + 14 * selected);
|
||||||
wrefresh(dialog);
|
wrefresh(dialog);
|
||||||
|
@ -26,16 +26,10 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
|
||||||
#ifndef KBUILD_NO_NLS
|
|
||||||
# include <libintl.h>
|
|
||||||
#else
|
|
||||||
# define gettext(Msgid) ((const char *) (Msgid))
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef __sun__
|
#ifdef __sun__
|
||||||
#define CURS_MACROS
|
#define CURS_MACROS
|
||||||
#endif
|
#endif
|
||||||
#include CURSES_LOC
|
#include <ncurses.h>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Colors in ncurses 1.9.9e do not work properly since foreground and
|
* Colors in ncurses 1.9.9e do not work properly since foreground and
|
||||||
|
@ -31,8 +31,8 @@ static void print_buttons(WINDOW * dialog, int height, int width, int selected)
|
|||||||
int x = width / 2 - 11;
|
int x = width / 2 - 11;
|
||||||
int y = height - 2;
|
int y = height - 2;
|
||||||
|
|
||||||
print_button(dialog, gettext(" Ok "), y, x, selected == 0);
|
print_button(dialog, " Ok ", y, x, selected == 0);
|
||||||
print_button(dialog, gettext(" Help "), y, x + 14, selected == 1);
|
print_button(dialog, " Help ", y, x + 14, selected == 1);
|
||||||
|
|
||||||
wmove(dialog, y, x + 1 + 14 * selected);
|
wmove(dialog, y, x + 1 + 14 * selected);
|
||||||
wrefresh(dialog);
|
wrefresh(dialog);
|
||||||
|
@ -157,11 +157,11 @@ static void print_buttons(WINDOW * win, int height, int width, int selected)
|
|||||||
int x = width / 2 - 28;
|
int x = width / 2 - 28;
|
||||||
int y = height - 2;
|
int y = height - 2;
|
||||||
|
|
||||||
print_button(win, gettext("Select"), y, x, selected == 0);
|
print_button(win, "Select", y, x, selected == 0);
|
||||||
print_button(win, gettext(" Exit "), y, x + 12, selected == 1);
|
print_button(win, " Exit ", y, x + 12, selected == 1);
|
||||||
print_button(win, gettext(" Help "), y, x + 24, selected == 2);
|
print_button(win, " Help ", y, x + 24, selected == 2);
|
||||||
print_button(win, gettext(" Save "), y, x + 36, selected == 3);
|
print_button(win, " Save ", y, x + 36, selected == 3);
|
||||||
print_button(win, gettext(" Load "), y, x + 48, selected == 4);
|
print_button(win, " Load ", y, x + 48, selected == 4);
|
||||||
|
|
||||||
wmove(win, y, x + 1 + 12 * selected);
|
wmove(win, y, x + 1 + 12 * selected);
|
||||||
wrefresh(win);
|
wrefresh(win);
|
||||||
|
@ -129,7 +129,7 @@ int dialog_textbox(const char *title, char *tbuf, int initial_height,
|
|||||||
|
|
||||||
print_title(dialog, title, width);
|
print_title(dialog, title, width);
|
||||||
|
|
||||||
print_button(dialog, gettext(" Exit "), height - 2, width / 2 - 4, TRUE);
|
print_button(dialog, " Exit ", height - 2, width / 2 - 4, TRUE);
|
||||||
wnoutrefresh(dialog);
|
wnoutrefresh(dialog);
|
||||||
getyx(dialog, cur_y, cur_x); /* Save cursor position */
|
getyx(dialog, cur_y, cur_x); /* Save cursor position */
|
||||||
|
|
||||||
|
@ -29,8 +29,8 @@ static void print_buttons(WINDOW * dialog, int height, int width, int selected)
|
|||||||
int x = width / 2 - 10;
|
int x = width / 2 - 10;
|
||||||
int y = height - 2;
|
int y = height - 2;
|
||||||
|
|
||||||
print_button(dialog, gettext(" Yes "), y, x, selected == 0);
|
print_button(dialog, " Yes ", y, x, selected == 0);
|
||||||
print_button(dialog, gettext(" No "), y, x + 13, selected == 1);
|
print_button(dialog, " No ", y, x + 13, selected == 1);
|
||||||
|
|
||||||
wmove(dialog, y, x + 1 + 13 * selected);
|
wmove(dialog, y, x + 1 + 13 * selected);
|
||||||
wrefresh(dialog);
|
wrefresh(dialog);
|
||||||
|
44
scripts/kconfig/mconf-cfg.sh
Executable file
44
scripts/kconfig/mconf-cfg.sh
Executable file
@ -0,0 +1,44 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
|
PKG="ncursesw"
|
||||||
|
PKG2="ncurses"
|
||||||
|
|
||||||
|
if pkg-config --exists $PKG; then
|
||||||
|
echo cflags=\"$(pkg-config --cflags $PKG)\"
|
||||||
|
echo libs=\"$(pkg-config --libs $PKG)\"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if pkg-config --exists $PKG2; then
|
||||||
|
echo cflags=\"$(pkg-config --cflags $PKG2)\"
|
||||||
|
echo libs=\"$(pkg-config --libs $PKG2)\"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Unfortunately, some distributions (e.g. openSUSE) cannot find ncurses
|
||||||
|
# by pkg-config.
|
||||||
|
if [ -f /usr/include/ncursesw/ncurses.h ]; then
|
||||||
|
echo cflags=\"-D_GNU_SOURCE -I/usr/include/ncursesw\"
|
||||||
|
echo libs=\"-lncursesw\"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -f /usr/include/ncurses/ncurses.h ]; then
|
||||||
|
echo cflags=\"-D_GNU_SOURCE -I/usr/include/ncurses\"
|
||||||
|
echo libs=\"-lncurses\"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -f /usr/include/ncurses.h ]; then
|
||||||
|
echo cflags=\"-D_GNU_SOURCE\"
|
||||||
|
echo libs=\"-lncurses\"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo >&2 "*"
|
||||||
|
echo >&2 "* Unable to find the ncurses package."
|
||||||
|
echo >&2 "* Install ncurses (ncurses-devel or libncurses-dev"
|
||||||
|
echo >&2 "* depending on your distribution)."
|
||||||
|
echo >&2 "*"
|
||||||
|
exit 1
|
@ -17,12 +17,11 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <locale.h>
|
|
||||||
|
|
||||||
#include "lkc.h"
|
#include "lkc.h"
|
||||||
#include "lxdialog/dialog.h"
|
#include "lxdialog/dialog.h"
|
||||||
|
|
||||||
static const char mconf_readme[] = N_(
|
static const char mconf_readme[] =
|
||||||
"Overview\n"
|
"Overview\n"
|
||||||
"--------\n"
|
"--------\n"
|
||||||
"This interface lets you select features and parameters for the build.\n"
|
"This interface lets you select features and parameters for the build.\n"
|
||||||
@ -171,37 +170,37 @@ static const char mconf_readme[] = N_(
|
|||||||
" blackbg => selects a color scheme with black background\n"
|
" blackbg => selects a color scheme with black background\n"
|
||||||
" classic => theme with blue background. The classic look\n"
|
" classic => theme with blue background. The classic look\n"
|
||||||
" bluetitle => an LCD friendly version of classic. (default)\n"
|
" bluetitle => an LCD friendly version of classic. (default)\n"
|
||||||
"\n"),
|
"\n",
|
||||||
menu_instructions[] = N_(
|
menu_instructions[] =
|
||||||
"Arrow keys navigate the menu. "
|
"Arrow keys navigate the menu. "
|
||||||
"<Enter> selects submenus ---> (or empty submenus ----). "
|
"<Enter> selects submenus ---> (or empty submenus ----). "
|
||||||
"Highlighted letters are hotkeys. "
|
"Highlighted letters are hotkeys. "
|
||||||
"Pressing <Y> includes, <N> excludes, <M> modularizes features. "
|
"Pressing <Y> includes, <N> excludes, <M> modularizes features. "
|
||||||
"Press <Esc><Esc> to exit, <?> for Help, </> for Search. "
|
"Press <Esc><Esc> to exit, <?> for Help, </> for Search. "
|
||||||
"Legend: [*] built-in [ ] excluded <M> module < > module capable"),
|
"Legend: [*] built-in [ ] excluded <M> module < > module capable",
|
||||||
radiolist_instructions[] = N_(
|
radiolist_instructions[] =
|
||||||
"Use the arrow keys to navigate this window or "
|
"Use the arrow keys to navigate this window or "
|
||||||
"press the hotkey of the item you wish to select "
|
"press the hotkey of the item you wish to select "
|
||||||
"followed by the <SPACE BAR>. "
|
"followed by the <SPACE BAR>. "
|
||||||
"Press <?> for additional information about this option."),
|
"Press <?> for additional information about this option.",
|
||||||
inputbox_instructions_int[] = N_(
|
inputbox_instructions_int[] =
|
||||||
"Please enter a decimal value. "
|
"Please enter a decimal value. "
|
||||||
"Fractions will not be accepted. "
|
"Fractions will not be accepted. "
|
||||||
"Use the <TAB> key to move from the input field to the buttons below it."),
|
"Use the <TAB> key to move from the input field to the buttons below it.",
|
||||||
inputbox_instructions_hex[] = N_(
|
inputbox_instructions_hex[] =
|
||||||
"Please enter a hexadecimal value. "
|
"Please enter a hexadecimal value. "
|
||||||
"Use the <TAB> key to move from the input field to the buttons below it."),
|
"Use the <TAB> key to move from the input field to the buttons below it.",
|
||||||
inputbox_instructions_string[] = N_(
|
inputbox_instructions_string[] =
|
||||||
"Please enter a string value. "
|
"Please enter a string value. "
|
||||||
"Use the <TAB> key to move from the input field to the buttons below it."),
|
"Use the <TAB> key to move from the input field to the buttons below it.",
|
||||||
setmod_text[] = N_(
|
setmod_text[] =
|
||||||
"This feature depends on another which has been configured as a module.\n"
|
"This feature depends on another which has been configured as a module.\n"
|
||||||
"As a result, this feature will be built as a module."),
|
"As a result, this feature will be built as a module.",
|
||||||
load_config_text[] = N_(
|
load_config_text[] =
|
||||||
"Enter the name of the configuration file you wish to load. "
|
"Enter the name of the configuration file you wish to load. "
|
||||||
"Accept the name shown to restore the configuration you "
|
"Accept the name shown to restore the configuration you "
|
||||||
"last retrieved. Leave blank to abort."),
|
"last retrieved. Leave blank to abort.",
|
||||||
load_config_help[] = N_(
|
load_config_help[] =
|
||||||
"\n"
|
"\n"
|
||||||
"For various reasons, one may wish to keep several different\n"
|
"For various reasons, one may wish to keep several different\n"
|
||||||
"configurations available on a single machine.\n"
|
"configurations available on a single machine.\n"
|
||||||
@ -211,11 +210,11 @@ load_config_help[] = N_(
|
|||||||
"configuration.\n"
|
"configuration.\n"
|
||||||
"\n"
|
"\n"
|
||||||
"If you are uncertain, then you have probably never used alternate\n"
|
"If you are uncertain, then you have probably never used alternate\n"
|
||||||
"configuration files. You should therefore leave this blank to abort.\n"),
|
"configuration files. You should therefore leave this blank to abort.\n",
|
||||||
save_config_text[] = N_(
|
save_config_text[] =
|
||||||
"Enter a filename to which this configuration should be saved "
|
"Enter a filename to which this configuration should be saved "
|
||||||
"as an alternate. Leave blank to abort."),
|
"as an alternate. Leave blank to abort.",
|
||||||
save_config_help[] = N_(
|
save_config_help[] =
|
||||||
"\n"
|
"\n"
|
||||||
"For various reasons, one may wish to keep different configurations\n"
|
"For various reasons, one may wish to keep different configurations\n"
|
||||||
"available on a single machine.\n"
|
"available on a single machine.\n"
|
||||||
@ -225,8 +224,8 @@ save_config_help[] = N_(
|
|||||||
"configuration options you have selected at that time.\n"
|
"configuration options you have selected at that time.\n"
|
||||||
"\n"
|
"\n"
|
||||||
"If you are uncertain what all this means then you should probably\n"
|
"If you are uncertain what all this means then you should probably\n"
|
||||||
"leave this blank.\n"),
|
"leave this blank.\n",
|
||||||
search_help[] = N_(
|
search_help[] =
|
||||||
"\n"
|
"\n"
|
||||||
"Search for symbols and display their relations.\n"
|
"Search for symbols and display their relations.\n"
|
||||||
"Regular expressions are allowed.\n"
|
"Regular expressions are allowed.\n"
|
||||||
@ -271,7 +270,7 @@ search_help[] = N_(
|
|||||||
"Examples: USB => find all symbols containing USB\n"
|
"Examples: USB => find all symbols containing USB\n"
|
||||||
" ^USB => find all symbols starting with USB\n"
|
" ^USB => find all symbols starting with USB\n"
|
||||||
" USB$ => find all symbols ending with USB\n"
|
" USB$ => find all symbols ending with USB\n"
|
||||||
"\n");
|
"\n";
|
||||||
|
|
||||||
static int indent;
|
static int indent;
|
||||||
static struct menu *current_menu;
|
static struct menu *current_menu;
|
||||||
@ -400,19 +399,19 @@ static void search_conf(void)
|
|||||||
struct subtitle_part stpart;
|
struct subtitle_part stpart;
|
||||||
|
|
||||||
title = str_new();
|
title = str_new();
|
||||||
str_printf( &title, _("Enter (sub)string or regexp to search for "
|
str_printf( &title, "Enter (sub)string or regexp to search for "
|
||||||
"(with or without \"%s\")"), CONFIG_);
|
"(with or without \"%s\")", CONFIG_);
|
||||||
|
|
||||||
again:
|
again:
|
||||||
dialog_clear();
|
dialog_clear();
|
||||||
dres = dialog_inputbox(_("Search Configuration Parameter"),
|
dres = dialog_inputbox("Search Configuration Parameter",
|
||||||
str_get(&title),
|
str_get(&title),
|
||||||
10, 75, "");
|
10, 75, "");
|
||||||
switch (dres) {
|
switch (dres) {
|
||||||
case 0:
|
case 0:
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
show_helptext(_("Search Configuration"), search_help);
|
show_helptext("Search Configuration", search_help);
|
||||||
goto again;
|
goto again;
|
||||||
default:
|
default:
|
||||||
str_free(&title);
|
str_free(&title);
|
||||||
@ -443,7 +442,7 @@ static void search_conf(void)
|
|||||||
|
|
||||||
res = get_relations_str(sym_arr, &head);
|
res = get_relations_str(sym_arr, &head);
|
||||||
set_subtitle();
|
set_subtitle();
|
||||||
dres = show_textbox_ext(_("Search Results"), (char *)
|
dres = show_textbox_ext("Search Results", (char *)
|
||||||
str_get(&res), 0, 0, keys, &vscroll,
|
str_get(&res), 0, 0, keys, &vscroll,
|
||||||
&hscroll, &update_text, (void *)
|
&hscroll, &update_text, (void *)
|
||||||
&data);
|
&data);
|
||||||
@ -491,7 +490,7 @@ static void build_conf(struct menu *menu)
|
|||||||
switch (prop->type) {
|
switch (prop->type) {
|
||||||
case P_MENU:
|
case P_MENU:
|
||||||
child_count++;
|
child_count++;
|
||||||
prompt = _(prompt);
|
prompt = prompt;
|
||||||
if (single_menu_mode) {
|
if (single_menu_mode) {
|
||||||
item_make("%s%*c%s",
|
item_make("%s%*c%s",
|
||||||
menu->data ? "-->" : "++>",
|
menu->data ? "-->" : "++>",
|
||||||
@ -508,7 +507,7 @@ static void build_conf(struct menu *menu)
|
|||||||
case P_COMMENT:
|
case P_COMMENT:
|
||||||
if (prompt) {
|
if (prompt) {
|
||||||
child_count++;
|
child_count++;
|
||||||
item_make(" %*c*** %s ***", indent + 1, ' ', _(prompt));
|
item_make(" %*c*** %s ***", indent + 1, ' ', prompt);
|
||||||
item_set_tag(':');
|
item_set_tag(':');
|
||||||
item_set_data(menu);
|
item_set_data(menu);
|
||||||
}
|
}
|
||||||
@ -516,7 +515,7 @@ static void build_conf(struct menu *menu)
|
|||||||
default:
|
default:
|
||||||
if (prompt) {
|
if (prompt) {
|
||||||
child_count++;
|
child_count++;
|
||||||
item_make("---%*c%s", indent + 1, ' ', _(prompt));
|
item_make("---%*c%s", indent + 1, ' ', prompt);
|
||||||
item_set_tag(':');
|
item_set_tag(':');
|
||||||
item_set_data(menu);
|
item_set_data(menu);
|
||||||
}
|
}
|
||||||
@ -560,10 +559,10 @@ static void build_conf(struct menu *menu)
|
|||||||
item_set_data(menu);
|
item_set_data(menu);
|
||||||
}
|
}
|
||||||
|
|
||||||
item_add_str("%*c%s", indent + 1, ' ', _(menu_get_prompt(menu)));
|
item_add_str("%*c%s", indent + 1, ' ', menu_get_prompt(menu));
|
||||||
if (val == yes) {
|
if (val == yes) {
|
||||||
if (def_menu) {
|
if (def_menu) {
|
||||||
item_add_str(" (%s)", _(menu_get_prompt(def_menu)));
|
item_add_str(" (%s)", menu_get_prompt(def_menu));
|
||||||
item_add_str(" --->");
|
item_add_str(" --->");
|
||||||
if (def_menu->list) {
|
if (def_menu->list) {
|
||||||
indent += 2;
|
indent += 2;
|
||||||
@ -575,7 +574,7 @@ static void build_conf(struct menu *menu)
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (menu == current_menu) {
|
if (menu == current_menu) {
|
||||||
item_make("---%*c%s", indent + 1, ' ', _(menu_get_prompt(menu)));
|
item_make("---%*c%s", indent + 1, ' ', menu_get_prompt(menu));
|
||||||
item_set_tag(':');
|
item_set_tag(':');
|
||||||
item_set_data(menu);
|
item_set_data(menu);
|
||||||
goto conf_childs;
|
goto conf_childs;
|
||||||
@ -618,17 +617,17 @@ static void build_conf(struct menu *menu)
|
|||||||
tmp = indent - tmp + 4;
|
tmp = indent - tmp + 4;
|
||||||
if (tmp < 0)
|
if (tmp < 0)
|
||||||
tmp = 0;
|
tmp = 0;
|
||||||
item_add_str("%*c%s%s", tmp, ' ', _(menu_get_prompt(menu)),
|
item_add_str("%*c%s%s", tmp, ' ', menu_get_prompt(menu),
|
||||||
(sym_has_value(sym) || !sym_is_changable(sym)) ?
|
(sym_has_value(sym) || !sym_is_changable(sym)) ?
|
||||||
"" : _(" (NEW)"));
|
"" : " (NEW)");
|
||||||
item_set_tag('s');
|
item_set_tag('s');
|
||||||
item_set_data(menu);
|
item_set_data(menu);
|
||||||
goto conf_childs;
|
goto conf_childs;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
item_add_str("%*c%s%s", indent + 1, ' ', _(menu_get_prompt(menu)),
|
item_add_str("%*c%s%s", indent + 1, ' ', menu_get_prompt(menu),
|
||||||
(sym_has_value(sym) || !sym_is_changable(sym)) ?
|
(sym_has_value(sym) || !sym_is_changable(sym)) ?
|
||||||
"" : _(" (NEW)"));
|
"" : " (NEW)");
|
||||||
if (menu->prompt->type == P_MENU) {
|
if (menu->prompt->type == P_MENU) {
|
||||||
item_add_str(" %s", menu_is_empty(menu) ? "----" : "--->");
|
item_add_str(" %s", menu_is_empty(menu) ? "----" : "--->");
|
||||||
return;
|
return;
|
||||||
@ -665,8 +664,8 @@ static void conf(struct menu *menu, struct menu *active_menu)
|
|||||||
break;
|
break;
|
||||||
set_subtitle();
|
set_subtitle();
|
||||||
dialog_clear();
|
dialog_clear();
|
||||||
res = dialog_menu(prompt ? _(prompt) : _("Main Menu"),
|
res = dialog_menu(prompt ? prompt : "Main Menu",
|
||||||
_(menu_instructions),
|
menu_instructions,
|
||||||
active_menu, &s_scroll);
|
active_menu, &s_scroll);
|
||||||
if (res == 1 || res == KEY_ESC || res == -ERRDISPLAYTOOSMALL)
|
if (res == 1 || res == KEY_ESC || res == -ERRDISPLAYTOOSMALL)
|
||||||
break;
|
break;
|
||||||
@ -708,7 +707,7 @@ static void conf(struct menu *menu, struct menu *active_menu)
|
|||||||
show_help(submenu);
|
show_help(submenu);
|
||||||
else {
|
else {
|
||||||
reset_subtitle();
|
reset_subtitle();
|
||||||
show_helptext(_("README"), _(mconf_readme));
|
show_helptext("README", mconf_readme);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
@ -793,13 +792,13 @@ static void show_help(struct menu *menu)
|
|||||||
help.max_width = getmaxx(stdscr) - 10;
|
help.max_width = getmaxx(stdscr) - 10;
|
||||||
menu_get_ext_help(menu, &help);
|
menu_get_ext_help(menu, &help);
|
||||||
|
|
||||||
show_helptext(_(menu_get_prompt(menu)), str_get(&help));
|
show_helptext(menu_get_prompt(menu), str_get(&help));
|
||||||
str_free(&help);
|
str_free(&help);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void conf_choice(struct menu *menu)
|
static void conf_choice(struct menu *menu)
|
||||||
{
|
{
|
||||||
const char *prompt = _(menu_get_prompt(menu));
|
const char *prompt = menu_get_prompt(menu);
|
||||||
struct menu *child;
|
struct menu *child;
|
||||||
struct symbol *active;
|
struct symbol *active;
|
||||||
|
|
||||||
@ -814,9 +813,9 @@ static void conf_choice(struct menu *menu)
|
|||||||
if (!menu_is_visible(child))
|
if (!menu_is_visible(child))
|
||||||
continue;
|
continue;
|
||||||
if (child->sym)
|
if (child->sym)
|
||||||
item_make("%s", _(menu_get_prompt(child)));
|
item_make("%s", menu_get_prompt(child));
|
||||||
else {
|
else {
|
||||||
item_make("*** %s ***", _(menu_get_prompt(child)));
|
item_make("*** %s ***", menu_get_prompt(child));
|
||||||
item_set_tag(':');
|
item_set_tag(':');
|
||||||
}
|
}
|
||||||
item_set_data(child);
|
item_set_data(child);
|
||||||
@ -826,8 +825,8 @@ static void conf_choice(struct menu *menu)
|
|||||||
item_set_tag('X');
|
item_set_tag('X');
|
||||||
}
|
}
|
||||||
dialog_clear();
|
dialog_clear();
|
||||||
res = dialog_checklist(prompt ? _(prompt) : _("Main Menu"),
|
res = dialog_checklist(prompt ? prompt : "Main Menu",
|
||||||
_(radiolist_instructions),
|
radiolist_instructions,
|
||||||
MENUBOX_HEIGTH_MIN,
|
MENUBOX_HEIGTH_MIN,
|
||||||
MENUBOX_WIDTH_MIN,
|
MENUBOX_WIDTH_MIN,
|
||||||
CHECKLIST_HEIGTH_MIN);
|
CHECKLIST_HEIGTH_MIN);
|
||||||
@ -868,26 +867,26 @@ static void conf_string(struct menu *menu)
|
|||||||
|
|
||||||
switch (sym_get_type(menu->sym)) {
|
switch (sym_get_type(menu->sym)) {
|
||||||
case S_INT:
|
case S_INT:
|
||||||
heading = _(inputbox_instructions_int);
|
heading = inputbox_instructions_int;
|
||||||
break;
|
break;
|
||||||
case S_HEX:
|
case S_HEX:
|
||||||
heading = _(inputbox_instructions_hex);
|
heading = inputbox_instructions_hex;
|
||||||
break;
|
break;
|
||||||
case S_STRING:
|
case S_STRING:
|
||||||
heading = _(inputbox_instructions_string);
|
heading = inputbox_instructions_string;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
heading = _("Internal mconf error!");
|
heading = "Internal mconf error!";
|
||||||
}
|
}
|
||||||
dialog_clear();
|
dialog_clear();
|
||||||
res = dialog_inputbox(prompt ? _(prompt) : _("Main Menu"),
|
res = dialog_inputbox(prompt ? prompt : "Main Menu",
|
||||||
heading, 10, 75,
|
heading, 10, 75,
|
||||||
sym_get_string_value(menu->sym));
|
sym_get_string_value(menu->sym));
|
||||||
switch (res) {
|
switch (res) {
|
||||||
case 0:
|
case 0:
|
||||||
if (sym_set_string_value(menu->sym, dialog_input_result))
|
if (sym_set_string_value(menu->sym, dialog_input_result))
|
||||||
return;
|
return;
|
||||||
show_textbox(NULL, _("You have made an invalid entry."), 5, 43);
|
show_textbox(NULL, "You have made an invalid entry.", 5, 43);
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
show_help(menu);
|
show_help(menu);
|
||||||
@ -915,10 +914,10 @@ static void conf_load(void)
|
|||||||
sym_set_change_count(1);
|
sym_set_change_count(1);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
show_textbox(NULL, _("File does not exist!"), 5, 38);
|
show_textbox(NULL, "File does not exist!", 5, 38);
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
show_helptext(_("Load Alternate Configuration"), load_config_help);
|
show_helptext("Load Alternate Configuration", load_config_help);
|
||||||
break;
|
break;
|
||||||
case KEY_ESC:
|
case KEY_ESC:
|
||||||
return;
|
return;
|
||||||
@ -941,10 +940,10 @@ static void conf_save(void)
|
|||||||
set_config_filename(dialog_input_result);
|
set_config_filename(dialog_input_result);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
show_textbox(NULL, _("Can't create file! Probably a nonexistent directory."), 5, 60);
|
show_textbox(NULL, "Can't create file! Probably a nonexistent directory.", 5, 60);
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
show_helptext(_("Save Alternate Configuration"), save_config_help);
|
show_helptext("Save Alternate Configuration", save_config_help);
|
||||||
break;
|
break;
|
||||||
case KEY_ESC:
|
case KEY_ESC:
|
||||||
return;
|
return;
|
||||||
@ -961,8 +960,8 @@ static int handle_exit(void)
|
|||||||
dialog_clear();
|
dialog_clear();
|
||||||
if (conf_get_changed())
|
if (conf_get_changed())
|
||||||
res = dialog_yesno(NULL,
|
res = dialog_yesno(NULL,
|
||||||
_("Do you wish to save your new configuration?\n"
|
"Do you wish to save your new configuration?\n"
|
||||||
"(Press <ESC><ESC> to continue kernel configuration.)"),
|
"(Press <ESC><ESC> to continue kernel configuration.)",
|
||||||
6, 60);
|
6, 60);
|
||||||
else
|
else
|
||||||
res = -1;
|
res = -1;
|
||||||
@ -972,26 +971,26 @@ static int handle_exit(void)
|
|||||||
switch (res) {
|
switch (res) {
|
||||||
case 0:
|
case 0:
|
||||||
if (conf_write(filename)) {
|
if (conf_write(filename)) {
|
||||||
fprintf(stderr, _("\n\n"
|
fprintf(stderr, "\n\n"
|
||||||
"Error while writing of the configuration.\n"
|
"Error while writing of the configuration.\n"
|
||||||
"Your configuration changes were NOT saved."
|
"Your configuration changes were NOT saved."
|
||||||
"\n\n"));
|
"\n\n");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
/* fall through */
|
/* fall through */
|
||||||
case -1:
|
case -1:
|
||||||
if (!silent)
|
if (!silent)
|
||||||
printf(_("\n\n"
|
printf("\n\n"
|
||||||
"*** End of the configuration.\n"
|
"*** End of the configuration.\n"
|
||||||
"*** Execute 'make' to start the build or try 'make help'."
|
"*** Execute 'make' to start the build or try 'make help'."
|
||||||
"\n\n"));
|
"\n\n");
|
||||||
res = 0;
|
res = 0;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if (!silent)
|
if (!silent)
|
||||||
fprintf(stderr, _("\n\n"
|
fprintf(stderr, "\n\n"
|
||||||
"Your configuration changes were NOT saved."
|
"Your configuration changes were NOT saved."
|
||||||
"\n\n"));
|
"\n\n");
|
||||||
if (res != KEY_ESC)
|
if (res != KEY_ESC)
|
||||||
res = 0;
|
res = 0;
|
||||||
}
|
}
|
||||||
@ -1009,10 +1008,6 @@ int main(int ac, char **av)
|
|||||||
char *mode;
|
char *mode;
|
||||||
int res;
|
int res;
|
||||||
|
|
||||||
setlocale(LC_ALL, "");
|
|
||||||
bindtextdomain(PACKAGE, LOCALEDIR);
|
|
||||||
textdomain(PACKAGE);
|
|
||||||
|
|
||||||
signal(SIGINT, sig_handler);
|
signal(SIGINT, sig_handler);
|
||||||
|
|
||||||
if (ac > 1 && strcmp(av[1], "-s") == 0) {
|
if (ac > 1 && strcmp(av[1], "-s") == 0) {
|
||||||
@ -1031,8 +1026,8 @@ int main(int ac, char **av)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (init_dialog(NULL)) {
|
if (init_dialog(NULL)) {
|
||||||
fprintf(stderr, N_("Your display is too small to run Menuconfig!\n"));
|
fprintf(stderr, "Your display is too small to run Menuconfig!\n");
|
||||||
fprintf(stderr, N_("It must be at least 19 lines by 80 columns.\n"));
|
fprintf(stderr, "It must be at least 19 lines by 80 columns.\n");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -214,9 +214,6 @@ void menu_add_option(int token, char *arg)
|
|||||||
zconf_error("trying to redefine defconfig symbol");
|
zconf_error("trying to redefine defconfig symbol");
|
||||||
sym_defconfig_list->flags |= SYMBOL_AUTO;
|
sym_defconfig_list->flags |= SYMBOL_AUTO;
|
||||||
break;
|
break;
|
||||||
case T_OPT_ENV:
|
|
||||||
prop_add_env(arg);
|
|
||||||
break;
|
|
||||||
case T_OPT_ALLNOCONFIG_Y:
|
case T_OPT_ALLNOCONFIG_Y:
|
||||||
current_entry->sym->flags |= SYMBOL_ALLNOCONFIG_Y;
|
current_entry->sym->flags |= SYMBOL_ALLNOCONFIG_Y;
|
||||||
break;
|
break;
|
||||||
@ -711,7 +708,7 @@ static void get_prompt_str(struct gstr *r, struct property *prop,
|
|||||||
struct menu *submenu[8], *menu, *location = NULL;
|
struct menu *submenu[8], *menu, *location = NULL;
|
||||||
struct jump_key *jump = NULL;
|
struct jump_key *jump = NULL;
|
||||||
|
|
||||||
str_printf(r, _("Prompt: %s\n"), _(prop->text));
|
str_printf(r, "Prompt: %s\n", prop->text);
|
||||||
menu = prop->menu->parent;
|
menu = prop->menu->parent;
|
||||||
for (i = 0; menu != &rootmenu && i < 8; menu = menu->parent) {
|
for (i = 0; menu != &rootmenu && i < 8; menu = menu->parent) {
|
||||||
bool accessible = menu_is_visible(menu);
|
bool accessible = menu_is_visible(menu);
|
||||||
@ -744,16 +741,16 @@ static void get_prompt_str(struct gstr *r, struct property *prop,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (i > 0) {
|
if (i > 0) {
|
||||||
str_printf(r, _(" Location:\n"));
|
str_printf(r, " Location:\n");
|
||||||
for (j = 4; --i >= 0; j += 2) {
|
for (j = 4; --i >= 0; j += 2) {
|
||||||
menu = submenu[i];
|
menu = submenu[i];
|
||||||
if (jump && menu == location)
|
if (jump && menu == location)
|
||||||
jump->offset = strlen(r->s);
|
jump->offset = strlen(r->s);
|
||||||
str_printf(r, "%*c-> %s", j, ' ',
|
str_printf(r, "%*c-> %s", j, ' ',
|
||||||
_(menu_get_prompt(menu)));
|
menu_get_prompt(menu));
|
||||||
if (menu->sym) {
|
if (menu->sym) {
|
||||||
str_printf(r, " (%s [=%s])", menu->sym->name ?
|
str_printf(r, " (%s [=%s])", menu->sym->name ?
|
||||||
menu->sym->name : _("<choice>"),
|
menu->sym->name : "<choice>",
|
||||||
sym_get_string_value(menu->sym));
|
sym_get_string_value(menu->sym));
|
||||||
}
|
}
|
||||||
str_append(r, "\n");
|
str_append(r, "\n");
|
||||||
@ -817,23 +814,23 @@ static void get_symbol_str(struct gstr *r, struct symbol *sym,
|
|||||||
|
|
||||||
prop = get_symbol_prop(sym);
|
prop = get_symbol_prop(sym);
|
||||||
if (prop) {
|
if (prop) {
|
||||||
str_printf(r, _(" Defined at %s:%d\n"), prop->menu->file->name,
|
str_printf(r, " Defined at %s:%d\n", prop->menu->file->name,
|
||||||
prop->menu->lineno);
|
prop->menu->lineno);
|
||||||
if (!expr_is_yes(prop->visible.expr)) {
|
if (!expr_is_yes(prop->visible.expr)) {
|
||||||
str_append(r, _(" Depends on: "));
|
str_append(r, " Depends on: ");
|
||||||
expr_gstr_print(prop->visible.expr, r);
|
expr_gstr_print(prop->visible.expr, r);
|
||||||
str_append(r, "\n");
|
str_append(r, "\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
get_symbol_props_str(r, sym, P_SELECT, _(" Selects: "));
|
get_symbol_props_str(r, sym, P_SELECT, " Selects: ");
|
||||||
if (sym->rev_dep.expr) {
|
if (sym->rev_dep.expr) {
|
||||||
expr_gstr_print_revdep(sym->rev_dep.expr, r, yes, " Selected by [y]:\n");
|
expr_gstr_print_revdep(sym->rev_dep.expr, r, yes, " Selected by [y]:\n");
|
||||||
expr_gstr_print_revdep(sym->rev_dep.expr, r, mod, " Selected by [m]:\n");
|
expr_gstr_print_revdep(sym->rev_dep.expr, r, mod, " Selected by [m]:\n");
|
||||||
expr_gstr_print_revdep(sym->rev_dep.expr, r, no, " Selected by [n]:\n");
|
expr_gstr_print_revdep(sym->rev_dep.expr, r, no, " Selected by [n]:\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
get_symbol_props_str(r, sym, P_IMPLY, _(" Implies: "));
|
get_symbol_props_str(r, sym, P_IMPLY, " Implies: ");
|
||||||
if (sym->implied.expr) {
|
if (sym->implied.expr) {
|
||||||
expr_gstr_print_revdep(sym->implied.expr, r, yes, " Implied by [y]:\n");
|
expr_gstr_print_revdep(sym->implied.expr, r, yes, " Implied by [y]:\n");
|
||||||
expr_gstr_print_revdep(sym->implied.expr, r, mod, " Implied by [m]:\n");
|
expr_gstr_print_revdep(sym->implied.expr, r, mod, " Implied by [m]:\n");
|
||||||
@ -852,7 +849,7 @@ struct gstr get_relations_str(struct symbol **sym_arr, struct list_head *head)
|
|||||||
for (i = 0; sym_arr && (sym = sym_arr[i]); i++)
|
for (i = 0; sym_arr && (sym = sym_arr[i]); i++)
|
||||||
get_symbol_str(&res, sym, head);
|
get_symbol_str(&res, sym, head);
|
||||||
if (!i)
|
if (!i)
|
||||||
str_append(&res, _("No matches found.\n"));
|
str_append(&res, "No matches found.\n");
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -867,7 +864,7 @@ void menu_get_ext_help(struct menu *menu, struct gstr *help)
|
|||||||
str_printf(help, "%s%s:\n\n", CONFIG_, sym->name);
|
str_printf(help, "%s%s:\n\n", CONFIG_, sym->name);
|
||||||
help_text = menu_get_help(menu);
|
help_text = menu_get_help(menu);
|
||||||
}
|
}
|
||||||
str_printf(help, "%s\n", _(help_text));
|
str_printf(help, "%s\n", help_text);
|
||||||
if (sym)
|
if (sym)
|
||||||
get_symbol_str(help, sym, NULL);
|
get_symbol_str(help, sym, NULL);
|
||||||
}
|
}
|
||||||
|
44
scripts/kconfig/nconf-cfg.sh
Normal file
44
scripts/kconfig/nconf-cfg.sh
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
|
PKG="ncursesw menuw panelw"
|
||||||
|
PKG2="ncurses menu panel"
|
||||||
|
|
||||||
|
if pkg-config --exists $PKG; then
|
||||||
|
echo cflags=\"$(pkg-config --cflags $PKG)\"
|
||||||
|
echo libs=\"$(pkg-config --libs $PKG)\"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if pkg-config --exists $PKG2; then
|
||||||
|
echo cflags=\"$(pkg-config --cflags $PKG2)\"
|
||||||
|
echo libs=\"$(pkg-config --libs $PKG2)\"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Unfortunately, some distributions (e.g. openSUSE) cannot find ncurses
|
||||||
|
# by pkg-config.
|
||||||
|
if [ -f /usr/include/ncursesw/ncurses.h ]; then
|
||||||
|
echo cflags=\"-D_GNU_SOURCE -I/usr/include/ncursesw\"
|
||||||
|
echo libs=\"-lncursesw -lmenuw -lpanelw\"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -f /usr/include/ncurses/ncurses.h ]; then
|
||||||
|
echo cflags=\"-D_GNU_SOURCE -I/usr/include/ncurses\"
|
||||||
|
echo libs=\"-lncurses -lmenu -lpanel\"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -f /usr/include/ncurses.h ]; then
|
||||||
|
echo cflags=\"-D_GNU_SOURCE\"
|
||||||
|
echo libs=\"-lncurses -lmenu -lpanel\"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo >&2 "*"
|
||||||
|
echo >&2 "* Unable to find the ncurses package."
|
||||||
|
echo >&2 "* Install ncurses (ncurses-devel or libncurses-dev"
|
||||||
|
echo >&2 "* depending on your distribution)."
|
||||||
|
echo >&2 "*"
|
||||||
|
exit 1
|
@ -15,7 +15,7 @@
|
|||||||
#include "nconf.h"
|
#include "nconf.h"
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
|
||||||
static const char nconf_global_help[] = N_(
|
static const char nconf_global_help[] =
|
||||||
"Help windows\n"
|
"Help windows\n"
|
||||||
"------------\n"
|
"------------\n"
|
||||||
"o Global help: Unless in a data entry window, pressing <F1> will give \n"
|
"o Global help: Unless in a data entry window, pressing <F1> will give \n"
|
||||||
@ -130,8 +130,8 @@ static const char nconf_global_help[] = N_(
|
|||||||
"\n"
|
"\n"
|
||||||
"Note that this mode can eventually be a little more CPU expensive than\n"
|
"Note that this mode can eventually be a little more CPU expensive than\n"
|
||||||
"the default mode, especially with a larger number of unfolded submenus.\n"
|
"the default mode, especially with a larger number of unfolded submenus.\n"
|
||||||
"\n"),
|
"\n",
|
||||||
menu_no_f_instructions[] = N_(
|
menu_no_f_instructions[] =
|
||||||
"Legend: [*] built-in [ ] excluded <M> module < > module capable.\n"
|
"Legend: [*] built-in [ ] excluded <M> module < > module capable.\n"
|
||||||
"Submenus are designated by a trailing \"--->\", empty ones by \"----\".\n"
|
"Submenus are designated by a trailing \"--->\", empty ones by \"----\".\n"
|
||||||
"\n"
|
"\n"
|
||||||
@ -147,8 +147,8 @@ menu_no_f_instructions[] = N_(
|
|||||||
"You do not have function keys support.\n"
|
"You do not have function keys support.\n"
|
||||||
"Press <1> instead of <F1>, <2> instead of <F2>, etc.\n"
|
"Press <1> instead of <F1>, <2> instead of <F2>, etc.\n"
|
||||||
"For verbose global help use key <1>.\n"
|
"For verbose global help use key <1>.\n"
|
||||||
"For help related to the current menu entry press <?> or <h>.\n"),
|
"For help related to the current menu entry press <?> or <h>.\n",
|
||||||
menu_instructions[] = N_(
|
menu_instructions[] =
|
||||||
"Legend: [*] built-in [ ] excluded <M> module < > module capable.\n"
|
"Legend: [*] built-in [ ] excluded <M> module < > module capable.\n"
|
||||||
"Submenus are designated by a trailing \"--->\", empty ones by \"----\".\n"
|
"Submenus are designated by a trailing \"--->\", empty ones by \"----\".\n"
|
||||||
"\n"
|
"\n"
|
||||||
@ -163,30 +163,30 @@ menu_instructions[] = N_(
|
|||||||
"\n"
|
"\n"
|
||||||
"Pressing <1> may be used instead of <F1>, <2> instead of <F2>, etc.\n"
|
"Pressing <1> may be used instead of <F1>, <2> instead of <F2>, etc.\n"
|
||||||
"For verbose global help press <F1>.\n"
|
"For verbose global help press <F1>.\n"
|
||||||
"For help related to the current menu entry press <?> or <h>.\n"),
|
"For help related to the current menu entry press <?> or <h>.\n",
|
||||||
radiolist_instructions[] = N_(
|
radiolist_instructions[] =
|
||||||
"Press <Up>, <Down>, <Home> or <End> to navigate a radiolist, select\n"
|
"Press <Up>, <Down>, <Home> or <End> to navigate a radiolist, select\n"
|
||||||
"with <Space>.\n"
|
"with <Space>.\n"
|
||||||
"For help related to the current entry press <?> or <h>.\n"
|
"For help related to the current entry press <?> or <h>.\n"
|
||||||
"For global help press <F1>.\n"),
|
"For global help press <F1>.\n",
|
||||||
inputbox_instructions_int[] = N_(
|
inputbox_instructions_int[] =
|
||||||
"Please enter a decimal value.\n"
|
"Please enter a decimal value.\n"
|
||||||
"Fractions will not be accepted.\n"
|
"Fractions will not be accepted.\n"
|
||||||
"Press <Enter> to apply, <Esc> to cancel."),
|
"Press <Enter> to apply, <Esc> to cancel.",
|
||||||
inputbox_instructions_hex[] = N_(
|
inputbox_instructions_hex[] =
|
||||||
"Please enter a hexadecimal value.\n"
|
"Please enter a hexadecimal value.\n"
|
||||||
"Press <Enter> to apply, <Esc> to cancel."),
|
"Press <Enter> to apply, <Esc> to cancel.",
|
||||||
inputbox_instructions_string[] = N_(
|
inputbox_instructions_string[] =
|
||||||
"Please enter a string value.\n"
|
"Please enter a string value.\n"
|
||||||
"Press <Enter> to apply, <Esc> to cancel."),
|
"Press <Enter> to apply, <Esc> to cancel.",
|
||||||
setmod_text[] = N_(
|
setmod_text[] =
|
||||||
"This feature depends on another feature which has been configured as a\n"
|
"This feature depends on another feature which has been configured as a\n"
|
||||||
"module. As a result, the current feature will be built as a module too."),
|
"module. As a result, the current feature will be built as a module too.",
|
||||||
load_config_text[] = N_(
|
load_config_text[] =
|
||||||
"Enter the name of the configuration file you wish to load.\n"
|
"Enter the name of the configuration file you wish to load.\n"
|
||||||
"Accept the name shown to restore the configuration you last\n"
|
"Accept the name shown to restore the configuration you last\n"
|
||||||
"retrieved. Leave empty to abort."),
|
"retrieved. Leave empty to abort.",
|
||||||
load_config_help[] = N_(
|
load_config_help[] =
|
||||||
"For various reasons, one may wish to keep several different\n"
|
"For various reasons, one may wish to keep several different\n"
|
||||||
"configurations available on a single machine.\n"
|
"configurations available on a single machine.\n"
|
||||||
"\n"
|
"\n"
|
||||||
@ -194,11 +194,11 @@ load_config_help[] = N_(
|
|||||||
"default one, entering its name here will allow you to load and modify\n"
|
"default one, entering its name here will allow you to load and modify\n"
|
||||||
"that configuration.\n"
|
"that configuration.\n"
|
||||||
"\n"
|
"\n"
|
||||||
"Leave empty to abort.\n"),
|
"Leave empty to abort.\n",
|
||||||
save_config_text[] = N_(
|
save_config_text[] =
|
||||||
"Enter a filename to which this configuration should be saved\n"
|
"Enter a filename to which this configuration should be saved\n"
|
||||||
"as an alternate. Leave empty to abort."),
|
"as an alternate. Leave empty to abort.",
|
||||||
save_config_help[] = N_(
|
save_config_help[] =
|
||||||
"For various reasons, one may wish to keep several different\n"
|
"For various reasons, one may wish to keep several different\n"
|
||||||
"configurations available on a single machine.\n"
|
"configurations available on a single machine.\n"
|
||||||
"\n"
|
"\n"
|
||||||
@ -206,8 +206,8 @@ save_config_help[] = N_(
|
|||||||
"and use the current configuration as an alternate to whatever\n"
|
"and use the current configuration as an alternate to whatever\n"
|
||||||
"configuration options you have selected at that time.\n"
|
"configuration options you have selected at that time.\n"
|
||||||
"\n"
|
"\n"
|
||||||
"Leave empty to abort.\n"),
|
"Leave empty to abort.\n",
|
||||||
search_help[] = N_(
|
search_help[] =
|
||||||
"Search for symbols (configuration variable names CONFIG_*) and display\n"
|
"Search for symbols (configuration variable names CONFIG_*) and display\n"
|
||||||
"their relations. Regular expressions are supported.\n"
|
"their relations. Regular expressions are supported.\n"
|
||||||
"Example: Search for \"^FOO\".\n"
|
"Example: Search for \"^FOO\".\n"
|
||||||
@ -244,7 +244,7 @@ search_help[] = N_(
|
|||||||
"USB => find all symbols containing USB\n"
|
"USB => find all symbols containing USB\n"
|
||||||
"^USB => find all symbols starting with USB\n"
|
"^USB => find all symbols starting with USB\n"
|
||||||
"USB$ => find all symbols ending with USB\n"
|
"USB$ => find all symbols ending with USB\n"
|
||||||
"\n");
|
"\n";
|
||||||
|
|
||||||
struct mitem {
|
struct mitem {
|
||||||
char str[256];
|
char str[256];
|
||||||
@ -388,7 +388,7 @@ static void print_function_line(void)
|
|||||||
static void handle_f1(int *key, struct menu *current_item)
|
static void handle_f1(int *key, struct menu *current_item)
|
||||||
{
|
{
|
||||||
show_scroll_win(main_window,
|
show_scroll_win(main_window,
|
||||||
_("Global help"), _(nconf_global_help));
|
"Global help", nconf_global_help);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -403,8 +403,8 @@ static void handle_f2(int *key, struct menu *current_item)
|
|||||||
static void handle_f3(int *key, struct menu *current_item)
|
static void handle_f3(int *key, struct menu *current_item)
|
||||||
{
|
{
|
||||||
show_scroll_win(main_window,
|
show_scroll_win(main_window,
|
||||||
_("Short help"),
|
"Short help",
|
||||||
_(current_instructions));
|
current_instructions);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -412,7 +412,7 @@ static void handle_f3(int *key, struct menu *current_item)
|
|||||||
static void handle_f4(int *key, struct menu *current_item)
|
static void handle_f4(int *key, struct menu *current_item)
|
||||||
{
|
{
|
||||||
int res = btn_dialog(main_window,
|
int res = btn_dialog(main_window,
|
||||||
_("Show all symbols?"),
|
"Show all symbols?",
|
||||||
2,
|
2,
|
||||||
" <Show All> ",
|
" <Show All> ",
|
||||||
"<Don't show all>");
|
"<Don't show all>");
|
||||||
@ -653,8 +653,8 @@ static int do_exit(void)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
res = btn_dialog(main_window,
|
res = btn_dialog(main_window,
|
||||||
_("Do you wish to save your new configuration?\n"
|
"Do you wish to save your new configuration?\n"
|
||||||
"<ESC> to cancel and resume nconfig."),
|
"<ESC> to cancel and resume nconfig.",
|
||||||
2,
|
2,
|
||||||
" <save> ",
|
" <save> ",
|
||||||
"<don't save>");
|
"<don't save>");
|
||||||
@ -670,15 +670,15 @@ static int do_exit(void)
|
|||||||
if (res)
|
if (res)
|
||||||
btn_dialog(
|
btn_dialog(
|
||||||
main_window,
|
main_window,
|
||||||
_("Error during writing of configuration.\n"
|
"Error during writing of configuration.\n"
|
||||||
"Your configuration changes were NOT saved."),
|
"Your configuration changes were NOT saved.",
|
||||||
1,
|
1,
|
||||||
"<OK>");
|
"<OK>");
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
btn_dialog(
|
btn_dialog(
|
||||||
main_window,
|
main_window,
|
||||||
_("Your configuration changes were NOT saved."),
|
"Your configuration changes were NOT saved.",
|
||||||
1,
|
1,
|
||||||
"<OK>");
|
"<OK>");
|
||||||
break;
|
break;
|
||||||
@ -697,12 +697,12 @@ static void search_conf(void)
|
|||||||
int dres;
|
int dres;
|
||||||
|
|
||||||
title = str_new();
|
title = str_new();
|
||||||
str_printf( &title, _("Enter (sub)string or regexp to search for "
|
str_printf( &title, "Enter (sub)string or regexp to search for "
|
||||||
"(with or without \"%s\")"), CONFIG_);
|
"(with or without \"%s\")", CONFIG_);
|
||||||
|
|
||||||
again:
|
again:
|
||||||
dres = dialog_inputbox(main_window,
|
dres = dialog_inputbox(main_window,
|
||||||
_("Search Configuration Parameter"),
|
"Search Configuration Parameter",
|
||||||
str_get(&title),
|
str_get(&title),
|
||||||
"", &dialog_input_result, &dialog_input_result_len);
|
"", &dialog_input_result, &dialog_input_result_len);
|
||||||
switch (dres) {
|
switch (dres) {
|
||||||
@ -710,7 +710,7 @@ static void search_conf(void)
|
|||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
show_scroll_win(main_window,
|
show_scroll_win(main_window,
|
||||||
_("Search Configuration"), search_help);
|
"Search Configuration", search_help);
|
||||||
goto again;
|
goto again;
|
||||||
default:
|
default:
|
||||||
str_free(&title);
|
str_free(&title);
|
||||||
@ -726,7 +726,7 @@ static void search_conf(void)
|
|||||||
res = get_relations_str(sym_arr, NULL);
|
res = get_relations_str(sym_arr, NULL);
|
||||||
free(sym_arr);
|
free(sym_arr);
|
||||||
show_scroll_win(main_window,
|
show_scroll_win(main_window,
|
||||||
_("Search Results"), str_get(&res));
|
"Search Results", str_get(&res));
|
||||||
str_free(&res);
|
str_free(&res);
|
||||||
str_free(&title);
|
str_free(&title);
|
||||||
}
|
}
|
||||||
@ -754,7 +754,7 @@ static void build_conf(struct menu *menu)
|
|||||||
switch (ptype) {
|
switch (ptype) {
|
||||||
case P_MENU:
|
case P_MENU:
|
||||||
child_count++;
|
child_count++;
|
||||||
prompt = _(prompt);
|
prompt = prompt;
|
||||||
if (single_menu_mode) {
|
if (single_menu_mode) {
|
||||||
item_make(menu, 'm',
|
item_make(menu, 'm',
|
||||||
"%s%*c%s",
|
"%s%*c%s",
|
||||||
@ -775,7 +775,7 @@ static void build_conf(struct menu *menu)
|
|||||||
item_make(menu, ':',
|
item_make(menu, ':',
|
||||||
" %*c*** %s ***",
|
" %*c*** %s ***",
|
||||||
indent + 1, ' ',
|
indent + 1, ' ',
|
||||||
_(prompt));
|
prompt);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
@ -783,7 +783,7 @@ static void build_conf(struct menu *menu)
|
|||||||
child_count++;
|
child_count++;
|
||||||
item_make(menu, ':', "---%*c%s",
|
item_make(menu, ':', "---%*c%s",
|
||||||
indent + 1, ' ',
|
indent + 1, ' ',
|
||||||
_(prompt));
|
prompt);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else
|
} else
|
||||||
@ -829,11 +829,11 @@ static void build_conf(struct menu *menu)
|
|||||||
}
|
}
|
||||||
|
|
||||||
item_add_str("%*c%s", indent + 1,
|
item_add_str("%*c%s", indent + 1,
|
||||||
' ', _(menu_get_prompt(menu)));
|
' ', menu_get_prompt(menu));
|
||||||
if (val == yes) {
|
if (val == yes) {
|
||||||
if (def_menu) {
|
if (def_menu) {
|
||||||
item_add_str(" (%s)",
|
item_add_str(" (%s)",
|
||||||
_(menu_get_prompt(def_menu)));
|
menu_get_prompt(def_menu));
|
||||||
item_add_str(" --->");
|
item_add_str(" --->");
|
||||||
if (def_menu->list) {
|
if (def_menu->list) {
|
||||||
indent += 2;
|
indent += 2;
|
||||||
@ -847,7 +847,7 @@ static void build_conf(struct menu *menu)
|
|||||||
if (menu == current_menu) {
|
if (menu == current_menu) {
|
||||||
item_make(menu, ':',
|
item_make(menu, ':',
|
||||||
"---%*c%s", indent + 1,
|
"---%*c%s", indent + 1,
|
||||||
' ', _(menu_get_prompt(menu)));
|
' ', menu_get_prompt(menu));
|
||||||
goto conf_childs;
|
goto conf_childs;
|
||||||
}
|
}
|
||||||
child_count++;
|
child_count++;
|
||||||
@ -894,17 +894,17 @@ static void build_conf(struct menu *menu)
|
|||||||
if (tmp < 0)
|
if (tmp < 0)
|
||||||
tmp = 0;
|
tmp = 0;
|
||||||
item_add_str("%*c%s%s", tmp, ' ',
|
item_add_str("%*c%s%s", tmp, ' ',
|
||||||
_(menu_get_prompt(menu)),
|
menu_get_prompt(menu),
|
||||||
(sym_has_value(sym) ||
|
(sym_has_value(sym) ||
|
||||||
!sym_is_changable(sym)) ? "" :
|
!sym_is_changable(sym)) ? "" :
|
||||||
_(" (NEW)"));
|
" (NEW)");
|
||||||
goto conf_childs;
|
goto conf_childs;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
item_add_str("%*c%s%s", indent + 1, ' ',
|
item_add_str("%*c%s%s", indent + 1, ' ',
|
||||||
_(menu_get_prompt(menu)),
|
menu_get_prompt(menu),
|
||||||
(sym_has_value(sym) || !sym_is_changable(sym)) ?
|
(sym_has_value(sym) || !sym_is_changable(sym)) ?
|
||||||
"" : _(" (NEW)"));
|
"" : " (NEW)");
|
||||||
if (menu->prompt && menu->prompt->type == P_MENU) {
|
if (menu->prompt && menu->prompt->type == P_MENU) {
|
||||||
item_add_str(" %s", menu_is_empty(menu) ? "----" : "--->");
|
item_add_str(" %s", menu_is_empty(menu) ? "----" : "--->");
|
||||||
return;
|
return;
|
||||||
@ -1086,8 +1086,8 @@ static void conf(struct menu *menu)
|
|||||||
if (!child_count)
|
if (!child_count)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
show_menu(prompt ? _(prompt) : _("Main Menu"),
|
show_menu(prompt ? prompt : "Main Menu",
|
||||||
_(menu_instructions),
|
menu_instructions,
|
||||||
current_index, &last_top_row);
|
current_index, &last_top_row);
|
||||||
keypad((menu_win(curses_menu)), TRUE);
|
keypad((menu_win(curses_menu)), TRUE);
|
||||||
while (!global_exit) {
|
while (!global_exit) {
|
||||||
@ -1227,13 +1227,13 @@ static void show_help(struct menu *menu)
|
|||||||
|
|
||||||
help = str_new();
|
help = str_new();
|
||||||
menu_get_ext_help(menu, &help);
|
menu_get_ext_help(menu, &help);
|
||||||
show_scroll_win(main_window, _(menu_get_prompt(menu)), str_get(&help));
|
show_scroll_win(main_window, menu_get_prompt(menu), str_get(&help));
|
||||||
str_free(&help);
|
str_free(&help);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void conf_choice(struct menu *menu)
|
static void conf_choice(struct menu *menu)
|
||||||
{
|
{
|
||||||
const char *prompt = _(menu_get_prompt(menu));
|
const char *prompt = menu_get_prompt(menu);
|
||||||
struct menu *child = NULL;
|
struct menu *child = NULL;
|
||||||
struct symbol *active;
|
struct symbol *active;
|
||||||
int selected_index = 0;
|
int selected_index = 0;
|
||||||
@ -1256,13 +1256,13 @@ static void conf_choice(struct menu *menu)
|
|||||||
|
|
||||||
if (child->sym == sym_get_choice_value(menu->sym))
|
if (child->sym == sym_get_choice_value(menu->sym))
|
||||||
item_make(child, ':', "<X> %s",
|
item_make(child, ':', "<X> %s",
|
||||||
_(menu_get_prompt(child)));
|
menu_get_prompt(child));
|
||||||
else if (child->sym)
|
else if (child->sym)
|
||||||
item_make(child, ':', " %s",
|
item_make(child, ':', " %s",
|
||||||
_(menu_get_prompt(child)));
|
menu_get_prompt(child));
|
||||||
else
|
else
|
||||||
item_make(child, ':', "*** %s ***",
|
item_make(child, ':', "*** %s ***",
|
||||||
_(menu_get_prompt(child)));
|
menu_get_prompt(child));
|
||||||
|
|
||||||
if (child->sym == active){
|
if (child->sym == active){
|
||||||
last_top_row = top_row(curses_menu);
|
last_top_row = top_row(curses_menu);
|
||||||
@ -1270,8 +1270,8 @@ static void conf_choice(struct menu *menu)
|
|||||||
}
|
}
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
show_menu(prompt ? _(prompt) : _("Choice Menu"),
|
show_menu(prompt ? prompt : "Choice Menu",
|
||||||
_(radiolist_instructions),
|
radiolist_instructions,
|
||||||
selected_index,
|
selected_index,
|
||||||
&last_top_row);
|
&last_top_row);
|
||||||
while (!global_exit) {
|
while (!global_exit) {
|
||||||
@ -1358,19 +1358,19 @@ static void conf_string(struct menu *menu)
|
|||||||
|
|
||||||
switch (sym_get_type(menu->sym)) {
|
switch (sym_get_type(menu->sym)) {
|
||||||
case S_INT:
|
case S_INT:
|
||||||
heading = _(inputbox_instructions_int);
|
heading = inputbox_instructions_int;
|
||||||
break;
|
break;
|
||||||
case S_HEX:
|
case S_HEX:
|
||||||
heading = _(inputbox_instructions_hex);
|
heading = inputbox_instructions_hex;
|
||||||
break;
|
break;
|
||||||
case S_STRING:
|
case S_STRING:
|
||||||
heading = _(inputbox_instructions_string);
|
heading = inputbox_instructions_string;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
heading = _("Internal nconf error!");
|
heading = "Internal nconf error!";
|
||||||
}
|
}
|
||||||
res = dialog_inputbox(main_window,
|
res = dialog_inputbox(main_window,
|
||||||
prompt ? _(prompt) : _("Main Menu"),
|
prompt ? prompt : "Main Menu",
|
||||||
heading,
|
heading,
|
||||||
sym_get_string_value(menu->sym),
|
sym_get_string_value(menu->sym),
|
||||||
&dialog_input_result,
|
&dialog_input_result,
|
||||||
@ -1381,7 +1381,7 @@ static void conf_string(struct menu *menu)
|
|||||||
dialog_input_result))
|
dialog_input_result))
|
||||||
return;
|
return;
|
||||||
btn_dialog(main_window,
|
btn_dialog(main_window,
|
||||||
_("You have made an invalid entry."), 0);
|
"You have made an invalid entry.", 0);
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
show_help(menu);
|
show_help(menu);
|
||||||
@ -1410,11 +1410,11 @@ static void conf_load(void)
|
|||||||
sym_set_change_count(1);
|
sym_set_change_count(1);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
btn_dialog(main_window, _("File does not exist!"), 0);
|
btn_dialog(main_window, "File does not exist!", 0);
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
show_scroll_win(main_window,
|
show_scroll_win(main_window,
|
||||||
_("Load Alternate Configuration"),
|
"Load Alternate Configuration",
|
||||||
load_config_help);
|
load_config_help);
|
||||||
break;
|
break;
|
||||||
case KEY_EXIT:
|
case KEY_EXIT:
|
||||||
@ -1441,13 +1441,13 @@ static void conf_save(void)
|
|||||||
set_config_filename(dialog_input_result);
|
set_config_filename(dialog_input_result);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
btn_dialog(main_window, _("Can't create file! "
|
btn_dialog(main_window, "Can't create file! "
|
||||||
"Probably a nonexistent directory."),
|
"Probably a nonexistent directory.",
|
||||||
1, "<OK>");
|
1, "<OK>");
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
show_scroll_win(main_window,
|
show_scroll_win(main_window,
|
||||||
_("Save Alternate Configuration"),
|
"Save Alternate Configuration",
|
||||||
save_config_help);
|
save_config_help);
|
||||||
break;
|
break;
|
||||||
case KEY_EXIT:
|
case KEY_EXIT:
|
||||||
@ -1480,10 +1480,6 @@ int main(int ac, char **av)
|
|||||||
int lines, columns;
|
int lines, columns;
|
||||||
char *mode;
|
char *mode;
|
||||||
|
|
||||||
setlocale(LC_ALL, "");
|
|
||||||
bindtextdomain(PACKAGE, LOCALEDIR);
|
|
||||||
textdomain(PACKAGE);
|
|
||||||
|
|
||||||
if (ac > 1 && strcmp(av[1], "-s") == 0) {
|
if (ac > 1 && strcmp(av[1], "-s") == 0) {
|
||||||
/* Silence conf_read() until the real callback is set up */
|
/* Silence conf_read() until the real callback is set up */
|
||||||
conf_set_message_callback(NULL);
|
conf_set_message_callback(NULL);
|
||||||
@ -1541,8 +1537,8 @@ int main(int ac, char **av)
|
|||||||
/* check for KEY_FUNC(1) */
|
/* check for KEY_FUNC(1) */
|
||||||
if (has_key(KEY_F(1)) == FALSE) {
|
if (has_key(KEY_F(1)) == FALSE) {
|
||||||
show_scroll_win(main_window,
|
show_scroll_win(main_window,
|
||||||
_("Instructions"),
|
"Instructions",
|
||||||
_(menu_no_f_instructions));
|
menu_no_f_instructions);
|
||||||
}
|
}
|
||||||
|
|
||||||
conf_set_message_callback(conf_message_callback);
|
conf_set_message_callback(conf_message_callback);
|
||||||
|
@ -14,7 +14,6 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <locale.h>
|
|
||||||
#include <ncurses.h>
|
#include <ncurses.h>
|
||||||
#include <menu.h>
|
#include <menu.h>
|
||||||
#include <panel.h>
|
#include <panel.h>
|
||||||
|
572
scripts/kconfig/preprocess.c
Normal file
572
scripts/kconfig/preprocess.c
Normal file
@ -0,0 +1,572 @@
|
|||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
|
//
|
||||||
|
// Copyright (C) 2018 Masahiro Yamada <yamada.masahiro@socionext.com>
|
||||||
|
|
||||||
|
#include <stdarg.h>
|
||||||
|
#include <stdbool.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
#include "list.h"
|
||||||
|
|
||||||
|
#define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]))
|
||||||
|
|
||||||
|
static char *expand_string_with_args(const char *in, int argc, char *argv[]);
|
||||||
|
|
||||||
|
static void __attribute__((noreturn)) pperror(const char *format, ...)
|
||||||
|
{
|
||||||
|
va_list ap;
|
||||||
|
|
||||||
|
fprintf(stderr, "%s:%d: ", current_file->name, yylineno);
|
||||||
|
va_start(ap, format);
|
||||||
|
vfprintf(stderr, format, ap);
|
||||||
|
va_end(ap);
|
||||||
|
fprintf(stderr, "\n");
|
||||||
|
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Environment variables
|
||||||
|
*/
|
||||||
|
static LIST_HEAD(env_list);
|
||||||
|
|
||||||
|
struct env {
|
||||||
|
char *name;
|
||||||
|
char *value;
|
||||||
|
struct list_head node;
|
||||||
|
};
|
||||||
|
|
||||||
|
static void env_add(const char *name, const char *value)
|
||||||
|
{
|
||||||
|
struct env *e;
|
||||||
|
|
||||||
|
e = xmalloc(sizeof(*e));
|
||||||
|
e->name = xstrdup(name);
|
||||||
|
e->value = xstrdup(value);
|
||||||
|
|
||||||
|
list_add_tail(&e->node, &env_list);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void env_del(struct env *e)
|
||||||
|
{
|
||||||
|
list_del(&e->node);
|
||||||
|
free(e->name);
|
||||||
|
free(e->value);
|
||||||
|
free(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* The returned pointer must be freed when done */
|
||||||
|
static char *env_expand(const char *name)
|
||||||
|
{
|
||||||
|
struct env *e;
|
||||||
|
const char *value;
|
||||||
|
|
||||||
|
if (!*name)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
list_for_each_entry(e, &env_list, node) {
|
||||||
|
if (!strcmp(name, e->name))
|
||||||
|
return xstrdup(e->value);
|
||||||
|
}
|
||||||
|
|
||||||
|
value = getenv(name);
|
||||||
|
if (!value)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We need to remember all referenced environment variables.
|
||||||
|
* They will be written out to include/config/auto.conf.cmd
|
||||||
|
*/
|
||||||
|
env_add(name, value);
|
||||||
|
|
||||||
|
return xstrdup(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
void env_write_dep(FILE *f, const char *autoconfig_name)
|
||||||
|
{
|
||||||
|
struct env *e, *tmp;
|
||||||
|
|
||||||
|
list_for_each_entry_safe(e, tmp, &env_list, node) {
|
||||||
|
fprintf(f, "ifneq \"$(%s)\" \"%s\"\n", e->name, e->value);
|
||||||
|
fprintf(f, "%s: FORCE\n", autoconfig_name);
|
||||||
|
fprintf(f, "endif\n");
|
||||||
|
env_del(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Built-in functions
|
||||||
|
*/
|
||||||
|
struct function {
|
||||||
|
const char *name;
|
||||||
|
unsigned int min_args;
|
||||||
|
unsigned int max_args;
|
||||||
|
char *(*func)(int argc, char *argv[]);
|
||||||
|
};
|
||||||
|
|
||||||
|
static char *do_error_if(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
if (!strcmp(argv[0], "y"))
|
||||||
|
pperror("%s", argv[1]);
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static char *do_filename(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
return xstrdup(current_file->name);
|
||||||
|
}
|
||||||
|
|
||||||
|
static char *do_info(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
printf("%s\n", argv[0]);
|
||||||
|
|
||||||
|
return xstrdup("");
|
||||||
|
}
|
||||||
|
|
||||||
|
static char *do_lineno(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
char buf[16];
|
||||||
|
|
||||||
|
sprintf(buf, "%d", yylineno);
|
||||||
|
|
||||||
|
return xstrdup(buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
static char *do_shell(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
FILE *p;
|
||||||
|
char buf[256];
|
||||||
|
char *cmd;
|
||||||
|
size_t nread;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
cmd = argv[0];
|
||||||
|
|
||||||
|
p = popen(cmd, "r");
|
||||||
|
if (!p) {
|
||||||
|
perror(cmd);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
nread = fread(buf, 1, sizeof(buf), p);
|
||||||
|
if (nread == sizeof(buf))
|
||||||
|
nread--;
|
||||||
|
|
||||||
|
/* remove trailing new lines */
|
||||||
|
while (buf[nread - 1] == '\n')
|
||||||
|
nread--;
|
||||||
|
|
||||||
|
buf[nread] = 0;
|
||||||
|
|
||||||
|
/* replace a new line with a space */
|
||||||
|
for (i = 0; i < nread; i++) {
|
||||||
|
if (buf[i] == '\n')
|
||||||
|
buf[i] = ' ';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pclose(p) == -1) {
|
||||||
|
perror(cmd);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
return xstrdup(buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
static char *do_warning_if(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
if (!strcmp(argv[0], "y"))
|
||||||
|
fprintf(stderr, "%s:%d: %s\n",
|
||||||
|
current_file->name, yylineno, argv[1]);
|
||||||
|
|
||||||
|
return xstrdup("");
|
||||||
|
}
|
||||||
|
|
||||||
|
static const struct function function_table[] = {
|
||||||
|
/* Name MIN MAX Function */
|
||||||
|
{ "error-if", 2, 2, do_error_if },
|
||||||
|
{ "filename", 0, 0, do_filename },
|
||||||
|
{ "info", 1, 1, do_info },
|
||||||
|
{ "lineno", 0, 0, do_lineno },
|
||||||
|
{ "shell", 1, 1, do_shell },
|
||||||
|
{ "warning-if", 2, 2, do_warning_if },
|
||||||
|
};
|
||||||
|
|
||||||
|
#define FUNCTION_MAX_ARGS 16
|
||||||
|
|
||||||
|
static char *function_expand(const char *name, int argc, char *argv[])
|
||||||
|
{
|
||||||
|
const struct function *f;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < ARRAY_SIZE(function_table); i++) {
|
||||||
|
f = &function_table[i];
|
||||||
|
if (strcmp(f->name, name))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (argc < f->min_args)
|
||||||
|
pperror("too few function arguments passed to '%s'",
|
||||||
|
name);
|
||||||
|
|
||||||
|
if (argc > f->max_args)
|
||||||
|
pperror("too many function arguments passed to '%s'",
|
||||||
|
name);
|
||||||
|
|
||||||
|
return f->func(argc, argv);
|
||||||
|
}
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Variables (and user-defined functions)
|
||||||
|
*/
|
||||||
|
static LIST_HEAD(variable_list);
|
||||||
|
|
||||||
|
struct variable {
|
||||||
|
char *name;
|
||||||
|
char *value;
|
||||||
|
enum variable_flavor flavor;
|
||||||
|
int exp_count;
|
||||||
|
struct list_head node;
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct variable *variable_lookup(const char *name)
|
||||||
|
{
|
||||||
|
struct variable *v;
|
||||||
|
|
||||||
|
list_for_each_entry(v, &variable_list, node) {
|
||||||
|
if (!strcmp(name, v->name))
|
||||||
|
return v;
|
||||||
|
}
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static char *variable_expand(const char *name, int argc, char *argv[])
|
||||||
|
{
|
||||||
|
struct variable *v;
|
||||||
|
char *res;
|
||||||
|
|
||||||
|
v = variable_lookup(name);
|
||||||
|
if (!v)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
if (argc == 0 && v->exp_count)
|
||||||
|
pperror("Recursive variable '%s' references itself (eventually)",
|
||||||
|
name);
|
||||||
|
|
||||||
|
if (v->exp_count > 1000)
|
||||||
|
pperror("Too deep recursive expansion");
|
||||||
|
|
||||||
|
v->exp_count++;
|
||||||
|
|
||||||
|
if (v->flavor == VAR_RECURSIVE)
|
||||||
|
res = expand_string_with_args(v->value, argc, argv);
|
||||||
|
else
|
||||||
|
res = xstrdup(v->value);
|
||||||
|
|
||||||
|
v->exp_count--;
|
||||||
|
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
void variable_add(const char *name, const char *value,
|
||||||
|
enum variable_flavor flavor)
|
||||||
|
{
|
||||||
|
struct variable *v;
|
||||||
|
char *new_value;
|
||||||
|
bool append = false;
|
||||||
|
|
||||||
|
v = variable_lookup(name);
|
||||||
|
if (v) {
|
||||||
|
/* For defined variables, += inherits the existing flavor */
|
||||||
|
if (flavor == VAR_APPEND) {
|
||||||
|
flavor = v->flavor;
|
||||||
|
append = true;
|
||||||
|
} else {
|
||||||
|
free(v->value);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* For undefined variables, += assumes the recursive flavor */
|
||||||
|
if (flavor == VAR_APPEND)
|
||||||
|
flavor = VAR_RECURSIVE;
|
||||||
|
|
||||||
|
v = xmalloc(sizeof(*v));
|
||||||
|
v->name = xstrdup(name);
|
||||||
|
v->exp_count = 0;
|
||||||
|
list_add_tail(&v->node, &variable_list);
|
||||||
|
}
|
||||||
|
|
||||||
|
v->flavor = flavor;
|
||||||
|
|
||||||
|
if (flavor == VAR_SIMPLE)
|
||||||
|
new_value = expand_string(value);
|
||||||
|
else
|
||||||
|
new_value = xstrdup(value);
|
||||||
|
|
||||||
|
if (append) {
|
||||||
|
v->value = xrealloc(v->value,
|
||||||
|
strlen(v->value) + strlen(new_value) + 2);
|
||||||
|
strcat(v->value, " ");
|
||||||
|
strcat(v->value, new_value);
|
||||||
|
free(new_value);
|
||||||
|
} else {
|
||||||
|
v->value = new_value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void variable_del(struct variable *v)
|
||||||
|
{
|
||||||
|
list_del(&v->node);
|
||||||
|
free(v->name);
|
||||||
|
free(v->value);
|
||||||
|
free(v);
|
||||||
|
}
|
||||||
|
|
||||||
|
void variable_all_del(void)
|
||||||
|
{
|
||||||
|
struct variable *v, *tmp;
|
||||||
|
|
||||||
|
list_for_each_entry_safe(v, tmp, &variable_list, node)
|
||||||
|
variable_del(v);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Evaluate a clause with arguments. argc/argv are arguments from the upper
|
||||||
|
* function call.
|
||||||
|
*
|
||||||
|
* Returned string must be freed when done
|
||||||
|
*/
|
||||||
|
static char *eval_clause(const char *str, size_t len, int argc, char *argv[])
|
||||||
|
{
|
||||||
|
char *tmp, *name, *res, *endptr, *prev, *p;
|
||||||
|
int new_argc = 0;
|
||||||
|
char *new_argv[FUNCTION_MAX_ARGS];
|
||||||
|
int nest = 0;
|
||||||
|
int i;
|
||||||
|
unsigned long n;
|
||||||
|
|
||||||
|
tmp = xstrndup(str, len);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If variable name is '1', '2', etc. It is generally an argument
|
||||||
|
* from a user-function call (i.e. local-scope variable). If not
|
||||||
|
* available, then look-up global-scope variables.
|
||||||
|
*/
|
||||||
|
n = strtoul(tmp, &endptr, 10);
|
||||||
|
if (!*endptr && n > 0 && n <= argc) {
|
||||||
|
res = xstrdup(argv[n - 1]);
|
||||||
|
goto free_tmp;
|
||||||
|
}
|
||||||
|
|
||||||
|
prev = p = tmp;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Split into tokens
|
||||||
|
* The function name and arguments are separated by a comma.
|
||||||
|
* For example, if the function call is like this:
|
||||||
|
* $(foo,$(x),$(y))
|
||||||
|
*
|
||||||
|
* The input string for this helper should be:
|
||||||
|
* foo,$(x),$(y)
|
||||||
|
*
|
||||||
|
* and split into:
|
||||||
|
* new_argv[0] = 'foo'
|
||||||
|
* new_argv[1] = '$(x)'
|
||||||
|
* new_argv[2] = '$(y)'
|
||||||
|
*/
|
||||||
|
while (*p) {
|
||||||
|
if (nest == 0 && *p == ',') {
|
||||||
|
*p = 0;
|
||||||
|
if (new_argc >= FUNCTION_MAX_ARGS)
|
||||||
|
pperror("too many function arguments");
|
||||||
|
new_argv[new_argc++] = prev;
|
||||||
|
prev = p + 1;
|
||||||
|
} else if (*p == '(') {
|
||||||
|
nest++;
|
||||||
|
} else if (*p == ')') {
|
||||||
|
nest--;
|
||||||
|
}
|
||||||
|
|
||||||
|
p++;
|
||||||
|
}
|
||||||
|
new_argv[new_argc++] = prev;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Shift arguments
|
||||||
|
* new_argv[0] represents a function name or a variable name. Put it
|
||||||
|
* into 'name', then shift the rest of the arguments. This simplifies
|
||||||
|
* 'const' handling.
|
||||||
|
*/
|
||||||
|
name = expand_string_with_args(new_argv[0], argc, argv);
|
||||||
|
new_argc--;
|
||||||
|
for (i = 0; i < new_argc; i++)
|
||||||
|
new_argv[i] = expand_string_with_args(new_argv[i + 1],
|
||||||
|
argc, argv);
|
||||||
|
|
||||||
|
/* Search for variables */
|
||||||
|
res = variable_expand(name, new_argc, new_argv);
|
||||||
|
if (res)
|
||||||
|
goto free;
|
||||||
|
|
||||||
|
/* Look for built-in functions */
|
||||||
|
res = function_expand(name, new_argc, new_argv);
|
||||||
|
if (res)
|
||||||
|
goto free;
|
||||||
|
|
||||||
|
/* Last, try environment variable */
|
||||||
|
if (new_argc == 0) {
|
||||||
|
res = env_expand(name);
|
||||||
|
if (res)
|
||||||
|
goto free;
|
||||||
|
}
|
||||||
|
|
||||||
|
res = xstrdup("");
|
||||||
|
free:
|
||||||
|
for (i = 0; i < new_argc; i++)
|
||||||
|
free(new_argv[i]);
|
||||||
|
free(name);
|
||||||
|
free_tmp:
|
||||||
|
free(tmp);
|
||||||
|
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Expand a string that follows '$'
|
||||||
|
*
|
||||||
|
* For example, if the input string is
|
||||||
|
* ($(FOO)$($(BAR)))$(BAZ)
|
||||||
|
* this helper evaluates
|
||||||
|
* $($(FOO)$($(BAR)))
|
||||||
|
* and returns a new string containing the expansion (note that the string is
|
||||||
|
* recursively expanded), also advancing 'str' to point to the next character
|
||||||
|
* after the corresponding closing parenthesis, in this case, *str will be
|
||||||
|
* $(BAR)
|
||||||
|
*/
|
||||||
|
static char *expand_dollar_with_args(const char **str, int argc, char *argv[])
|
||||||
|
{
|
||||||
|
const char *p = *str;
|
||||||
|
const char *q;
|
||||||
|
int nest = 0;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* In Kconfig, variable/function references always start with "$(".
|
||||||
|
* Neither single-letter variables as in $A nor curly braces as in ${CC}
|
||||||
|
* are supported. '$' not followed by '(' loses its special meaning.
|
||||||
|
*/
|
||||||
|
if (*p != '(') {
|
||||||
|
*str = p;
|
||||||
|
return xstrdup("$");
|
||||||
|
}
|
||||||
|
|
||||||
|
p++;
|
||||||
|
q = p;
|
||||||
|
while (*q) {
|
||||||
|
if (*q == '(') {
|
||||||
|
nest++;
|
||||||
|
} else if (*q == ')') {
|
||||||
|
if (nest-- == 0)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
q++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!*q)
|
||||||
|
pperror("unterminated reference to '%s': missing ')'", p);
|
||||||
|
|
||||||
|
/* Advance 'str' to after the expanded initial portion of the string */
|
||||||
|
*str = q + 1;
|
||||||
|
|
||||||
|
return eval_clause(p, q - p, argc, argv);
|
||||||
|
}
|
||||||
|
|
||||||
|
char *expand_dollar(const char **str)
|
||||||
|
{
|
||||||
|
return expand_dollar_with_args(str, 0, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
static char *__expand_string(const char **str, bool (*is_end)(char c),
|
||||||
|
int argc, char *argv[])
|
||||||
|
{
|
||||||
|
const char *in, *p;
|
||||||
|
char *expansion, *out;
|
||||||
|
size_t in_len, out_len;
|
||||||
|
|
||||||
|
out = xmalloc(1);
|
||||||
|
*out = 0;
|
||||||
|
out_len = 1;
|
||||||
|
|
||||||
|
p = in = *str;
|
||||||
|
|
||||||
|
while (1) {
|
||||||
|
if (*p == '$') {
|
||||||
|
in_len = p - in;
|
||||||
|
p++;
|
||||||
|
expansion = expand_dollar_with_args(&p, argc, argv);
|
||||||
|
out_len += in_len + strlen(expansion);
|
||||||
|
out = xrealloc(out, out_len);
|
||||||
|
strncat(out, in, in_len);
|
||||||
|
strcat(out, expansion);
|
||||||
|
free(expansion);
|
||||||
|
in = p;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_end(*p))
|
||||||
|
break;
|
||||||
|
|
||||||
|
p++;
|
||||||
|
}
|
||||||
|
|
||||||
|
in_len = p - in;
|
||||||
|
out_len += in_len;
|
||||||
|
out = xrealloc(out, out_len);
|
||||||
|
strncat(out, in, in_len);
|
||||||
|
|
||||||
|
/* Advance 'str' to the end character */
|
||||||
|
*str = p;
|
||||||
|
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool is_end_of_str(char c)
|
||||||
|
{
|
||||||
|
return !c;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Expand variables and functions in the given string. Undefined variables
|
||||||
|
* expand to an empty string.
|
||||||
|
* The returned string must be freed when done.
|
||||||
|
*/
|
||||||
|
static char *expand_string_with_args(const char *in, int argc, char *argv[])
|
||||||
|
{
|
||||||
|
return __expand_string(&in, is_end_of_str, argc, argv);
|
||||||
|
}
|
||||||
|
|
||||||
|
char *expand_string(const char *in)
|
||||||
|
{
|
||||||
|
return expand_string_with_args(in, 0, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool is_end_of_token(char c)
|
||||||
|
{
|
||||||
|
/* Why are '.' and '/' valid characters for symbols? */
|
||||||
|
return !(isalnum(c) || c == '_' || c == '-' || c == '.' || c == '/');
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Expand variables in a token. The parsing stops when a token separater
|
||||||
|
* (in most cases, it is a whitespace) is encountered. 'str' is updated to
|
||||||
|
* point to the next character.
|
||||||
|
*
|
||||||
|
* The returned string must be freed when done.
|
||||||
|
*/
|
||||||
|
char *expand_one_token(const char **str)
|
||||||
|
{
|
||||||
|
return __expand_string(str, is_end_of_token, 0, NULL);
|
||||||
|
}
|
25
scripts/kconfig/qconf-cfg.sh
Executable file
25
scripts/kconfig/qconf-cfg.sh
Executable file
@ -0,0 +1,25 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
|
PKG="Qt5Core Qt5Gui Qt5Widgets"
|
||||||
|
PKG2="QtCore QtGui"
|
||||||
|
|
||||||
|
if pkg-config --exists $PKG; then
|
||||||
|
echo cflags=\"-std=c++11 -fPIC $(pkg-config --cflags Qt5Core Qt5Gui Qt5Widgets)\"
|
||||||
|
echo libs=\"$(pkg-config --libs $PKG)\"
|
||||||
|
echo moc=\"$(pkg-config --variable=host_bins Qt5Core)/moc\"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if pkg-config --exists $PKG2; then
|
||||||
|
echo cflags=\"$(pkg-config --cflags $PKG2)\"
|
||||||
|
echo libs=\"$(pkg-config --libs $PKG2)\"
|
||||||
|
echo moc=\"$(pkg-config --variable=moc_location QtCore)\"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo >&2 "*"
|
||||||
|
echo >&2 "* Could not find Qt via pkg-config."
|
||||||
|
echo >&2 "* Please install either Qt 4.8 or 5.x. and make sure it's in PKG_CONFIG_PATH"
|
||||||
|
echo >&2 "*"
|
||||||
|
exit 1
|
@ -34,10 +34,6 @@
|
|||||||
#include "qconf.moc"
|
#include "qconf.moc"
|
||||||
#include "images.c"
|
#include "images.c"
|
||||||
|
|
||||||
#ifdef _
|
|
||||||
# undef _
|
|
||||||
# define _ qgettext
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static QApplication *configApp;
|
static QApplication *configApp;
|
||||||
static ConfigSettings *configSettings;
|
static ConfigSettings *configSettings;
|
||||||
@ -46,12 +42,7 @@ QAction *ConfigMainWindow::saveAction;
|
|||||||
|
|
||||||
static inline QString qgettext(const char* str)
|
static inline QString qgettext(const char* str)
|
||||||
{
|
{
|
||||||
return QString::fromLocal8Bit(gettext(str));
|
return QString::fromLocal8Bit(str);
|
||||||
}
|
|
||||||
|
|
||||||
static inline QString qgettext(const QString& str)
|
|
||||||
{
|
|
||||||
return QString::fromLocal8Bit(gettext(str.toLatin1()));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ConfigSettings::ConfigSettings()
|
ConfigSettings::ConfigSettings()
|
||||||
@ -127,7 +118,7 @@ void ConfigItem::updateMenu(void)
|
|||||||
|
|
||||||
sym = menu->sym;
|
sym = menu->sym;
|
||||||
prop = menu->prompt;
|
prop = menu->prompt;
|
||||||
prompt = _(menu_get_prompt(menu));
|
prompt = qgettext(menu_get_prompt(menu));
|
||||||
|
|
||||||
if (prop) switch (prop->type) {
|
if (prop) switch (prop->type) {
|
||||||
case P_MENU:
|
case P_MENU:
|
||||||
@ -216,7 +207,7 @@ void ConfigItem::updateMenu(void)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (!sym_has_value(sym) && visible)
|
if (!sym_has_value(sym) && visible)
|
||||||
prompt += _(" (NEW)");
|
prompt += " (NEW)";
|
||||||
set_prompt:
|
set_prompt:
|
||||||
setText(promptColIdx, prompt);
|
setText(promptColIdx, prompt);
|
||||||
}
|
}
|
||||||
@ -327,7 +318,7 @@ ConfigList::ConfigList(ConfigView* p, const char *name)
|
|||||||
setVerticalScrollMode(ScrollPerPixel);
|
setVerticalScrollMode(ScrollPerPixel);
|
||||||
setHorizontalScrollMode(ScrollPerPixel);
|
setHorizontalScrollMode(ScrollPerPixel);
|
||||||
|
|
||||||
setHeaderLabels(QStringList() << _("Option") << _("Name") << "N" << "M" << "Y" << _("Value"));
|
setHeaderLabels(QStringList() << "Option" << "Name" << "N" << "M" << "Y" << "Value");
|
||||||
|
|
||||||
connect(this, SIGNAL(itemSelectionChanged(void)),
|
connect(this, SIGNAL(itemSelectionChanged(void)),
|
||||||
SLOT(updateSelection(void)));
|
SLOT(updateSelection(void)));
|
||||||
@ -883,7 +874,7 @@ void ConfigList::contextMenuEvent(QContextMenuEvent *e)
|
|||||||
QAction *action;
|
QAction *action;
|
||||||
|
|
||||||
headerPopup = new QMenu(this);
|
headerPopup = new QMenu(this);
|
||||||
action = new QAction(_("Show Name"), this);
|
action = new QAction("Show Name", this);
|
||||||
action->setCheckable(true);
|
action->setCheckable(true);
|
||||||
connect(action, SIGNAL(toggled(bool)),
|
connect(action, SIGNAL(toggled(bool)),
|
||||||
parent(), SLOT(setShowName(bool)));
|
parent(), SLOT(setShowName(bool)));
|
||||||
@ -891,7 +882,7 @@ void ConfigList::contextMenuEvent(QContextMenuEvent *e)
|
|||||||
action, SLOT(setOn(bool)));
|
action, SLOT(setOn(bool)));
|
||||||
action->setChecked(showName);
|
action->setChecked(showName);
|
||||||
headerPopup->addAction(action);
|
headerPopup->addAction(action);
|
||||||
action = new QAction(_("Show Range"), this);
|
action = new QAction("Show Range", this);
|
||||||
action->setCheckable(true);
|
action->setCheckable(true);
|
||||||
connect(action, SIGNAL(toggled(bool)),
|
connect(action, SIGNAL(toggled(bool)),
|
||||||
parent(), SLOT(setShowRange(bool)));
|
parent(), SLOT(setShowRange(bool)));
|
||||||
@ -899,7 +890,7 @@ void ConfigList::contextMenuEvent(QContextMenuEvent *e)
|
|||||||
action, SLOT(setOn(bool)));
|
action, SLOT(setOn(bool)));
|
||||||
action->setChecked(showRange);
|
action->setChecked(showRange);
|
||||||
headerPopup->addAction(action);
|
headerPopup->addAction(action);
|
||||||
action = new QAction(_("Show Data"), this);
|
action = new QAction("Show Data", this);
|
||||||
action->setCheckable(true);
|
action->setCheckable(true);
|
||||||
connect(action, SIGNAL(toggled(bool)),
|
connect(action, SIGNAL(toggled(bool)),
|
||||||
parent(), SLOT(setShowData(bool)));
|
parent(), SLOT(setShowData(bool)));
|
||||||
@ -1086,7 +1077,7 @@ void ConfigInfoView::menuInfo(void)
|
|||||||
if (sym) {
|
if (sym) {
|
||||||
if (_menu->prompt) {
|
if (_menu->prompt) {
|
||||||
head += "<big><b>";
|
head += "<big><b>";
|
||||||
head += print_filter(_(_menu->prompt->text));
|
head += print_filter(_menu->prompt->text);
|
||||||
head += "</b></big>";
|
head += "</b></big>";
|
||||||
if (sym->name) {
|
if (sym->name) {
|
||||||
head += " (";
|
head += " (";
|
||||||
@ -1117,7 +1108,7 @@ void ConfigInfoView::menuInfo(void)
|
|||||||
str_free(&help_gstr);
|
str_free(&help_gstr);
|
||||||
} else if (_menu->prompt) {
|
} else if (_menu->prompt) {
|
||||||
head += "<big><b>";
|
head += "<big><b>";
|
||||||
head += print_filter(_(_menu->prompt->text));
|
head += print_filter(_menu->prompt->text);
|
||||||
head += "</b></big><br><br>";
|
head += "</b></big><br><br>";
|
||||||
if (showDebug()) {
|
if (showDebug()) {
|
||||||
if (_menu->prompt->visible.expr) {
|
if (_menu->prompt->visible.expr) {
|
||||||
@ -1152,7 +1143,7 @@ QString ConfigInfoView::debug_info(struct symbol *sym)
|
|||||||
case P_PROMPT:
|
case P_PROMPT:
|
||||||
case P_MENU:
|
case P_MENU:
|
||||||
debug += QString().sprintf("prompt: <a href=\"m%p\">", prop->menu);
|
debug += QString().sprintf("prompt: <a href=\"m%p\">", prop->menu);
|
||||||
debug += print_filter(_(prop->text));
|
debug += print_filter(prop->text);
|
||||||
debug += "</a><br>";
|
debug += "</a><br>";
|
||||||
break;
|
break;
|
||||||
case P_DEFAULT:
|
case P_DEFAULT:
|
||||||
@ -1234,7 +1225,7 @@ void ConfigInfoView::expr_print_help(void *data, struct symbol *sym, const char
|
|||||||
QMenu* ConfigInfoView::createStandardContextMenu(const QPoint & pos)
|
QMenu* ConfigInfoView::createStandardContextMenu(const QPoint & pos)
|
||||||
{
|
{
|
||||||
QMenu* popup = Parent::createStandardContextMenu(pos);
|
QMenu* popup = Parent::createStandardContextMenu(pos);
|
||||||
QAction* action = new QAction(_("Show Debug Info"), popup);
|
QAction* action = new QAction("Show Debug Info", popup);
|
||||||
action->setCheckable(true);
|
action->setCheckable(true);
|
||||||
connect(action, SIGNAL(toggled(bool)), SLOT(setShowDebug(bool)));
|
connect(action, SIGNAL(toggled(bool)), SLOT(setShowDebug(bool)));
|
||||||
connect(this, SIGNAL(showDebugChanged(bool)), action, SLOT(setOn(bool)));
|
connect(this, SIGNAL(showDebugChanged(bool)), action, SLOT(setOn(bool)));
|
||||||
@ -1261,11 +1252,11 @@ ConfigSearchWindow::ConfigSearchWindow(ConfigMainWindow* parent, const char *nam
|
|||||||
QHBoxLayout* layout2 = new QHBoxLayout(0);
|
QHBoxLayout* layout2 = new QHBoxLayout(0);
|
||||||
layout2->setContentsMargins(0, 0, 0, 0);
|
layout2->setContentsMargins(0, 0, 0, 0);
|
||||||
layout2->setSpacing(6);
|
layout2->setSpacing(6);
|
||||||
layout2->addWidget(new QLabel(_("Find:"), this));
|
layout2->addWidget(new QLabel("Find:", this));
|
||||||
editField = new QLineEdit(this);
|
editField = new QLineEdit(this);
|
||||||
connect(editField, SIGNAL(returnPressed()), SLOT(search()));
|
connect(editField, SIGNAL(returnPressed()), SLOT(search()));
|
||||||
layout2->addWidget(editField);
|
layout2->addWidget(editField);
|
||||||
searchButton = new QPushButton(_("Search"), this);
|
searchButton = new QPushButton("Search", this);
|
||||||
searchButton->setAutoDefault(false);
|
searchButton->setAutoDefault(false);
|
||||||
connect(searchButton, SIGNAL(clicked()), SLOT(search()));
|
connect(searchButton, SIGNAL(clicked()), SLOT(search()));
|
||||||
layout2->addWidget(searchButton);
|
layout2->addWidget(searchButton);
|
||||||
@ -1387,44 +1378,44 @@ ConfigMainWindow::ConfigMainWindow(void)
|
|||||||
toolBar = new QToolBar("Tools", this);
|
toolBar = new QToolBar("Tools", this);
|
||||||
addToolBar(toolBar);
|
addToolBar(toolBar);
|
||||||
|
|
||||||
backAction = new QAction(QPixmap(xpm_back), _("Back"), this);
|
backAction = new QAction(QPixmap(xpm_back), "Back", this);
|
||||||
connect(backAction, SIGNAL(triggered(bool)), SLOT(goBack()));
|
connect(backAction, SIGNAL(triggered(bool)), SLOT(goBack()));
|
||||||
backAction->setEnabled(false);
|
backAction->setEnabled(false);
|
||||||
QAction *quitAction = new QAction(_("&Quit"), this);
|
QAction *quitAction = new QAction("&Quit", this);
|
||||||
quitAction->setShortcut(Qt::CTRL + Qt::Key_Q);
|
quitAction->setShortcut(Qt::CTRL + Qt::Key_Q);
|
||||||
connect(quitAction, SIGNAL(triggered(bool)), SLOT(close()));
|
connect(quitAction, SIGNAL(triggered(bool)), SLOT(close()));
|
||||||
QAction *loadAction = new QAction(QPixmap(xpm_load), _("&Load"), this);
|
QAction *loadAction = new QAction(QPixmap(xpm_load), "&Load", this);
|
||||||
loadAction->setShortcut(Qt::CTRL + Qt::Key_L);
|
loadAction->setShortcut(Qt::CTRL + Qt::Key_L);
|
||||||
connect(loadAction, SIGNAL(triggered(bool)), SLOT(loadConfig()));
|
connect(loadAction, SIGNAL(triggered(bool)), SLOT(loadConfig()));
|
||||||
saveAction = new QAction(QPixmap(xpm_save), _("&Save"), this);
|
saveAction = new QAction(QPixmap(xpm_save), "&Save", this);
|
||||||
saveAction->setShortcut(Qt::CTRL + Qt::Key_S);
|
saveAction->setShortcut(Qt::CTRL + Qt::Key_S);
|
||||||
connect(saveAction, SIGNAL(triggered(bool)), SLOT(saveConfig()));
|
connect(saveAction, SIGNAL(triggered(bool)), SLOT(saveConfig()));
|
||||||
conf_set_changed_callback(conf_changed);
|
conf_set_changed_callback(conf_changed);
|
||||||
// Set saveAction's initial state
|
// Set saveAction's initial state
|
||||||
conf_changed();
|
conf_changed();
|
||||||
QAction *saveAsAction = new QAction(_("Save &As..."), this);
|
QAction *saveAsAction = new QAction("Save &As...", this);
|
||||||
connect(saveAsAction, SIGNAL(triggered(bool)), SLOT(saveConfigAs()));
|
connect(saveAsAction, SIGNAL(triggered(bool)), SLOT(saveConfigAs()));
|
||||||
QAction *searchAction = new QAction(_("&Find"), this);
|
QAction *searchAction = new QAction("&Find", this);
|
||||||
searchAction->setShortcut(Qt::CTRL + Qt::Key_F);
|
searchAction->setShortcut(Qt::CTRL + Qt::Key_F);
|
||||||
connect(searchAction, SIGNAL(triggered(bool)), SLOT(searchConfig()));
|
connect(searchAction, SIGNAL(triggered(bool)), SLOT(searchConfig()));
|
||||||
singleViewAction = new QAction(QPixmap(xpm_single_view), _("Single View"), this);
|
singleViewAction = new QAction(QPixmap(xpm_single_view), "Single View", this);
|
||||||
singleViewAction->setCheckable(true);
|
singleViewAction->setCheckable(true);
|
||||||
connect(singleViewAction, SIGNAL(triggered(bool)), SLOT(showSingleView()));
|
connect(singleViewAction, SIGNAL(triggered(bool)), SLOT(showSingleView()));
|
||||||
splitViewAction = new QAction(QPixmap(xpm_split_view), _("Split View"), this);
|
splitViewAction = new QAction(QPixmap(xpm_split_view), "Split View", this);
|
||||||
splitViewAction->setCheckable(true);
|
splitViewAction->setCheckable(true);
|
||||||
connect(splitViewAction, SIGNAL(triggered(bool)), SLOT(showSplitView()));
|
connect(splitViewAction, SIGNAL(triggered(bool)), SLOT(showSplitView()));
|
||||||
fullViewAction = new QAction(QPixmap(xpm_tree_view), _("Full View"), this);
|
fullViewAction = new QAction(QPixmap(xpm_tree_view), "Full View", this);
|
||||||
fullViewAction->setCheckable(true);
|
fullViewAction->setCheckable(true);
|
||||||
connect(fullViewAction, SIGNAL(triggered(bool)), SLOT(showFullView()));
|
connect(fullViewAction, SIGNAL(triggered(bool)), SLOT(showFullView()));
|
||||||
|
|
||||||
QAction *showNameAction = new QAction(_("Show Name"), this);
|
QAction *showNameAction = new QAction("Show Name", this);
|
||||||
showNameAction->setCheckable(true);
|
showNameAction->setCheckable(true);
|
||||||
connect(showNameAction, SIGNAL(toggled(bool)), configView, SLOT(setShowName(bool)));
|
connect(showNameAction, SIGNAL(toggled(bool)), configView, SLOT(setShowName(bool)));
|
||||||
showNameAction->setChecked(configView->showName());
|
showNameAction->setChecked(configView->showName());
|
||||||
QAction *showRangeAction = new QAction(_("Show Range"), this);
|
QAction *showRangeAction = new QAction("Show Range", this);
|
||||||
showRangeAction->setCheckable(true);
|
showRangeAction->setCheckable(true);
|
||||||
connect(showRangeAction, SIGNAL(toggled(bool)), configView, SLOT(setShowRange(bool)));
|
connect(showRangeAction, SIGNAL(toggled(bool)), configView, SLOT(setShowRange(bool)));
|
||||||
QAction *showDataAction = new QAction(_("Show Data"), this);
|
QAction *showDataAction = new QAction("Show Data", this);
|
||||||
showDataAction->setCheckable(true);
|
showDataAction->setCheckable(true);
|
||||||
connect(showDataAction, SIGNAL(toggled(bool)), configView, SLOT(setShowData(bool)));
|
connect(showDataAction, SIGNAL(toggled(bool)), configView, SLOT(setShowData(bool)));
|
||||||
|
|
||||||
@ -1435,21 +1426,21 @@ ConfigMainWindow::ConfigMainWindow(void)
|
|||||||
connect(optGroup, SIGNAL(triggered(QAction *)), menuView,
|
connect(optGroup, SIGNAL(triggered(QAction *)), menuView,
|
||||||
SLOT(setOptionMode(QAction *)));
|
SLOT(setOptionMode(QAction *)));
|
||||||
|
|
||||||
configView->showNormalAction = new QAction(_("Show Normal Options"), optGroup);
|
configView->showNormalAction = new QAction("Show Normal Options", optGroup);
|
||||||
configView->showAllAction = new QAction(_("Show All Options"), optGroup);
|
configView->showAllAction = new QAction("Show All Options", optGroup);
|
||||||
configView->showPromptAction = new QAction(_("Show Prompt Options"), optGroup);
|
configView->showPromptAction = new QAction("Show Prompt Options", optGroup);
|
||||||
configView->showNormalAction->setCheckable(true);
|
configView->showNormalAction->setCheckable(true);
|
||||||
configView->showAllAction->setCheckable(true);
|
configView->showAllAction->setCheckable(true);
|
||||||
configView->showPromptAction->setCheckable(true);
|
configView->showPromptAction->setCheckable(true);
|
||||||
|
|
||||||
QAction *showDebugAction = new QAction( _("Show Debug Info"), this);
|
QAction *showDebugAction = new QAction("Show Debug Info", this);
|
||||||
showDebugAction->setCheckable(true);
|
showDebugAction->setCheckable(true);
|
||||||
connect(showDebugAction, SIGNAL(toggled(bool)), helpText, SLOT(setShowDebug(bool)));
|
connect(showDebugAction, SIGNAL(toggled(bool)), helpText, SLOT(setShowDebug(bool)));
|
||||||
showDebugAction->setChecked(helpText->showDebug());
|
showDebugAction->setChecked(helpText->showDebug());
|
||||||
|
|
||||||
QAction *showIntroAction = new QAction( _("Introduction"), this);
|
QAction *showIntroAction = new QAction("Introduction", this);
|
||||||
connect(showIntroAction, SIGNAL(triggered(bool)), SLOT(showIntro()));
|
connect(showIntroAction, SIGNAL(triggered(bool)), SLOT(showIntro()));
|
||||||
QAction *showAboutAction = new QAction( _("About"), this);
|
QAction *showAboutAction = new QAction("About", this);
|
||||||
connect(showAboutAction, SIGNAL(triggered(bool)), SLOT(showAbout()));
|
connect(showAboutAction, SIGNAL(triggered(bool)), SLOT(showAbout()));
|
||||||
|
|
||||||
// init tool bar
|
// init tool bar
|
||||||
@ -1463,7 +1454,7 @@ ConfigMainWindow::ConfigMainWindow(void)
|
|||||||
toolBar->addAction(fullViewAction);
|
toolBar->addAction(fullViewAction);
|
||||||
|
|
||||||
// create config menu
|
// create config menu
|
||||||
QMenu* config = menu->addMenu(_("&File"));
|
QMenu* config = menu->addMenu("&File");
|
||||||
config->addAction(loadAction);
|
config->addAction(loadAction);
|
||||||
config->addAction(saveAction);
|
config->addAction(saveAction);
|
||||||
config->addAction(saveAsAction);
|
config->addAction(saveAsAction);
|
||||||
@ -1471,11 +1462,11 @@ ConfigMainWindow::ConfigMainWindow(void)
|
|||||||
config->addAction(quitAction);
|
config->addAction(quitAction);
|
||||||
|
|
||||||
// create edit menu
|
// create edit menu
|
||||||
QMenu* editMenu = menu->addMenu(_("&Edit"));
|
QMenu* editMenu = menu->addMenu("&Edit");
|
||||||
editMenu->addAction(searchAction);
|
editMenu->addAction(searchAction);
|
||||||
|
|
||||||
// create options menu
|
// create options menu
|
||||||
QMenu* optionMenu = menu->addMenu(_("&Option"));
|
QMenu* optionMenu = menu->addMenu("&Option");
|
||||||
optionMenu->addAction(showNameAction);
|
optionMenu->addAction(showNameAction);
|
||||||
optionMenu->addAction(showRangeAction);
|
optionMenu->addAction(showRangeAction);
|
||||||
optionMenu->addAction(showDataAction);
|
optionMenu->addAction(showDataAction);
|
||||||
@ -1486,7 +1477,7 @@ ConfigMainWindow::ConfigMainWindow(void)
|
|||||||
|
|
||||||
// create help menu
|
// create help menu
|
||||||
menu->addSeparator();
|
menu->addSeparator();
|
||||||
QMenu* helpMenu = menu->addMenu(_("&Help"));
|
QMenu* helpMenu = menu->addMenu("&Help");
|
||||||
helpMenu->addAction(showIntroAction);
|
helpMenu->addAction(showIntroAction);
|
||||||
helpMenu->addAction(showAboutAction);
|
helpMenu->addAction(showAboutAction);
|
||||||
|
|
||||||
@ -1534,14 +1525,14 @@ void ConfigMainWindow::loadConfig(void)
|
|||||||
if (s.isNull())
|
if (s.isNull())
|
||||||
return;
|
return;
|
||||||
if (conf_read(QFile::encodeName(s)))
|
if (conf_read(QFile::encodeName(s)))
|
||||||
QMessageBox::information(this, "qconf", _("Unable to load configuration!"));
|
QMessageBox::information(this, "qconf", "Unable to load configuration!");
|
||||||
ConfigView::updateListAll();
|
ConfigView::updateListAll();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ConfigMainWindow::saveConfig(void)
|
bool ConfigMainWindow::saveConfig(void)
|
||||||
{
|
{
|
||||||
if (conf_write(NULL)) {
|
if (conf_write(NULL)) {
|
||||||
QMessageBox::information(this, "qconf", _("Unable to save configuration!"));
|
QMessageBox::information(this, "qconf", "Unable to save configuration!");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
@ -1723,11 +1714,11 @@ void ConfigMainWindow::closeEvent(QCloseEvent* e)
|
|||||||
e->accept();
|
e->accept();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
QMessageBox mb("qconf", _("Save configuration?"), QMessageBox::Warning,
|
QMessageBox mb("qconf", "Save configuration?", QMessageBox::Warning,
|
||||||
QMessageBox::Yes | QMessageBox::Default, QMessageBox::No, QMessageBox::Cancel | QMessageBox::Escape);
|
QMessageBox::Yes | QMessageBox::Default, QMessageBox::No, QMessageBox::Cancel | QMessageBox::Escape);
|
||||||
mb.setButtonText(QMessageBox::Yes, _("&Save Changes"));
|
mb.setButtonText(QMessageBox::Yes, "&Save Changes");
|
||||||
mb.setButtonText(QMessageBox::No, _("&Discard Changes"));
|
mb.setButtonText(QMessageBox::No, "&Discard Changes");
|
||||||
mb.setButtonText(QMessageBox::Cancel, _("Cancel Exit"));
|
mb.setButtonText(QMessageBox::Cancel, "Cancel Exit");
|
||||||
switch (mb.exec()) {
|
switch (mb.exec()) {
|
||||||
case QMessageBox::Yes:
|
case QMessageBox::Yes:
|
||||||
if (saveConfig())
|
if (saveConfig())
|
||||||
@ -1746,7 +1737,7 @@ void ConfigMainWindow::closeEvent(QCloseEvent* e)
|
|||||||
|
|
||||||
void ConfigMainWindow::showIntro(void)
|
void ConfigMainWindow::showIntro(void)
|
||||||
{
|
{
|
||||||
static const QString str = _("Welcome to the qconf graphical configuration tool.\n\n"
|
static const QString str = "Welcome to the qconf graphical configuration tool.\n\n"
|
||||||
"For each option, a blank box indicates the feature is disabled, a check\n"
|
"For each option, a blank box indicates the feature is disabled, a check\n"
|
||||||
"indicates it is enabled, and a dot indicates that it is to be compiled\n"
|
"indicates it is enabled, and a dot indicates that it is to be compiled\n"
|
||||||
"as a module. Clicking on the box will cycle through the three states.\n\n"
|
"as a module. Clicking on the box will cycle through the three states.\n\n"
|
||||||
@ -1756,16 +1747,16 @@ void ConfigMainWindow::showIntro(void)
|
|||||||
"options must be enabled to support the option you are interested in, you can\n"
|
"options must be enabled to support the option you are interested in, you can\n"
|
||||||
"still view the help of a grayed-out option.\n\n"
|
"still view the help of a grayed-out option.\n\n"
|
||||||
"Toggling Show Debug Info under the Options menu will show the dependencies,\n"
|
"Toggling Show Debug Info under the Options menu will show the dependencies,\n"
|
||||||
"which you can then match by examining other options.\n\n");
|
"which you can then match by examining other options.\n\n";
|
||||||
|
|
||||||
QMessageBox::information(this, "qconf", str);
|
QMessageBox::information(this, "qconf", str);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigMainWindow::showAbout(void)
|
void ConfigMainWindow::showAbout(void)
|
||||||
{
|
{
|
||||||
static const QString str = _("qconf is Copyright (C) 2002 Roman Zippel <zippel@linux-m68k.org>.\n"
|
static const QString str = "qconf is Copyright (C) 2002 Roman Zippel <zippel@linux-m68k.org>.\n"
|
||||||
"Copyright (C) 2015 Boris Barbulovski <bbarbulovski@gmail.com>.\n\n"
|
"Copyright (C) 2015 Boris Barbulovski <bbarbulovski@gmail.com>.\n\n"
|
||||||
"Bug reports and feature request can also be entered at http://bugzilla.kernel.org/\n");
|
"Bug reports and feature request can also be entered at http://bugzilla.kernel.org/\n";
|
||||||
|
|
||||||
QMessageBox::information(this, "qconf", str);
|
QMessageBox::information(this, "qconf", str);
|
||||||
}
|
}
|
||||||
@ -1826,7 +1817,7 @@ static const char *progname;
|
|||||||
|
|
||||||
static void usage(void)
|
static void usage(void)
|
||||||
{
|
{
|
||||||
printf(_("%s [-s] <config>\n").toLatin1().constData(), progname);
|
printf("%s [-s] <config>\n", progname);
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1835,9 +1826,6 @@ int main(int ac, char** av)
|
|||||||
ConfigMainWindow* v;
|
ConfigMainWindow* v;
|
||||||
const char *name;
|
const char *name;
|
||||||
|
|
||||||
bindtextdomain(PACKAGE, LOCALEDIR);
|
|
||||||
textdomain(PACKAGE);
|
|
||||||
|
|
||||||
progname = av[0];
|
progname = av[0];
|
||||||
configApp = new QApplication(ac, av);
|
configApp = new QApplication(ac, av);
|
||||||
if (ac > 1 && av[1][0] == '-') {
|
if (ac > 1 && av[1][0] == '-') {
|
||||||
|
@ -33,33 +33,6 @@ struct symbol *sym_defconfig_list;
|
|||||||
struct symbol *modules_sym;
|
struct symbol *modules_sym;
|
||||||
tristate modules_val;
|
tristate modules_val;
|
||||||
|
|
||||||
struct expr *sym_env_list;
|
|
||||||
|
|
||||||
static void sym_add_default(struct symbol *sym, const char *def)
|
|
||||||
{
|
|
||||||
struct property *prop = prop_alloc(P_DEFAULT, sym);
|
|
||||||
|
|
||||||
prop->expr = expr_alloc_symbol(sym_lookup(def, SYMBOL_CONST));
|
|
||||||
}
|
|
||||||
|
|
||||||
void sym_init(void)
|
|
||||||
{
|
|
||||||
struct symbol *sym;
|
|
||||||
struct utsname uts;
|
|
||||||
static bool inited = false;
|
|
||||||
|
|
||||||
if (inited)
|
|
||||||
return;
|
|
||||||
inited = true;
|
|
||||||
|
|
||||||
uname(&uts);
|
|
||||||
|
|
||||||
sym = sym_lookup("UNAME_RELEASE", 0);
|
|
||||||
sym->type = S_STRING;
|
|
||||||
sym->flags |= SYMBOL_AUTO;
|
|
||||||
sym_add_default(sym, uts.release);
|
|
||||||
}
|
|
||||||
|
|
||||||
enum symbol_type sym_get_type(struct symbol *sym)
|
enum symbol_type sym_get_type(struct symbol *sym)
|
||||||
{
|
{
|
||||||
enum symbol_type type = sym->type;
|
enum symbol_type type = sym->type;
|
||||||
@ -906,59 +879,6 @@ struct symbol *sym_find(const char *name)
|
|||||||
return symbol;
|
return symbol;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Expand symbol's names embedded in the string given in argument. Symbols'
|
|
||||||
* name to be expanded shall be prefixed by a '$'. Unknown symbol expands to
|
|
||||||
* the empty string.
|
|
||||||
*/
|
|
||||||
char *sym_expand_string_value(const char *in)
|
|
||||||
{
|
|
||||||
const char *src;
|
|
||||||
char *res;
|
|
||||||
size_t reslen;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Note: 'in' might come from a token that's about to be
|
|
||||||
* freed, so make sure to always allocate a new string
|
|
||||||
*/
|
|
||||||
reslen = strlen(in) + 1;
|
|
||||||
res = xmalloc(reslen);
|
|
||||||
res[0] = '\0';
|
|
||||||
|
|
||||||
while ((src = strchr(in, '$'))) {
|
|
||||||
char *p, name[SYMBOL_MAXLENGTH];
|
|
||||||
const char *symval = "";
|
|
||||||
struct symbol *sym;
|
|
||||||
size_t newlen;
|
|
||||||
|
|
||||||
strncat(res, in, src - in);
|
|
||||||
src++;
|
|
||||||
|
|
||||||
p = name;
|
|
||||||
while (isalnum(*src) || *src == '_')
|
|
||||||
*p++ = *src++;
|
|
||||||
*p = '\0';
|
|
||||||
|
|
||||||
sym = sym_find(name);
|
|
||||||
if (sym != NULL) {
|
|
||||||
sym_calc_value(sym);
|
|
||||||
symval = sym_get_string_value(sym);
|
|
||||||
}
|
|
||||||
|
|
||||||
newlen = strlen(res) + strlen(symval) + strlen(src) + 1;
|
|
||||||
if (newlen > reslen) {
|
|
||||||
reslen = newlen;
|
|
||||||
res = xrealloc(res, reslen);
|
|
||||||
}
|
|
||||||
|
|
||||||
strcat(res, symval);
|
|
||||||
in = src;
|
|
||||||
}
|
|
||||||
strcat(res, in);
|
|
||||||
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
|
|
||||||
const char *sym_escape_string_value(const char *in)
|
const char *sym_escape_string_value(const char *in)
|
||||||
{
|
{
|
||||||
const char *p;
|
const char *p;
|
||||||
@ -1401,32 +1321,3 @@ const char *prop_get_type_name(enum prop_type type)
|
|||||||
}
|
}
|
||||||
return "unknown";
|
return "unknown";
|
||||||
}
|
}
|
||||||
|
|
||||||
static void prop_add_env(const char *env)
|
|
||||||
{
|
|
||||||
struct symbol *sym, *sym2;
|
|
||||||
struct property *prop;
|
|
||||||
char *p;
|
|
||||||
|
|
||||||
sym = current_entry->sym;
|
|
||||||
sym->flags |= SYMBOL_AUTO;
|
|
||||||
for_all_properties(sym, prop, P_ENV) {
|
|
||||||
sym2 = prop_get_symbol(prop);
|
|
||||||
if (strcmp(sym2->name, env))
|
|
||||||
menu_warn(current_entry, "redefining environment symbol from %s",
|
|
||||||
sym2->name);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
prop = prop_alloc(P_ENV, sym);
|
|
||||||
prop->expr = expr_alloc_symbol(sym_lookup(env, SYMBOL_CONST));
|
|
||||||
|
|
||||||
sym_env_list = expr_alloc_one(E_LIST, sym_env_list);
|
|
||||||
sym_env_list->right.sym = sym;
|
|
||||||
|
|
||||||
p = getenv(env);
|
|
||||||
if (p)
|
|
||||||
sym_add_default(sym, p);
|
|
||||||
else
|
|
||||||
menu_warn(current_entry, "environment variable %s undefined", env);
|
|
||||||
}
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#
|
#
|
||||||
# Automatically generated file; DO NOT EDIT.
|
# Automatically generated file; DO NOT EDIT.
|
||||||
# Linux Kernel Configuration
|
# Main menu
|
||||||
#
|
#
|
||||||
# CONFIG_A is not set
|
# CONFIG_A is not set
|
||||||
|
27
scripts/kconfig/tests/preprocess/builtin_func/Kconfig
Normal file
27
scripts/kconfig/tests/preprocess/builtin_func/Kconfig
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
|
# 'info' prints the argument to stdout.
|
||||||
|
$(info,hello world 0)
|
||||||
|
|
||||||
|
# 'warning-if', if the first argument is y, sends the second argument to stderr,
|
||||||
|
# and the message is prefixed with the current file name and line number.
|
||||||
|
$(warning-if,y,hello world 1)
|
||||||
|
|
||||||
|
# 'error-if' is similar, but it terminates the parsing immediately.
|
||||||
|
# The following is just no-op since the first argument is not y.
|
||||||
|
$(error-if,n,this should not be printed)
|
||||||
|
|
||||||
|
# Shorthand
|
||||||
|
warning = $(warning-if,y,$(1))
|
||||||
|
|
||||||
|
# 'shell' executes a command, and returns its stdout.
|
||||||
|
$(warning,$(shell,echo hello world 3))
|
||||||
|
|
||||||
|
# Every newline in the output is replaced with a space,
|
||||||
|
# but any trailing newlines are deleted.
|
||||||
|
$(warning,$(shell,printf 'hello\nworld\n\n4\n\n\n'))
|
||||||
|
|
||||||
|
# 'filename' is expanded to the currently parsed file name,
|
||||||
|
# 'lineno' to the line number.
|
||||||
|
$(warning,filename=$(filename))
|
||||||
|
$(warning,lineno=$(lineno))
|
@ -0,0 +1,9 @@
|
|||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
"""
|
||||||
|
Built-in function tests.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def test(conf):
|
||||||
|
assert conf.oldaskconfig() == 0
|
||||||
|
assert conf.stdout_contains('expected_stdout')
|
||||||
|
assert conf.stderr_matches('expected_stderr')
|
@ -0,0 +1,5 @@
|
|||||||
|
Kconfig:8: hello world 1
|
||||||
|
Kconfig:18: hello world 3
|
||||||
|
Kconfig:22: hello world 4
|
||||||
|
Kconfig:26: filename=Kconfig
|
||||||
|
Kconfig:27: lineno=27
|
@ -0,0 +1 @@
|
|||||||
|
hello world 0
|
@ -0,0 +1,5 @@
|
|||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
|
X = $(Y)
|
||||||
|
Y = $(X)
|
||||||
|
$(info $(X))
|
@ -0,0 +1,11 @@
|
|||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
"""
|
||||||
|
Detect circular variable expansion.
|
||||||
|
|
||||||
|
If a recursively expanded variable references itself (eventually),
|
||||||
|
it should fail with an error message.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def test(conf):
|
||||||
|
assert conf.oldaskconfig() != 0
|
||||||
|
assert conf.stderr_matches('expected_stderr')
|
@ -0,0 +1 @@
|
|||||||
|
Kconfig:5: Recursive variable 'X' references itself (eventually)
|
44
scripts/kconfig/tests/preprocess/escape/Kconfig
Normal file
44
scripts/kconfig/tests/preprocess/escape/Kconfig
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
|
# Shorthand
|
||||||
|
warning = $(warning-if,y,$(1))
|
||||||
|
|
||||||
|
# You can not pass commas directly to a function since they are treated as
|
||||||
|
# delimiters. You can use the following trick to do so.
|
||||||
|
comma := ,
|
||||||
|
$(warning,hello$(comma) world)
|
||||||
|
|
||||||
|
# Like Make, single quotes, double quotes, spaces are treated verbatim.
|
||||||
|
# The following prints the text as-is.
|
||||||
|
$(warning, ' " '" ' ''' "'")
|
||||||
|
|
||||||
|
# Unlike Make, '$' has special meaning only when it is followed by '('.
|
||||||
|
# No need to escape '$' itself.
|
||||||
|
$(warning,$)
|
||||||
|
$(warning,$$)
|
||||||
|
$ := 1
|
||||||
|
$(warning,$($))
|
||||||
|
|
||||||
|
# You need a trick to escape '$' followed by '('
|
||||||
|
# The following should print "$(X)". It should not be expanded further.
|
||||||
|
dollar := $
|
||||||
|
$(warning,$(dollar)(X))
|
||||||
|
|
||||||
|
# You need a trick to treat unbalanced parentheses.
|
||||||
|
# The following should print "(".
|
||||||
|
left_paren := (
|
||||||
|
$(warning,$(left_paren))
|
||||||
|
|
||||||
|
# A simple expanded should not be expanded multiple times.
|
||||||
|
# The following should print "$(X)". It should not be expanded further.
|
||||||
|
Y := $(dollar)(X)
|
||||||
|
$(warning,$(Y))
|
||||||
|
|
||||||
|
# The following should print "$(X)" as well.
|
||||||
|
Y = $(dollar)(X)
|
||||||
|
$(warning,$(Y))
|
||||||
|
|
||||||
|
# The following should print "$(".
|
||||||
|
# It should not be emit "unterminated reference" error.
|
||||||
|
unterminated := $(dollar)(
|
||||||
|
$(warning,$(unterminated))
|
8
scripts/kconfig/tests/preprocess/escape/__init__.py
Normal file
8
scripts/kconfig/tests/preprocess/escape/__init__.py
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
"""
|
||||||
|
Escape sequence tests.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def test(conf):
|
||||||
|
assert conf.oldaskconfig() == 0
|
||||||
|
assert conf.stderr_matches('expected_stderr')
|
10
scripts/kconfig/tests/preprocess/escape/expected_stderr
Normal file
10
scripts/kconfig/tests/preprocess/escape/expected_stderr
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
Kconfig:9: hello, world
|
||||||
|
Kconfig:13: ' " '" ' ''' "'"
|
||||||
|
Kconfig:17: $
|
||||||
|
Kconfig:18: $$
|
||||||
|
Kconfig:20: 1
|
||||||
|
Kconfig:25: $(X)
|
||||||
|
Kconfig:30: (
|
||||||
|
Kconfig:35: $(X)
|
||||||
|
Kconfig:39: $(X)
|
||||||
|
Kconfig:44: $(
|
53
scripts/kconfig/tests/preprocess/variable/Kconfig
Normal file
53
scripts/kconfig/tests/preprocess/variable/Kconfig
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
|
# Shorthand
|
||||||
|
warning = $(warning-if,y,$(1))
|
||||||
|
|
||||||
|
# Simply expanded variable.
|
||||||
|
X := 1
|
||||||
|
SIMPLE := $(X)
|
||||||
|
X := 2
|
||||||
|
$(warning,SIMPLE = $(SIMPLE))
|
||||||
|
|
||||||
|
# Recursively expanded variable.
|
||||||
|
X := 1
|
||||||
|
RECURSIVE = $(X)
|
||||||
|
X := 2
|
||||||
|
$(warning,RECURSIVE = $(RECURSIVE))
|
||||||
|
|
||||||
|
# Append something to a simply expanded variable.
|
||||||
|
Y := 3
|
||||||
|
SIMPLE += $(Y)
|
||||||
|
Y := 4
|
||||||
|
$(warning,SIMPLE = $(SIMPLE))
|
||||||
|
|
||||||
|
# Append something to a recursively expanded variable.
|
||||||
|
Y := 3
|
||||||
|
RECURSIVE += $(Y)
|
||||||
|
Y := 4
|
||||||
|
$(warning,RECURSIVE = $(RECURSIVE))
|
||||||
|
|
||||||
|
# Use += operator to an undefined variable.
|
||||||
|
# This works as a recursively expanded variable.
|
||||||
|
Y := 3
|
||||||
|
UNDEFINED_VARIABLE += $(Y)
|
||||||
|
Y := 4
|
||||||
|
$(warning,UNDEFINED_VARIABLE = $(UNDEFINED_VARIABLE))
|
||||||
|
|
||||||
|
# You can use variable references for the lefthand side of assignment statement.
|
||||||
|
X := A
|
||||||
|
Y := B
|
||||||
|
$(X)$(Y) := 5
|
||||||
|
$(warning,AB = $(AB))
|
||||||
|
|
||||||
|
# User-defined function.
|
||||||
|
greeting = $(1), my name is $(2).
|
||||||
|
$(warning,$(greeting,Hello,John))
|
||||||
|
|
||||||
|
# The number of arguments is not checked for user-defined functions.
|
||||||
|
# If some arguments are optional, it is useful to pass fewer parameters.
|
||||||
|
# $(2) will be blank in this case.
|
||||||
|
$(warning,$(greeting,Hello))
|
||||||
|
|
||||||
|
# Unreferenced parameters are just ignored.
|
||||||
|
$(warning,$(greeting,Hello,John,ignored,ignored))
|
8
scripts/kconfig/tests/preprocess/variable/__init__.py
Normal file
8
scripts/kconfig/tests/preprocess/variable/__init__.py
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
"""
|
||||||
|
Variable and user-defined function tests.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def test(conf):
|
||||||
|
assert conf.oldaskconfig() == 0
|
||||||
|
assert conf.stderr_matches('expected_stderr')
|
@ -0,0 +1,9 @@
|
|||||||
|
Kconfig:10: SIMPLE = 1
|
||||||
|
Kconfig:16: RECURSIVE = 2
|
||||||
|
Kconfig:22: SIMPLE = 1 3
|
||||||
|
Kconfig:28: RECURSIVE = 2 4
|
||||||
|
Kconfig:35: UNDEFINED_VARIABLE = 4
|
||||||
|
Kconfig:41: AB = 5
|
||||||
|
Kconfig:45: Hello, my name is John.
|
||||||
|
Kconfig:50: Hello, my name is .
|
||||||
|
Kconfig:53: Hello, my name is John.
|
@ -14,18 +14,16 @@
|
|||||||
struct file *file_lookup(const char *name)
|
struct file *file_lookup(const char *name)
|
||||||
{
|
{
|
||||||
struct file *file;
|
struct file *file;
|
||||||
char *file_name = sym_expand_string_value(name);
|
|
||||||
|
|
||||||
for (file = file_list; file; file = file->next) {
|
for (file = file_list; file; file = file->next) {
|
||||||
if (!strcmp(name, file->name)) {
|
if (!strcmp(name, file->name)) {
|
||||||
free(file_name);
|
|
||||||
return file;
|
return file;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
file = xmalloc(sizeof(*file));
|
file = xmalloc(sizeof(*file));
|
||||||
memset(file, 0, sizeof(*file));
|
memset(file, 0, sizeof(*file));
|
||||||
file->name = file_name;
|
file->name = xstrdup(name);
|
||||||
file->next = file_list;
|
file->next = file_list;
|
||||||
file_list = file;
|
file_list = file;
|
||||||
return file;
|
return file;
|
||||||
@ -34,8 +32,6 @@ struct file *file_lookup(const char *name)
|
|||||||
/* write a dependency file as used by kbuild to track dependencies */
|
/* write a dependency file as used by kbuild to track dependencies */
|
||||||
int file_write_dep(const char *name)
|
int file_write_dep(const char *name)
|
||||||
{
|
{
|
||||||
struct symbol *sym, *env_sym;
|
|
||||||
struct expr *e;
|
|
||||||
struct file *file;
|
struct file *file;
|
||||||
FILE *out;
|
FILE *out;
|
||||||
|
|
||||||
@ -54,21 +50,7 @@ int file_write_dep(const char *name)
|
|||||||
fprintf(out, "\n%s: \\\n"
|
fprintf(out, "\n%s: \\\n"
|
||||||
"\t$(deps_config)\n\n", conf_get_autoconfig_name());
|
"\t$(deps_config)\n\n", conf_get_autoconfig_name());
|
||||||
|
|
||||||
expr_list_for_each_sym(sym_env_list, e, sym) {
|
env_write_dep(out, conf_get_autoconfig_name());
|
||||||
struct property *prop;
|
|
||||||
const char *value;
|
|
||||||
|
|
||||||
prop = sym_get_env_prop(sym);
|
|
||||||
env_sym = prop_get_symbol(prop);
|
|
||||||
if (!env_sym)
|
|
||||||
continue;
|
|
||||||
value = getenv(env_sym->name);
|
|
||||||
if (!value)
|
|
||||||
value = "";
|
|
||||||
fprintf(out, "ifneq \"$(%s)\" \"%s\"\n", env_sym->name, value);
|
|
||||||
fprintf(out, "%s: FORCE\n", conf_get_autoconfig_name());
|
|
||||||
fprintf(out, "endif\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
fprintf(out, "\n$(deps_config): ;\n");
|
fprintf(out, "\n$(deps_config): ;\n");
|
||||||
fclose(out);
|
fclose(out);
|
||||||
@ -165,3 +147,14 @@ char *xstrdup(const char *s)
|
|||||||
fprintf(stderr, "Out of memory.\n");
|
fprintf(stderr, "Out of memory.\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *xstrndup(const char *s, size_t n)
|
||||||
|
{
|
||||||
|
char *p;
|
||||||
|
|
||||||
|
p = strndup(s, n);
|
||||||
|
if (p)
|
||||||
|
return p;
|
||||||
|
fprintf(stderr, "Out of memory.\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
@ -1,13 +1,13 @@
|
|||||||
%option nostdinit noyywrap never-interactive full ecs
|
%option nostdinit noyywrap never-interactive full ecs
|
||||||
%option 8bit nodefault yylineno
|
%option 8bit nodefault yylineno
|
||||||
%option noinput
|
%x COMMAND HELP STRING PARAM ASSIGN_VAL
|
||||||
%x COMMAND HELP STRING PARAM
|
|
||||||
%{
|
%{
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2002 Roman Zippel <zippel@linux-m68k.org>
|
* Copyright (C) 2002 Roman Zippel <zippel@linux-m68k.org>
|
||||||
* Released under the terms of the GNU GPL v2.0.
|
* Released under the terms of the GNU GPL v2.0.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <assert.h>
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
@ -35,6 +35,8 @@ struct buffer *current_buf;
|
|||||||
|
|
||||||
static int last_ts, first_ts;
|
static int last_ts, first_ts;
|
||||||
|
|
||||||
|
static char *expand_token(const char *in, size_t n);
|
||||||
|
static void append_expanded_string(const char *in);
|
||||||
static void zconf_endhelp(void);
|
static void zconf_endhelp(void);
|
||||||
static void zconf_endfile(void);
|
static void zconf_endfile(void);
|
||||||
|
|
||||||
@ -101,17 +103,28 @@ n [A-Za-z0-9_-]
|
|||||||
<COMMAND>{
|
<COMMAND>{
|
||||||
{n}+ {
|
{n}+ {
|
||||||
const struct kconf_id *id = kconf_id_lookup(yytext, yyleng);
|
const struct kconf_id *id = kconf_id_lookup(yytext, yyleng);
|
||||||
BEGIN(PARAM);
|
|
||||||
current_pos.file = current_file;
|
current_pos.file = current_file;
|
||||||
current_pos.lineno = yylineno;
|
current_pos.lineno = yylineno;
|
||||||
if (id && id->flags & TF_COMMAND) {
|
if (id && id->flags & TF_COMMAND) {
|
||||||
|
BEGIN(PARAM);
|
||||||
yylval.id = id;
|
yylval.id = id;
|
||||||
return id->token;
|
return id->token;
|
||||||
}
|
}
|
||||||
alloc_string(yytext, yyleng);
|
alloc_string(yytext, yyleng);
|
||||||
yylval.string = text;
|
yylval.string = text;
|
||||||
return T_WORD;
|
return T_VARIABLE;
|
||||||
}
|
}
|
||||||
|
({n}|$)+ {
|
||||||
|
/* this token includes at least one '$' */
|
||||||
|
yylval.string = expand_token(yytext, yyleng);
|
||||||
|
if (strlen(yylval.string))
|
||||||
|
return T_VARIABLE;
|
||||||
|
free(yylval.string);
|
||||||
|
}
|
||||||
|
"=" { BEGIN(ASSIGN_VAL); yylval.flavor = VAR_RECURSIVE; return T_ASSIGN; }
|
||||||
|
":=" { BEGIN(ASSIGN_VAL); yylval.flavor = VAR_SIMPLE; return T_ASSIGN; }
|
||||||
|
"+=" { BEGIN(ASSIGN_VAL); yylval.flavor = VAR_APPEND; return T_ASSIGN; }
|
||||||
|
[[:blank:]]+
|
||||||
. warn_ignored_character(*yytext);
|
. warn_ignored_character(*yytext);
|
||||||
\n {
|
\n {
|
||||||
BEGIN(INITIAL);
|
BEGIN(INITIAL);
|
||||||
@ -119,6 +132,16 @@ n [A-Za-z0-9_-]
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
<ASSIGN_VAL>{
|
||||||
|
[^[:blank:]\n]+.* {
|
||||||
|
alloc_string(yytext, yyleng);
|
||||||
|
yylval.string = text;
|
||||||
|
return T_ASSIGN_VAL;
|
||||||
|
}
|
||||||
|
\n { BEGIN(INITIAL); return T_EOL; }
|
||||||
|
.
|
||||||
|
}
|
||||||
|
|
||||||
<PARAM>{
|
<PARAM>{
|
||||||
"&&" return T_AND;
|
"&&" return T_AND;
|
||||||
"||" return T_OR;
|
"||" return T_OR;
|
||||||
@ -147,6 +170,13 @@ n [A-Za-z0-9_-]
|
|||||||
yylval.string = text;
|
yylval.string = text;
|
||||||
return T_WORD;
|
return T_WORD;
|
||||||
}
|
}
|
||||||
|
({n}|[/.$])+ {
|
||||||
|
/* this token includes at least one '$' */
|
||||||
|
yylval.string = expand_token(yytext, yyleng);
|
||||||
|
if (strlen(yylval.string))
|
||||||
|
return T_WORD;
|
||||||
|
free(yylval.string);
|
||||||
|
}
|
||||||
#.* /* comment */
|
#.* /* comment */
|
||||||
\\\n ;
|
\\\n ;
|
||||||
[[:blank:]]+
|
[[:blank:]]+
|
||||||
@ -157,12 +187,13 @@ n [A-Za-z0-9_-]
|
|||||||
}
|
}
|
||||||
|
|
||||||
<STRING>{
|
<STRING>{
|
||||||
[^'"\\\n]+/\n {
|
"$".* append_expanded_string(yytext);
|
||||||
|
[^$'"\\\n]+/\n {
|
||||||
append_string(yytext, yyleng);
|
append_string(yytext, yyleng);
|
||||||
yylval.string = text;
|
yylval.string = text;
|
||||||
return T_WORD_QUOTE;
|
return T_WORD_QUOTE;
|
||||||
}
|
}
|
||||||
[^'"\\\n]+ {
|
[^$'"\\\n]+ {
|
||||||
append_string(yytext, yyleng);
|
append_string(yytext, yyleng);
|
||||||
}
|
}
|
||||||
\\.?/\n {
|
\\.?/\n {
|
||||||
@ -249,6 +280,58 @@ n [A-Za-z0-9_-]
|
|||||||
}
|
}
|
||||||
|
|
||||||
%%
|
%%
|
||||||
|
static char *expand_token(const char *in, size_t n)
|
||||||
|
{
|
||||||
|
char *out;
|
||||||
|
int c;
|
||||||
|
char c2;
|
||||||
|
const char *rest, *end;
|
||||||
|
|
||||||
|
new_string();
|
||||||
|
append_string(in, n);
|
||||||
|
|
||||||
|
/* get the whole line because we do not know the end of token. */
|
||||||
|
while ((c = input()) != EOF) {
|
||||||
|
if (c == '\n') {
|
||||||
|
unput(c);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
c2 = c;
|
||||||
|
append_string(&c2, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
rest = text;
|
||||||
|
out = expand_one_token(&rest);
|
||||||
|
|
||||||
|
/* push back unused characters to the input stream */
|
||||||
|
end = rest + strlen(rest);
|
||||||
|
while (end > rest)
|
||||||
|
unput(*--end);
|
||||||
|
|
||||||
|
free(text);
|
||||||
|
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void append_expanded_string(const char *str)
|
||||||
|
{
|
||||||
|
const char *end;
|
||||||
|
char *res;
|
||||||
|
|
||||||
|
str++;
|
||||||
|
|
||||||
|
res = expand_dollar(&str);
|
||||||
|
|
||||||
|
/* push back unused characters to the input stream */
|
||||||
|
end = str + strlen(str);
|
||||||
|
while (end > str)
|
||||||
|
unput(*--end);
|
||||||
|
|
||||||
|
append_string(res, strlen(res));
|
||||||
|
|
||||||
|
free(res);
|
||||||
|
}
|
||||||
|
|
||||||
void zconf_starthelp(void)
|
void zconf_starthelp(void)
|
||||||
{
|
{
|
||||||
new_string();
|
new_string();
|
||||||
|
@ -41,6 +41,7 @@ static struct menu *current_menu, *current_entry;
|
|||||||
struct expr *expr;
|
struct expr *expr;
|
||||||
struct menu *menu;
|
struct menu *menu;
|
||||||
const struct kconf_id *id;
|
const struct kconf_id *id;
|
||||||
|
enum variable_flavor flavor;
|
||||||
}
|
}
|
||||||
|
|
||||||
%token <id>T_MAINMENU
|
%token <id>T_MAINMENU
|
||||||
@ -77,6 +78,9 @@ static struct menu *current_menu, *current_entry;
|
|||||||
%token T_CLOSE_PAREN
|
%token T_CLOSE_PAREN
|
||||||
%token T_OPEN_PAREN
|
%token T_OPEN_PAREN
|
||||||
%token T_EOL
|
%token T_EOL
|
||||||
|
%token <string> T_VARIABLE
|
||||||
|
%token <flavor> T_ASSIGN
|
||||||
|
%token <string> T_ASSIGN_VAL
|
||||||
|
|
||||||
%left T_OR
|
%left T_OR
|
||||||
%left T_AND
|
%left T_AND
|
||||||
@ -92,7 +96,7 @@ static struct menu *current_menu, *current_entry;
|
|||||||
%type <id> end
|
%type <id> end
|
||||||
%type <id> option_name
|
%type <id> option_name
|
||||||
%type <menu> if_entry menu_entry choice_entry
|
%type <menu> if_entry menu_entry choice_entry
|
||||||
%type <string> symbol_option_arg word_opt
|
%type <string> symbol_option_arg word_opt assign_val
|
||||||
|
|
||||||
%destructor {
|
%destructor {
|
||||||
fprintf(stderr, "%s:%d: missing end statement for this entry\n",
|
fprintf(stderr, "%s:%d: missing end statement for this entry\n",
|
||||||
@ -109,7 +113,7 @@ static struct menu *current_menu, *current_entry;
|
|||||||
%%
|
%%
|
||||||
input: nl start | start;
|
input: nl start | start;
|
||||||
|
|
||||||
start: mainmenu_stmt stmt_list | no_mainmenu_stmt stmt_list;
|
start: mainmenu_stmt stmt_list | stmt_list;
|
||||||
|
|
||||||
/* mainmenu entry */
|
/* mainmenu entry */
|
||||||
|
|
||||||
@ -118,19 +122,6 @@ mainmenu_stmt: T_MAINMENU prompt nl
|
|||||||
menu_add_prompt(P_MENU, $2, NULL);
|
menu_add_prompt(P_MENU, $2, NULL);
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Default main menu, if there's no mainmenu entry */
|
|
||||||
|
|
||||||
no_mainmenu_stmt: /* empty */
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
* Hack: Keep the main menu title on the heap so we can safely free it
|
|
||||||
* later regardless of whether it comes from the 'prompt' in
|
|
||||||
* mainmenu_stmt or here
|
|
||||||
*/
|
|
||||||
menu_add_prompt(P_MENU, xstrdup("Linux Kernel Configuration"), NULL);
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
stmt_list:
|
stmt_list:
|
||||||
/* empty */
|
/* empty */
|
||||||
| stmt_list common_stmt
|
| stmt_list common_stmt
|
||||||
@ -156,6 +147,7 @@ common_stmt:
|
|||||||
| config_stmt
|
| config_stmt
|
||||||
| menuconfig_stmt
|
| menuconfig_stmt
|
||||||
| source_stmt
|
| source_stmt
|
||||||
|
| assignment_stmt
|
||||||
;
|
;
|
||||||
|
|
||||||
option_error:
|
option_error:
|
||||||
@ -524,31 +516,42 @@ symbol: nonconst_symbol
|
|||||||
word_opt: /* empty */ { $$ = NULL; }
|
word_opt: /* empty */ { $$ = NULL; }
|
||||||
| T_WORD
|
| T_WORD
|
||||||
|
|
||||||
|
/* assignment statement */
|
||||||
|
|
||||||
|
assignment_stmt: T_VARIABLE T_ASSIGN assign_val T_EOL { variable_add($1, $3, $2); free($1); free($3); }
|
||||||
|
|
||||||
|
assign_val:
|
||||||
|
/* empty */ { $$ = xstrdup(""); };
|
||||||
|
| T_ASSIGN_VAL
|
||||||
|
;
|
||||||
|
|
||||||
%%
|
%%
|
||||||
|
|
||||||
void conf_parse(const char *name)
|
void conf_parse(const char *name)
|
||||||
{
|
{
|
||||||
const char *tmp;
|
|
||||||
struct symbol *sym;
|
struct symbol *sym;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
zconf_initscan(name);
|
zconf_initscan(name);
|
||||||
|
|
||||||
sym_init();
|
|
||||||
_menu_init();
|
_menu_init();
|
||||||
|
|
||||||
if (getenv("ZCONF_DEBUG"))
|
if (getenv("ZCONF_DEBUG"))
|
||||||
yydebug = 1;
|
yydebug = 1;
|
||||||
yyparse();
|
yyparse();
|
||||||
|
|
||||||
|
/* Variables are expanded in the parse phase. We can free them here. */
|
||||||
|
variable_all_del();
|
||||||
|
|
||||||
if (yynerrs)
|
if (yynerrs)
|
||||||
exit(1);
|
exit(1);
|
||||||
if (!modules_sym)
|
if (!modules_sym)
|
||||||
modules_sym = sym_find( "n" );
|
modules_sym = sym_find( "n" );
|
||||||
|
|
||||||
tmp = rootmenu.prompt->text;
|
if (!menu_has_prompt(&rootmenu)) {
|
||||||
rootmenu.prompt->text = _(rootmenu.prompt->text);
|
current_entry = &rootmenu;
|
||||||
rootmenu.prompt->text = sym_expand_string_value(rootmenu.prompt->text);
|
menu_add_prompt(P_MENU, "Main menu", NULL);
|
||||||
free((char*)tmp);
|
}
|
||||||
|
|
||||||
menu_finalize(&rootmenu);
|
menu_finalize(&rootmenu);
|
||||||
for_all_symbols(i, sym) {
|
for_all_symbols(i, sym) {
|
||||||
@ -780,3 +783,4 @@ void zconfdump(FILE *out)
|
|||||||
#include "expr.c"
|
#include "expr.c"
|
||||||
#include "symbol.c"
|
#include "symbol.c"
|
||||||
#include "menu.c"
|
#include "menu.c"
|
||||||
|
#include "preprocess.c"
|
||||||
|
Loading…
Reference in New Issue
Block a user