Compiling Emacs Lisp code from the command-line
Project description
elispcomp - Compile Emacs Lisp code from the command-line
The elispcomp
command line tool allows compiling Emacs Lisp (Elisp) code directly from the terminal or from a shell script. It facilitates the generation of optimized .elc
(byte-compiled) and .eln
(native-compiled) files, which can significantly improve the performance of Emacs.
The command line tool executes a headless instance of Emacs and Elisp that recursively scans the specified directories, byte compiling and native compiling all the .el
files that haven't been compiled yet. It supports various configuration options, allowing you to adapt the compilation process to suit your needs.
When configured appropriately, Emacs can compile to both .elc
and .eln
files. However, for those who wish to automate the background compilation of .el
files using a script, the elispcomp
command-line tool can be beneficial in ensuring that their Emacs setup remains up-to-date without manual intervention and without starting an Emacs instance.
Installation
To get started with elispcomp
, you can install it using pip
:
pip install --user elispcomp
This command installs elispcomp
and places the executable in your ~/.local/bin/
directory, making it easily accessible from your command line.
Requirements
- Python 3
- Emacs >= 28
Usage
The elispcomp
command line tool is straightforward to use.
First example: To compile all .el
files located in the ~/.emacs.d/lisp
directory:
elispcomp ~/.emacs.d/lisp
Second example: To compile all .el
files located in the ~/.emacs.d/lisp
directory, and store the native-compiled files in the ~/.emacs.d/eln-cache
directory:
elispcomp --eln-cache ~/.emacs.d/eln-cache ~/.emacs.d/lisp
Command line options
usage: elispcomp [--option] [N]
Recursively byte and native compile .el files.
positional arguments:
N The directories to be scanned recursively by Emacs to locate the '.el'
files for compilation.
options:
-h, --help show this help message and exit
-c ELN_CACHE, --eln-cache ELN_CACHE
The eln-cache directory where Emacs stores the compiled native compiled
code. Defaults to the default Emacs eln-cache directory.
-e EMACS_BIN, --emacs-bin EMACS_BIN
Path to the Emacs binary. Defaults: emacs
-j JOBS, --jobs JOBS Specify the number of parallel jobs for compilation. Default: Half the
number of available CPUs
-b, --disable-byte-compile, --disable-byte-comp
Disable byte compile. Default: enabled
-n, --disable-native-compile, --disable-native-comp
Disable native compilation. Default: enabled
-i LOAD_PATH, --load-path LOAD_PATH
Recursively adds the subdirectories of the specified directory to the
Emacs `load-path`. This option can be used multiple times to include
several directories.
-a, --ensure-native-compile-available, --ensure-native-comp-available
Fail when native compilation is not available.
Frequently asked questions
Can't I achieve the same result using Emacs?
Indeed, when configured appropriately, Emacs can compile to both .elc
and .eln
files.
The elispcomp
command-line tool is an Emacs wrapper that makes it easy to compile Emacs Lisp (Elisp) code directly from the terminal or from a script. It provides options and ensures that the byte compilation and native compilation processes are truly finished before quitting with an error code.
The elispcomp
command-line tool can also be used in conjunction with other tools like parallel
to speed up the compilation process.
How does the author utilize elispcomp?
The author utilizes the elispcomp
tool to compile multiple Emacs Lisp files across various machines and Emacs versions. With a diverse range of machines and Emacs versions in his workflow, elispcomp
ensures consistent compilation results and compatibility.
Additionally, the author employs the parallel
command-line tool to enhance the efficiency of the byte-compilation process. This tool allows the distribution of the compilation workload across multiple processors, significantly accelerating the process.
Is elispcomp written in Python or Elisp?
Most of what elispcomp does is written in Elisp, including scanning directories, which is handled by the Emacs functions (byte-recompile-directory)
and (native-compile-async)
. Python handles the command-line interface (arguments), and Emacs and the Elisp code does the rest (byte compilation, native compilation, and waiting until all the .el files are byte compiled and native compiled).
License
Copyright (c) 2024 James Cherti
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program. If not, see https://www.gnu.org/licenses/.
Links
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file elispcomp-1.0.9.tar.gz
.
File metadata
- Download URL: elispcomp-1.0.9.tar.gz
- Upload date:
- Size: 11.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 455da02d9b0a1ecb2f48b1d92b67c3cb1ae678f9701a52687426c46aa46793f8 |
|
MD5 | c08ac8ca5e055e719de1766aa25ec3ad |
|
BLAKE2b-256 | e118731e96a9a4f82a7b8c0baef10b0af23925c88b17b92fef50e8f3450044aa |
File details
Details for the file elispcomp-1.0.9-py3-none-any.whl
.
File metadata
- Download URL: elispcomp-1.0.9-py3-none-any.whl
- Upload date:
- Size: 10.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 131433151121da76b3d0018c789a7a517ea29584e4fcb28af40eaba3b6910d21 |
|
MD5 | ee849a38c9bcc0b329f331cdffc89451 |
|
BLAKE2b-256 | 7f340abe7bef4d71e49a2bc913f437bdf3760b8362ba34fd7e7151a6a6fcfed7 |