Ho scritto un piccolo script Python che si occupa di questo problema. La logica esamina ogni riga del file package.accept_keywords
e agisce solo sulle righe che iniziano con =
o <=
. Queste righe hanno una versione con limite massimo in modo che possiamo verificare se sono più necessarie. Le linee senza qualificatore o a >=
vengono lasciate così come sono, poiché non possiamo sapere se sono obsolete.
Le righe che ci interessano vengono quindi analizzate e viene verificata la versione installata del pacchetto. Se la versione installata è più recente della versione con parole chiave o non è più installata, la parola chiave viene considerata obsoleta. Se il pacchetto installato è la stessa versione della versione con parole chiave, il pacchetto installato viene controllato per vedere se è ancora con parole chiave. Se è stato stabilizzato, la linea è obsoleta, altrimenti viene mantenuta.
#!/bin/env python
import re
import portage
vartree = portage.db[portage.root]['vartree']
with open('/etc/portage/package.accept_keywords') as f:
for x in f:
# eat newline
x = x.rstrip()
# we only want lines with a bounded max version
if re.match('^(=|<=)',x):
# get the package cpv atom -- strip the =|<= and the trailing keyword(s)
cpv_masked = re.sub('[<=]','',x.split(' ',1)[0])
cat, pkg, ver, rev = portage.catpkgsplit(cpv_masked)
# get cpv for all installed versions of the package
cpv_installed = vartree.dep_match(cat+'/'+pkg)
for cpv in cpv_installed:
cmp = portage.pkgcmp(portage.pkgsplit(cpv), portage.pkgsplit(cpv_masked))
# if the installed version is not newer than the masked version
if (cmp <= 0):
# check if this version is still keyworded
cpv_keywords = vartree.dbapi.aux_get(cpv, ['KEYWORDS'])
# keep keyword if the package has no keywords (**)
if not cpv_keywords[0]:
print(x)
break
# check if the installed package is still keyworded
for cpv_keyword in cpv_keywords[0].split(' '):
if cpv_masked_keyword == cpv_keyword:
# it is, keep the atom and move on to the next one
print(x)
break
else:
# keep atoms that have an unbounded max version
print(x)
Questo stamperà il nuovo file delle parole chiave per lo standard out. Nota : non reindirizzare l'output in /etc/portage/package.accept_keywords
altrimenti si ostruirà il file e si perderà tutto.
Ciò contribuirà notevolmente a ripulire il file delle parole chiave e per le altre preoccupazioni, ordinare il file e quindi esaminarlo per più righe per lo stesso pacchetto aiuterà a risolvere la maggior parte di ciò che resta.