How to debug and fix emacs progn: WakaTime Error (2)

Error message

The emacs plugin wakatime shows the following error message when save file each time.

error in process sentinel: progn: WakaTime Error (2)
error in process sentinel: WakaTime Error (2)
error in process sentinel: progn: WakaTime Error (2)
error in process sentinel: WakaTime Error (2)

Debug

Turn on the debug

M-x toggle-debug-on-error

The *backtrace* content

Debugger entered--Lisp error: (error "WakaTime Error (2)")
  signal(error ("WakaTime Error (2)"))
  error("WakaTime Error (%s)" 2)
  (progn (error "WakaTime Error (%s)" exit-status))
  (if (and (not (= 0 exit-status)) (not (= 102 exit-status))) (progn (error "WakaTime Error (%s)" exit-status)))
  (when (and (not (= 0 exit-status)) (not (= 102 exit-status))) (error "WakaTime Error (%s)" exit-status))
  (let ((exit-status (process-exit-status process))) (when (and (not (= 0 exit-status)) (not (= 102 exit-status))) (error "WakaTime Error (%s)" exit-status)) (when (= 102 exit-status) (if nil (error "WakaTime Error (%s)" exit-status) (wakatime-prompt-api-key) (wakatime-call nil t))))
  (progn (kill-buffer (process-buffer process)) (let ((exit-status (process-exit-status process))) (when (and (not (= 0 exit-status)) (not (= 102 exit-status))) (error "WakaTime Error (%s)" exit-status)) (when (= 102 exit-status) (if nil (error "WakaTime Error (%s)" exit-status) (wakatime-prompt-api-key) (wakatime-call nil t)))))
  (if (memq (process-status process) (quote (exit signal))) (progn (kill-buffer (process-buffer process)) (let ((exit-status (process-exit-status process))) (when (and (not (= 0 exit-status)) (not (= 102 exit-status))) (error "WakaTime Error (%s)" exit-status)) (when (= 102 exit-status) (if nil (error "WakaTime Error (%s)" exit-status) (wakatime-prompt-api-key) (wakatime-call nil t))))))
  (when (memq (process-status process) (quote (exit signal))) (kill-buffer (process-buffer process)) (let ((exit-status (process-exit-status process))) (when (and (not (= 0 exit-status)) (not (= 102 exit-status))) (error "WakaTime Error (%s)" exit-status)) (when (= 102 exit-status) (if nil (error "WakaTime Error (%s)" exit-status) (wakatime-prompt-api-key) (wakatime-call nil t)))))
  (lambda (process signal) (when (memq (process-status process) (quote (exit signal))) (kill-buffer (process-buffer process)) (let ((exit-status (process-exit-status process))) (when (and (not (= 0 exit-status)) (not (= 102 exit-status))) (error "WakaTime Error (%s)" exit-status)) (when (= 102 exit-status) (if nil (error "WakaTime Error (%s)" exit-status) (wakatime-prompt-api-key) (wakatime-call nil t))))))(#<process Shell> "exited abnormally with code 2\n")

Go to the wakatime source file wakatime-mode.el, and find the position which the error happen.

(defun wakatime-call (command)
  "Call WakaTime COMMAND."
  (let*
    (
      (process-environment (if wakatime-python-path
                               (cons (format "PYTHONPATH=%s" wakatime-python-path) process-environment)
                             process-environment))
      (process
        (start-process
          "Shell"
          (generate-new-buffer " *WakaTime messages*")
          shell-file-name
          shell-command-switch
          command
        )
      )
    )

    (set-process-sentinel process
      (lambda (process signal)
        (when (memq (process-status process) '(exit signal))
          (kill-buffer (process-buffer process))
          (let ((exit-status (process-exit-status process)))
            (when (and (not (= 0 exit-status)) (not (= 102 exit-status)))
              (error "WakaTime Error (%s)" exit-status)
            )
          )
        )
      )
    )

    (set-process-query-on-exit-flag process nil)
  )
)

Find the origin wakatime-call function caller

(defun wakatime-save ()
  "Send save notice to WakaTime."
  (when (buffer-file-name (current-buffer))
    (wakatime-call (wakatime-client-command t))))

Execute (wakatime-client-command t) in *ielm* (M-x ielm)

ELISP> (wakatime-client-command t)
"/usr/bin/python2 /usr/local/bin/wakatime --file \"nil\" --write --plugin emacs-wakatime/1.0.2 --key e191899f-9e2a-4d00-8100-4e9f9523fedb --time 1476063658.33"

Here, we find that wakatime plugin executes a command in subprocess. So, we can execute in terminal manually:

➜  ~ /usr/bin/python2 /usr/local/bin/wakatime --file \"nil\" --write --plugin emacs-wakatime/1.0.2 --key e191899f-9e2a-4d00-8100-4e9f9523fedb --time 1476063658.33
Error: Could not read from config file /home/aborn/.wakatime.cfg

Solution

The really reason is Could not read from config file /home/aborn/.wakatime.cfg. Then we manually create the file /home/aborn/.wakatime.cfg with its content:

[settings]
api_key = e191899f-9e2a-4d00-8100-4e9f9523fedb

Note: pls replace api_key with your wakatime api_key.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,828评论 19 139
  • 夏屿先生阅读 1,607评论 0 2
  • 这座城市很小,我们不断的遇见别人,也被别人遇见。 一 曾经以为费力的在人生这张白纸上描绘的人和事,都会在心中留下一...
    柚子幺幺阅读 2,801评论 1 0
  • 1:感恩我学习了种子智慧,处处种下感恩的种 子! 2:感恩老师组织的抱团学习让我每天,看到群里家人们积极点参加,触...
    卡娃拉阅读 2,463评论 0 0
  • 本篇文章已授权微信公众号 dasu_Android(大苏)独家发布 老规矩,看效果 介绍 Gank平台的移动端又来...
    请叫我大苏阅读 8,340评论 11 41

友情链接更多精彩内容