tvl-depot/users/wpcarro/emacs/default.nix
William Carroll cdc18c025a refactor(wpcarro/emacs): Drop support for vendor directory
I don't think this is worth lugging around anymore.

Additionally: drop usage of `builtins.path`.

I originally started using `builtins.path` because a blog post about Nix style
recommended it (I cannot remember which), but I'm starting to think this is a
bit too verbose for my taste, and I forget what the benefits are.

Change-Id: If6579f28bac56ad7afec2c5d5a5e4828601c93c3
Reviewed-on: https://cl.tvl.fyi/c/depot/+/5083
Reviewed-by: wpcarro <wpcarro@gmail.com>
Autosubmit: wpcarro <wpcarro@gmail.com>
Tested-by: BuildkiteCI
2022-01-28 23:42:58 +00:00

170 lines
3.8 KiB
Nix

{ depot, pkgs, lib, ... }:
# TODO(wpcarro): See if it's possible to expose emacsclient on PATH, so that I
# don't need to depend on wpcarros-emacs and emacs in my NixOS configurations.
let
inherit (builtins) path;
inherit (depot.third_party.nixpkgs) emacsPackagesGen emacs27;
inherit (depot.users) wpcarro;
inherit (pkgs) runCommand writeShellScriptBin;
inherit (lib) mapAttrsToList;
inherit (lib.strings) concatStringsSep makeBinPath;
emacsBinPath = makeBinPath (
wpcarro.common.shell-utils ++
(with pkgs; [
clipmenu
ispell
nix
pass
scrot
xorg.xset
]));
emacsWithPackages = (emacsPackagesGen emacs27).emacsWithPackages;
wpcarrosEmacs = emacsWithPackages (epkgs:
(with epkgs.tvlPackages; [
tvl
]) ++
(with epkgs.elpaPackages; [
exwm
]) ++
(with epkgs.melpaPackages; [
org-bullets
sly
notmuch
elm-mode
ts
vterm
base16-theme
password-store
# TODO(wpcarro): Prefer an Emacs client for clipmenud.
clipmon
evil
evil-collection
evil-commentary
evil-surround
key-chord
# TODO(wpcarro): Assess whether or not I need this with Nix.
add-node-modules-path
web-mode
rjsx-mode
tide
prettier-js
flycheck
diminish
doom-themes
telephone-line
which-key
all-the-icons
all-the-icons-ivy
ivy
ivy-pass
ivy-prescient
restclient
package-lint
parsec
magit-popup
direnv
alert
nix-mode
racer
rust-mode
rainbow-delimiters
racket-mode
lispyville
elisp-slime-nav
py-yapf
reason-mode
elixir-mode
go-mode
company
markdown-mode
refine
deferred
magit
request
pcre2el
helpful
# TODO(wpcarro): Determine if Nix solves this problem.
exec-path-from-shell
yasnippet
projectile
deadgrep
counsel
counsel-projectile
# TODO(wpcarro): Learn what this is.
engine-mode
eglot
dap-mode
lsp-ui
suggest
paradox
flymake-shellcheck
fish-mode
tuareg
haskell-mode
use-package
general
clojure-mode
cider
f
dash
company
counsel
flycheck
emojify
]));
loadPath = concatStringsSep ":" [
./.emacs.d/wpc
# TODO(wpcarro): Explain why the trailing ":" is needed.
"${wpcarrosEmacs.deps}/share/emacs/site-lisp:"
];
# Transform an attrset into "export k=v" statements.
makeEnvVars = env: concatStringsSep "\n"
(mapAttrsToList (k: v: "export ${k}=\"${v}\"") env);
withEmacsPath = { emacsBin, env ? {} }:
writeShellScriptBin "wpcarros-emacs" ''
export XMODIFIERS=emacs
export PATH="${emacsBinPath}:$PATH"
export EMACSLOADPATH="${loadPath}"
${makeEnvVars env}
exec ${emacsBin} \
--debug-init \
--no-init-file \
--no-site-file \
--no-site-lisp \
--load ${./.emacs.d/init.el} \
"$@"
'';
in {
inherit withEmacsPath;
nixos = withEmacsPath {
emacsBin = "${wpcarrosEmacs}/bin/emacs";
};
# Script that asserts my Emacs can initialize without warnings or errors.
check = runCommand "check-emacs" {} ''
# Even though Buildkite defines this, I'd still like still be able to test
# this locally without depending on my ability to remember to set CI=true.
export CI=true
export PATH="${emacsBinPath}:$PATH"
export EMACSLOADPATH="${loadPath}"
${wpcarrosEmacs}/bin/emacs \
--no-site-file \
--no-site-lisp \
--no-init-file \
--script ${./ci.el} \
${./.emacs.d/init.el} && \
touch $out
'';
meta.targets = [ "nixos" "check" ];
}