From 0f5723f9ae5d7fe2a82ad45e4505710b6a13be41 Mon Sep 17 00:00:00 2001 From: Daniel Kraus Date: Fri, 27 Oct 2023 08:13:59 +0200 Subject: [PATCH] Font lock JSON messages in the lsp-log buffer (#4154) --- lsp-mode.el | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/lsp-mode.el b/lsp-mode.el index d2a4da70054..cf2d0e7ea60 100644 --- a/lsp-mode.el +++ b/lsp-mode.el @@ -3147,6 +3147,22 @@ TYPE can either be `incoming' or `outgoing'" :type type :body body)) +(defun lsp--log-font-lock-json (body) + "Font lock JSON BODY." + (with-temp-buffer + (insert body) + ;; We set the temp buffer file-name extension to .json and call `set-auto-mode' + ;; so the users configured json mode is used which could be + ;; `json-mode', `json-ts-mode', `jsonian-mode', etc. + (let ((buffer-file-name "lsp-log.json")) + (delay-mode-hooks + (set-auto-mode) + (if (fboundp 'font-lock-ensure) + (font-lock-ensure) + (with-no-warnings + (font-lock-fontify-buffer))))) + (buffer-string))) + (defun lsp--log-entry-pp (entry) (cl-assert (lsp--log-entry-p entry)) (pcase-let (((cl-struct lsp--log-entry timestamp method id type process-time @@ -3174,7 +3190,7 @@ TYPE can either be `incoming' or `outgoing'" (if (memq type '(incoming-resp ougoing-resp)) "Result: " "Params: ") - (json-encode body) + (lsp--log-font-lock-json (json-encode body)) "\n\n\n")) (setq str (propertize str 'mouse-face 'highlight 'read-only t)) (insert str)))