diff options
author | Paul Eggleton <paul.eggleton@linux.intel.com> | 2013-08-09 13:52:05 +0000 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2013-08-16 11:21:02 +0100 |
commit | 840a427ed2943136fba60c721d19870c79dabe23 (patch) | |
tree | 95dd4603f8ebe514e8331704bb7fa5511c7acd95 | |
parent | baaa7adc168999bfe09e1f287608cc92f86ec0c0 (diff) | |
download | poky-840a427ed2943136fba60c721d19870c79dabe23.tar.gz |
bitbake: taskdata: report close matches with NoProvider errors
Assuming there is no known reason why an item is not provided, show
close matches on the assumption that it might have been a typo or
other mistake.
(Bitbake rev: ed81b0856b4a3892b53d39871eaaa6273390ea75)
Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r-- | bitbake/lib/bb/event.py | 3 | ||||
-rw-r--r-- | bitbake/lib/bb/taskdata.py | 13 | ||||
-rw-r--r-- | bitbake/lib/bb/ui/crumbs/runningbuild.py | 10 | ||||
-rw-r--r-- | bitbake/lib/bb/ui/knotty.py | 9 |
4 files changed, 29 insertions, 6 deletions
diff --git a/bitbake/lib/bb/event.py b/bitbake/lib/bb/event.py index 9c134eed0d..ba25d38d89 100644 --- a/bitbake/lib/bb/event.py +++ b/bitbake/lib/bb/event.py | |||
@@ -341,12 +341,13 @@ class DiskFull(Event): | |||
341 | class NoProvider(Event): | 341 | class NoProvider(Event): |
342 | """No Provider for an Event""" | 342 | """No Provider for an Event""" |
343 | 343 | ||
344 | def __init__(self, item, runtime=False, dependees=None, reasons=[]): | 344 | def __init__(self, item, runtime=False, dependees=None, reasons=[], close_matches=[]): |
345 | Event.__init__(self) | 345 | Event.__init__(self) |
346 | self._item = item | 346 | self._item = item |
347 | self._runtime = runtime | 347 | self._runtime = runtime |
348 | self._dependees = dependees | 348 | self._dependees = dependees |
349 | self._reasons = reasons | 349 | self._reasons = reasons |
350 | self._close_matches = close_matches | ||
350 | 351 | ||
351 | def getItem(self): | 352 | def getItem(self): |
352 | return self._item | 353 | return self._item |
diff --git a/bitbake/lib/bb/taskdata.py b/bitbake/lib/bb/taskdata.py index c08186a718..58fe1995f2 100644 --- a/bitbake/lib/bb/taskdata.py +++ b/bitbake/lib/bb/taskdata.py | |||
@@ -390,6 +390,17 @@ class TaskData: | |||
390 | reasons.append("%s PROVIDES %s but was skipped: %s" % (skipitem.pn, item, skipitem.skipreason)) | 390 | reasons.append("%s PROVIDES %s but was skipped: %s" % (skipitem.pn, item, skipitem.skipreason)) |
391 | return reasons | 391 | return reasons |
392 | 392 | ||
393 | def get_close_matches(self, item, provider_list): | ||
394 | import difflib | ||
395 | if self.skiplist: | ||
396 | skipped = [] | ||
397 | for fn in self.skiplist: | ||
398 | skipped.append(self.skiplist[fn].pn) | ||
399 | full_list = provider_list + skipped | ||
400 | else: | ||
401 | full_list = provider_list | ||
402 | return difflib.get_close_matches(item, full_list, cutoff=0.7) | ||
403 | |||
393 | def add_provider(self, cfgData, dataCache, item): | 404 | def add_provider(self, cfgData, dataCache, item): |
394 | try: | 405 | try: |
395 | self.add_provider_internal(cfgData, dataCache, item) | 406 | self.add_provider_internal(cfgData, dataCache, item) |
@@ -411,7 +422,7 @@ class TaskData: | |||
411 | return | 422 | return |
412 | 423 | ||
413 | if not item in dataCache.providers: | 424 | if not item in dataCache.providers: |
414 | bb.event.fire(bb.event.NoProvider(item, dependees=self.get_dependees_str(item), reasons=self.get_reasons(item)), cfgData) | 425 | bb.event.fire(bb.event.NoProvider(item, dependees=self.get_dependees_str(item), reasons=self.get_reasons(item), close_matches=self.get_close_matches(item, dataCache.providers.keys())), cfgData) |
415 | raise bb.providers.NoProvider(item) | 426 | raise bb.providers.NoProvider(item) |
416 | 427 | ||
417 | if self.have_build_target(item): | 428 | if self.have_build_target(item): |
diff --git a/bitbake/lib/bb/ui/crumbs/runningbuild.py b/bitbake/lib/bb/ui/crumbs/runningbuild.py index 78fa1417f5..abd3300149 100644 --- a/bitbake/lib/bb/ui/crumbs/runningbuild.py +++ b/bitbake/lib/bb/ui/crumbs/runningbuild.py | |||
@@ -375,10 +375,16 @@ class RunningBuild (gobject.GObject): | |||
375 | r = "R" | 375 | r = "R" |
376 | else: | 376 | else: |
377 | r = "" | 377 | r = "" |
378 | |||
379 | extra = '' | ||
380 | if not event._reasons: | ||
381 | if event._close_matches: | ||
382 | extra = ". Close matches:\n %s" % '\n '.join(event._close_matches) | ||
383 | |||
378 | if event._dependees: | 384 | if event._dependees: |
379 | msg = "Nothing %sPROVIDES '%s' (but %s %sDEPENDS on or otherwise requires it)\n" % (r, event._item, ", ".join(event._dependees), r) | 385 | msg = "Nothing %sPROVIDES '%s' (but %s %sDEPENDS on or otherwise requires it)%s\n" % (r, event._item, ", ".join(event._dependees), r, extra) |
380 | else: | 386 | else: |
381 | msg = "Nothing %sPROVIDES '%s'\n" % (r, event._item) | 387 | msg = "Nothing %sPROVIDES '%s'%s\n" % (r, event._item, extra) |
382 | if event._reasons: | 388 | if event._reasons: |
383 | for reason in event._reasons: | 389 | for reason in event._reasons: |
384 | msg += ("%s\n" % reason) | 390 | msg += ("%s\n" % reason) |
diff --git a/bitbake/lib/bb/ui/knotty.py b/bitbake/lib/bb/ui/knotty.py index 2c8293d985..09ad99ebe8 100644 --- a/bitbake/lib/bb/ui/knotty.py +++ b/bitbake/lib/bb/ui/knotty.py | |||
@@ -416,10 +416,15 @@ def main(server, eventHandler, params, tf = TerminalFilter): | |||
416 | else: | 416 | else: |
417 | r = "" | 417 | r = "" |
418 | 418 | ||
419 | extra = '' | ||
420 | if not event._reasons: | ||
421 | if event._close_matches: | ||
422 | extra = ". Close matches:\n %s" % '\n '.join(event._close_matches) | ||
423 | |||
419 | if event._dependees: | 424 | if event._dependees: |
420 | logger.error("Nothing %sPROVIDES '%s' (but %s %sDEPENDS on or otherwise requires it)", r, event._item, ", ".join(event._dependees), r) | 425 | logger.error("Nothing %sPROVIDES '%s' (but %s %sDEPENDS on or otherwise requires it)%s", r, event._item, ", ".join(event._dependees), r, extra) |
421 | else: | 426 | else: |
422 | logger.error("Nothing %sPROVIDES '%s'", r, event._item) | 427 | logger.error("Nothing %sPROVIDES '%s'%s", r, event._item, extra) |
423 | if event._reasons: | 428 | if event._reasons: |
424 | for reason in event._reasons: | 429 | for reason in event._reasons: |
425 | logger.error("%s", reason) | 430 | logger.error("%s", reason) |