Mercurial > hg > xemacs
comparison shared/alarm.el @ 0:107d592c5f4a
DICE versions, used by pers/common, recursive, I think/hope
author | Henry S. Thompson <ht@inf.ed.ac.uk> |
---|---|
date | Mon, 08 Feb 2021 11:44:37 +0000 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:107d592c5f4a |
---|---|
1 ;;; Last edited: Thu Jun 11 10:49:18 1992 | |
2 ;;; alarm facility for emacs | |
3 | |
4 (provide 'alarm) | |
5 | |
6 (defvar alarm-process nil) | |
7 | |
8 (defvar alarm-callback nil) | |
9 | |
10 (defun alarm (seconds function) | |
11 "After SECONDS, funcall FUNCTION" | |
12 (if (and alarm-process | |
13 (not (eq (process-status alarm-process) 'exit))) | |
14 (error "already waiting") | |
15 (setq alarm-callback function) | |
16 (setq alarm-process | |
17 (start-process "alarm-clock" nil | |
18 "/bin/sleep" (format "%d" seconds))) | |
19 (set-process-sentinel alarm-process (function alarm-sentinel))) | |
20 ) | |
21 | |
22 (defun alarm-sentinel (process reason) | |
23 (setq asm reason) | |
24 (if (equal reason "finished\n") | |
25 (funcall alarm-callback) | |
26 (error "Bogus alarm message: %s" reason))) | |
27 | |
28 (defun alarm-stop () "turn off alarm" | |
29 (interactive) | |
30 (set-process-sentinel alarm-process nil) | |
31 (kill-process alarm-process) | |
32 (setq alarm-process nil)) | |
33 | |
34 (defvar idle-last-command nil) | |
35 (defvar idle-last-input-char nil) | |
36 (defvar idle-time nil) | |
37 (defvar idle-interval nil) | |
38 (defvar idle-function nil) | |
39 (defvar idle-count nil) | |
40 | |
41 (defun idle-timeout (seconds function &optional check-interval) | |
42 "If idle for SECONDS, call FUNCTION. Check every CHECK-INTERVAL, or 60 secs" | |
43 (setq idle-last-command last-command) | |
44 (setq idle-last-input-char last-input-char) | |
45 (setq idle-time seconds) | |
46 (setq idle-start-time (current-msec-time)) | |
47 (setq idle-interval (or check-interval 60)) | |
48 (setq idle-count (/ (+ seconds (1- idle-interval)) idle-interval)) | |
49 (setq idle-function function) | |
50 (alarm idle-interval (function idle-check))) | |
51 | |
52 (defun idle-check () | |
53 (setq idle-count (max (1- idle-count) 0)) | |
54 ; (message "trying") | |
55 (if (and | |
56 (eq idle-last-command last-command) | |
57 ; (message "tic") | |
58 (= idle-last-input-char last-input-char) | |
59 ; (message "toc") | |
60 ) | |
61 (if (and (= idle-count 0) | |
62 ; (message "torum") | |
63 (or | |
64 (let ((last-field-3 (last-event-time))) | |
65 ;; allow for wrap | |
66 (or (not last-field-3) | |
67 ; (progn (message "tarum") nil) | |
68 (let ((last (logand 8388607 | |
69 last-field-3)) | |
70 (time (current-msec-time))) | |
71 ; (message "%d %d %d" last time idle-time) | |
72 (> (/ (if (< time last) | |
73 (+ (- time last) 8388607) | |
74 (- time last)) | |
75 1000) | |
76 idle-time)))))) | |
77 (save-excursion | |
78 (set-buffer (get-buffer-create "*Idle*")) | |
79 (insert-string "Idle at " (current-time-string) | |
80 (format " :\n %s -> " | |
81 idle-function)) | |
82 (insert-string (format "%s\n" | |
83 (save-excursion (funcall idle-function))))) | |
84 (alarm idle-interval (function idle-check))) | |
85 (setq idle-last-command last-command) | |
86 (setq idle-last-input-char last-input-char) | |
87 (setq idle-count (/ (+ idle-time (1- idle-interval)) idle-interval)) | |
88 (alarm idle-interval (function idle-check)))) | |
89 | |
90 (defvar idle-save-timeout nil) | |
91 | |
92 (defun idle-save (&optional minutes) | |
93 "If idle for more MINUTES (defaults to 5), save all changed buffers" | |
94 (interactive "nIdle after minutes: ") | |
95 (idle-timeout (setq idle-save-timeout (* 60 (or minutes 5))) | |
96 (quote idle-save-doit))) | |
97 | |
98 (defun idle-save-doit () | |
99 (let ((bufs (buffer-list)) | |
100 result) | |
101 (while bufs | |
102 (let ((buf (car bufs)) file-name) | |
103 (if (and (buffer-modified-p buf) | |
104 (setq file-name (buffer-file-name buf)) | |
105 (string-match "\\.babyl$" file-name)) | |
106 (progn (set-buffer buf) | |
107 (let ((require-final-newline nil)) | |
108 (save-buffer) | |
109 (setq result (cons file-name result)))))) | |
110 (setq bufs (cdr bufs))) | |
111 (idle-timeout idle-save-timeout (quote idle-save-doit)) | |
112 (if result | |
113 (mapconcat (function identity) | |
114 result | |
115 " ") | |
116 "nil"))) | |
117 | |
118 ;; defaults | |
119 (defun current-msec-time () (the-time)) | |
120 (defun last-event-time () | |
121 (and (boundp '*last-event*) | |
122 (> (length *last-event*) 3) | |
123 (elt *last-event* 3))) |