相关文章推荐
威武的南瓜  ·  [Android]StateMachine介 ...·  5 月前    · 
威武的南瓜  ·  Top 5 typeorm Code ...·  11 月前    · 
爱看球的牙膏  ·  IDEA ...·  43 秒前    · 
帅气的红茶  ·  清华大学出版社·  2 小时前    · 
阳刚的凉面  ·  Python Web ...·  2 小时前    · 
傻傻的馒头  ·  利用Pycharm + ...·  2 小时前    · 

我们的实现方法

不久前,我们 介绍了我们的发现 以及在 CLion 中支持 Makefile 项目的方法。
在那篇博客中,我们概述了各种现代 C++ IDE 和编辑器首选处理 Makefile 的方法:
编译包装器用于包装实际的编译器调用,然后执行完整的构建并提取项目信息。
在执行任何构建过程之前,将使用 LD_PRELOAD 环境变量并加载特定的动态库,以拦截编译器调用并收集项目信息。
解析 make 命令的输出,通常与 --just-print 选项一起使用以避免实际构建。
第三个选项提供了几个非常重要的好处:
它不会影响构建过程。
与完整的项目构建相比,它使我们可以更快地收集信息。
这将是一个“便携式”选项,因为 IDE 理论上可以从记录在另一台计算机上的 Make 输出开始。
因此,我们采用了第三种方法并实现了原型设计。我们已经与一系列项目中进行了测试,您可以在我们的 Confluence 页面 上找到项目列表。我们希望它也能与其他各种项目应用。 现在轮到您尝试一下使用您的 Makefile 项目并与我们分享反馈!

如何在 CLion 中开始使用 Makefile 项目

要在 CLion 中打开 Makefile 项目:
在项目中选择文件 | 打开(File | Open)。
您可以将文件夹作为项目打开,CLion 将搜索顶级 Makefile (以及 CMakeList.txt compile_commands.json 文件)并建议将其作为项目打开。
或者在 Open 对话框中直接将 CLion 指向 Makefile
CLion 可能会要求您清理项目。
这是必需的,因为 Make 构建是增量的,在未清理的项目上运行时,只会编译更新的文件,因此重新加载项目将无法正常进行并会丢失所有未更改的文件。
CLion 现在将尝试加载项目。
成功加载项目后,您可以在 CLion 中开始使用它,并从其提供的所有智能 IDE 功能中受益。
如果默认设置不适合您,您可以调整一些重要设置。
转到设置/偏好 | 构建、执行、部署 | Makefile 设置 ( Settings/Preferences | Build, Execution, Deployment | Makefile settings):
在这里您可以更改:
用于加载 Makefile 项目的 工具链
支持所有 本地 工具链(Clang、GCC、MinGW、Cygwin、WSL)。
Visual Studio 工具链依赖于 NMake,当前不支持该工具,但是如果您使用 GNU Make 构建项目,将可以在 CLion 中使用。
远程模式尚未包括在内。
用于在 CLion 中调用 make 命令以提取项目信息的 参数
在 CLion 中与 make 命令一起使用 Build Clean Make 目标以提取项目信息。
对于 Build,空字段表示 CLion 将采用项目的 Makefile 中指定的第一个目标。
以下是在 CLion 中使用 Makefile 项目的一些最终技巧:
提示 1 :CLion 在您的 Makefile 项目中搜索目标,以便您可以立即在运行/调试配置中开始使用它们:

并且如果CLion无法找到您的 Make 目标,则可以创建 Make 类型的自定义构建目标并在配置中使用它:

提示 2 :支持源外版本,但您可能需要在项目加载后调用工具| Makefile |更改项目根目录 (Tools | Makefile | Change Project Root),以在项目视图中更好地显示您的源。
提示 3 :目前,CLion 不会在文件更改(例如添加新文件)时自动更新或重新加载项目。
更新后,Makefile 上的通知将出现,这样您就不会忘记重新加载项目。但是,如果您的项目使用了配置步骤,请不要忘记先调用它以更新 Makefile 并获取通知。

如果出现问题而项目无法正确加载,该怎么办?

我们已经与一系列项目中进行了测试,您可以在 我们的 Confluence 页面 上找到项目列表。我们希望它在包括您在内的许多其他项目应用。但是,如果遇到任何问题,请采取以下行动:
在设置/偏好 | 构建、执行、部署 | Makefile 设置 ( Settings/Preferences | Build, Execution, Deployment | Makefile settings)中检查您正在使用的 工具链
您应该能够在所选环境中构建项目。
在设置/偏好 | 构建、执行、部署 | Makefile 设置 ( Settings/Preferences | Build, Execution, Deployment | Makefile settings)中检查重新加载参数和构建目标。
大多数成功运行的项目都可以使用默认参数,但您可能需要在这种情况下进行一些更改。
尝试工具 | Makefile | 清理并重新加载 Makefile 项目(Tools | Makefile | Clean and Reload Makefile Project)。
如果上述步骤无济于事,请尝试从 系统目录 中的 /makefiles 中清理项目。
例如,我的 macOS 上的 postgres 项目可以在 ~/Library/Caches/JetBrains/CLion2020.2/makefiles/postgres.dc29ef09 中找到。
清理后请重新加载项目。
最后,如果以上所有提示对您都不起作用,请转到帮助 | 诊断工具 | 调试日志设置…(Help | Diagnostic Tools | Debug Log Settings… ),并通过添加 com.jetbrains.cidr.cpp.makefile 来打开调试日志,
然后重现问题并将日志提交给我们的跟踪器或支持。

