1
0
mirror of https://github.com/openSUSE/osc.git synced 2025-01-27 07:06:13 +01:00

- always use the latest version of a package (in case the dir contains multiple versions of a package) when running "osc build --prefer-pkgs /path/to/pkgs"

This commit is contained in:
Marcus Hüwe 2009-09-21 17:29:20 +00:00
parent 5083dfd6d0
commit 1130e28061

View File

@ -234,8 +234,8 @@ def get_prefer_pkgs(dirs, wanted_arch, type):
suffix = '*.deb'
for dir in dirs:
paths += glob.glob(os.path.join(os.path.abspath(dir), suffix))
prefer_pkgs = []
pkgqs = []
prefer_pkgs = {}
pkgqs = {}
for path in paths:
if path.endswith('src.rpm'):
continue
@ -247,15 +247,16 @@ def get_prefer_pkgs(dirs, wanted_arch, type):
# instead of thip assumption, we should probably rather take the
# requested arch for this package from buildinfo
# also, it will ignore i686 packages, how to handle those?
# XXX: if multiple versions of a package are encountered we have a
# kind of "unpredictable" behaviour: should we always take the newest version?
if arch in [wanted_arch, 'noarch', 'all'] or wanted_arch in arch_map.get(arch, []):
prefer_pkgs.append((name, path))
pkgqs.append(pkgq)
depfile = create_deps(pkgqs)
curpkgq = pkgqs.get(name)
if curpkgq is not None and curpkgq.vercmp(pkgq) > 0:
continue
prefer_pkgs[name] = path
pkgqs[name] = pkgq
depfile = create_deps(pkgqs.values())
cpio = cpio.CpioWrite()
cpio.add('deps', '\n'.join(depfile))
return dict(prefer_pkgs), cpio
return prefer_pkgs, cpio
def create_deps(pkgqs):