我已经获取了一个大型C项目App A的源代码,并对其进行了修改以生成我的版本,App B. App A和App B都在Debian和Red Hat上完全编译,现在我想为两个平台构建二进制包。
我需要做的最后一次修改是确保App B可以与App A一起安装而不受任何干扰。我应该能够在终端中唤起app-a
和app-b
,并且在任何桌面环境中都将它们列为单独的软件项。
项目有一个debian/
文件夹(包含rules
,control
等)和一个包含rpm/
文件的SPEC
文件夹。目前,构建和安装.rpm和.deb软件包的工作原理除了App B被识别为App A,因此不符合上述要求。 ldd
显示程序具有完全相同的依赖关系,我无法进行库的静态链接。
我希望安装该应用程序的应用程序和修改版本,并将其识别为我构建的.deb和.rpm文件中的单独应用程序。
我需要对项目进行哪些修改才能达到预期效果?请具体,因为我已经开始研究软件包构建,但无法找到解决此问题的材料。
答案 0 :(得分:0)
我会回答Debian包装。
确保在两个变体中创建的二进制可执行文件的名称不同。例如。变体“A”将具有可执行文件/usr/bin/app-a
,而变体“B”将具有/usr/bin/app-b
。这应该是显而易见的,因为否则你将无法同时安装它们。
如果您的软件包含其他文件,例如库或其他资源,则这些文件也需要进入不同的目录,例如/usr/lib/app-a/...
和/usr/lib/app-b
在每个项目中,编辑debian/control
文件并更改创建的二进制包的名称。名称是Package:
字段的值。此外,您还需要更改源包(Source:
字段的名称,通常位于debian/control
的最顶部。)
(可选)如果两个变体共享大多数文件,并且只有可执行文件(/usr/bin/app-{a,b}
)不同,您可能希望将两者结合在一个源包中,并构建三个来自该单个源包的em>二进制包:一个包含两个项目共享的文件(Package: app-common
),每个变量一个(Package: app-a
和Package: app-b
)。然后,您将需要Makefile
来构建两个变体,并为dh_install
编写配置文件,将文件排序到正确的目录中(app-a
需要进入debian/app-a/usr/bin
并且类似于app-b
)。