栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何在主模式钩子中访问目录局部变量?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何在主模式钩子中访问目录局部变量?

这是因为

normal-mode
调用
(set-auto-mode)
(hack-local-variables)
按顺序。

但是

hack-local-variables-hook
在处理局部变量之后运行,这将启用一些解决方案:

  1. 首先是让Emacs为每种主要模式运行一个新的“局部变量钩子”:

    (add-hook 'hack-local-variables-hook 'run-local-vars-mode-hook)

    (defun run-local-vars-mode-hook ()
    “Run a hook for the major-mode after the local variables have been processed.”
    (run-hooks (intern (concat (symbol-name major-mode) “-local-vars-hook”))))

    (add-hook ‘python-mode-local-vars-hook ‘cr/python-mode-shell-setup)

(使用该方法,可以原样使用您的原始功能。)

  1. 第二种选择是利用可选

    LOCAL
    参数
    add-hook
    ,使指定函数在本地缓冲区中。使用这种方法,您可以如下所述编写钩子:

    (add-hook 'python-mode-hook 'cr/python-mode-shell-setup)

    (defun cr/python-mode-shell-setup ()
    (add-hook ‘hack-local-variables-hook
    (lambda () (message “virtualenv-name is %s” cr/virtualenv-name)
    (let ((python-base (cr/virtualenv)))
    (cond ((and (fboundp ‘ipython-shell-hook) (file-executable-p (concat python-base “/bin/ipython”)))
    (setq python-python-command (concat python-base “/bin/ipython”))
    (setq py-python-command (concat python-base “/bin/ipython”))
    (setq py-python-command-args ‘( “-colors” “NoColor”)))
    (t
    (setq python-python-command (concat python-base “/bin/python”))
    (setq py-python-command (concat python-base “/bin/python”))
    (setq py-python-command-args nil)))))
    nil t)) ; buffer-local hack-local-variables-hook

python-mode-hook
先运行,然后
hack-local-variables-hook
仅针对当前缓冲区注册匿名函数;然后在处理完局部变量后调用该函数。

  1. Lindydancer的评论提出了第三种方法。它不像其他两个那么干净,但是无论如何都证明很有趣。我不喜欢引起
    (hack-local-variables)
    两次调用的想法,但是我看到如果在
    local-enable-local-variables
    本地设置缓冲区,它将阻止
    (hack-local-variables)
    执行任何操作,因此 可以 执行以下操作:
    (defun cr/python-mode-shell-setup ()

    (report-errors “File local-variables error: %s”
    (hack-local-variables)))
    (set (make-local-variable ‘local-enable-local-variables) nil)
    (let ((python-base (cr/virtualenv)))
    …))

显然,这会稍微修改正常的执行顺序,因此可能会产生副作用。我担心如果文件中的局部变量 注释
设置了相同的主要模式,则可能会导致无限递归,但这实际上似乎不是问题。

局部变量标头注释(例如

-*- mode: foo -*-
)由处理
(set-auto-mode)
,因此可以;但是
mode: foo
LocalVariables:
注释似乎是由处理的
(hack-local-variables)
,这将是一个问题,因此,如果以这种方式设置模式,我认为它将导致递归。

在实践中,我可以通过使用一个简单的函数作为“模式”来触发问题,该函数只是尝试运行其钩子而已。但是,以“适当”模式进行测试不会出现问题,因此实际上可能是安全的。我没有对此做进一步的研究(因为其他两个解决方案都比这更清洁),但是我想延迟模式钩子机制可能解释了这一点?



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/651417.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号