如何为C ++创建EDE项目

时间:2012-02-21 12:46:24

标签: c++ emacs cedet emacs-semantic

我一直在尝试为C ++建立一个EDE项目(emacs24 +内置CEDET),我开始变得绝望,因为我似乎无法找到我希望生成makefile的方式。我对Emacs比较陌生。 我会试着描述一下我在做什么:

我有一个像这样的玩具项目:

main.cpp
other/
  Utils.cpp 
  Utils.h
  CGrabBuffer.cpp
  CGrabBuffer.h

main.cpp在“other /”目录中包含.h。这些是我通过这个简单的目录设置来设置EDE项目的步骤:

  • 在emacs中打开main.cpp并执行M-x ede-new;输入:Make;名称:main-proj
  • 打开“其他”目录中的一个文件并执行M-x ede-new;输入:Make;名称:aux-proj
  • 现在是时候创建目标了(我相信在这种情况下是三个):
    • 在main.cpp缓冲区:M-x ede-new-target;名称:main;输入:program。出现提示时,我将main.cpp添加到此目标。
    • 我对其他两个目标(Utils具有Utils.cpp和Utils.h以及具有CGrabBuffer.cpp和CGrabBuffer.h的CGrabBuffer)重复相同的操作。在这里,我发现了第一个问题。这两个目标必须是什么类型的?我只希望他们生成.o文件。
  • 完成此操作后,我将M-x ede-customize-current-target键入所有三个目标,然后添加一些包含路径,一些库等。
  • 在此之后,如果我调用M-x ede-compile-project它不会编译,因为:
    • 它首先尝试编译main.cpp;在尝试构建main.cpp之前,我不知道如何指定(使用EDE)需要Utils.o和CGrabBuffer.o。
    • 如果我手动更改顺序(编辑Makefile),则无法链接main.cpp,因为它找不到Utils.o和CGrabBuffer.o。

正如你所看到的,我正处于一团糟之中。也许我甚至不理解EDE中“目标”的含义。我还读到了ede-cpp-root-project的存在,它必须在.emacs文件中指定。我没有尝试过,因为我认为它只是帮助语义。它不会生成Makefile,是吗?我是否可以(或者我需要)使用Project.el构建的EDE项目和使用ede-cpp-root-project进行语义相同的事情?或者它是多余的?

抱歉,如果我误解了很多东西,但我很困惑,对emacs不熟悉会让事情变得更糟。谢谢你的耐心等待!

编辑:有一些修补和我收到的回复我已经能够弄清楚很多东西,所以非常感谢。我还不明白的是使用ede-cpp-root-project,它必须在.emacs文件中指定。它只是用于c ++语义吗?使用Project.el的项目和.emacs中的elisp行吗?

是多余的

2 个答案:

答案 0 :(得分:7)

EDE旨在处理许多不同类型的项目,通常是在其他工具中使用Emacs编写构建系统的类型。

为您创建Makefile的EDE项目类型可以做很多事情,但是您需要对构建系统有一些基本的了解才能使它有用,而且您确实需要自定义项目以获得任何内容复杂性工作。

我最近在EDE手册中添加了一个部分,以帮助自动生成Automake文件的基本项目设置。你可以在这里查看教程:

http://www.randomsample.de/cedetdocs/ede/ede/Quick-Start.html

相同的步骤将适用于仅使用Make的项目,但由于额外的复杂性,基于Make的项目通常会遇到共享库的问题。

迈克的回答非常好,但我认为只需将.h文件添加到与.cpp来源相同的目标即可。它将分别跟踪它们。

另一个有用的技巧是使用整个项目编译键击(C-c.C),每当你改变一些大的东西时它使用大写C.这将重新生成Makefile,重新运行任何所需的Automake功能,并从顶部开始。

编辑:您只需要一个项目区域的EDE项目。当没有其他自动项目类型工作时,ede-cpp-root项目很有用。当你在.emacs文件中创建它时,这样需要项目定义的其他工具,如语义的智能完成和标记查找,都可以工作。

答案 1 :(得分:3)

嗯,我想我实际上已经弄清楚了这一次,但这很难看。 Utils.cppCGrabBuffer.cpp不应该获得自己的目标,因为似乎没有合适的目标类型。相反,您需要创建一个存档或库,它将自动为您编译Utils.cppCGrabBuffer.cpp。下面,我假设你想要静态,但它很容易改变。

[对于档案馆或图书馆不熟悉的人,他们基本上只是将.o个文件收集到一个单独的单元中。它实际上并没有使编译更难。阅读更多here。]

1)按照上面的前两个步骤(包括制作main目标,而不是其他目标。)

2)切换到Utils.cpp并执行M-x ede-new-target;名称:aux;输入:archive。出现提示时,将Utils.cpp添加到此目标。

3)切换到CGrabBuffer.cpp并执行C-c . a;目标:aux

4)使用M-x ede-proj-regenerate重新生成Makefile。此时,如果您在make子目录中运行other,则应获取存档libaux.a

5)切换回main.cpp并执行M-x ede-customize-current-target。这将打开一个交互式emacs自定义缓冲区,允许您编辑ede配置的详细信息。在Ldflags部分下,点击[INS]。这会弹出一个新行Link Flag:,并有一些不同颜色的框供您输入(我的是灰色)。输入-Lother -laux,以便在编译other/libaux.a时包含main。然后,在缓冲区的顶部,按[Accept],这将保存该更改并切换回main.cpp。

6)使用M-x ede-proj-regenerate重新生成Makefile。

现在,不幸的是,Makefile首先生成main目标,然后进入other目录并进行生成。不幸的是,这意味着顶级目录中的make不能在干净的树上运行。我不知道为什么会这样,因为在任何用EDE制作的项目中,似乎永远不会是你想要的。除了这个黑客之外,我找不到任何改变方法:

7)做M-x customize-project;在Inference-Rules点击[INS]下。然后输入Target:all;依赖关系:aux main;规则:[INS];字符串@:。 (最后一个只是为了防止带有选项卡的空规则出错;可能是EDE错误。)单击[Accept],然后重新生成Makefile。

现在,在您的顶级目录中,您可以运行make,main应该是一个可用的可执行文件。

我很快就确信EDE还没有准备好被其作者以外的人使用。尽管它的大小和他们已经明确投入的努力量,它太过马车,太违反直觉,而且不够聪明。真是太遗憾了。 Emacs需要这样的东西。