mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-11 13:49:23 -05:00
ui: Only suggest modules that export the unbound variable identifier.
Fixes <https://bugs.gnu.org/43498>. Reported by Tobias Geerinckx-Rice <me@tobias.gr>. * guix/ui.scm (known-variable-definition): Check for variables in the public interface of HEAD, not in HEAD itself. * tests/guix-build.sh: Add test.
This commit is contained in:
parent
48720afb32
commit
5ef1508942
2 changed files with 29 additions and 1 deletions
|
@ -297,7 +297,8 @@ (define (module<? m1 m2)
|
||||||
(hash-map->list (lambda (name module)
|
(hash-map->list (lambda (name module)
|
||||||
module)
|
module)
|
||||||
(module-submodules head)))))
|
(module-submodules head)))))
|
||||||
(match (module-local-variable head variable)
|
(match (and=> (module-public-interface head)
|
||||||
|
(cut module-local-variable <> variable))
|
||||||
(#f (loop next suggestions visited))
|
(#f (loop next suggestions visited))
|
||||||
(_
|
(_
|
||||||
(match (module-name head)
|
(match (module-name head)
|
||||||
|
|
|
@ -198,6 +198,33 @@ grep "forget.*(guix build-system gnu)" "$module_dir/err" # hint
|
||||||
|
|
||||||
rm -f "$module_dir"/*
|
rm -f "$module_dir"/*
|
||||||
|
|
||||||
|
# Unbound variable: don't suggest modules that do not export the variable.
|
||||||
|
cat > "$module_dir/aa-private.scm" <<EOF
|
||||||
|
(define-module (aa-private))
|
||||||
|
(define make-thing #f)
|
||||||
|
(set! make-thing make-thing) ;don't inline
|
||||||
|
EOF
|
||||||
|
|
||||||
|
cat > "$module_dir/bb-public.scm" <<EOF
|
||||||
|
(define-module (bb-public) #:export (make-thing))
|
||||||
|
(define make-thing identity)
|
||||||
|
EOF
|
||||||
|
|
||||||
|
cat > "$module_dir/cc-user.scm" <<EOF
|
||||||
|
;; Make those module available in the global name space.
|
||||||
|
(load-from-path "aa-private.scm")
|
||||||
|
(load-from-path "bb-public.scm")
|
||||||
|
|
||||||
|
(define-module (cc-user))
|
||||||
|
(make-thing 42)
|
||||||
|
EOF
|
||||||
|
! guix build -f "$module_dir/cc-user.scm" -n 2> "$module_dir/err"
|
||||||
|
cat "$module_dir/err"
|
||||||
|
grep "make-thing.*unbound" "$module_dir/err" # actual error
|
||||||
|
grep "forget.*(bb-public)" "$module_dir/err" # hint
|
||||||
|
|
||||||
|
rm -f "$module_dir"/*
|
||||||
|
|
||||||
# Wrong 'define-module' clause reported by 'warn-about-load-error'.
|
# Wrong 'define-module' clause reported by 'warn-about-load-error'.
|
||||||
cat > "$module_dir/foo.scm" <<EOF
|
cat > "$module_dir/foo.scm" <<EOF
|
||||||
(define-module (something foo)
|
(define-module (something foo)
|
||||||
|
|
Loading…
Reference in a new issue