# HG changeset patch # User Rob Landley # Date 1328332588 21600 # Node ID 8b0487639db93ea33f182efee4396e24b11c7f7b # Parent 312b8acb65aa42e95e232f74ad78a49c52df75e7 Add autodetect for container support. diff -r 312b8acb65aa -r 8b0487639db9 Makefile --- a/Makefile Fri Feb 03 22:39:55 2012 -0600 +++ b/Makefile Fri Feb 03 23:16:28 2012 -0600 @@ -12,7 +12,7 @@ include kconfig/Makefile $(KCONFIG_TOP): generated/Config.in -generated/Config.in: toys/*.c +generated/Config.in: toys/*.c scripts/genconfig.sh scripts/genconfig.sh HOSTCC:=cc diff -r 312b8acb65aa -r 8b0487639db9 scripts/genconfig.sh --- a/scripts/genconfig.sh Fri Feb 03 22:39:55 2012 -0600 +++ b/scripts/genconfig.sh Fri Feb 03 23:16:28 2012 -0600 @@ -4,16 +4,29 @@ # before menuconfig. (It's called again from scripts/make.sh just to be sure.) mkdir -p generated +OUTFILE=generated/Config.in -function genconfig() +genconfig() { - for i in $(echo toys/*.c | sort) + # Probe for container support on target + + echo -e "# container support\nconfig TOYBOX_CONTAINER\n\tbool" || return 1 + $CC -c -xc -o /dev/null - 2>/dev/null << EOF + #include + int x=CLONE_NEWNS|CLONE_NEWUTS|CLONE_NEWIPC|CLONE_NEWNET; +EOF + [ $? -eq 0 ] && DEFAULT=y || DEFAULT=n + echo -e "\tdefault $DEFAULT\n" || return 1 + + # extract config stanzas from each command source file, in alphabetical order + + for i in $(ls -1 toys/*.c) do # Grab the config block for Config.in echo "# $i" - sed -n '/^\*\//q;/^config [A-Z]/,$p' $i || exit 1 + sed -n '/^\*\//q;/^config [A-Z]/,$p' $i || return 1 echo done } -genconfig > generated/Config.in +genconfig > generated/Config.in || rm "$OUTFILE" diff -r 312b8acb65aa -r 8b0487639db9 toys/unshare.c --- a/toys/unshare.c Fri Feb 03 22:39:55 2012 -0600 +++ b/toys/unshare.c Fri Feb 03 23:16:28 2012 -0600 @@ -11,6 +11,7 @@ config UNSHARE bool "unshare" default y + depends on TOYBOX_CONTAINER help usage: unshare [-muin] COMMAND...