spacemacs/layers/+lang/scheme/packages.el

189 lines
6.1 KiB
EmacsLisp

;;; packages.el --- Scheme Layer packages File for Spacemacs
;;
;; Copyright (c) 2012-2022 Sylvain Benner & Contributors
;;
;; Author: Sylvain Benner <sylvain.benner@gmail.com>
;; URL: https://github.com/syl20bnr/spacemacs
;;
;; This file is not part of GNU Emacs.
;;
;; This program is free software; you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation, either version 3 of the License, or
;; (at your option) any later version.
;;
;; This program is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;; GNU General Public License for more details.
;;
;; You should have received a copy of the GNU General Public License
;; along with this program. If not, see <http://www.gnu.org/licenses/>.
(defconst scheme-packages
'(company
evil-cleverparens
geiser
ggtags
counsel-gtags
helm-gtags
(geiser-chez :toggle (memq 'chez scheme-implementations))
(geiser-chibi :toggle (memq 'chibi scheme-implementations))
(geiser-chicken :toggle (memq 'chicken scheme-implementations))
(geiser-gambit :toggle (memq 'gambit scheme-implementations))
(geiser-gauche :toggle (memq 'gauche scheme-implementations))
(geiser-guile :toggle (memq 'guile scheme-implementations))
(geiser-kawa :toggle (memq 'kawa scheme-implementations))
(geiser-mit :toggle (memq 'mit scheme-implementations))
(geiser-racket :toggle (memq 'racket scheme-implementations))))
(defun scheme/post-init-company ()
;; Geiser provides completion as long as company mode is loaded.
(spacemacs|add-company-backends :modes scheme-mode :backends company-capf))
(defun scheme/pre-init-evil-cleverparens ()
(spacemacs|use-package-add-hook evil-cleverparens
:pre-init
(add-to-list 'evil-lisp-safe-structural-editing-modes 'scheme-mode)))
(defun scheme/init-geiser ()
(use-package geiser
:commands run-geiser
:init (spacemacs/register-repl 'geiser 'run-geiser "geiser")
:config
(progn
;; prefixes
(spacemacs/declare-prefix-for-mode 'scheme-mode "mc" "compiling")
(spacemacs/declare-prefix-for-mode 'scheme-mode "mg" "navigation")
(spacemacs/declare-prefix-for-mode 'scheme-mode "mh" "documentation")
(spacemacs/declare-prefix-for-mode 'scheme-mode "mi" "insertion")
(spacemacs/declare-prefix-for-mode 'scheme-mode "mm" "macroexpansion")
(spacemacs/declare-prefix-for-mode 'scheme-mode "ms" "repl")
;; key bindings
(spacemacs/set-leader-keys-for-major-mode 'scheme-mode
"'" 'geiser-mode-switch-to-repl
"," 'lisp-state-toggle-lisp-state
"cc" 'geiser-compile-current-buffer
"cp" 'geiser-add-to-load-path
"eb" 'geiser-eval-buffer
"ee" 'geiser-eval-last-sexp
"ef" 'geiser-eval-definition
"el" 'lisp-state-eval-sexp-end-of-line
"er" 'geiser-eval-region
"gm" 'geiser-edit-module
"gn" 'next-error
"gN" 'previous-error
"hh" 'geiser-doc-symbol-at-point
"hd" 'geiser-doc-look-up-manual
"hm" 'geiser-doc-module
"h<" 'geiser-xref-callers
"h>" 'geiser-xref-callees
"il" 'geiser-insert-lambda
"me" 'geiser-expand-last-sexp
"mf" 'geiser-expand-definition
"mr" 'geiser-expand-region
"si" 'geiser-mode-switch-to-repl
"sb" 'geiser-eval-buffer
"sB" 'geiser-eval-buffer-and-go
"sf" 'geiser-eval-definition
"sF" 'geiser-eval-definition-and-go
"se" 'geiser-eval-last-sexp
"sr" 'geiser-eval-region
"sR" 'geiser-eval-region-and-go
"ss" 'geiser-set-scheme)
(evil-define-key 'insert geiser-repl-mode-map
(kbd "S-<return>") 'geiser-repl--newline-and-indent
(kbd "C-l") 'geiser-repl-clear-buffer
(kbd "C-d") 'geiser-repl-exit)
(evil-define-key 'normal geiser-repl-mode-map
"]]" 'geiser-repl-next-prompt
"[[" 'geiser-repl-previous-prompt
"gj" 'geiser-repl-next-prompt
"gk" 'geiser-repl-previous-prompt)
(spacemacs/declare-prefix-for-mode 'geiser-repl-mode "mh" "help")
(spacemacs/declare-prefix-for-mode 'geiser-repl-mode "mi" "insert")
(spacemacs/set-leader-keys-for-major-mode 'geiser-repl-mode
"C" 'geiser-repl-clear-buffer
"k" 'geiser-repl-interrupt
"f" 'geiser-load-file
"il" 'geiser-insert-lambda
"im" 'geiser-repl-import-module
"u" 'geiser-repl-unload-function
"hh" 'geiser-doc-symbol-at-point
"s" 'geiser-squarify
"q" 'geiser-repl-exit)
(evilified-state-evilify-map geiser-doc-mode-map
:mode geiser-doc-mode
:eval-after-load geiser-doc
:bindings
"o" 'link-hint-open-link
"]]" 'geiser-doc-next-section
"[[" 'geiser-doc-previous-section
">" 'geiser-doc-next
"<" 'geiser-doc-previous
"gp" 'geiser-doc-previous
"gn" 'geiser-doc-next
"gz" 'geiser-doc-switch-to-repl
(kbd "C-j") 'forward-button
(kbd "C-k") 'backward-button))))
(defun scheme/post-init-ggtags ()
(add-hook 'scheme-mode-local-vars-hook #'spacemacs/ggtags-mode-enable))
(defun scheme/post-init-counsel-gtags ()
(spacemacs/counsel-gtags-define-keys-for-mode 'scheme-mode))
(defun scheme/post-init-helm-gtags ()
(spacemacs/helm-gtags-define-keys-for-mode 'scheme-mode))
(defun scheme/init-geiser-chez ()
(use-package geiser-chez
:defer t))
(defun scheme/init-geiser-chibi ()
(use-package geiser-chibi
:defer t))
(defun scheme/init-geiser-chicken ()
(use-package geiser-chicken
:defer t))
(defun scheme/init-geiser-gambit ()
(use-package geiser-gambit
:defer t))
(defun scheme/init-geiser-gauche ()
(use-package geiser-gauche
:defer t))
(defun scheme/init-geiser-guile ()
(use-package geiser-guile
:defer t))
(defun scheme/init-geiser-kawa ()
(use-package geiser-kawa
:defer t))
(defun scheme/init-geiser-mit ()
(use-package geiser-mit
:defer t))
(defun scheme/init-geiser-racket ()
(use-package geiser-racket
:defer t))