mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-06-19 18:20:22 +02:00
eval: Store docstrings for lambdas.
Fixes <http://bugs.gnu.org/12173>. Reported by Ian Price <ianprice90@googlemail.com>. * libguile/memoize.c (MAKMEMO_LAMBDA): New `docstring' parameter. Add it as the second argument of `SCM_M_LAMBDA'. Update caller. (memoize)[SCM_M_LAMBDA]: Extract docstring from EXP; when `memoize' returns, add the docstring to the lambda's arguments. (unmemoize)[SCM_M_LAMBDA]: Adjust to new argument layout of `SCM_M_LAMBDA'. * libguile/eval.c (BOOT_CLOSURE_NUM_REQUIRED_ARGS, BOOT_CLOSURE_HAS_REST_ARGS, BOOT_CLOSURE_IS_REST, BOOT_CLOSURE_PARSE_FULL): Adjust to new argument layout of `SCM_M_LAMBDA'. * module/ice-9/eval.scm (primitive-eval)[make-general-closure]: Likewise. [eval]: When EXP is a lambda, match its docstring; when the docstring is not #f, add it to the closures procedure properties. * test-suite/tests/eval.test ("docstrings"): New test prefix. * libguile/procs.c (sym_documentation): Rename to... (scm_sym_documentation): ... this. Make it global. * libguile/procs.h (scm_sym_documentation): New declaration.
This commit is contained in:
parent
fc32c44995
commit
c438cd7175
6 changed files with 130 additions and 68 deletions
|
@ -427,6 +427,36 @@
|
|||
(thunk (let loop () (cons 's (loop)))))
|
||||
(call-with-vm vm thunk))))
|
||||
|
||||
;;;
|
||||
;;; docstrings
|
||||
;;;
|
||||
|
||||
(with-test-prefix "docstrings"
|
||||
|
||||
(pass-if-equal "fixed closure"
|
||||
'("hello" "world")
|
||||
(map procedure-documentation
|
||||
(list (eval '(lambda (a b) "hello" (+ a b))
|
||||
(current-module))
|
||||
(eval '(lambda (a b) "world" (- a b))
|
||||
(current-module)))))
|
||||
|
||||
(pass-if-equal "fixed closure with many args"
|
||||
"So many args."
|
||||
(procedure-documentation
|
||||
(eval '(lambda (a b c d e f g h i j k)
|
||||
"So many args."
|
||||
(+ a b))
|
||||
(current-module))))
|
||||
|
||||
(pass-if-equal "general closure"
|
||||
"How general."
|
||||
(procedure-documentation
|
||||
(eval '(lambda* (a b #:key k #:rest r)
|
||||
"How general."
|
||||
(+ a b))
|
||||
(current-module)))))
|
||||
|
||||
;;;
|
||||
;;; local-eval
|
||||
;;;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue