summaryrefslogtreecommitdiff
path: root/emacs/pit.el
blob: cce26946b45c26d1739d79772582118e637e2d7a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
;;; pit --- support for pit -*- lexical-binding: t; -*-
;;; Commentary:
;;; Code:

(require 'dash)
(require 's)
(require 'cl-lib)
(require 'rx)
(require 'hydra)
(require 'comint)

(defcustom pit/repl-buffer-name "*pit-repl*"
  "Name of the pit REPL buffer."
  :type '(string)
  :group 'pit)

(defcustom pit/interpreter-path "~/src/libcolonq/pit/pit"
  "Path to the pit interpreter."
  :type '(string)
  :group 'pit)

(define-derived-mode pit/mode lisp-mode "pit"
  "Major mode for pit source code."
  )
(add-to-list 'auto-mode-alist `(,(rx ".pit" eos) . pit/mode))

(defun pit/repl-buffer ()
  "Ensure the REPL is running and return its buffer."
  (make-comint-in-buffer "pit" pit/repl-buffer-name pit/interpreter-path nil)
  (get-buffer pit/repl-buffer-name))

(defun pit/repl-process ()
  "Return the Comint process for the REPL."
  (get-buffer-process (pit/repl-buffer)))

(defun pit/send-string (s)
  "Send string S to the REPL."
  (comint-send-string (pit/repl-process) (s-concat s "\n")))

(defun pit/eval-region (start end)
  "Send the region from START to END to the REPL."
  (interactive "r")
  (comint-send-region (pit/repl-process) start end)
  (comint-send-string (pit/repl-process) "\n"))

(defun pit/eval-defun ()
  "Send the defun under point to the REPL."
  (interactive)
  (save-excursion
    (end-of-defun)
    (beginning-of-defun)
    (let ((start (point)))
      (forward-sexp)
      (pit/eval-region start (point)))))

(defun pit/eval-buffer ()
  "Send the current buffer to the REPL."
  (interactive)
  (pit/send-string (format "(progn %s 'done)" (buffer-string))))

(defun pit/restart ()
  "Restart the pit REPL."
  (interactive)
  (kill-buffer pit/repl-buffer-name)
  (pit/repl))

(defun pit/repl ()
  "Launch the pit REPL."
  (interactive)
  (switch-to-buffer (pit/repl-buffer)))

;;;; configuration
(defhydra pit/ide (:color teal :hint nil)
  "Dispatcher > pit IDE."
  ("<f12>" keyboard-escape-quit)
  ("S" pit/restart "start")
  ("e" pit/eval-defun "eval")
  ("i" pit/eval-buffer "buffer")
  ("r" pit/repl "repl"))
(defun pit/setup ()
  "Configuration for `pit/mode'."
  (setq-local c/contextual-ide 'pit/ide/body))
(add-hook 'pit/mode-hook #'pit/setup)

(provide 'pit)
;;; pit.el ends here