utils: Define ‘search-input-file’ procedure.
authorMaxime Devos <maximedevos@telenet.be>
Mon, 31 May 2021 16:36:09 +0000 (18:36 +0200)
committerLudovic Courtès <ludo@gnu.org>
Fri, 4 Jun 2021 20:34:26 +0000 (22:34 +0200)
commit5378edeab4e90f9dec6ae9bc5706a4ac790294b7
treebaed37d75161af23a14feb08c54403c7e8fc77cb
parent8b0899963faa3b04ed09192ac58db0a711c6a654
utils: Define ‘search-input-file’ procedure.

The procedure ‘which’ from (guix build utils)
is used for two different purposes:

  1. for finding the absolute file name of a binary
     that needs to run during the build process

  2. for finding the absolute file name of a binary,
     for the target system (as in --target=TARGET),
     e.g. for substituting sh->/gnu/store/.../bin/sh,
     python->/gnu/store/.../bin/python.

When compiling natively (target=#f in Guix parlance),
this is perfectly fine.

However, when cross-compiling, there is a problem.
"which" looks in $PATH for binaries.  That's good for purpose (1),
but incorrect for (2), as the $PATH contains binaries from native-inputs
instead of inputs.

This commit defines a ‘search-input-file’ procedure. It functions
like 'which', but instead of searching in $PATH, it searches in
the 'inputs' of the build phase, which must be passed to
‘search-input-file’ as an argument. Also, the file name must
include "bin/" or "sbin/" as appropriate.

* guix/build/utils.scm (search-input-file): New procedure.
* tests/build-utils.scm
  ("search-input-file: exception if not found")
  ("search-input-file: can find if existent"): Test it.
* doc/guix.texi (File Search): Document it.

Partially-Fixes: <https://issues.guix.gnu.org/47869>
Co-Authored-By: Ludovic Courtès <ludo@gnu.org>
Signed-off-by: Ludovic Courtès <ludo@gnu.org>
doc/guix.texi
guix/build/utils.scm
tests/build-utils.scm