msg.py 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. # ex:ts=4:sw=4:sts=4:et
  2. # -*- tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*-
  3. """
  4. BitBake 'msg' implementation
  5. Message handling infrastructure for bitbake
  6. """
  7. # Copyright (C) 2006 Richard Purdie
  8. #
  9. # This program is free software; you can redistribute it and/or modify
  10. # it under the terms of the GNU General Public License version 2 as
  11. # published by the Free Software Foundation.
  12. #
  13. # This program is distributed in the hope that it will be useful,
  14. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. # GNU General Public License for more details.
  17. #
  18. # You should have received a copy of the GNU General Public License along
  19. # with this program; if not, write to the Free Software Foundation, Inc.,
  20. # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
  21. import sys, os, re, bb
  22. from bb import utils
  23. debug_level = {}
  24. verbose = False
  25. domain = bb.utils.Enum(
  26. 'Build',
  27. 'Cache',
  28. 'Collection',
  29. 'Data',
  30. 'Depends',
  31. 'Fetcher',
  32. 'Parsing',
  33. 'Provider',
  34. 'RunQueue',
  35. 'TaskData',
  36. 'Util')
  37. #
  38. # Message control functions
  39. #
  40. def set_debug_level(level):
  41. bb.msg.debug_level = {}
  42. for domain in bb.msg.domain:
  43. bb.msg.debug_level[domain] = level
  44. bb.msg.debug_level['default'] = level
  45. def set_verbose(level):
  46. bb.msg.verbose = level
  47. def set_debug_domains(domains):
  48. for domain in domains:
  49. found = False
  50. for ddomain in bb.msg.domain:
  51. if domain == str(ddomain):
  52. bb.msg.debug_level[ddomain] = bb.msg.debug_level[ddomain] + 1
  53. found = True
  54. if not found:
  55. std_warn("Logging domain %s is not valid, ignoring" % domain)
  56. #
  57. # Message handling functions
  58. #
  59. def debug(level, domain, msg, fn = None):
  60. if debug_level[domain] >= level:
  61. print 'DEBUG: ' + msg
  62. def note(level, domain, msg, fn = None):
  63. if level == 1 or verbose or debug_level[domain] >= 1:
  64. std_note(msg)
  65. def warn(domain, msg, fn = None):
  66. std_warn(msg)
  67. def error(domain, msg, fn = None):
  68. std_error(msg)
  69. def fatal(domain, msg, fn = None):
  70. std_fatal(msg)
  71. #
  72. # Compatibility functions for the original message interface
  73. #
  74. def std_debug(lvl, msg):
  75. if debug_level['default'] >= lvl:
  76. print 'DEBUG: ' + msg
  77. def std_note(msg):
  78. print 'NOTE: ' + msg
  79. def std_warn(msg):
  80. print 'WARNING: ' + msg
  81. def std_error(msg):
  82. print 'ERROR: ' + msg
  83. def std_fatal(msg):
  84. print 'ERROR: ' + msg
  85. sys.exit(1)