通用代码完成库/工具
Posted
技术标签:
【中文标题】通用代码完成库/工具【英文标题】:Generic code completion library/tool 【发布时间】:2012-09-01 19:56:50 【问题描述】:我正在尝试在我最喜欢的编辑器中设置正确的代码完成,我们称之为 AnEditor 以避免互联网上充斥着特定于程序的答案。 (而且语言是语言,你知道。)编辑器有两个我喜欢它的特性:它在控制台和 GUI 中工作得一样好,所以我可以通过网络使用它,而且它具有很大的可扩展性。所以我不愿意使用成熟的 IDE。但是编辑器没有可靠的代码完成功能,但如果我找到合适的解决方案可以插入它。
我已经在 Google 上搜索了一大堆关于“[editor/IDE Y] 中的“[language X] 补全”的问题和解决方案。似乎每个新的 IDE 都在从头开始为每种语言实现其代码完成,解析器等等。每个更简单的编辑器(包括 AnEditor)都会执行以下操作之一:
仅完成标准库函数名称, 或使用 ctags,它提供基于正则表达式的延迟“解析”(用于非 C 程序),并且不应该告诉您刚才输入的变量的类型,因此对于真正的代码完成不是很有用, 如果编辑器可以通过插件进行扩展,还有其他方法,但它们通常归结为上述或多或少的变态组合,以及大量自定义正则表达式。现在的问题是,为什么我们不能有一个健全的代码完成库,我可以将其插入 AnEditor 并让其他人插入 ABigIDE?据我所知(解密 C 指针丛林不是我的目标),答案应该是这样的:
yacc/lex/bison 风格的通用解析器(或静态分析器),以某种方式放松以容忍编写过程中的代码,能够理解 JavaDoc 风格的 cmets。而且速度快,最好是这样,它可以在飞行中使用 一个索引,可以告诉类的成员、方法的签名及其在文件中的位置(ctags 现在这样做)、返回值和来自 JavaDoc cmets 的其他文档 另一个知道变量类型的索引,以及一个根据当前正在编写的文件或代码中的位置告知类型的函数因此,要完成某些语言工作,您需要为该语言制定解析器规则,在标准库和您的项目上建立索引,调用类型识别函数并查找类的成员和文档。或者,如果您正在处理对象构造或静态调用,则只需列出类和成员。
如果 Eclipse、Netbeans 和 JetBrains 已经在 Java 中成功地做到了(所以我应该 plug Eclipse to AnEditor),为什么没有人能以一种不那么臃肿和更通用的方式来做呢?还是我错过了什么,未来已经潜伏在某个地方?
【问题讨论】:
您可能想查看ctags
。例如,请参阅Autocomplete libraries for Java, C, php?、Is there an alternative to ctags that works better?、How does Geany auto-completion work?、Autocompletion in Vim 和朋友。
【参考方案1】:
所以:到目前为止,几乎所有人都解决了这个确切的问题。 ‘Language servers’ provide a protocol to plug language-specific semantics-aware completion and other features to different editors and IDEs.
值得注意的是,“语言服务器”往往是用它们解析的相同语言开发的。在 Python 等速度较慢的语言中,这可能是一个值得怀疑的决定。
对于某些语言,类似的解决方案在一段时间内可用,独立于语言服务器 - 例如。 Tern for JS、Scion 和 ghc-mod 用于 Haskell 等。这些往往主要服务于 Emacs 和 Vim。可以预见,这样的解决方案主要出现在非主流语言上,就像所有编译成 JS 的语言一样——它们的出现似乎比为每个编辑器/IDE 开发单独的插件更快。
【讨论】:
以上是关于通用代码完成库/工具的主要内容,如果未能解决你的问题,请参考以下文章