gpt4 book ai didi

php - Omnicompletion 停止提供有用的预测

转载 作者:可可西里 更新时间:2023-11-01 12:57:00 25 4
gpt4 key购买 nike

我正在尝试在 Ubuntu 12.04.1 (LTS) 上使用 ctags 5.9~svn20110310 在 vi​​m 7.3 中为 PHP 设置 omni 补全,但我遇到了一个非常奇怪的问题,补全为同一类的实例提供了完全不同的预测.

我有以下两个文件:

// Foo.php
class Foo {
public function do_stuff() {
echo 'Working...';
}
}

// index.php
require 'Foo.php';
$f = new Foo();
$f->[cursor position 1]

$g = new Foo();
$g->[cursor position 2]

当光标在位置 1 并且我按下 CTRL+X CTRL+O 它完成了符合我们预期的 do_stuff(。但是当我按下 CTRL+X CTRL+O 在第二个位置,我得到一个以 key, next, rewind 开头的预测列表。我做错了什么?

最佳答案

编辑:关于您的具体问题,如果您有旧版本的 phpcomplete.vim,您可能只能通过使用特殊的 phpdoc 标记来正确完成变量( see this question ) 或在声明变量后重新生成标签文件。

您很可能没有做错任何事; ctags 中的 PHP 支持非常基础而且不是很严格,不幸的是,这也意味着缺少 Vim 支持。快速查看 ctags 模块可以说明问题:

ctags/php.c

就是这样。只是几个相对基本的正则表达式。底部的解析器不再使用了,不幸的是已经很长时间没有使用了。

使问题复杂化的事实是,Vim 中 PHP 的标准 omnicomplete 函数充其量是骇人听闻的;只要说它涉及 在所有打开的窗口之间切换 作为其完成过程的一部分(这种做法被 Vim 文档明确谴责)就足够了。自己看看:

phpcomplete.vim/autoload/phpcomplete.vim

长期以来,我一直在与 Vim 中糟糕的 PHP 补全作斗争,并且确定只有彻底检修才能产生令人满意的结果。我已经加入了 ctags dev 邮件列表,并且我计划改进那里的 PHP 支持,然后再继续使 Vim 的 omnicompletion 尽可能地在解释语言中工作。不幸的是,目前解决方案是等到支持更好,或者自己修复。

关于php - Omnicompletion 停止提供有用的预测,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12582458/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com