From: Zac Medico Date: Sat, 29 Oct 2011 22:43:35 +0000 (-0700) Subject: action_metadata: clean up src entry validation X-Git-Tag: v2.2.0_alpha72~10 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=fea1962b7e8df9a8568b009a8f52b3c8ade67043;p=portage.git action_metadata: clean up src entry validation This eliminates a bunch of redundant eclasses code that we handle with template.validate_entry() instead. --- diff --git a/pym/_emerge/actions.py b/pym/_emerge/actions.py index 036b471a1..7a1bcb5f8 100644 --- a/pym/_emerge/actions.py +++ b/pym/_emerge/actions.py @@ -1732,6 +1732,13 @@ def action_metadata(settings, portdb, myopts, porttrees=None): continue ebuild_hash = hashed_path(ebuild_location) + try: + if not tree_data.src_db.validate_entry(src, + ebuild_hash, tree_data.eclass_db): + continue + except CacheError: + continue + eapi = src.get('EAPI') if not eapi: eapi = '0' @@ -1758,6 +1765,9 @@ def action_metadata(settings, portdb, myopts, porttrees=None): if src_chf != dest_chf: # populate src entry with dest_chf_key + # (the validity of the dest_chf that we generate from the + # ebuild here relies on the fact that we already used + # validate_entry to validate the ebuild with src_chf) src[dest_chf_key] = dest_chf_getter(ebuild_hash) if dest is not None: @@ -1781,40 +1791,6 @@ def action_metadata(settings, portdb, myopts, porttrees=None): # so there's no need to overwrite it. continue - try: - inherited = src.get('INHERITED', '') - eclasses = src.get('_eclasses_') - except CacheError: - continue - - if eclasses is not None: - if tree_data.eclass_db.validate_and_rewrite_cache( - src['_eclasses_'], tree_data.src_db.validation_chf, - tree_data.src_db.store_eclass_paths) is None: - continue - inherited = eclasses - else: - inherited = inherited.split() - - if tree_data.src_db.complete_eclass_entries and \ - eclasses is None: - continue - - if inherited: - # Even if _eclasses_ already exists, replace it with data from - # eclass_cache, in order to insert local eclass paths. - try: - eclasses = tree_data.eclass_db.get_eclass_data(inherited) - except KeyError: - # INHERITED contains a non-existent eclass. - continue - - if eclasses is None: - continue - src['_eclasses_'] = eclasses - else: - src['_eclasses_'] = {} - if not eapi_supported: src = { 'EAPI' : '-' + eapi,