index : archinstall32 | |
Archlinux32 installer | gitolite user |
summaryrefslogtreecommitdiff |
author | Anton Hvornum <anton.feeds+github@gmail.com> | 2020-10-18 13:31:54 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-10-18 13:31:54 +0200 |
commit | 7dd38f167b05b413ad14e5e8a837a23490c0989e (patch) | |
tree | adaf3b046fb4ee3fba6c083b4217ceec1ad42058 /archinstall/lib/packages.py | |
parent | b6c5942da69e5eeb3db60f1af40e9f33db6800e9 (diff) | |
parent | a69e1af4f1b13e0a47d4dc634c03b5bc383b9adc (diff) |
-rw-r--r-- | archinstall/lib/packages.py | 18 |
diff --git a/archinstall/lib/packages.py b/archinstall/lib/packages.py index 3a671784..2f5ebe94 100644 --- a/archinstall/lib/packages.py +++ b/archinstall/lib/packages.py @@ -1,5 +1,6 @@ import urllib.request, urllib.parse import ssl, json +from .exceptions import * BASE_URL = 'https://www.archlinux.org/packages/search/json/?name={package}' @@ -24,4 +25,19 @@ def find_packages(*names): result = {} for package in names: result[package] = find_package(package) - return result
\ No newline at end of file + return result + +def validate_package_list(packages :list): + """ + Validates a list of given packages. + Raises `RequirementError` if one or more packages are not found. + """ + invalid_packages = [] + for package in packages: + if not find_package(package)['results']: + invalid_packages.append(package) + + if invalid_packages: + raise RequirementError(f"Invalid package names: {invalid_packages}") + + return True
\ No newline at end of file |