From 341a75e0e1b7c1fe304b7844453edc514a73e8d5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ale=C5=A1=20Mat=C4=9Bj?= Date: Fri, 15 Nov 2024 08:23:19 +0100 Subject: [PATCH] Fix copr chroot specification: replace faulty regex with simpler split The regex `-[^-]*` has multiple matches in a chroot like: `fedora-rawhide-x86_64`, the result of the `regex_replace` is just `fedora`. Replace it with simpler split. --- dnf5-plugins/copr_plugin/copr_repo.cpp | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/dnf5-plugins/copr_plugin/copr_repo.cpp b/dnf5-plugins/copr_plugin/copr_repo.cpp index b109903cd..070f79885 100644 --- a/dnf5-plugins/copr_plugin/copr_repo.cpp +++ b/dnf5-plugins/copr_plugin/copr_repo.cpp @@ -258,9 +258,11 @@ CoprRepo::CoprRepo( baseurl_chroot = selected_chroot; if (!available_chroots.contains(selected_chroot)) available_chroots_error(available_chroots, selected_chroot); - // remove the "-" suffix - json_selector = std::regex_replace(selected_chroot, std::regex("-[^-]*"), ""); - arch = std::regex_replace(selected_chroot, std::regex(".*-"), ""); + // Chroot can look like: fedora-rawhide-x86_64 + // Split on second/last "-" to: "fedora-rawhide" and "x86_64" + size_t second_dash_pos = selected_chroot.find_last_of("-"); + json_selector = selected_chroot.substr(0, second_dash_pos); + arch = selected_chroot.substr(second_dash_pos + 1); } else { baseurl_chroot = get_repo_triplet(available_chroots, config_name_version, arch, json_selector); if (baseurl_chroot.empty()) {