diff --git a/src/ostreeutil.rs b/src/ostreeutil.rs index e38a9d9f..b2afc51b 100644 --- a/src/ostreeutil.rs +++ b/src/ostreeutil.rs @@ -6,20 +6,29 @@ use std::path::Path; +use anyhow::Result; +use log::debug; + /// https://github.com/coreos/rpm-ostree/pull/969/commits/dc0e8db5bd92e1f478a0763d1a02b48e57022b59 #[cfg(any(target_arch = "x86_64", target_arch = "aarch64"))] pub(crate) const BOOT_PREFIX: &str = "usr/lib/ostree-boot"; +const LEGACY_RPMOSTREE_DBPATH: &str = "usr/share/rpm"; +const SYSIMAGE_RPM_DBPATH: &str = "usr/lib/sysimage/rpm"; -pub(crate) fn rpm_cmd>(sysroot: P) -> std::process::Command { +pub(crate) fn rpm_cmd>(sysroot: P) -> Result { + let mut c = std::process::Command::new("rpm"); let sysroot = sysroot.as_ref(); - let dbpath = sysroot.join("usr/share/rpm"); - let dbpath_arg = { + for dbpath in [SYSIMAGE_RPM_DBPATH, LEGACY_RPMOSTREE_DBPATH] { + let dbpath = sysroot.join(dbpath); + if !dbpath.try_exists()? { + continue; + } let mut s = std::ffi::OsString::new(); s.push("--dbpath="); s.push(dbpath.as_os_str()); - s - }; - let mut c = std::process::Command::new("rpm"); - c.arg(&dbpath_arg); - c + c.arg(s); + return Ok(c); + } + debug!("Failed to find well-known rpmdb path"); + Ok(c) } diff --git a/src/packagesystem.rs b/src/packagesystem.rs index 2536a93c..8c5d1f7e 100644 --- a/src/packagesystem.rs +++ b/src/packagesystem.rs @@ -52,7 +52,7 @@ pub(crate) fn query_files( where T: AsRef, { - let mut c = ostreeutil::rpm_cmd(sysroot_path); + let mut c = ostreeutil::rpm_cmd(sysroot_path)?; c.args(["-q", "--queryformat", "%{nevra},%{buildtime} ", "-f"]); for arg in paths { c.arg(arg.as_ref());