Richard W.M. Jones
2014-Feb-27 18:20 UTC
[Libguestfs] FYI: [PATCH supermin] rpm: Add support for OpenSUSE.
Olaf, I added this patch to supermin 5, which enables support for OpenSUSE / zypper, and allowed me to rebuild libguestfs on 13.1. It is largely based on the previous code that you did, but I have dropped support for the --packager-config option. I can add this back if you want, although I'd like to avoid use of the 'inifiles' library. If you want to try this you will need to: - git clone supermin - compile supermin - either install supermin 5, or: export SUPERMIN=/path/to/supermin/src/supermin - configure & compile libguestfs (>= 1.25.38) in the usual way Rich.
Richard W.M. Jones
2014-Feb-27 18:20 UTC
[Libguestfs] [PATCH supermin] rpm: Add support for OpenSUSE.
This is based on the existing support for OpenSUSE / zypper in
supermin 4 which was added by Olaf Hering.
---
src/rpm.ml | 85 ++++++++++++++++++++++++++++++++++++++++++++++++++------------
1 file changed, 69 insertions(+), 16 deletions(-)
diff --git a/src/rpm.ml b/src/rpm.ml
index bb55411..0a57c32 100644
--- a/src/rpm.ml
+++ b/src/rpm.ml
@@ -22,11 +22,15 @@ open Printf
open Utils
open Package_handler
-let rpm_detect () +let fedora_detect () Config.rpm <> "no"
&&
Config.yumdownloader <> "no" &&
- (file_exists "/etc/redhat-release" ||
- file_exists "/etc/fedora-release")
+ (file_exists "/etc/redhat-release" || file_exists
"/etc/fedora-release")
+
+let opensuse_detect () + Config.rpm <> "no" &&
+ Config.zypper <> "no" &&
+ file_exists "/etc/SuSE-release"
let settings = ref no_settings
@@ -166,7 +170,10 @@ let rpm_get_all_files pkgs
let rpm_get_files pkg = rpm_get_all_files (PackageSet.singleton pkg)
-let rpm_download_all_packages pkgs dir +let rpm_get_package_database_mtime () +
(lstat "/var/lib/rpm/Packages").st_mtime
+
+let rec fedora_download_all_packages pkgs dir let tdir = !settings.tmpdir //
string_random8 () in
(* It's quite complex to get yumdownloader to download specific
@@ -195,6 +202,50 @@ let rpm_download_all_packages pkgs dir (quoted_list
rpms) in
run_command cmd;
+ rpm_unpack tdir dir
+
+and opensuse_download_all_packages pkgs dir + let tdir = !settings.tmpdir //
string_random8 () in
+
+ let rpms = List.map rpm_of_pkg (PackageSet.elements pkgs) in
+ let rpms = List.map (
+ fun { name = name; arch = arch } ->
+ sprintf "%s.%s" name arch
+ ) rpms in
+
+ (* This isn't quite right because zypper will resolve the dependencies
+ * of the listed packages against the public repos and download all the
+ * dependencies too. We only really want it to download the named
+ * packages. XXX
+ *)
+ let cmd + sprintf "
+ %s%s \\
+ --root %s \\
+ --reposd-dir /etc/zypp/repos.d \\
+ --cache-dir %s \\
+ --pkg-cache-dir %s \\
+ --gpg-auto-import-keys --no-gpg-checks --non-interactive \\
+ install \\
+ --auto-agree-with-licenses --download-only \\
+ %s"
+ Config.zypper
+ (if !settings.debug >= 1 then " --verbose --verbose" else
" --quiet")
+ (quote tdir)
+ (quote tdir)
+ (quote tdir)
+ (quoted_list rpms) in
+ run_command cmd;
+
+ rpm_unpack tdir dir
+
+and fedora_download_package pkg dir + fedora_download_all_packages
(PackageSet.singleton pkg) dir
+
+and opensuse_download_package pkg dir + opensuse_download_all_packages
(PackageSet.singleton pkg) dir
+
+and rpm_unpack tdir dir (* Unpack each downloaded package.
*
* yumdownloader can't necessarily download the specific file that we
@@ -203,21 +254,16 @@ let rpm_download_all_packages pkgs dir let cmd
sprintf "
umask 0000
-for f in %s/*.rpm; do
+for f in `find %s -name '*.rpm'`; do
rpm2cpio \"$f\" | (cd %s && cpio --quiet -id)
done"
(quote tdir) (quote dir) in
run_command cmd
-let rpm_download_package pkg dir - rpm_download_all_packages
(PackageSet.singleton pkg) dir
-
-let rpm_get_package_database_mtime () - (lstat
"/var/lib/rpm/Packages").st_mtime
-
+(* We register package handlers for each RPM distro variant. *)
let () - let ph = {
- ph_detect = rpm_detect;
+ let fedora = {
+ ph_detect = fedora_detect;
ph_init = rpm_init;
ph_package_of_string = rpm_package_of_string;
ph_package_to_string = rpm_package_to_string;
@@ -226,8 +272,15 @@ let () ph_get_all_requires = rpm_get_all_requires;
ph_get_files = rpm_get_files;
ph_get_all_files = rpm_get_all_files;
- ph_download_package = rpm_download_package;
- ph_download_all_packages = rpm_download_all_packages;
ph_get_package_database_mtime = rpm_get_package_database_mtime;
+ ph_download_package = fedora_download_package;
+ ph_download_all_packages = fedora_download_all_packages;
} in
- register_package_handler "rpm" ph
+ register_package_handler "rpm-fedora" fedora;
+ let opensuse = {
+ fedora with
+ ph_detect = opensuse_detect;
+ ph_download_package = opensuse_download_package;
+ ph_download_all_packages = opensuse_download_all_packages;
+ } in
+ register_package_handler "rpm-opensuse" opensuse
--
1.8.5.3
Olaf Hering
2014-Mar-03 08:56 UTC
Re: [Libguestfs] FYI: [PATCH supermin] rpm: Add support for OpenSUSE.
On Thu, Feb 27, Richard W.M. Jones wrote:> I added this patch to supermin 5, which enables support for OpenSUSE / > zypper, and allowed me to rebuild libguestfs on 13.1.Thanks for porting the zypper patches. Right now I dont have time to continue with zypper support for supermin. Olaf