我想在Linux,OSX和Windows上分发C / C ++项目的可执行文件和库。 什么是首选的CPack生成器,即可能为大多数用户提供? 在Windows上,似乎只有NSIS,但在Linux和OSX上有几种select。 顺便说一下,也会生成一个源代码分发,因此从理论上讲,所有平台的用户都应该能够自己编译代码,但是为了方便,我们希望提供预编译的二进制代码。
每个不同的平台都有多种常见的做法。 哪一个最适合你,取决于多种因素,但以下至少应该有助于选择CMake / CPack直接支持的更为流行的格式。 我假设你通过CMake使用CPack(即通过CPack模块 ,也可能使用CPackComponent模块的包组件)。
视窗:
苹果电脑
Mac有多种选择,但哪一种最合适取决于你想要打包的内容。 如果您只想提供一个应用程序包,则DMG包生成器 (有时也称为DragNDrop生成器)可能就是您想要的。 用户很熟悉这些,他们很容易使用。 避免捆绑发电机 ,它是支持它的年龄较大和更受限制,DMG发电机应该是首选。
对于包含多个单一包的软件包,DMG生成器仍然可能适用,但适当的安装程序可能更合适。 直到最近几年, PackageMaker发生器才成为这个产品的发展方向,但是它已经被ProductBuild生成器所取代(从3.7版开始支持CMake)。
Linux的
在基于RedHat的系统上,RPM通常是选择的软件包格式(使用RPM生成器 ),而对于基于Debian的系统,DEB格式是首选(使用DEB生成器 )。 基于Debian的系统可以使用像外星人这样的工具来支持RPM,但是用户几乎总是更喜欢本地的DEB格式。 如果你很乐意提供这两种方法,你可以保持两个阵营愉快,但请注意,你将不得不小心注意二进制兼容性。 简单的软件包曾经能够针对LSB(Linux标准库)进行构建,以生成适用于所有主要Linux发行版(甚至基于Debian的版本)的单个RPM,但是LSB并没有真正跟上最新的发展,它从来没有真正支持最复杂的应用程序需要的全套功能(或他们提供的软件包的版本太旧)。 然而,LSB提供了非常有用的工具,比如应用程序检查器,用于评估您构建的包(无论如何)是否会丢失各种Linux发行版中的符号等。
请注意,对于Linux,您应该区分是将打包包装在Linux发行版中,还是希望用户在发行版的打包系统之外下载和安装软件包。 较大的独立商业软件产品将倾向于作为独立软件包(包括相关库等)进行分发,并且默认安装在/opt
下(如果它们遵循LSB和文件系统层次结构标准–FHS (PDF)所倡导的那样)。 理想情况下,您可以使您的软件包可以重新定位,这样分发维护人员可以更轻松地调整您的打包方法以适应其分发需求。
RPM和DEB都在一定程度上支持源代码包。
跨平台