Skip to content

Latest commit

 

History

History
20 lines (16 loc) · 1.78 KB

README.org

File metadata and controls

20 lines (16 loc) · 1.78 KB

twist2elpa: Build an ELPA-compatible package archive from your Nix configuration

This repository provides tools for producing the standard package.el-compliant package artifacts from your twist.nix configuration.

Although twist.nix is cross-platform, it is still limited to Nix. For example, you can’t use your configuration on Windows. With twist2elpa, you can build and distribute ELPA packages with little effort, so you can install them using package.el. Because package.el is shipped with Emacs, this means you can use your favorite packages on any operating system that supports Emacs, with the package revisions exactly the same as your preferred environment. First develop your configuration with Nix, and then run it on anywhere.

Since this functionality is experimental, it is maintained in a separate repository, and it does not guarantee 100% compatibility with ELPA or MELPA.

Usage

This repository exposes an nixpkgs overlay from the flake. The overlay provides emacsTwist2Elpa attribute set, which contains the following functions:

buildElpaPackage
Builds a single Emacs Lisp package that can be installed using package-install-file.
buildElpaArchive
Builds a package archive that can be added to package-archives. You can upload the directory to a server like S3 and use it as a replacement for ELPA and MELPA.
buildElpaArchiveAsTar
Like buildElpaArchive, but creates a tar archive. Once you upload the archive to somewhere like GitHub Releases, you can download and use it offline on another machine.

It is *not*​ recommended to add your twist2elpa-generated archive to package-archives alongside ELPA and/or MELPA. Rather, the generated archive works as a replacement, or proxy, for GNU/nonGNU ELPA and MELPA.