12

我想建立一个共享库。GNU/Linux 是开发和目标平台。C是实现语言。

我无法决定我想如何设置构建系统并一直在三个选项之间徘徊,每个选项都有很多不喜欢的理由:

  • 手工制作的 Makefiles - 我过去几乎都是这样工作的
  • GNU Autotools - 今年早些时候我使用 autotools 构建了一个共享的 C 库,但忘记了我是如何做到的,以及我在哪里使用了数百个教程。
  • waf - 据说很简单,但不是那么容易我今天下午就开始工作了。

我无法决定去哪个。我会选择一个,开始工作,然后遇到问题并决定另一个系统更好。我被卡住了。有人可以对此有所了解,这可能会帮助我解决这个问题吗?

4

4 回答 4

17

以下是我多年来注意到的工具的一些链接(和网站的引用):

PreMake:你是一个软件项目的经理。您的用户要求您提供 Visual Studio 工作区文件,但您没有 Visual Studio!或者,也许您是一名 Windows 开发人员,努力使 Makefile 与 Linux 端口保持同步。这是开源项目的一个常见问题:将您的用户限制在一个构建工具上——赶走潜在的贡献者——或者手动维护两套、三套或更多套构建脚本。输入预制。

CMake:欢迎使用 CMake,这是一个跨平台的开源构建系统。CMake 是一系列工具,旨在构建、测试和打包软件。CMake 用于使用简单的平台和编译器独立配置文件来控制软件编译过程。CMake 生成可在您选择的编译器环境中使用的本机 makefile 和工作区。

buildconf:它最初只是一个小的构建准备脚本......多年来已经发展成为一个非常有用的实用程序,为我节省了支持请求和跨平台编译的时间和精力。它与使用 GNU 构建系统的项目中常见的相同类型的脚本——也称为 GNU Autotools 或每个工具单独称为 Autoconf、Automake 和 Libtool。这些项目经常编写自定义帮助脚本,为项目的开发人员准备构建系统,通常运行各种工具,如 libtoolize、autoconf 或 autoreconf。这个脚本通常被命名为 buildconf 或 autogen.sh 但目的是一样的:准备你的构建系统进行编译

BSDBuild:BSDBuild(以前称为 csoft-mk)是一个简单、独立且可移植的构建系统,源自传统的 4.4BSD 共享/mk 文件。BSDBuild 允许 BSD 样式的 makefile,但没有 BSD make 扩展(它使用标准的 Bourne 脚本片段代替),因此构建系统可移植到大多数操作系统和 make 风格。

iCompile : iCompile 零配置构建系统

OMake:(OCaml)OMake 是一个为可扩展性和可移植性而设计的构建系统。

BakeFile : Bakefile 是跨平台、跨编译器的原生 makefile 生成器。它将构建任务的独立于编译器的描述作为输入并生成本机 makefile(autoconf 的 Makefile.in、Visual C++ 项目、bcc makefile 等)。

SCons是一种开源软件构建工具,即下一代构建工具。将 SCons 视为经典Make实用程序的改进的跨平台替代品,其集成功能类似于autoconf/automake编译器缓存(如ccache. 简而言之,SCons 是一种更简单、更可靠、更快速的软件构建方式。

制作项目:“制作项目”是制作项目骨架的 bash 脚本。它使用命令行提供的信息自动启动新项目的任务。默认创建的包是使用自动工具管理的选定骨架的“hello world”项目。

未维护或失效的项目 (07-2012)

cppmake : Cppmake 是一个前端 make ,它比手动编写 makefile 更省力、更准确地构建 C++ 程序。

spray:Spray 是一个构建工具,可帮助您配置、构建和安装项目。它的用途类似于 autotools 或 CMake,但使用 Python 编程语言遵循 SCons 和 waf 的精神创建。

于 2009-10-20T18:10:29.150 回答
7

好吧:所有系统都很糟糕。有些只是吸得少。正如 mutt mailer 所说。也就是说,一些快速评论:

  • Qt非常好并且有据可查,我喜欢创建的 .pro 文件。此外,它是可靠的跨平台预订,如果您需要,您现在可以获得 IDE 等。
  • CMake是我们在工作中使用的,它也是跨平台的,人们可以习惯它,但我仍然觉得它很古怪。
  • GNU Autoconf et al 是我在我的项目中使用的。古怪,但我已经习惯了它和 Intertubes 上的无数工作示例。
  • 可能是斯康斯
于 2009-10-20T18:00:09.730 回答
7

由于构建系统的目的是将库安装到目标系统中,因此您应该使用安装该软件的每个人都熟悉的通用工具之一。

所以构建系统的主要目的是灵活的配置能力。

每个人都可以使用的是CMakeAutotools。坚持他们。

于 2009-10-20T18:03:11.060 回答
1

我经常使用 mkproject ( Make Project )。它是人们建议使用的普通 autotools 东西,但它确实会加载您的默认配置,有点像 IDE 项目生成器,非常理智的最小但有用的默认值。其余的由您通过简单的自动工具来管理(info configure、info autoconf、info automake 是您的助手,顺便说一下 mkproject 严格遵循)。

您总是使用一些基本程序来启动项目,编辑 configure.ac 编辑 Makefile.am,...,mkproject 就是这样做的,而不会侵入 autotools 层或添加新语法。很酷的是,通过参数它可以从头开始个性化您的 autotools 项目,从而节省时间和错误。

如果您使用自动工具并生成随机/大量项目,请尝试一下,它带有手册和信息页面,甚至网站也告诉如何使用它。

于 2012-08-17T22:46:10.287 回答