From 2db2123c703a189738e517b210b92d4fdce42410 Mon Sep 17 00:00:00 2001
From: Joel Grunbaum <joelgrun@gmail.com>
Date: Fri, 20 Feb 2026 04:02:58 +0000
Subject: [PATCH] Refresh repos with pacman for deps
---
src/archrepobuild/resolver.py | 22 ++++++++++++++++++----
src/archrepobuild/builder.py | 2 +-
2 files changed, 19 insertions(+), 5 deletions(-)
diff --git a/src/archrepobuild/builder.py b/src/archrepobuild/builder.py
index 38ee9ac..1445c5b 100644
--- a/src/archrepobuild/builder.py
+++ b/src/archrepobuild/builder.py
@@ -533,7 +533,7 @@
logger.info(f"Adding {pkg_name} to repository")
self.repo.add_packages(result)
# Refresh resolver cache to recognize the newly added package
- self.resolver._refresh_pacman_cache()
+ self.resolver._refresh_pacman_cache(sync=True)
elif result.status == BuildStatus.FAILED:
logger.error(f"Failed to process {pkg_name}, aborting")
if pkg_name == package:
diff --git a/src/archrepobuild/resolver.py b/src/archrepobuild/resolver.py
index 70d9f3b..fffbeb1 100644
--- a/src/archrepobuild/resolver.py
+++ b/src/archrepobuild/resolver.py
@@ -78,9 +78,22 @@
self._pacman_cache: dict[str, set[str]] = {} # repo -> packages
self._pacman_checked = False
- def _refresh_pacman_cache(self) -> None:
- """Refresh cache of packages available from official repos."""
+ def _refresh_pacman_cache(self, sync: bool = False) -> None:
+ """Refresh cache of packages available from official repos.
+
+ Args:
+ sync: Whether to synchronize pacman databases first using sudo pacman -Sy
+ """
try:
+ if sync:
+ logger.info("Synchronizing pacman databases...")
+ subprocess.run(
+ ["sudo", "pacman", "-Sy", "--noconfirm"],
+ capture_output=True,
+ text=True,
+ check=True,
+ )
+
result = subprocess.run(
["pacman", "-Sl"],
capture_output=True,
@@ -102,8 +115,9 @@
total_pkgs = sum(len(pkgs) for pkgs in self._pacman_cache.values())
logger.debug(f"Cached {total_pkgs} packages from {len(self._pacman_cache)} repos")
except subprocess.CalledProcessError as e:
- logger.warning(f"Failed to get pacman package list: {e}")
- self._pacman_cache = {}
+ logger.warning(f"Failed to refresh pacman cache: {e}")
+ if not self._pacman_cache:
+ self._pacman_cache = {}
def is_in_repos(self, name: str, include_all: bool = True) -> str | None:
"""Check if package is available in repositories.
--
Gitblit v1.10.0