-
Notifications
You must be signed in to change notification settings - Fork 72
/
Copy pathidris-events.el
77 lines (62 loc) · 2.64 KB
/
idris-events.el
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
;;; idris-events.el --- Logging of events in inferior Idris -*- lexical-binding: t -*-
;; Copyright (C) 2013 Hannes Mehnert
;; Author: Hannes Mehnert <[email protected]>
;; License:
;; Inspiration is taken from SLIME/DIME (http://common-lisp.net/project/slime/) (https://github.com/dylan-lang/dylan-mode)
;; Therefore license is GPL
;; This file 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, or (at your option)
;; any later version.
;; This file 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 GNU Emacs; see the file COPYING. If not, write to
;; the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
;; Boston, MA 02111-1307, USA.
(require 'pp)
(require 'idris-core)
(require 'idris-common-utils)
(require 'idris-settings)
(defvar idris-event-buffer-name (idris-buffer-name :events)
"The name of the Idris event buffer.")
(defun idris-events-buffer ()
"Return or create the event log buffer."
(or (get-buffer idris-event-buffer-name)
(let ((buffer (get-buffer-create idris-event-buffer-name)))
(with-current-buffer buffer
(buffer-disable-undo)
(set (make-local-variable 'outline-regexp) "^(")
(set (make-local-variable 'comment-start) ";")
(set (make-local-variable 'comment-end) "")
(setq buffer-read-only t))
buffer)))
(defun idris-event-log (event sending)
"Record the fact that EVENT occured in the SENDING direction.
The event is only logged if `idris-log-events' is non-nil."
(when idris-log-events
(with-current-buffer (idris-events-buffer)
(goto-char (point-max))
(let ((buffer-read-only nil)
(time (format-time-string "%H:%M:%S")))
(save-excursion
(if sending
(insert (concat time " -> "))
(insert (concat time " <- ")))
(idris-pprint-event event (current-buffer))))
(goto-char (point-max)))))
(defun idris-pprint-event (event buffer)
"Pretty print EVENT in BUFFER."
(let ((print-length 20)
(print-level 10)
(pp-escape-newlines t))
(pp event buffer)))
(defun idris-dump-events-to-file (file)
"Dump event log to FILE."
(when idris-log-events
(with-current-buffer (idris-events-buffer)
(write-file file))))
(provide 'idris-events)
;;; idris-events.el ends here