From 49784fe9fe641cecad6987f2d9afe6dc4b812b9c Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Sun, 4 Nov 2007 18:00:56 +0000 Subject: Make Manifest.create() do some basic validation of ebuild file names like portdbapi.cp_list() would do. svn path=/main/trunk/; revision=8423 --- pym/portage/manifest.py | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) (limited to 'pym') diff --git a/pym/portage/manifest.py b/pym/portage/manifest.py index 3116922b7..ac08e5fb1 100644 --- a/pym/portage/manifest.py +++ b/pym/portage/manifest.py @@ -441,11 +441,22 @@ class Manifest(object): self.__init__(self.pkgdir, self.distdir, fetchlist_dict=self.fetchlist_dict, from_scratch=True, manifest1_compat=self.compat) + cpvlist = [] + pn = os.path.basename(self.pkgdir.rstrip(os.path.sep)) + cat = self._pkgdir_category() for pkgdir, pkgdir_dirs, pkgdir_files in os.walk(self.pkgdir): break for f in pkgdir_files: if f.endswith(".ebuild"): mytype = "EBUILD" + pf = f[:-7] + ps = portage.versions.pkgsplit(pf) + cpv = "%s/%s" % (cat, pf) + if not ps: + raise PortagePackageException(cpv) + if ps[0] != pn: + raise PortagePackageException(cpv) + cpvlist.append(cpv) elif manifest2MiscfileFilter(f): mytype = "MISC" else: @@ -462,7 +473,6 @@ class Manifest(object): continue self.fhashdict["AUX"][f] = perform_multiple_checksums( os.path.join(self.pkgdir, "files", f.lstrip(os.sep)), self.hashes) - cpvlist = [os.path.join(self._pkgdir_category(), x[:-7]) for x in os.listdir(self.pkgdir) if x.endswith(".ebuild")] distlist = set() for cpv in cpvlist: distlist.update(self._getCpvDistfiles(cpv)) -- cgit v1.2.3-1-g7c22