跨平台IDE集成开发环境Clion教程:管理Makefile项目

翻译|使用教程|编辑:吴园园|2019-08-19 17:27:30.300|阅读 58 次

概述:CLion是一款专为开发C及C++所设计的跨平台IDE。本篇教程将为您介绍如何管理Makefile项目。

相关链接:

CLion是一款专为开发C及C++所设计的跨平台IDE。它是以IntelliJ为基础设计的,包含了许多智能功能来提高开发人员的生产力。这种强大的IDE帮助开发人员在Linux、OS X和Windows上来开发C/C++,同时它还使用智能编辑器来提高代码质量、自动代码重构并且深度整合CMake编译系统,从而提高开发人员的工作效率。

点击下载CLion最新试用版

虽然目前在Clion中不支持Makefile作为项目格式,但您可以使用以下解决方法在File Watchers和编译数据库的帮助下管理Makefile项目。

下面的示例显示了如何构建监视Makefile中的更改的元构建系统,然后相应地重新生成和重新加载编译数据库。这样,它允许您从CLion内部完全管理Makefile项目。此外,您可以借助自定义生成目标和自定义运行/调试配置来构建和运行/调试此类项目。

假设我们有一个简单的Makefile项目,包含三个模块,general,io_lib和math_lib,每个模块都存储在一个包含Makefile的单独目录中,在根目录中,是构建所有目标的主Makefile:

TARGETS = Math Io Generalall: $(TARGETS)Math:
    @$(MAKE) -C math_lib    -f MakefileIo:
    @$(MAKE) -C io_lib      -f MakefileGeneral:
    @$(MAKE) -C general     -f Makefileclean:
    @$(MAKE) -C io_lib      -f Makefile clean
    @$(MAKE) -C math_lib    -f Makefile clean
    @$(MAKE) -C general     -f Makefile clean

现在让我们采取以下步骤:

1.创建编译数据库

首先,我们需要为我们的测试项目创建一个JSON编译数据库。我们将用于此的工具是编译生成器。安装该工具后,我们可以compiledb make从项目根目录运行并获取compile_commands.json文件:

跨平台IDE集成开发环境Clion教程:管理Makefile项目

2.安装Makefile支持插件

这是一个可选步骤,但对我们的任务非常有帮助:安装了Makefile Support插件后 ,GNU Makefile文件类型在CLion中变得可识别,我们获得了Makefile的语法高亮和编辑功能。

3.在CLion 打开并配置编译数据库 

下一步是将我们在步骤1中创建的编译数据库打开为CLion中的项目。导入成功完成后,我们可以开始使用项目文件。

跨平台IDE集成开发环境Clion教程:管理Makefile项目

要在compile_command.json中的每次更改时自动重新加载项目,我们需要在Settings / Preferences |中设置Use auto-import复选框。 构建,执行,部署| 编译数据库:

跨平台IDE集成开发环境Clion教程:管理Makefile项目

4.为Makefile创建文件监视器

现在我们可以创建一个文件监视器来跟踪Makefile中的更改。让我们导航到设置/首选项| 工具| 文件监视器,创建一个新的文件监视器并将其分配给位于项目根目录和子目录中的GNU Makefile类型的所有文件(注意$ProjectFileDir$宏):

跨平台IDE集成开发环境Clion教程:管理Makefile项目

5.修改Makefile 

现在,让我们改变Makefiles中的内容。我们可以在IDE外部执行此操作(因为设置了Trigger,外部更改上的观察器复选框),或者直接来自CLion编辑器。

例如,我们可以向math_lib模块添加一个新的源文件,并将其放入相应Makefile中的源列表中:

跨平台IDE集成开发环境Clion教程:管理Makefile项目

在该更改之后,Makefile_watcher被触发运行 compiledb -n make。此命令在不执行实际构建的情况下重新生成编译数据库,CLion会自动重新加载它,以便项目与修改后的Makefile同步。

现在compile_commands.json中有四个条目:

跨平台IDE集成开发环境Clion教程:管理Makefile项目

同样,如果我们决定不将io_funcs库包含 到构建中,我们可以Io从主Makefile中删除目标:

为响应此更改,Makefile_watcher再次触发,并相应地重新加载编译数据库:

跨平台IDE集成开发环境Clion教程:管理Makefile项目

6.使文件监视器全局化

我们可能想要做的最后一件事是使Makefile_watcher全局化。启用此设置后,观察程序将在所有项目中可用,因此我们可以轻松地将其重用于我们在CLion中管理的其他Makefile应用程序:

跨平台IDE集成开发环境Clion教程:管理Makefile项目

这样,文件观察器和编译数据库的组合创建了一种机制,可以使用基于Make的项目,而无需让CLion编辑Makefile或手动重新创建编译数据库。此外,您可以将此方法应用于任何具有用于生成编译数据库的补充工具的构建系统。

请注意,目前,在此方案中,CLion会为触发文件监视器的Makefile中的每个更改重新加载整个编译数据库。因此,将此工作流应用于大型代码库时可能会遇到性能问题。


以上就是管理Makefile项目教程的全部内容,您学会了吗?欢迎评论分享您的疑问和看法~

想要购买Clion正版授权的朋友可以咨询慧都官方客服

更多精彩内容,敬请关注下方的微信公众号,及时获取产品最新资讯▼▼▼

图片2.jpg



标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处,尊重他人劳动成果

文章转载自:Clion https://www.jetbrains.com/help/clion/managing-makefile-projects.html

登录慧都网发表评论登录


暂无评论...

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
相关厂商
相关产品
CLion

CLion是一款专为开发C及C++所设计的跨平台IDE。

在线客服 在线QQ 电话咨询
400-700-1020
反馈
在线客服系统
live chat