diff options
author | Chris Larson <chris_larson@mentor.com> | 2010-12-09 20:29:31 -0500 |
---|---|---|
committer | Richard Purdie <rpurdie@linux.intel.com> | 2011-01-04 14:46:48 +0000 |
commit | e2363f3cdddb597c0321b6c396306be966ac58f9 (patch) | |
tree | cef6f4fd59a91c558a528b841c3159f264f68234 /bitbake/lib/bb/utils.py | |
parent | b4eff9fcefe2fefab1caaf22e497317e9338063e (diff) | |
download | openembedded-core-e2363f3cdddb597c0321b6c396306be966ac58f9.tar.gz openembedded-core-e2363f3cdddb597c0321b6c396306be966ac58f9.tar.bz2 openembedded-core-e2363f3cdddb597c0321b6c396306be966ac58f9.tar.xz openembedded-core-e2363f3cdddb597c0321b6c396306be966ac58f9.zip |
build: use a contextmanager for locks
Also don't bother passing logfile to exec_func_python, at least until we start
adding the logfile as a file handler to the bitbake logger.
(Bitbake rev: f99ee4680c9f67b7ed13fc06044ba2382f9a782c)
Signed-off-by: Chris Larson <chris_larson@mentor.com>
Signed-off-by: Richard Purdie <rpurdie@linux.intel.com>
Diffstat (limited to 'bitbake/lib/bb/utils.py')
-rw-r--r-- | bitbake/lib/bb/utils.py | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/bitbake/lib/bb/utils.py b/bitbake/lib/bb/utils.py index d9f543bc6..ba50801ae 100644 --- a/bitbake/lib/bb/utils.py +++ b/bitbake/lib/bb/utils.py @@ -26,6 +26,7 @@ import logging import bb import bb.msg from commands import getstatusoutput +from contextlib import contextmanager logger = logging.getLogger("BitBake.Util") @@ -398,6 +399,18 @@ def simple_exec(code, context): def better_eval(source, locals): return eval(source, _context, locals) +@contextmanager +def fileslocked(files): + locks = [] + if files: + for lockfile in files: + locks.append(bb.utils.lockfile(lock)) + + yield + + for lock in locks: + bb.utils.unlockfile(lock) + def lockfile(name): """ Use the file fn as a lock file, return when the lock has been acquired. |