2019-12-14 16:25:04 +01:00
|
|
|
# This file builds an Emacs pre-configured with the packages I need
|
|
|
|
# and my personal Emacs configuration.
|
2023-08-27 01:22:20 +02:00
|
|
|
{ depot, lib, pkgs, ... }:
|
2018-03-04 00:07:38 +01:00
|
|
|
|
2022-01-30 17:06:58 +01:00
|
|
|
pkgs.makeOverridable
|
2023-06-23 15:02:41 +02:00
|
|
|
({ emacs ? pkgs.emacs-unstable }:
|
2022-01-30 17:06:58 +01:00
|
|
|
let
|
2022-03-13 17:19:07 +01:00
|
|
|
emacsWithPackages = (pkgs.emacsPackagesFor emacs).emacsWithPackages;
|
2018-09-19 22:59:42 +02:00
|
|
|
|
2022-01-30 17:06:58 +01:00
|
|
|
# If switching telega versions, use this variable because it will
|
|
|
|
# keep the version check, binary path and so on in sync.
|
|
|
|
currentTelega = epkgs: epkgs.melpaPackages.telega;
|
2021-12-13 16:53:22 +01:00
|
|
|
|
2022-01-30 17:06:58 +01:00
|
|
|
# $PATH for binaries that need to be available to Emacs
|
|
|
|
emacsBinPath = lib.makeBinPath [
|
2023-08-27 01:22:20 +02:00
|
|
|
depot.users.tazjin.gio-list-apps
|
2022-01-30 17:06:58 +01:00
|
|
|
(currentTelega pkgs.emacsPackages)
|
|
|
|
pkgs.libwebp # for dwebp, required by telega
|
|
|
|
];
|
2019-12-19 15:48:22 +01:00
|
|
|
|
2022-01-30 17:06:58 +01:00
|
|
|
identity = x: x;
|
2020-02-07 13:41:43 +01:00
|
|
|
|
2022-01-30 17:06:58 +01:00
|
|
|
tazjinsEmacs = pkgfun: (emacsWithPackages (epkgs: pkgfun (with epkgs; [
|
|
|
|
ace-link
|
|
|
|
ace-window
|
|
|
|
avy
|
|
|
|
bazel
|
|
|
|
browse-kill-ring
|
|
|
|
cargo
|
|
|
|
clojure-mode
|
|
|
|
cmake-mode
|
|
|
|
company
|
refactor(tazjin/emacs): ivy,swiper,counsel -> vertico,consult
vertico and consult are more modern versions of interactive narrowing
helpers, as those implemented by ivy and its related packages.
The primary differences (and what I care about here) is that they are
more focused on integration with the core Emacs primitives, rather
than building an ecosystem around them.
For example:
* vertico enhances `completing-read' and friends, but does not attempt
to provide its own ecosystem of functions to *trigger* completions.
* vertico integrates with the default `completion-style' system,
meaning that I can continue to use things like prescient without
extra packages that integrate it with vertico
* consult does not rely on vertico or any other specific completion
framework (such as counsel/swiper do with ivy), and simply
implements its functions using completing-read
This reduces the overall amount of code in the dependency closure and
leads to a less special setup.
Functionality is basically equivalent, except for two things which
counsel came with that I will need to substitute:
* counsel-notmuch (actually this was a separate package, but I didn't
use it much anyways, so just ignoring it for now)
* counsel-linux-app (opening desktop shortcuts, this I will need to make)
As a side note, consult notes "This package is a part of GNU Emacs",
but it doesn't seem to be the case.
Change-Id: Ia046b763bf3d401b505e0f6393cfe1ccd6f41293
Reviewed-on: https://cl.tvl.fyi/c/depot/+/9155
Tested-by: BuildkiteCI
Reviewed-by: tazjin <tazjin@tvl.su>
2023-08-27 00:12:29 +02:00
|
|
|
consult
|
2022-01-30 17:06:58 +01:00
|
|
|
d-mode
|
2022-05-22 21:01:30 +02:00
|
|
|
deft
|
2022-01-30 17:06:58 +01:00
|
|
|
direnv
|
|
|
|
dockerfile-mode
|
|
|
|
elixir-mode
|
|
|
|
elm-mode
|
|
|
|
erlang
|
|
|
|
exwm
|
|
|
|
flymake
|
|
|
|
go-mode
|
|
|
|
google-c-style
|
|
|
|
gruber-darker-theme
|
|
|
|
haskell-mode
|
|
|
|
ht
|
|
|
|
hydra
|
|
|
|
idle-highlight-mode
|
|
|
|
jq-mode
|
|
|
|
kotlin-mode
|
2023-08-02 11:51:34 +02:00
|
|
|
kubernetes
|
2022-01-30 17:06:58 +01:00
|
|
|
lsp-mode
|
|
|
|
magit
|
|
|
|
markdown-toc
|
|
|
|
meson-mode
|
|
|
|
multi-term
|
|
|
|
multiple-cursors
|
|
|
|
nginx-mode
|
|
|
|
nix-mode
|
|
|
|
notmuch
|
|
|
|
paredit
|
|
|
|
password-store
|
|
|
|
pinentry
|
|
|
|
polymode
|
|
|
|
prescient
|
|
|
|
protobuf-mode
|
|
|
|
rainbow-delimiters
|
|
|
|
rainbow-mode
|
|
|
|
refine
|
|
|
|
request
|
|
|
|
restclient
|
|
|
|
rust-mode
|
|
|
|
sly
|
2022-11-18 15:01:41 +01:00
|
|
|
string-edit-at-point
|
2022-01-30 17:06:58 +01:00
|
|
|
telephone-line
|
|
|
|
terraform-mode
|
|
|
|
toml-mode
|
|
|
|
undo-tree
|
|
|
|
use-package
|
|
|
|
uuidgen
|
refactor(tazjin/emacs): ivy,swiper,counsel -> vertico,consult
vertico and consult are more modern versions of interactive narrowing
helpers, as those implemented by ivy and its related packages.
The primary differences (and what I care about here) is that they are
more focused on integration with the core Emacs primitives, rather
than building an ecosystem around them.
For example:
* vertico enhances `completing-read' and friends, but does not attempt
to provide its own ecosystem of functions to *trigger* completions.
* vertico integrates with the default `completion-style' system,
meaning that I can continue to use things like prescient without
extra packages that integrate it with vertico
* consult does not rely on vertico or any other specific completion
framework (such as counsel/swiper do with ivy), and simply
implements its functions using completing-read
This reduces the overall amount of code in the dependency closure and
leads to a less special setup.
Functionality is basically equivalent, except for two things which
counsel came with that I will need to substitute:
* counsel-notmuch (actually this was a separate package, but I didn't
use it much anyways, so just ignoring it for now)
* counsel-linux-app (opening desktop shortcuts, this I will need to make)
As a side note, consult notes "This package is a part of GNU Emacs",
but it doesn't seem to be the case.
Change-Id: Ia046b763bf3d401b505e0f6393cfe1ccd6f41293
Reviewed-on: https://cl.tvl.fyi/c/depot/+/9155
Tested-by: BuildkiteCI
Reviewed-by: tazjin <tazjin@tvl.su>
2023-08-27 00:12:29 +02:00
|
|
|
vertico
|
2022-01-30 17:06:58 +01:00
|
|
|
vterm
|
|
|
|
web-mode
|
|
|
|
websocket
|
|
|
|
which-key
|
|
|
|
xelb
|
|
|
|
yaml-mode
|
|
|
|
yasnippet
|
2022-05-22 21:01:30 +02:00
|
|
|
zetteldeft
|
2022-01-30 17:06:58 +01:00
|
|
|
zoxide
|
2020-02-24 17:40:43 +01:00
|
|
|
|
2022-01-30 17:06:58 +01:00
|
|
|
# Wonky stuff
|
|
|
|
(currentTelega epkgs)
|
2021-12-13 16:53:22 +01:00
|
|
|
|
2022-01-30 17:06:58 +01:00
|
|
|
# Custom depot packages (either ours, or overridden ones)
|
|
|
|
tvlPackages.dottime
|
|
|
|
tvlPackages.nix-util
|
|
|
|
tvlPackages.passively
|
|
|
|
tvlPackages.rcirc
|
|
|
|
tvlPackages.term-switcher
|
|
|
|
tvlPackages.tvl
|
|
|
|
])));
|
2021-12-13 16:31:25 +01:00
|
|
|
|
2022-01-30 17:06:58 +01:00
|
|
|
# Tired of telega.el runtime breakages through tdlib
|
|
|
|
# incompatibility. Target to make that a build failure instead.
|
|
|
|
tdlibCheck =
|
|
|
|
let
|
|
|
|
tgEmacs = emacsWithPackages (epkgs: [ (currentTelega epkgs) ]);
|
|
|
|
verifyTdlibVersion = builtins.toFile "verify-tdlib-version.el" ''
|
|
|
|
(require 'telega)
|
|
|
|
(defvar tdlib-version "${pkgs.tdlib.version}")
|
|
|
|
(when (or (version< tdlib-version
|
|
|
|
telega-tdlib-min-version)
|
|
|
|
(and telega-tdlib-max-version
|
|
|
|
(version< telega-tdlib-max-version
|
|
|
|
tdlib-version)))
|
|
|
|
(message "Found TDLib version %s, but require %s to %s"
|
|
|
|
tdlib-version telega-tdlib-min-version telega-tdlib-max-version)
|
|
|
|
(kill-emacs 1))
|
|
|
|
'';
|
|
|
|
in
|
2022-09-26 19:33:05 +02:00
|
|
|
pkgs.runCommand "tdlibCheck" { } ''
|
2022-01-30 17:06:58 +01:00
|
|
|
export PATH="${emacsBinPath}:$PATH"
|
|
|
|
${tgEmacs}/bin/emacs --script ${verifyTdlibVersion} && touch $out
|
|
|
|
'';
|
|
|
|
in
|
|
|
|
lib.fix
|
2022-02-08 09:57:52 +01:00
|
|
|
(self: l: f: (pkgs.writeShellScriptBin "tazjins-emacs" ''
|
2021-12-13 16:31:25 +01:00
|
|
|
export PATH="${emacsBinPath}:$PATH"
|
2022-01-30 17:06:58 +01:00
|
|
|
exec ${tazjinsEmacs f}/bin/emacs \
|
2019-12-17 00:55:23 +01:00
|
|
|
--debug-init \
|
|
|
|
--no-site-file \
|
2019-12-17 01:36:34 +01:00
|
|
|
--no-site-lisp \
|
2019-12-17 00:55:23 +01:00
|
|
|
--no-init-file \
|
2022-01-30 17:06:58 +01:00
|
|
|
--directory ${./config} ${if l != null then "--directory ${l}" else ""} \
|
2019-12-17 00:55:23 +01:00
|
|
|
--eval "(require 'init)" $@
|
2022-02-08 09:57:52 +01:00
|
|
|
'').overrideAttrs
|
|
|
|
(_: {
|
|
|
|
passthru = {
|
|
|
|
# Call overrideEmacs with a function (pkgs -> pkgs) to modify the
|
|
|
|
# packages that should be included in this Emacs distribution.
|
|
|
|
overrideEmacs = f': self l f';
|
2022-01-30 17:06:58 +01:00
|
|
|
|
2022-02-08 09:57:52 +01:00
|
|
|
# Call withLocalConfig with the path to a *folder* containing a
|
|
|
|
# `local.el` which provides local system configuration.
|
|
|
|
withLocalConfig = confDir: self confDir f;
|
2022-01-30 17:06:58 +01:00
|
|
|
|
2022-02-08 09:57:52 +01:00
|
|
|
# Build a derivation that uses the specified local Emacs (i.e.
|
|
|
|
# built outside of Nix) instead
|
|
|
|
withLocalEmacs = emacsBin: pkgs.writeShellScriptBin "tazjins-emacs" ''
|
|
|
|
export PATH="${emacsBinPath}:$PATH"
|
|
|
|
export EMACSLOADPATH="${(tazjinsEmacs f).deps}/share/emacs/site-lisp:"
|
|
|
|
exec ${emacsBin} \
|
|
|
|
--debug-init \
|
|
|
|
--no-site-file \
|
|
|
|
--no-site-lisp \
|
|
|
|
--no-init-file \
|
|
|
|
--directory ${./config} \
|
|
|
|
${if l != null then "--directory ${l}" else ""} \
|
|
|
|
--eval "(require 'init)" $@
|
|
|
|
'';
|
2021-12-13 16:31:25 +01:00
|
|
|
|
2022-02-08 09:57:52 +01:00
|
|
|
# Expose telega/tdlib version check as a target that is built in
|
|
|
|
# CI.
|
|
|
|
#
|
|
|
|
# TODO(tazjin): uncomment when telega works again
|
|
|
|
inherit tdlibCheck;
|
|
|
|
meta.ci.targets = [ "tdlibCheck" ];
|
|
|
|
};
|
|
|
|
}))
|
2022-01-30 17:06:58 +01:00
|
|
|
null
|
|
|
|
identity
|
|
|
|
)
|
|
|
|
{ }
|