summaryrefslogtreecommitdiffstats
path: root/lib/bb/parse/ast.py
diff options
context:
space:
mode:
authorChris Larson <chris_larson@mentor.com>2010-03-31 09:14:18 -0700
committerChris Larson <chris_larson@mentor.com>2010-03-31 09:14:18 -0700
commit0c2ed40277e157406ea25c858f14c3cebb73c21b (patch)
tree317dd2dc9151f768570591a537d5a2d2672f2737 /lib/bb/parse/ast.py
parent5ead16f14f996bcbb2fb14277b8ce5a9317b8160 (diff)
downloadbitbake-0c2ed40277e157406ea25c858f14c3cebb73c21b.tar.gz
Resurrect merged anonfunc execution
Signed-off-by: Chris Larson <chris_larson@mentor.com>
Diffstat (limited to 'lib/bb/parse/ast.py')
-rw-r--r--lib/bb/parse/ast.py13
1 files changed, 9 insertions, 4 deletions
diff --git a/lib/bb/parse/ast.py b/lib/bb/parse/ast.py
index d2ae09a4a..d767882e5 100644
--- a/lib/bb/parse/ast.py
+++ b/lib/bb/parse/ast.py
@@ -122,8 +122,12 @@ class MethodNode:
def eval(self, data):
if self.func_name == "__anonymous":
+ funcname = ("__anon_%s_%s" % (self.lineno, self.fn.translate(string.maketrans('/.+-', '____'))))
+ if not funcname in bb.methodpool._parsed_fns:
+ text = "def %s(d):\n" % (funcname) + '\n'.join(self.body)
+ bb.methodpool.insert_method(funcname, text, self.fn)
anonfuncs = bb.data.getVar('__BBANONFUNCS', data) or []
- anonfuncs.append((self.fn, "\n".join(self.body)))
+ anonfuncs.append(funcname)
bb.data.setVar('__BBANONFUNCS', anonfuncs, data)
else:
bb.data.setVarFlag(self.func_name, "func", 1, data)
@@ -297,9 +301,10 @@ def finalise(fn, d):
bb.data.expandKeys(d)
bb.data.update_data(d)
- for fn, func in bb.data.getVar("__BBANONFUNCS", d) or []:
- funcdef = "def __anonfunc(d):\n%s\n__anonfunc(d)" % func.rstrip()
- bb.utils.better_exec(funcdef, {"d": d}, funcdef, fn)
+ code = []
+ for funcname in bb.data.getVar("__BBANONFUNCS", d) or []:
+ code.append("%s(d)" % funcname)
+ bb.utils.simple_exec("\n".join(code), {"d": d})
bb.data.update_data(d)
all_handlers = {}