summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Larson <chris_larson@mentor.com>2010-12-15 15:13:07 -0700
committerChris Larson <chris_larson@mentor.com>2010-12-15 15:13:07 -0700
commit7d80a5355cb540aae8d3082c1efebb72da4f93c6 (patch)
tree3b4a63670665e64b67d27e95a85f51bbb52c92f8
parentbeadff2eca1eb95f0411115dd72ddb4c3c44c604 (diff)
downloadbitbake-7d80a5355cb540aae8d3082c1efebb72da4f93c6.tar.gz
process: handle OSErrors other than file not found
Signed-off-by: Chris Larson <chris_larson@mentor.com>
-rw-r--r--lib/bb/process.py10
1 files changed, 7 insertions, 3 deletions
diff --git a/lib/bb/process.py b/lib/bb/process.py
index f02332df9..dc97e3f72 100644
--- a/lib/bb/process.py
+++ b/lib/bb/process.py
@@ -10,8 +10,9 @@ def subprocess_setup():
signal.signal(signal.SIGPIPE, signal.SIG_DFL)
class CmdError(RuntimeError):
- def __init__(self, command):
+ def __init__(self, command, message=None):
self.command = command
+ self.message = message
def __str__(self):
if not isinstance(self.command, basestring):
@@ -19,7 +20,10 @@ class CmdError(RuntimeError):
else:
cmd = self.command
- return "Execution of '%s' failed" % cmd
+ msg = "Execution of '%s' failed" % cmd
+ if self.message:
+ msg += ': %s' % self.message
+ return msg
class NotFoundError(CmdError):
def __str__(self):
@@ -94,7 +98,7 @@ def run(cmd, input=None, **options):
if exc.errno == 2:
raise NotFoundError(cmd)
else:
- raise
+ raise CmdError(cmd, exc)
if log:
stdout, stderr = _logged_communicate(pipe, log, input)