我正在使用wxWidgets
的C ++ Linux应用程序,需要作为已编译的二进制应用程序进行分发。项目负责人已指定我们要包含应用程序的所有依赖项,以便最终用户不需要安装任何东西来运行应用程序,只要它们已经安装了标准系统组件(libc
等)。我认为这个要求是最终用户要求的。我知道这不是您可能认为的Linux应用程序的“正常”分发过程。
对于自身没有很多依赖项的简单库,这不是问题。但对于wxWidgets
,我遇到webkitgtk
类(在应用程序中使用)所需的WebView
问题。 webkitgtk
本身有许多依赖项,可能有自己的依赖项,依此类推。基本上,通过尝试将所有内容都包含在应用程序中,看起来我正在打开真正的蠕虫病毒,而项目中更高级的开发人员似乎同意。
所以我想知道,分发此类应用程序有哪些选择?我已经尝试搜索有关此信息,而流行的观点似乎是让最终用户安装wxWidgets
。这些是我遇到的选项:
wxWidgets
(在GTK
和webkitgtk
之上)。这里的缺点是用户必须安装多个依赖项,如果它们不在包管理器中具有上述适当版本的发行版上,这对他们来说可能是一个真正的麻烦。这也意味着我们无法提供特别要求的东西。GTK
和webkitgtk
,而不是wxWidgets
。与上面相同的缺点,但具有较少的依赖性。另一个缺点是,如果安装了不同版本的依赖项,则可能存在版本兼容性问题,而不是用于构建打包的wxWidgets
库。在评估这些不同选项的利弊时,我是否正确?我有什么选择吗?
谢谢!
答案 0 :(得分:3)
大卫 最好的解决方案可能是要求用户安装X11,GTK + {2,3}和WebKit-GTK。 wxWidgets可以与应用程序静态链接。
您可以要求用户让WebKit-GTK至少为X.Y.Z版本,并且应该满足要求。将WebKit-GTK与其所有依赖项集成,特别是因为依赖于GTK +本身将非常困难。所以,如果你走这条路,你就会被搞砸。
答案 1 :(得分:2)
作为linux用户,我通过包管理器投票支持手动依赖安装。它并不难,甚至可以自动完成,如果你提供包(不只是二进制)。携带运行时可能导致问题(例如Debian上的Steam)。另一种选择是提供两种口味:全包和需要依赖。