ld-wrapper: Unless in a build env., allow files that symlink to the store.

* gnu/packages/ld-wrapper.scm (pure-file-name?): As a last resort, when
  %BUILD-DIRECTORY is false, check whether FILE is a symlink, and loop
  over it to check whether its target is in the store.
This commit is contained in:
Ludovic Courtès 2013-06-12 09:39:31 +02:00
parent d4c7486079
commit cfbf7877a6

View file

@ -11,7 +11,7 @@
exec @GUILE@ -c "(load-compiled \"$0.go\") (apply $main (cdr (command-line)))" "$@" exec @GUILE@ -c "(load-compiled \"$0.go\") (apply $main (cdr (command-line)))" "$@"
!# !#
;;; GNU Guix --- Functional package management for GNU ;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2012 Ludovic Courtès <ludo@gnu.org> ;;; Copyright © 2012, 2013 Ludovic Courtès <ludo@gnu.org>
;;; ;;;
;;; This file is part of GNU Guix. ;;; This file is part of GNU Guix.
;;; ;;;
@ -82,13 +82,26 @@ (define %debug?
(getenv "GUIX_LD_WRAPPER_DEBUG")) (getenv "GUIX_LD_WRAPPER_DEBUG"))
(define (pure-file-name? file) (define (pure-file-name? file)
;; Return #t when FILE is the name of a file either within the store or ;; Return #t when FILE is the name of a file either within the store
;; within the build directory. ;; (possibly via a symlink) or within the build directory.
(or (not (string-prefix? "/" file)) (define %max-symlink-depth 50)
(string-prefix? %store-directory file)
(string-prefix? %temporary-directory file) (let loop ((file file)
(and %build-directory (depth 0))
(string-prefix? %build-directory file)))) (or (not (string-prefix? "/" file))
(string-prefix? %store-directory file)
(string-prefix? %temporary-directory file)
(if %build-directory
(string-prefix? %build-directory file)
;; When used from a user environment, FILE may refer to
;; ~/.guix-profile/lib/libfoo.so, which is itself a symlink to the
;; store. Check whether this is the case.
(let ((s (false-if-exception (lstat file))))
(and s
(eq? 'symlink (stat:type s))
(< depth %max-symlink-depth)
(loop (readlink file) (+ 1 depth))))))))
(define (switch-arguments switch args) (define (switch-arguments switch args)
;; Return the arguments passed for the occurrences of SWITCH--e.g., ;; Return the arguments passed for the occurrences of SWITCH--e.g.,