;; -*- lexical-binding: t; -*- ;;;;;;;;;;;; elpaca initialise ;;;;;;;;;;;;;;;;;; (defvar elpaca-installer-version 0.12) (defvar elpaca-directory (expand-file-name "elpa/" user-emacs-directory)) (defvar elpaca-builds-directory (expand-file-name "builds/" elpaca-directory)) (defvar elpaca-sources-directory (expand-file-name "sources/" elpaca-directory)) (defvar elpaca-order '(elpaca :repo "https://github.com/progfolio/elpaca.git" :ref nil :depth 1 :inherit ignore :files (:defaults "elpaca-test.el" (:exclude "extensions")) :build (:not elpaca-activate))) (let* ((repo (expand-file-name "elpa/" elpaca-sources-directory)) (build (expand-file-name "elpa/" elpaca-builds-directory)) (order (cdr elpaca-order)) (default-directory repo)) (add-to-list 'load-path (if (file-exists-p build) build repo)) (unless (file-exists-p repo) (make-directory repo t) (when (<= emacs-major-version 28) (require 'subr-x)) (condition-case-unless-debug err (if-let* ((buffer (pop-to-buffer-same-window "*elpaca-bootstrap*")) ((zerop (apply #'call-process `("git" nil ,buffer t "clone" ,@(when-let* ((depth (plist-get order :depth))) (list (format "--depth=%d" depth) "--no-single-branch")) ,(plist-get order :repo) ,repo)))) ((zerop (call-process "git" nil buffer t "checkout" (or (plist-get order :ref) "--")))) (emacs (concat invocation-directory invocation-name)) ((zerop (call-process emacs nil buffer nil "-Q" "-L" "." "--batch" "--eval" "(byte-recompile-directory \".\" 0 'force)"))) ((require 'elpaca)) ((elpaca-generate-autoloads "elpaca" repo))) (progn (message "%s" (buffer-string)) (kill-buffer buffer)) (error "%s" (with-current-buffer buffer (buffer-string)))) ((error) (warn "%s" err) (delete-directory repo 'recursive)))) (unless (require 'elpaca-autoloads nil t) (require 'elpaca) (elpaca-generate-autoloads "elpaca" repo) (let ((load-source-file-function nil)) (load "./elpaca-autoloads")))) (add-hook 'after-init-hook #'elpaca-process-queues) (elpaca `(,@elpaca-order)) ;; Install a package via the elpaca macro ;; See the "recipes" section of the manual for more details. ;; (elpaca example-package) ;; Uncomment for systems which cannot create symlinks: (when (eq system-type 'windows-nt) (elpaca-no-symlink-mode)) ;; Install use-package support (elpaca elpaca-use-package ;; Enable use-package :ensure support for Elpaca. (elpaca-use-package-mode)) ;;When installing a package used in the init file itself, ;;e.g. a package which adds a use-package key word, ;;use the :wait recipe keyword to block until that package is installed/configured. ;;For example: ;;(use-package general :ensure (:wait t) :demand t) (setq elpaca-lock-file (expand-file-name "lock-file.eld" user-emacs-directory)) (setq use-package-always-ensure t use-package-expand-minimally t use-package-always-defer t) (use-package elpaca-ui :ensure nil :bind (:map elpaca-ui-mode-map ("p" . previous-line) ("F" . elpaca-ui-mark-pull)) :hook (elpaca-log-mode . elpaca-log-update-mode) :after popper :init (add-to-list 'popper-reference-buffers 'elpaca-log-mode) (setf (alist-get '(major-mode . elpaca-log-mode) display-buffer-alist nil nil #'equal) '((display-buffer-at-bottom display-buffer-in-side-window) (side . below) (slot . 49) (window-height . 0.4) (body-function . select-window)) (alist-get "\\*elpaca-diff\\*" display-buffer-alist nil nil #'equal) '((display-buffer-reuse-window display-buffer-in-atom-window) (side . right)))) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; (provide 'init-elpaca)