feat(emacs): Add telega.el support
Packages the telega-server binary and adds the required mode into Emacs. Unread message count is displayed in the modeline, which is neat. Probably need to figure out some key bindings for this.
This commit is contained in:
parent
166aff23bc
commit
c1a5d7d62a
4 changed files with 30 additions and 0 deletions
1
third_party/default.nix
vendored
1
third_party/default.nix
vendored
|
@ -69,6 +69,7 @@ let
|
||||||
stdenv
|
stdenv
|
||||||
stern
|
stern
|
||||||
symlinkJoin
|
symlinkJoin
|
||||||
|
tdlib
|
||||||
terraform_0_12
|
terraform_0_12
|
||||||
thttpd
|
thttpd
|
||||||
tree
|
tree
|
||||||
|
|
22
third_party/telega/default.nix
vendored
Normal file
22
third_party/telega/default.nix
vendored
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
# Telega is an Emacs client for Telegram. It requires a native server
|
||||||
|
# component to run correctly, which is built by this derivation.
|
||||||
|
{ pkgs, ... }:
|
||||||
|
|
||||||
|
with pkgs.third_party;
|
||||||
|
|
||||||
|
stdenv.mkDerivation {
|
||||||
|
name = "telega";
|
||||||
|
buildInputs = [ tdlib ];
|
||||||
|
|
||||||
|
src = fetchFromGitHub {
|
||||||
|
owner = "zevlg";
|
||||||
|
repo = "telega.el";
|
||||||
|
rev = "d532b16067cf24728a2aa03a7aeaebe2ceac7df4";
|
||||||
|
sha256 = "1s2sd07sin9sy833wqprhbfk5j1d1s4azzvj6d8k68sxlgz8996m";
|
||||||
|
} + "/server";
|
||||||
|
|
||||||
|
installPhase = ''
|
||||||
|
mkdir -p $out/bin
|
||||||
|
mv telega-server $out/bin/
|
||||||
|
'';
|
||||||
|
}
|
|
@ -171,6 +171,7 @@
|
||||||
(use-package nix-util)
|
(use-package nix-util)
|
||||||
(use-package nginx-mode)
|
(use-package nginx-mode)
|
||||||
(use-package rust-mode)
|
(use-package rust-mode)
|
||||||
|
(use-package telega :config (telega-mode-line-mode 1))
|
||||||
(use-package terraform-mode)
|
(use-package terraform-mode)
|
||||||
(use-package toml-mode)
|
(use-package toml-mode)
|
||||||
(use-package web-mode)
|
(use-package web-mode)
|
||||||
|
|
|
@ -11,6 +11,9 @@ let
|
||||||
localPackages = pkgs.tools.emacs-pkgs;
|
localPackages = pkgs.tools.emacs-pkgs;
|
||||||
emacsWithPackages = (third_party.emacsPackagesNgGen third_party.emacs26).emacsWithPackages;
|
emacsWithPackages = (third_party.emacsPackagesNgGen third_party.emacs26).emacsWithPackages;
|
||||||
|
|
||||||
|
# $PATH for binaries that need to be available to Emacs
|
||||||
|
emacsBinPath = lib.makeBinPath [ third_party.telega ];
|
||||||
|
|
||||||
identity = x: x;
|
identity = x: x;
|
||||||
tazjinsEmacs = pkgfun: (emacsWithPackages(epkgs: pkgfun(
|
tazjinsEmacs = pkgfun: (emacsWithPackages(epkgs: pkgfun(
|
||||||
# Actual ELPA packages (the enlightened!)
|
# Actual ELPA packages (the enlightened!)
|
||||||
|
@ -68,6 +71,7 @@ let
|
||||||
sly
|
sly
|
||||||
string-edit
|
string-edit
|
||||||
swiper
|
swiper
|
||||||
|
telega
|
||||||
telephone-line
|
telephone-line
|
||||||
terraform-mode
|
terraform-mode
|
||||||
toml-mode
|
toml-mode
|
||||||
|
@ -90,6 +94,7 @@ let
|
||||||
term-switcher
|
term-switcher
|
||||||
]))));
|
]))));
|
||||||
in lib.fix(self: l: f: third_party.writeShellScriptBin "tazjins-emacs" ''
|
in lib.fix(self: l: f: third_party.writeShellScriptBin "tazjins-emacs" ''
|
||||||
|
export PATH="${emacsBinPath}:$PATH"
|
||||||
exec ${tazjinsEmacs f}/bin/emacs \
|
exec ${tazjinsEmacs f}/bin/emacs \
|
||||||
--debug-init \
|
--debug-init \
|
||||||
--no-site-file \
|
--no-site-file \
|
||||||
|
@ -109,6 +114,7 @@ in lib.fix(self: l: f: third_party.writeShellScriptBin "tazjins-emacs" ''
|
||||||
# Build a derivation that uses the specified local Emacs (i.e.
|
# Build a derivation that uses the specified local Emacs (i.e.
|
||||||
# built outside of Nix) instead
|
# built outside of Nix) instead
|
||||||
withLocalEmacs = emacsBin: third_party.writeShellScriptBin "tazjins-emacs" ''
|
withLocalEmacs = emacsBin: third_party.writeShellScriptBin "tazjins-emacs" ''
|
||||||
|
export PATH="${emacsBinPath}:$PATH"
|
||||||
export EMACSLOADPATH="${(tazjinsEmacs f).deps}/share/emacs/site-lisp:"
|
export EMACSLOADPATH="${(tazjinsEmacs f).deps}/share/emacs/site-lisp:"
|
||||||
exec ${emacsBin} \
|
exec ${emacsBin} \
|
||||||
--debug-init \
|
--debug-init \
|
||||||
|
|
Loading…
Reference in a new issue