CLion 2020.2 EAP2 带来了期待已久的 Makefile 项目支持。尽管它仍在初期阶段,具备各类局限性和已知问题,但足以应付大量项目。web
您有 Makefile 项目吗?查看原文获取免费的 EAP 版本并当即尝试。与咱们分享您的反馈!在文章中,咱们将回答:算法
☞后台工做原理是什么?编程
☞如何在 CLion 中开始使用 Makefile 项目?json
☞若是出现问题而项目没法正确加载,该怎么办?微信
☞有哪些已知问题和局限性?app
咱们的实现方法编辑器
不久前,咱们介绍了咱们的发现以及在 CLion 中支持 Makefile 项目的方法。在那篇博客中,咱们概述了各类现代 C++ IDE 和编辑器首选处理 Makefile 的方法:工具
①编译包装器用于包装实际的编译器调用,而后执行完整的构建并提取项目信息。post
②在执行任何构建过程以前,将使用 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

JetBrains教育产品:课程创新者的新功能
2018开发人员生态系统:C和C++的主要趋势
JetBrains 将提供免费开源教育产品!
2018开发人员生态系统调查,什么是编程世界的驱动力

本文分享自微信公众号 - Kotlin(KotlinX)。
若有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一块儿分享。