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

93 lines
2.9 KiB
EmacsLisp

;;; packages.el --- Pact Layer packages File for Spacemacs
;;
;; Copyright (c) 2012-2022 Sylvain Benner & Contributors
;;
;; Author: Colin Woodbury <colin@kadena.io>
;; 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/>.
;;; Commentary:
;;; Code:
(defconst pact-packages
'(
flycheck
flycheck-pact
pact-mode
))
(defun pact/post-init-flycheck ()
"Initialize flycheck."
(spacemacs/enable-flycheck 'pact-mode))
(defun pact/init-flycheck-pact ()
"Initialize flycheck-pact."
(use-package flycheck-pact
:commands flycheck-pact-interactive-buffer
:init (add-hook 'flycheck-mode-hook 'flycheck-pact-interactive-buffer)))
(defun pact/init-pact-mode ()
"Initialize pact-mode."
(use-package pact-mode
:defer t
:init
(progn
(spacemacs/register-repl 'pact-mode 'spacemacs/pact-repl "pact"))
:config
(progn
(defun spacemacs/pact-repl ()
"Open a pact repl in a side frame."
(interactive)
(if (get-buffer-process inferior-lisp-buffer)
;; Borrowed from `switch-to-lisp':
(let ((pop-up-frames
;; Be willing to use another frame
;; that already has the window in it.
(or pop-up-frames
(get-buffer-window inferior-lisp-buffer t))))
(pop-to-buffer inferior-lisp-buffer))
(progn
(spacemacs/new-empty-buffer-right)
(pact-mode)
(run-lisp inferior-lisp-program))))
(defun spacemacs/pact-load-file ()
"Load the current buffer into the Pact repl, optionally starting
the repl if it hasn't yet been."
(interactive)
(let ((curr (current-buffer)))
(progn
(unless (get-buffer-process inferior-lisp-buffer)
(spacemacs/pact-repl)
(pop-to-buffer curr))
(pact-load-file nil)
(pop-to-buffer curr))))
(dolist (prefix '(("ms" . "repl")))
(spacemacs/declare-prefix-for-mode 'pact-mode (car prefix) (cdr prefix)))
(spacemacs/set-leader-keys-for-major-mode 'pact-mode
;; REPL
"s'" 'spacemacs/pact-repl
"sb" 'spacemacs/pact-load-file))))
;;; packages.el ends here