From a1e00bb21685d9b9b0157fa878703b5d139893fd Mon Sep 17 00:00:00 2001 From: Soonho Kong Date: Fri, 5 Sep 2014 15:22:59 -0700 Subject: [PATCH] refactor(emacs/lean-server): restructure async queue handling routine --- src/emacs/lean-info.el | 6 ++--- src/emacs/lean-server.el | 51 +++++++++++++++++++--------------------- 2 files changed, 27 insertions(+), 30 deletions(-) diff --git a/src/emacs/lean-info.el b/src/emacs/lean-info.el index f65a807ac..7be493d3f 100644 --- a/src/emacs/lean-info.el +++ b/src/emacs/lean-info.el @@ -555,9 +555,9 @@ Take out \"BEGININFO\" and \"ENDINFO\" and Use \"ACK\" as a delim." (lean-server-check-current-file file-name) (lean-server-send-cmd-async (lean-cmd-info line-number) (lambda (info-record) - (if (lean-info-record-nay info-record) - (lean-get-info-record-at-point cont) - (funcall cont info-record)))))) + (cond ((lean-info-record-nay info-record) + (lean-get-info-record-at-point cont)) + (t (funcall cont info-record))))))) (defun lean-get-full-name-at-point-cont (info-record) "Continuation of lean-get-full-name-at-point" diff --git a/src/emacs/lean-server.el b/src/emacs/lean-server.el index 0e6ddef1d..29d9b7ff3 100644 --- a/src/emacs/lean-server.el +++ b/src/emacs/lean-server.el @@ -41,9 +41,7 @@ (defun lean-server-trace (format-string &rest args) "Display a message at the bottom of the *lean-server* buffer." - (message "?\n") (when lean-server-trace-mode - (message "!\n") (when lean-global-server-last-time-sent (let ((time-diff (- (float-time) lean-global-server-last-time-sent))) (lean-server-output-to-buffer lean-server-trace-buffer-name @@ -56,10 +54,11 @@ (defun lean-server-debug (format-string &rest args) "Display a message at the bottom of the *lean-server-debug* buffer." (when lean-server-debug-mode - (lean-server-output-to-buffer lean-server-debug-buffer-name - (concat "%s -- " format-string "\n") - (cons (format-time-string "%H:%M:%S:%3N" (current-time)) - args)))) + (let ((time-str (format-time-string "%H:%M:%S.%3N" (current-time)))) + (lean-server-output-to-buffer lean-server-debug-buffer-name + (concat "%s -- " format-string "\n") + (cons (propertize time-str 'face 'font-lock-keyword-face) + args))))) (defun lean-server-turn-on-debug-mode () (interactive) @@ -147,6 +146,12 @@ ;; How to create an async process ;; ============================== + +(defun lean-server-cancel-retry-timer () + (when (timerp lean-global-retry-timer) + (cancel-timer lean-global-retry-timer)) + (setq lean-global-retry-timer nil)) + (defun lean-server-initialize-global-vars () "Initialize lean-server related global variables" (setq lean-global-server-buffer nil) @@ -154,9 +159,7 @@ (setq lean-global-server-message-to-process nil) (setq lean-global-server-last-time-sent nil) (setq lean-global-async-task-queue nil) - (when (timerp lean-global-retry-timer) - (cancel-timer lean-global-retry-timer)) - (setq lean-global-retry-timer nil)) + (lean-server-cancel-retry-timer)) (defun lean-server-create-process () "Create lean-server process." @@ -327,16 +330,10 @@ If it's not the same with file-name (default: buffer-file-name), send VISIT cmd. (lean-server-send-cmd cmd) (when cont (setq lean-global-async-task-queue (-snoc lean-global-async-task-queue cont)) - (lean-server-cancel-retry-timer) (lean-server-debug "send-cmd-async: added to the queue = %S" (length lean-global-async-task-queue)) (lean-server-debug "send-cmd-async: call handler") - (lean-server-event-handler))) - -(defun lean-server-cancel-retry-timer () - (when (timerp lean-global-retry-timer) - (cancel-timer lean-global-retry-timer) - (setq lean-global-retry-timer nil))) + (lean-server-set-timer-for-event-handler))) (defun lean-server-consume-all-async-tasks () (while lean-global-async-task-queue @@ -415,17 +412,17 @@ If it's not the same with file-name (default: buffer-file-name), send VISIT cmd. (defun lean-server-event-handler () "Process an item from async-task-queue. -If it's successful, take it out from the queue. Otherwise, set an - idle-timer to call the handler again" - (setq lean-global-retry-timer nil) - (let* ((cont (car lean-global-async-task-queue)) - (result (lean-server-check-and-process-buffer-with-cont cont))) - (pcase result - (`(PROCESSED ,ret) - (!cdr lean-global-async-task-queue) - ret))) - (when lean-global-async-task-queue - (lean-server-set-timer-for-event-handler))) +If it's successful, take it out from the queue. +Otherwise, set an idle-timer to call the handler again" + (lean-server-cancel-retry-timer) + (when (eq major-mode 'lean-mode) + (let* ((cont (car lean-global-async-task-queue)) + (result (lean-server-check-and-process-buffer-with-cont cont))) + (pcase result + (`(PROCESSED ,ret) + (!cdr lean-global-async-task-queue) + ret))) + (if lean-global-async-task-queue (lean-server-set-timer-for-event-handler)))) (defadvice save-buffers-kill-emacs (before lean-server-kill-before-kill-emacs activate)