Allow to filter versions by build number using --build option

This commit is contained in:
Jakub Jirutka 2023-11-21 01:50:58 +01:00
parent 62860db43b
commit 9018aa6e5b

View File

@ -541,8 +541,8 @@ class gibMacOS:
return return
print("{} not found".format(prod)) print("{} not found".format(prod))
def get_for_version(self, vers, dmg = False): def get_for_version(self, vers, build = None, dmg = False):
self.u.head("Downloading for {}".format(vers)) self.u.head("Downloading for {} {}".format(vers, build or ""))
print("") print("")
# Map the versions to their names # Map the versions to their names
v = self.version_names.get(vers.lower(),vers.lower()) v = self.version_names.get(vers.lower(),vers.lower())
@ -551,6 +551,8 @@ class gibMacOS:
v_dict[self.version_names[n]] = n v_dict[self.version_names[n]] = n
n = v_dict.get(v, v) n = v_dict.get(v, v)
for p in sorted(self.mac_prods, key=lambda x:x['version'], reverse=True): for p in sorted(self.mac_prods, key=lambda x:x['version'], reverse=True):
if build and p["build"] != build:
continue
pt = p["title"].lower() pt = p["title"].lower()
pv = p["version"].lower() pv = p["version"].lower()
# Need to compare verisons - n = name, v = version # Need to compare verisons - n = name, v = version
@ -575,11 +577,11 @@ class gibMacOS:
if (n in pt) and not len(name_match): if (n in pt) and not len(name_match):
self.download_prod(p, dmg) self.download_prod(p, dmg)
return return
print("'{}' not found".format(vers)) print("'{}' '{}' not found".format(vers, build))
if __name__ == '__main__': if __name__ == '__main__':
parser = argparse.ArgumentParser() parser = argparse.ArgumentParser()
parser.add_argument("-l", "--latest", help="downloads the version available in the current catalog (overrides --version and --product)", action="store_true") parser.add_argument("-l", "--latest", help="downloads the version available in the current catalog (overrides --build, --version and --product)", action="store_true")
parser.add_argument("-r", "--recovery", help="looks for RecoveryHDUpdate.pkg and RecoveryHDMetaDmg.pkg in lieu of com.apple.mpkg.OSInstall (overrides --dmg)", action="store_true") parser.add_argument("-r", "--recovery", help="looks for RecoveryHDUpdate.pkg and RecoveryHDMetaDmg.pkg in lieu of com.apple.mpkg.OSInstall (overrides --dmg)", action="store_true")
parser.add_argument("-d", "--dmg", help="downloads only the .dmg files", action="store_true") parser.add_argument("-d", "--dmg", help="downloads only the .dmg files", action="store_true")
parser.add_argument("-s", "--savelocal", help="uses a locally saved sucatalog.plist if exists", action="store_true") parser.add_argument("-s", "--savelocal", help="uses a locally saved sucatalog.plist if exists", action="store_true")
@ -587,6 +589,7 @@ if __name__ == '__main__':
parser.add_argument("-c", "--catalog", help="sets the CATALOG to use - publicrelease, public, customer, developer") parser.add_argument("-c", "--catalog", help="sets the CATALOG to use - publicrelease, public, customer, developer")
parser.add_argument("-p", "--product", help="sets the product id to search for (overrides --version)") parser.add_argument("-p", "--product", help="sets the product id to search for (overrides --version)")
parser.add_argument("-v", "--version", help="sets the version of macOS to target - eg '-v 10.14' or '-v Yosemite'") parser.add_argument("-v", "--version", help="sets the version of macOS to target - eg '-v 10.14' or '-v Yosemite'")
parser.add_argument("-b", "--build", help="sets the build of macOS to target - eg '22G120' (must be used together with --version)")
parser.add_argument("-m", "--maxos", help="sets the max macOS version to consider when building the url - eg 10.14") parser.add_argument("-m", "--maxos", help="sets the max macOS version to consider when building the url - eg 10.14")
parser.add_argument("-i", "--print-urls", help="only prints the download URLs, does not actually download them", action="store_true") parser.add_argument("-i", "--print-urls", help="only prints the download URLs, does not actually download them", action="store_true")
args = parser.parse_args() args = parser.parse_args()
@ -625,7 +628,7 @@ if __name__ == '__main__':
g.get_for_product(args.product, args.dmg) g.get_for_product(args.product, args.dmg)
exit() exit()
if args.version != None: if args.version != None:
g.get_for_version(args.version, args.dmg) g.get_for_version(args.version, args.build, args.dmg)
exit() exit()
while True: while True: