aboutsummaryrefslogtreecommitdiffstats
path: root/lib/bb/msg.py
diff options
context:
space:
mode:
authorRichard Purdie <richard.purdie@linuxfoundation.org>2014-03-26 16:55:35 +0000
committerRichard Purdie <richard.purdie@linuxfoundation.org>2014-03-27 10:15:48 +0000
commitd3e1419ef76be5e9ec976597361a5e14a7b6bcb6 (patch)
treee487e9b366d6db28b2923c997b843367d14867de /lib/bb/msg.py
parent32e171bcc92c6e27fefee971e8714ddf8e1a8ac1 (diff)
downloadbitbake-contrib-d3e1419ef76be5e9ec976597361a5e14a7b6bcb6.tar.gz
msg: Add stdout/stderr filters
Add logging filters which can be used to split output between stdout and stderr, ERROR messages and above as passed by the Err filter, anything below ERROR is passed by the Out filter. This is useful when trying to make stderr more useful. Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'lib/bb/msg.py')
-rw-r--r--lib/bb/msg.py18
1 files changed, 16 insertions, 2 deletions
diff --git a/lib/bb/msg.py b/lib/bb/msg.py
index 59769707e..d79768db2 100644
--- a/lib/bb/msg.py
+++ b/lib/bb/msg.py
@@ -126,7 +126,21 @@ class BBLogFilter(object):
return True
return False
+class BBLogFilterStdErr(BBLogFilter):
+ def filter(self, record):
+ if not BBLogFilter.filter(self, record):
+ return False
+ if record.levelno >= logging.ERROR:
+ return True
+ return False
+class BBLogFilterStdOut(BBLogFilter):
+ def filter(self, record):
+ if not BBLogFilter.filter(self, record):
+ return False
+ if record.levelno < logging.ERROR:
+ return True
+ return False
# Message control functions
#
@@ -164,10 +178,10 @@ def constructLogOptions():
debug_domains["BitBake.%s" % domainarg] = logging.DEBUG - dlevel + 1
return level, debug_domains
-def addDefaultlogFilter(handler):
+def addDefaultlogFilter(handler, cls = BBLogFilter):
level, debug_domains = constructLogOptions()
- BBLogFilter(handler, level, debug_domains)
+ cls(handler, level, debug_domains)
#
# Message handling functions