已知问题和局限性

使用的算法中最脆弱的部分是从 make 命令的输出中提取编译命令。
我们发现某些情况下会发生问题:
项目禁止打印目录。
因此,该算法无法正确检测正在构建的源文件。
编译器未知,或者无法正确提取编译标志。
诸如 libtool 之类的各种包装器都会通过隐藏编译标志并干扰 Make 的输出( CPP-19549 CPP-19305 )而产生更多问题。
我们采用了几种启发法来克服测试项目中遇到的情况。
用户还可以在提取项目信息时控制用于调用 make 命令的参数:设置/偏好 | 构建、执行、部署 | Makefile | 参数(Settings/Preferences | Build, Execution, Deployment | Makefile | Arguments)。
接下来可以期待什么?
Makefile 支持插件 :该插件提供代码高亮显示功能以及对构建 make 项目的一些支持。
计划是重新设计并将其捆绑到 CLion( CPP-16933 )中。
稍后将为 Makefile 项目启用单元测试集成( CPP-20718 )。
添加将 Makefile 链接到现有项目的功能( CPP-20733 )。
更改工具链或影响项目加载的其他设置应触发重新加载( CPP-18982 )。
为了扩展对 GNU Autotool 项目的支持,允许用户为 Makefile 项目( CPP-16924 )设置”预配置”步骤。
支持非 GNU Makes(NMake、BSD)( CPP-18723 )。
用编译包装器实现该方法,并使它与当前的包装器结合使用。
但在此之前,我们计划完善当前的原型并解决各种问题。所以,您的反馈对我们非常重要且宝贵。
请在我们的 问题跟踪器 中报告您遇到的任何问题。
查看我们在以下提供了在原型中测试过的项目列表: CLion 中的 Makefile 项目

立即下载 CLION 2020.2 EAP

您的 CLion 团队
JetBrains
The Drive to Develop

更新:本场直播活动已结束,收看直播回放,下载 PHP 升级指南 PPT、Swoole 社区动态前瞻 PPT 随着最近宣布的 PHP 7.3 End of life 并迎来 PHP 8.1, PHP 生态圈可谓向前迈进了一大步。JetBrains 近期在 PHP 生态圈上也有众多更新,包括正式发布 PhpStorm 2021.3,除了支持 PHP 8.1 新语法外,也有许多新特性的支持。针对 PHP 静态分析也推出 Qodana,可以轻松地集成至 CI/CD 服务器。为让 PHP 核心开发成员有更坚实的基础,JetBrains 也号召成为 PHP 基金会的主要成员。 是时候升级你的代码啦!1 月 13 日,就让我们为您讲解如何使用 PhpStorm 为你的 PHP 项目升级,并通过 Qodana 等工具维护代码质量。另外也有来自 Swoole 消息,为大家介绍最新更新及 Swoole Dashboard 等工具。 点击进入直播间 您还可以前往我们的微信公众号,提前预约本次直播! 本次直播将为您带来: PHP 升级指南 升级项目的 PHP 版本除了要仔细阅读官方的迁移指南外,还需要人工修改代码,一有缺漏就会在运行时期出错,风险很高。其实我们可以在 PhpStorm 的协助下,通过配置 Language Level、善用 Remote Interpreter 及 Code Insp

更新:本场直播活动已结束,收看直播回放 JetBrains 2021.3 系列产品现已发布!跟以往不一样的地方是,这次我们除了推出所有 IDE 的 2021.3 更新外,还包含了 JetBrains Gateway、Space 开发环境及全新的 Fleet 轻量编辑器。 这些更新都为我们揭示了一个全新的开发趋势。12 月 16 日,就让我们为您一一讲解我们在这新趋势下的开发利器吧! 点击进入直播间 本次直播将为您带来: Code With Me 在编程时需要协助?JetBrains IDE 内建的 Code With Me 功能,即便跟同事身处世界两端也能一键启动结对编程。在 IDE 里就能同时共享编辑工具、视频及音频,不需依赖其他会议软件。 JetBrains Gateway 从 2021.3 起,IntelliJ IDEA Ultimate、PyCharm Professional、GoLand、PhpStorm 和 RubyMine 等 IDE 捆绑 JetBrains Gateway,你可以通过 SSH 连接至远程服务器及运行 IDE 后端,并使用基于 IntelliJ 平台的本地轻量客户端编写、导航、重构、运行、调试和测试项目,体验就像是使用本地安装的 JetBrains IDE 处理本地托管的项目。 Space 开发环境和 Fleet 觉得配置服务器麻烦

 
推荐文章