Blob Blame History Raw
From 92d5d7e8c27088fa3fb8e5e6e9c5b8d3209053d6 Mon Sep 17 00:00:00 2001
From: "Richard W.M. Jones" <rjones@redhat.com>
Date: Tue, 30 May 2023 09:12:14 +0100
Subject: [PATCH 4/4] rpm: Detect dnf5 and omit missing options

Fixes: https://bugzilla.redhat.com/show_bug.cgi?id=2209412
---
 src/ph_rpm.ml | 23 +++++++++++++++++++++--
 1 file changed, 21 insertions(+), 2 deletions(-)

diff --git a/src/ph_rpm.ml b/src/ph_rpm.ml
index 2c199c1..3e803c6 100644
--- a/src/ph_rpm.ml
+++ b/src/ph_rpm.ml
@@ -482,19 +482,38 @@ and download_all_packages_with_dnf pkgs dir tdir =
   (* Old dnf didn't create the destdir directory, newer versions do. *)
   mkdir tdir 0o700;
 
+  (* dnf5 lacks various options so we have to detect it:
+   * https://github.com/rpm-software-management/dnf5/issues/580
+   * https://github.com/rpm-software-management/dnf5/issues/581
+   *)
+  let is_dnf5 = is_dnf5 () in
+  let debug_quiet_option =
+    if !settings.debug < 1 then " -q"
+    else if not is_dnf5 then " -v"
+    else "" in
+
   let rpms = pkgs_as_NA_rpms pkgs in
 
   let cmd =
-    sprintf "%s download%s%s --destdir=%s --disableexcludes=all %s"
+    sprintf "%s download%s%s%s --destdir=%s %s"
       Config.dnf
-      (if !settings.debug >= 1 then " -v" else " -q")
+      debug_quiet_option
       (match !settings.packager_config with
       | None -> ""
       | Some filename -> sprintf " -c %s" (quote filename))
+      (if not is_dnf5 then " --disableexcludes=all" else "")
       (quote tdir)
       (quoted_list rpms) in
   run_command cmd
 
+and is_dnf5 () =
+  let cmd = sprintf "%s --version" Config.dnf in
+  let lines = run_command_get_lines cmd in
+  match lines with
+  | [] -> error "rpm: no output from '%s' command" cmd
+  | line :: _ when find line "version 5" >= 0 -> true
+  | _ -> false
+
 and pkgs_as_NA_rpms pkgs =
   let rpms = List.map rpm_of_pkg (PackageSet.elements pkgs) in
   List.map (
-- 
2.40.1