]> git.eshelyaron.com Git - emacs.git/commit
(function-history): New symbol property (bug#53632)
authorStefan Monnier <monnier@iro.umontreal.ca>
Mon, 31 Jan 2022 16:07:06 +0000 (11:07 -0500)
committerStefan Monnier <monnier@iro.umontreal.ca>
Mon, 31 Jan 2022 16:07:26 +0000 (11:07 -0500)
commit1d1b664fbb9232aa40d8daa54a689cfd63d38aa9
tree164ad10242c8566c3c8fa1d0c12c50804f82d791
parent90bbf27f02b1e7bf9cc0f0206313795c210c565b
(function-history): New symbol property (bug#53632)

Rework the code we have in Fdefalias that tries to keep track
of definitions so as to be able to undo them later.

We used to store in `load-history` when an autoload is redefined as
a non-autoload and in the `autoload` symbol property we used to store
the autoload data that used to be used before it got overriden.

Instead, store the history of the function definition of
a symbol in its `function-history` symbol property.
To make this list cheap in the default case, the latest value is not stored
in the list (since it's in the `symbol-function`) and neither is the first
file.  So if there's only been a single definition (the most common case),
the list is empty and the property is just not present at all.

The patch also gets rid of the `autoload` vs `defun` distinction in
`load-history` which seems unnecessary (a significant part of the
motivation for this patch was to get rid of the special handling of
autoloads in this part of the code).

* src/data.c (add_to_function_history): New function.
(defalias): Use it.  Don't add the `t` entries for autoloads and always
use `defun` regardless of the kind of definition.
Change `Vautoload_queue` to only hold the function
symbols since the rest is now available from `function-history`.
* src/eval.c (un_autoload): Adjust accordingly.

* src/lread.c (load-history): Udate docstring.

* lisp/loadhist.el (loadhist-unload-filename): New var.
(unload-feature): Bind it.
(loadhist-unload-element): Document its availability.
(loadhist--restore-autoload): Delete var.
(loadhist--unload-function): Delete function.
(loadhist-unload-element): Delete the `t` and `autoload` methods.
Rewrite the `defun` method using `function-history`.

* lisp/help-fns.el: Require `seq`.
(help-fns--autoloaded-p): Rewrite.
(help-fns-function-description-header): Adjust call accordingly.

* doc/lispref/loading.texi (Where Defined): Remove `autoload` and `t`
entries from `load-history` since we don't generate them any more.
Document the `function-history` which replaces the `autoload` property.
(Unloading): Adjust symbol property name accordingly.

* test/lisp/loadhist-resources/loadhist--bar.el:
* test/lisp/loadhist-resources/loadhist--foo.el: New files.
* test/lisp/loadhist-tests.el (loadhist-tests-unload-feature-nested)
(loadhist-tests-unload-feature-notnested): New tests.
doc/lispref/loading.texi
etc/NEWS
lisp/help-fns.el
lisp/loadhist.el
src/data.c
src/eval.c
src/lread.c
test/lisp/loadhist-resources/loadhist--bar.el [new file with mode: 0644]
test/lisp/loadhist-resources/loadhist--foo.el [new file with mode: 0644]
test/lisp/loadhist-tests.el