gpt4 book ai didi

c++ - 跨目录头文件的 Emacs-24 自动完成

转载 作者:太空宇宙 更新时间:2023-11-04 13:49:05 26 4
gpt4 key购买 nike

自动完成 不适用于具有多个模块的 Emacs C++ 项目。每个子模块所依赖的头文件既存在于模块本身,也存在于其他模块中。换句话说,一个模块可以包括另一个模块的头文件。

下面是我的示例源代码:

.
├── CMakeLists.txt
├── my_inc
│   ├── CMakeLists.txt
│   ├── myadd.cpp
│   └── myadd.h
├── README.md
└── src
├── CMakeLists.txt
├── Hello.java
├── helper.cpp
├── helper.h
└── main.cpp

main.cpp:

#include "myadd.h"
#include "helper.h"
int main() {
MyAdd add_obj;
Helper h;
h.toString(); // Auto-complete works since Helper is in the same directory.
add_obj. // Auto-complete for add_obj does not work
// because myadd.h is in another directory (my_inc).
}

当我在 h 之后键入 . 时,方法列表会弹出,但对于变量 add_obj 则不会,它的类定义在来自其他模块 my_incmyadd.h


我已经尝试了一些解决方案(与 CEDET 相关):

  • (ede-cpp-root-project)

    此解决方案在这里确实有效。我不想申请这个,因为

    1. 它会使我的 .emacs 变大,因为我有很多项目。

    2. :include-path 这里无法处理 20 多个子模块的复杂头依赖,这使得这个解决方案更像玩具。我更喜欢将配置与 .emacs 分开。

  • EDE项目

    我通过 ede-new 和 c c 创建项目和目标。 t,但这仅用于编译而不是名称,方法自动完成。

  • ede-generic-project

    this question 的解决方案中所述和 manual on ede-generic-project但我收到此错误:

    eieio-oref: Wrong type argument: (or eieio-object-p class-p), nil

    一旦我执行:

    M-x ede-customize-project RET(ede-enable-generic-projects) 之后。


环境:我使用 Emacs 24.3 并安装了 auto-completecedet2.0

最佳答案

处理涉及项目、头文件和完成的问题时,第一步是启用(global-semantic-decoration-mode 1),其中包括一种机制,可以在可以时以红色突出显示头文件找到了。这有助于快速解决配置问题。

如果您想保持您的 .emacs 文件干净并获得一些项目支持,那么通用项目类型是一个不错的选择,直到该错误开始出现为止。在撰写本文时(2014 年 7 月 14 日),该问题已在 ede-ldf 分支下的 CEDET bzr 存储库中修复,并将很快合并。

如果你有很多子模块,你也可以依赖像 GNU Global 这样的工具。 cedet 手册有一个关于使用 GNU Global 的简短部分,其中包含帮助它定位文件所需的片段。这样,Global 将跟踪您的所有 header ,然后可用于查找它们。如果您所有的 header 都有一个唯一的名称,那么您就万事大吉了。如果文件“myadd.h”存在于多个地方,并且您需要根据 C 文件所在的位置选择哪个“myadd.h”,那么您将不走运,并且需要自定义项目类型来执行此操作。

每次配置更改后,您都需要使用要找到的 header 对缓冲区进行强制重新解析,以便刷新缓存。使用 C-u M-x bovinate RET 强制执行。

关于c++ - 跨目录头文件的 Emacs-24 自动完成,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24292833/

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