Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/karimaziev/elisp-scan
Find unused code in Emacs Lisp files.
https://github.com/karimaziev/elisp-scan
emacs-lisp emacs-package emacs-packages
Last synced: 10 days ago
JSON representation
Find unused code in Emacs Lisp files.
- Host: GitHub
- URL: https://github.com/karimaziev/elisp-scan
- Owner: KarimAziev
- License: gpl-3.0
- Created: 2022-04-14T18:00:21.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2024-11-09T13:02:57.000Z (2 months ago)
- Last Synced: 2024-12-24T10:37:21.123Z (25 days ago)
- Topics: emacs-lisp, emacs-package, emacs-packages
- Language: Emacs Lisp
- Homepage:
- Size: 1.93 MB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.org
- License: LICENSE
Awesome Lists containing this project
README
* elisp-scan
Find unused code and print reports for Emacs Lisp files.
~elisp-scan~ use mixed text search - initial "dumb" searching with ~ag~, then parses the code with elisp.
[[./demo.gif][./demo.gif]]
** Requirements
- Emacs 28.1
- ~ag~ or ~find~** Installation
*** with straight-use-package
Put the following in your init file:
#+begin_src elisp
(use-package elisp-scan
:straight (elisp-scan
:type git
:host github
:repo "KarimAziev/elisp-scan"))
#+end_src*** Manual
Or download the repository and add it to your ~load-path~.
#+begin_src elisp
(add-to-list 'load-path "/path/to/elisp-scan/")
(require 'elisp-scan)
#+end_src
** UsageThe most straightforward usage is to invoke transient popup ~M-x elisp-scan-menu~ and ~M-x elisp-scan-list-menu~ (in report buffers).
- ~elisp-scan-file~ Scan the Elisp file and show the report.
- ~elisp-scan-dir~ Scan elisp files in the directory and show the report.
- ~elisp-scan-project~ Scan project files and show the report.
- ~elisp-scan-all-unused-defs~ Same as ~elisp-scan-project~ but with predefined filters to show only unused items.This command will activate =elisp-scan-report-mode= with such bindings:
| Key | Command |
|-----------+-----------------------------------------|
| =RET= | View entry |
| =D= | Remove marked entries or entry at point |
| =K= | Cancel rendering |
| =m= | Mark entry |
| =u= | Unmark entry |
| =C-c C-n= | Move to the next entry start |
| =C-c C-p= | Move to the previous entry start |
| =C-.= | Show transient menu |
| =.= | Show transient menu |
| =?= | Show transient menu |** Other commands
- ~elisp-scan-rename-symbol~
Rename exact matches of the symbol at the point.
- ~elisp-scan-ivy-read-unused-items~
Read unused definitions of the current file with ivy. To remove one item without exiting the minibuffer, use =C-c C-d=. To remove or back up a batch of items, mark them. With the optional prefix =arg= include only the current file.** Customizations
- ~elisp-scan-initial-filters~ Initial filters in report list mode.
- ~elisp-scan-permanent-dirs~ In which directories always check usage.
- ~elisp-scan-types-symbols~ List of symbols to check.