]> git.eshelyaron.com Git - emacs.git/commitdiff
Revert an unfinished feature that made it to the last commit
authorJoão Távora <joaotavora@gmail.com>
Fri, 1 Jun 2018 15:09:19 +0000 (16:09 +0100)
committerJoão Távora <joaotavora@gmail.com>
Fri, 1 Jun 2018 15:09:19 +0000 (16:09 +0100)
commit ee6ab89666704232f744d6262040979b0142c44b
   Author: João Távora <joaotavora@gmail.com>
   Date:   Fri Jun 1 14:43:30 2018 +0100

   Add MELPA badge

lisp/progmodes/eglot.el

index 3dfe159762110c3211655ef36f3a3b575957f404..a991cb1f785bcc916b7a6a5e306e98366c8471e0 100644 (file)
@@ -908,15 +908,12 @@ that case, also signal textDocument/didOpen."
 
 (put 'eglot--mode-line-format 'risky-local-variable t)
 
-(defun eglot--mouse-call (what)
+(defun eglot--mode-line-call (what)
   "Make an interactive lambda for calling WHAT from mode-line."
   (lambda (event)
     (interactive "e")
-    (let ((start (event-start event))) (with-selected-window (posn-window start)
-                                         (save-excursion
-                                           (goto-char (or (posn-point start)
-                                                          (point)))
-                                           (call-interactively what))))))
+    (with-selected-window (posn-window (event-start event))
+      (call-interactively what))))
 
 (defun eglot--mode-line-props (thing face defs &optional prepend)
   "Helper for function `eglot--mode-line-format'.
@@ -924,7 +921,7 @@ Uses THING, FACE, DEFS and PREPEND."
   (cl-loop with map = (make-sparse-keymap)
            for (elem . rest) on defs
            for (key def help) = elem
-           do (define-key map `[mode-line ,key] (eglot--mouse-call def))
+           do (define-key map `[mode-line ,key] (eglot--mode-line-call def))
            concat (format "%s: %s" key help) into blurb
            when rest concat "\n" into blurb
            finally (return `(:propertize ,thing
@@ -971,41 +968,6 @@ Uses THING, FACE, DEFS and PREPEND."
 (add-to-list 'mode-line-misc-info
              `(eglot--managed-mode (" [" eglot--mode-line-format "] ")))
 
-\f
-;; A horrible hack of Flymake's insufficient API that must go into
-;; Emacs master, or better, 26.2
-(cl-defstruct (eglot--diag (:include flymake--diag)
-                           (:constructor eglot--make-diag
-                                         (buffer beg end type text props)))
-  props)
-(advice-add 'flymake--highlight-line :after
-            (lambda (diag)
-              (when (cl-typep diag 'eglot--diag)
-                (let ((ov (cl-find diag
-                                   (overlays-at (flymake-diagnostic-beg diag))
-                                   :key (lambda (ov)
-                                          (overlay-get ov 'flymake-diagnostic)))))
-                  (cl-loop for (key . value) in (eglot--diag-props diag)
-                           do (overlay-put ov key value)))))
-            '((name . eglot-hacking-in-some-per-diag-overlay-properties)))
-
-
-(defun eglot--overlay-diag-props ()
-  `((mouse-face . highlight)
-    (help-echo . (lambda (window _ov pos)
-                   (with-selected-window window
-                     (concat (mapconcat
-                              #'flymake-diagnostic-text
-                              (flymake-diagnostics pos)
-                              "\n")
-                             "\nmouse-1: Get LSP code actions"))))
-    (keymap . ,(let ((map (make-sparse-keymap)))
-                 (define-key map [mouse-1]
-                   (eglot--mouse-call 'eglot-get-code-actions))
-                 map))))
-
-
-
 \f
 ;;; Protocol implementation (Requests, notifications, etc)
 ;;;
@@ -1075,18 +1037,16 @@ function with the server still running."
       (with-current-buffer buffer
         (cl-loop
          for diag-spec across diagnostics
-         collect (cl-destructuring-bind (&key range ((:severity sev)) _group
+         collect (cl-destructuring-bind (&key range severity _group
                                               _code source message)
                      diag-spec
-                   (setq message (concat source ": " message))
                    (pcase-let ((`(,beg . ,end) (eglot--range-region range)))
-                     (eglot--make-diag (current-buffer) beg end
-                                       (cond ((<= sev 1) ':error)
-                                             ((= sev 2)  ':warning)
-                                             (t          ':note))
-                                       message (cons
-                                                `(eglot-lsp-diag . ,diag-spec)
-                                                (eglot--overlay-diag-props)))))
+                     (flymake-make-diagnostic (current-buffer)
+                                              beg end
+                                              (cond ((<= severity 1) :error)
+                                                    ((= severity 2)  :warning)
+                                                    (t               :note))
+                                              (concat source ": " message))))
          into diags
          finally (cond (eglot--current-flymake-report-fn
                         (funcall eglot--current-flymake-report-fn diags)
@@ -1568,44 +1528,6 @@ If SKIP-SIGNATURE, don't try to send textDocument/signatureHelp."
                                           :newName ,newname))
    current-prefix-arg))
 
-
-(defun eglot-get-code-actions (&optional beg end)
-  "Get code actions between BEG and END."
-  (interactive
-   (let (diags)
-     (cond ((region-active-p) (list (region-beginning) (region-end)))
-           ((setq diags (flymake-diagnostics (point)))
-            (list (cl-reduce #'min (mapcar #'flymake-diagnostic-beg diags))
-                  (cl-reduce #'max (mapcar #'flymake-diagnostic-end diags))))
-           (t (list (point-min) (point-max))))))
-  (let* ((actions (eglot--request
-                   (eglot--current-server-or-lose)
-                   :textDocument/codeAction
-                   (list :textDocument (eglot--TextDocumentIdentifier)
-                         :range (list :start (eglot--pos-to-lsp-position beg)
-                                      :end (eglot--pos-to-lsp-position end))
-                         :context
-                         `(:diagnostics
-                           [,@(mapcar (lambda (diag)
-                                        (cdr (assoc 'eglot-lsp-diag
-                                                    (eglot--diag-props diag))))
-                                      (cl-remove-if-not
-                                       (lambda (diag) (cl-typep diag 'eglot--diag))
-                                       (flymake-diagnostics beg end)))]))))
-         (menu (let ((map (make-sparse-keymap)))
-                 (mapc (eglot--lambda (&key title command _arguments)
-                         (define-key map (vector (intern command))
-                           `(,title dummy)))
-                       actions)
-                 (setq map `(keymap "Code actions here:" ,@(cdr map)))))
-         (command-sym  (car
-                        (if (listp last-nonmenu-event)
-                            (x-popup-menu last-nonmenu-event menu)
-                          (tmm-prompt menu))))
-
-         )
-    (message "would be applying %S" command-sym)))
-
 \f
 ;;; Dynamic registration
 ;;;
@@ -1679,9 +1601,7 @@ If SKIP-SIGNATURE, don't try to send textDocument/signatureHelp."
   (let* ((root (car (project-roots (eglot--project server))))
          (cache (expand-file-name ".cquery_cached_index/" root)))
     (list :cacheDirectory (file-name-as-directory cache)
-          :progressReportFrequencyMs -1
-          :discoverSystemIncludes :json-false
-          :enableIndexOnDidChange t)))
+          :progressReportFrequencyMs -1)))
 
 (cl-defmethod eglot-handle-notification
   ((_server eglot-cquery) (_method (eql :$cquery/progress))