[Emacs] Better straight.el usage

Add username for Github and Gitlab when using straight fork
Change default remote when a package is cloned by straight
Install use-package through straight.el
This commit is contained in:
Lucien Cartier-Tilet 2022-01-05 14:10:40 +01:00
parent cc70db8439
commit 55a12d8a80
Signed by: phundrak
GPG Key ID: BD7789E705CB8DCA

View File

@ -729,11 +729,11 @@ confusion between the two of them.
:CUSTOM_ID: Package-Management-Straightry3lel6184j0 :CUSTOM_ID: Package-Management-Straightry3lel6184j0
:END: :END:
For my package management, I prefer to use ~straight~ ([[https://github.com/raxod502/straight.el][Github]]). This is For my package management, I prefer to use ~straight~ ([[https://github.com/raxod502/straight.el][Github]]). This is
due to its capacity of integrating nicely with ~use-package~, which is due to its capacity of integrating nicely with ~use-package~, which also
also supported by ~general~ which I use for my keybindings (see below), supports ~general~ which I use for my keybindings (see below), but also
but also because with it I can specify where to retrieve packages that because with it I can specify where to retrieve packages that are not
are not on MELPA or ELPA but on Github and other online Git on MELPA or ELPA but on Github and other online Git repositories too.
repositories too. First, lets bootstrap straight.
#+begin_src emacs-lisp #+begin_src emacs-lisp
(defvar bootstrap-version) (defvar bootstrap-version)
(defvar comp-deferred-compilation-deny-list ()) ; workaround, otherwise straight shits itself (defvar comp-deferred-compilation-deny-list ()) ; workaround, otherwise straight shits itself
@ -748,16 +748,45 @@ repositories too.
(goto-char (point-max)) (goto-char (point-max))
(eval-print-last-sexp))) (eval-print-last-sexp)))
(load bootstrap-file nil 'nomessage)) (load bootstrap-file nil 'nomessage))
#+end_src
Now, we can refresh our package list in order to be able to install
stuff.
#+begin_src emacs-lisp
(package-initialize) (package-initialize)
(unless package-archive-contents (unless package-archive-contents
(package-refresh-contents)) (package-refresh-contents))
;; Initialize use-package on non-Linux platforms #+end_src
(unless (package-installed-p 'use-package)
(package-install 'use-package))
(require 'use-package) From time to time, I fork some packages either because Im trying to
implement something new in said package, or because the package is
unmaintained and I want to continue developing it a bit more. Straight
provides a nice feature for using forks of a package with its ~:fork~
option. If set to ~t~, then straight will attempt to retrieve the
package with the same name but with a different username on the same
host. This username is retrieved through the following variable:
#+begin_src emacs-lisp
(setq straight-host-usernames
'((github . "Phundrak")
(gitlab . "Phundrak")))
#+end_src
The huge advantage of straight is it clones through git the packages
it installs. This means development can be done directly on the
downloaded package. However, Forge (a Magit extension for interacting
with websites such as Github, Gitlab, and such) interacts by default
with the forge described by the ~origin~ remote, which isnt necessarily
the one I want Forge to interact with by default. Therefore, all
default remotes are named ~straight~ so it wont collide with my regular
development flow.
#+begin_src emacs-lisp
(setq straight-vc-git-default-remote-name "straight")
#+end_src
We finally come to the ~use-package~ installation. This is done like so:
#+begin_src emacs-lisp
(straight-use-package '(use-package :build t))
(setq use-package-always-ensure t) (setq use-package-always-ensure t)
#+end_src #+end_src