Loading pkgs/build-support/cc-wrapper/cc-wrapper.sh +18 −0 Original line number Diff line number Diff line Loading @@ -33,6 +33,7 @@ cInclude=1 expandResponseParams "$@" linkType=$(checkLinkType "${params[@]}") declare -ag positionalArgs=() declare -i n=0 nParams=${#params[@]} while (( "$n" < "$nParams" )); do Loading @@ -54,6 +55,17 @@ while (( "$n" < "$nParams" )); do c++*) isCxx=1 ;; esac ;; --) # Everything else is positional args! # See: https://github.com/llvm/llvm-project/commit/ed1d07282cc9d8e4c25d585e03e5c8a1b6f63a74 # Any positional arg (i.e. any argument after `--`) will be # interpreted as a "non flag" arg: if [[ -v "params[$n]" ]]; then nonFlagArgs=1; fi positionalArgs=("${params[@]:$n}") params=("${params[@]:0:$((n - 1))}") break; ;; -?*) ;; *) nonFlagArgs=1 ;; # Includes a solitary dash (`-`) which signifies standard input; it is not a flag esac Loading Loading @@ -207,6 +219,12 @@ if [ "$cc1" = 1 ]; then extraBefore=() fi # Finally, if we got any positional args, append them to `extraAfter` # now: if [[ "${#positionalArgs[@]}" -gt 0 ]]; then extraAfter+=(-- "${positionalArgs[@]}") fi # Optionally print debug info. if (( "${NIX_DEBUG:-0}" >= 1 )); then # Old bash workaround, see ld-wrapper for explanation. Loading pkgs/test/cc-wrapper/default.nix +23 −0 Original line number Diff line number Diff line Loading @@ -13,6 +13,8 @@ in stdenv.mkDerivation { name = "cc-wrapper-test"; buildCommand = '' set -o pipefail NIX_DEBUG=1 $CC -v NIX_DEBUG=1 $CXX -v Loading Loading @@ -43,6 +45,27 @@ in stdenv.mkDerivation { ''} ''} ${# See: https://github.com/llvm/llvm-project/commit/ed1d07282cc9d8e4c25d585e03e5c8a1b6f63a74 # `gcc` does not support this so we gate the test on `clang` lib.optionalString stdenv.cc.isClang '' printf "checking whether cc-wrapper accepts -- followed by positional (file) args..." >&2 mkdir -p positional # Make sure `--` is not parsed as a "non flag arg"; we should get an # input file error here and *not* a linker error. { ! $CC --; } |& grep -q "no input files" # And that positional file args _must_ be files (this is just testing # that we remembered to put the `--` back in the args to the compiler): { ! $CC -c -- -o foo ${./foo.c}; } \ |& grep -q "no such file or directory: '-o'" # Now check that we accept single and multiple positional file args: $CC -c -DVALUE=42 -o positional/foo.o -- ${./foo.c} $CC -o positional/main -- positional/foo.o ${./ldflags-main.c} ${emulator} ./positional/main ''} printf "checking whether compiler uses NIX_CFLAGS_COMPILE... " >&2 mkdir -p foo/include cp ${./foo.c} foo/include/foo.h Loading Loading
pkgs/build-support/cc-wrapper/cc-wrapper.sh +18 −0 Original line number Diff line number Diff line Loading @@ -33,6 +33,7 @@ cInclude=1 expandResponseParams "$@" linkType=$(checkLinkType "${params[@]}") declare -ag positionalArgs=() declare -i n=0 nParams=${#params[@]} while (( "$n" < "$nParams" )); do Loading @@ -54,6 +55,17 @@ while (( "$n" < "$nParams" )); do c++*) isCxx=1 ;; esac ;; --) # Everything else is positional args! # See: https://github.com/llvm/llvm-project/commit/ed1d07282cc9d8e4c25d585e03e5c8a1b6f63a74 # Any positional arg (i.e. any argument after `--`) will be # interpreted as a "non flag" arg: if [[ -v "params[$n]" ]]; then nonFlagArgs=1; fi positionalArgs=("${params[@]:$n}") params=("${params[@]:0:$((n - 1))}") break; ;; -?*) ;; *) nonFlagArgs=1 ;; # Includes a solitary dash (`-`) which signifies standard input; it is not a flag esac Loading Loading @@ -207,6 +219,12 @@ if [ "$cc1" = 1 ]; then extraBefore=() fi # Finally, if we got any positional args, append them to `extraAfter` # now: if [[ "${#positionalArgs[@]}" -gt 0 ]]; then extraAfter+=(-- "${positionalArgs[@]}") fi # Optionally print debug info. if (( "${NIX_DEBUG:-0}" >= 1 )); then # Old bash workaround, see ld-wrapper for explanation. Loading
pkgs/test/cc-wrapper/default.nix +23 −0 Original line number Diff line number Diff line Loading @@ -13,6 +13,8 @@ in stdenv.mkDerivation { name = "cc-wrapper-test"; buildCommand = '' set -o pipefail NIX_DEBUG=1 $CC -v NIX_DEBUG=1 $CXX -v Loading Loading @@ -43,6 +45,27 @@ in stdenv.mkDerivation { ''} ''} ${# See: https://github.com/llvm/llvm-project/commit/ed1d07282cc9d8e4c25d585e03e5c8a1b6f63a74 # `gcc` does not support this so we gate the test on `clang` lib.optionalString stdenv.cc.isClang '' printf "checking whether cc-wrapper accepts -- followed by positional (file) args..." >&2 mkdir -p positional # Make sure `--` is not parsed as a "non flag arg"; we should get an # input file error here and *not* a linker error. { ! $CC --; } |& grep -q "no input files" # And that positional file args _must_ be files (this is just testing # that we remembered to put the `--` back in the args to the compiler): { ! $CC -c -- -o foo ${./foo.c}; } \ |& grep -q "no such file or directory: '-o'" # Now check that we accept single and multiple positional file args: $CC -c -DVALUE=42 -o positional/foo.o -- ${./foo.c} $CC -o positional/main -- positional/foo.o ${./ldflags-main.c} ${emulator} ./positional/main ''} printf "checking whether compiler uses NIX_CFLAGS_COMPILE... " >&2 mkdir -p foo/include cp ${./foo.c} foo/include/foo.h Loading