|
|
@ -281,11 +281,12 @@ class Britney(object):
|
|
|
|
self.binaries = {}
|
|
|
|
self.binaries = {}
|
|
|
|
self.all_selected = []
|
|
|
|
self.all_selected = []
|
|
|
|
self.excuses = {}
|
|
|
|
self.excuses = {}
|
|
|
|
|
|
|
|
self._hint_parser = HintParser(self)
|
|
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
self.hints = self.read_hints(self.options.hintsdir)
|
|
|
|
self.read_hints(self.options.hintsdir)
|
|
|
|
except AttributeError:
|
|
|
|
except AttributeError:
|
|
|
|
self.hints = self.read_hints(os.path.join(self.options.unstable, 'Hints'))
|
|
|
|
self.read_hints(os.path.join(self.options.unstable, 'Hints'))
|
|
|
|
|
|
|
|
|
|
|
|
if self.options.nuninst_cache:
|
|
|
|
if self.options.nuninst_cache:
|
|
|
|
self.log("Not building the list of non-installable packages, as requested", type="I")
|
|
|
|
self.log("Not building the list of non-installable packages, as requested", type="I")
|
|
|
@ -493,6 +494,10 @@ class Britney(object):
|
|
|
|
self.policies.append(AgePolicy(self.options, MINDAYS))
|
|
|
|
self.policies.append(AgePolicy(self.options, MINDAYS))
|
|
|
|
self.policies.append(RCBugPolicy(self.options))
|
|
|
|
self.policies.append(RCBugPolicy(self.options))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@property
|
|
|
|
|
|
|
|
def hints(self):
|
|
|
|
|
|
|
|
return self._hint_parser.hints
|
|
|
|
|
|
|
|
|
|
|
|
def log(self, msg, type="I"):
|
|
|
|
def log(self, msg, type="I"):
|
|
|
|
"""Print info messages according to verbosity level
|
|
|
|
"""Print info messages according to verbosity level
|
|
|
|
|
|
|
|
|
|
|
@ -1030,13 +1035,12 @@ class Britney(object):
|
|
|
|
The method returns a dictionary where the key is the command, and
|
|
|
|
The method returns a dictionary where the key is the command, and
|
|
|
|
the value is the list of affected packages.
|
|
|
|
the value is the list of affected packages.
|
|
|
|
"""
|
|
|
|
"""
|
|
|
|
hint_parser = HintParser(self)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for who in self.HINTS.keys():
|
|
|
|
for who in self.HINTS.keys():
|
|
|
|
if who == 'command-line':
|
|
|
|
if who == 'command-line':
|
|
|
|
lines = self.options.hints and self.options.hints.split(';') or ()
|
|
|
|
lines = self.options.hints and self.options.hints.split(';') or ()
|
|
|
|
filename = '<cmd-line>'
|
|
|
|
filename = '<cmd-line>'
|
|
|
|
hint_parser.parse_hints(who, self.HINTS[who], filename, lines)
|
|
|
|
self._hint_parser.parse_hints(who, self.HINTS[who], filename, lines)
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
filename = os.path.join(hintsdir, who)
|
|
|
|
filename = os.path.join(hintsdir, who)
|
|
|
|
if not os.path.isfile(filename):
|
|
|
|
if not os.path.isfile(filename):
|
|
|
@ -1044,9 +1048,9 @@ class Britney(object):
|
|
|
|
continue
|
|
|
|
continue
|
|
|
|
self.log("Loading hints list from %s" % filename)
|
|
|
|
self.log("Loading hints list from %s" % filename)
|
|
|
|
with open(filename, encoding='utf-8') as f:
|
|
|
|
with open(filename, encoding='utf-8') as f:
|
|
|
|
hint_parser.parse_hints(who, self.HINTS[who], filename, f)
|
|
|
|
self._hint_parser.parse_hints(who, self.HINTS[who], filename, f)
|
|
|
|
|
|
|
|
|
|
|
|
hints = hint_parser.hints
|
|
|
|
hints = self._hint_parser.hints
|
|
|
|
|
|
|
|
|
|
|
|
for x in ["block", "block-all", "block-udeb", "unblock", "unblock-udeb", "force", "urgent", "remove", "age-days"]:
|
|
|
|
for x in ["block", "block-all", "block-udeb", "unblock", "unblock-udeb", "force", "urgent", "remove", "age-days"]:
|
|
|
|
z = {}
|
|
|
|
z = {}
|
|
|
@ -1078,8 +1082,6 @@ class Britney(object):
|
|
|
|
if len(hints["block"]) == 0 and len(hints["block-udeb"]) == 0:
|
|
|
|
if len(hints["block"]) == 0 and len(hints["block-udeb"]) == 0:
|
|
|
|
self.log("WARNING: No block hints at all, not even udeb ones!", type="W")
|
|
|
|
self.log("WARNING: No block hints at all, not even udeb ones!", type="W")
|
|
|
|
|
|
|
|
|
|
|
|
return hints
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Utility methods for package analysis
|
|
|
|
# Utility methods for package analysis
|
|
|
|
# ------------------------------------
|
|
|
|
# ------------------------------------
|
|
|
@ -2804,7 +2806,7 @@ class Britney(object):
|
|
|
|
elif user_input and user_input[0] in ('remove', 'approve', 'urgent', 'age-days',
|
|
|
|
elif user_input and user_input[0] in ('remove', 'approve', 'urgent', 'age-days',
|
|
|
|
'block', 'block-udeb', 'unblock', 'unblock-udeb',
|
|
|
|
'block', 'block-udeb', 'unblock', 'unblock-udeb',
|
|
|
|
'block-all', 'force'):
|
|
|
|
'block-all', 'force'):
|
|
|
|
self.hints.add_hint('hint-tester', ' '.join(user_input))
|
|
|
|
self._hint_parser.parse_hints('hint-tester', Britney.HINTS_ALL, '<stdin>', [' '.join(user_input)])
|
|
|
|
self.write_excuses()
|
|
|
|
self.write_excuses()
|
|
|
|
# run a hint
|
|
|
|
# run a hint
|
|
|
|
elif user_input and user_input[0] in ('easy', 'hint', 'force-hint'):
|
|
|
|
elif user_input and user_input[0] in ('easy', 'hint', 'force-hint'):
|
|
|
|