无法使用 org-link-open-from-string 打开链接,因为 (file-name-directory (buffer-file-name)) 似乎返回 nil

问题描述

我已经遇到这个问题很长时间了(这让我很难知道最初是什么原因造成的),但直到现在我都可以忽略它,但是如果现在我的工作流程会简单得多我可以解决这个问题。

很长一段时间我注意到,如果我在议程的标题上调用 org-open-at-point (Cc Co),在选择我希望打开的链接后,它会因为错误的类型参数而失败,我最近发现这不是我想象的议程问题,但实际上每当我在标题上调用此函数时,甚至直接在 org 文件中都会发生。

但是,如果我直接在链接上调用该函数,即使是标题中包含的链接,它也会按预期工作(尽管直接在属性抽屉中包含的链接上调用时不会)。

到目前为止,我已经将范围缩小到这样一个事实,即当在标题上调用时,org-open-at-point 调用 org-link-open-from-string,直接调用时似乎不是这种情况在一个链接上。大概是将我从提示中选择的链接作为字符串提供给此函数,而直接在链接本身上调用时不需要那种繁琐。 (虽然我不明白为什么直接在属性抽屉中的链接上调用时仍然会出现此错误)。

这里是 emacs-lisp 调试器的输出,稍微清理了一下,以提高可读性。我唯一能想到的是 org-mode-hook 中的某些东西正在做一些奇怪的事情?

(wrong-type-argument stringp nil)
  file-name-directory(nil)
  (string-match-p (concat (getenv "DATA_DIR") "/Notes") (file-name-directory (buffer-file-name)))
  (if (string-match-p (concat (getenv "DATA_DIR") "/Notes") (file-name-directory (buffer-file-name))) (howm-mode))
  (lambda nil (if (string-match-p (concat (getenv "DATA_DIR") "/Notes") (file-name-directory (buffer-file-name))) (howm-mode)))()
  run-hooks(change-major-mode-after-body-hook text-mode-hook outline-mode-hook org-mode-hook)
  apply(run-hooks (change-major-mode-after-body-hook text-mode-hook outline-mode-hook org-mode-hook))
  run-mode-hooks(org-mode-hook)
  org-mode()
  org-link-open-from-string("[[pdftools:/data/Reading.bib]]")
  eval((org-link-open-from-string "[[pdftools:/data/Reading.bib]]") t)
  eval-expression((org-link-open-from-string "[[pdftools:/data/Reading.bib]]") nil nil 127)
  funcall-interactively(eval-expression (org-link-open-from-string "[[pdftools:/data/Reading.bib]]") nil nil 127)
  call-interactively(eval-expression nil nil)
  command-execute(eval-expression)

我真的被这里的人难住了,在这上面花了几个小时,在过去的几个月里偶尔也会“谷歌搜索”。我发现的其他人似乎没有类似的问题。

请忽略我在此处调用非 PDF 的 pdftools 链接这一事实,这与它无关,无论链接的格式如何,该问题都是可复制的,并且不是排他性的pdftools 链接或不匹配的文件链接类型或类似的东西。

是什么导致了这个问题?我在这上面花了几十个小时,但无济于事。老实说,我对 Emacs 中的调试器还是个新手。

更新:像这样放下我的想法让我意识到由于我添加的这个钩子而调用了对 (buffer-file-name) 的冒犯性调用

(add-hook 'org-mode-hook '(lambda ()
    (if (string-match-p (concat (getenv "DATA_DIR") "/Notes") (file-name-directory (buffer-file-name)))
    (howm-mode))))

我仍然不知道缓冲区文件名为零的原因是什么,但是删除这段代码确实解决了当前的问题。

现在我想我仍然需要回答的问题是,为什么?是否有可能在值实际上为零时调用此函数,即没有缓冲区?我一直认为总会有一个缓冲区。这个钩子对我的工作流程也很重要。

另一个更新:刚刚意识到我可以使用条件来解决这个问题:

(add-hook 'org-mode-hook '(lambda ()
    (if
      (string-match-p (concat (getenv "DATA_DIR") "/Notes") (if
        (buffer-file-name) (file-name-directory (buffer-file-name)) (message "No buffer file name.")))
(howm-mode))))

(是的,我意识到这确实效率低下且功能不佳,我稍后会清理它;)

但是,如果有人对缓冲区文件名到底是如何为零有一个解释,我很想知道,因为我仍在慢慢地学习 Emacs 的内部结构。

又一次编辑:很明显,现在我已经想到了,但即使我怀疑一个缓冲区总是在缓冲区中,但并非所有缓冲区都有关联的文件也是如此。因此为零值。为什么我在调用 org-hooks 的那一刻最终在一个非文件缓冲区中,我不是 100% 确定。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)