Read testing data files only once

Signed-off-by: Niels Thykier <niels@thykier.net>
bzr-import-20160707
Niels Thykier 13 years ago
parent 34467e964a
commit cd1735492c

@ -268,16 +268,19 @@ class Britney:
# initialize the apt_pkg back-end # initialize the apt_pkg back-end
apt_pkg.init() apt_pkg.init()
self.systems = {} self.systems = {}
self.sources = {}
self.binaries = {}
# if requested, build the non-installable status and save it # if requested, build the non-installable status and save it
# if this or the population of self.binaries below takes a very # if this or the population of self.binaries below takes a very
# long time, try increasing SIZEOFHASHMAP in lib/dpkg.c and rebuilding # long time, try increasing SIZEOFHASHMAP in lib/dpkg.c and rebuilding
if not self.options.nuninst_cache: if not self.options.nuninst_cache:
self.__log("Building the list of non-installable packages for the full archive", type="I") self.__log("Building the list of non-installable packages for the full archive", type="I")
self.sources = {'testing': self.read_sources(self.options.testing)} self.sources['testing'] = self.read_sources(self.options.testing)
self.binaries['testing'] = {}
nuninst = {} nuninst = {}
for arch in self.options.architectures: for arch in self.options.architectures:
self.binaries = {'testing': {arch: self.read_binaries(self.options.testing, "testing", arch)}} self.binaries['testing'][arch] = self.read_binaries(self.options.testing, "testing", arch)
self.build_systems(arch) self.build_systems(arch)
self.__log("> Checking for non-installable packages for architecture %s" % arch, type="I") self.__log("> Checking for non-installable packages for architecture %s" % arch, type="I")
result = self.get_nuninst(arch, build=True) result = self.get_nuninst(arch, build=True)
@ -299,15 +302,24 @@ class Britney:
# read the source and binary packages for the involved distributions # read the source and binary packages for the involved distributions
# if this takes a very long time, try increasing SIZEOFHASHMAP in # if this takes a very long time, try increasing SIZEOFHASHMAP in
# lib/dpkg.c and rebuilding # lib/dpkg.c and rebuilding
self.sources = {'testing': self.read_sources(self.options.testing), if 'testing' not in self.sources:
'unstable': self.read_sources(self.options.unstable), self.sources['testing'] = self.read_sources(self.options.testing)
'tpu': self.read_sources(self.options.tpu),} self.sources['unstable'] = self.read_sources(self.options.unstable)
self.sources['tpu'] = self.read_sources(self.options.tpu)
if hasattr(self.options, 'pu'): if hasattr(self.options, 'pu'):
self.sources['pu'] = self.read_sources(self.options.pu) self.sources['pu'] = self.read_sources(self.options.pu)
else: else:
self.sources['pu'] = {} self.sources['pu'] = {}
self.binaries = {'testing': {}, 'unstable': {}, 'tpu': {}, 'pu': {}}
if 'testing' not in self.binaries:
self.binaries['testing'] = {}
self.binaries['unstable'] = {}
self.binaries['tpu'] = {}
self.binaries['pu'] = {}
for arch in self.options.architectures: for arch in self.options.architectures:
if arch not in self.binaries['testing']:
self.binaries['testing'][arch] = self.read_binaries(self.options.testing, "testing", arch) self.binaries['testing'][arch] = self.read_binaries(self.options.testing, "testing", arch)
self.binaries['unstable'][arch] = self.read_binaries(self.options.unstable, "unstable", arch) self.binaries['unstable'][arch] = self.read_binaries(self.options.unstable, "unstable", arch)
self.binaries['tpu'][arch] = self.read_binaries(self.options.tpu, "tpu", arch) self.binaries['tpu'][arch] = self.read_binaries(self.options.tpu, "tpu", arch)

Loading…
Cancel
Save