From c926e87f47bfef1a367cac732b64a07a2415c91e Mon Sep 17 00:00:00 2001 From: Chris Larson Date: Wed, 31 Mar 2010 09:14:18 -0700 Subject: Resurrect merged anonfunc execution (Bitbake rev: 0c2ed40277e157406ea25c858f14c3cebb73c21b) Signed-off-by: Chris Larson Signed-off-by: Richard Purdie --- bitbake/lib/bb/parse/ast.py | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) (limited to 'bitbake/lib') diff --git a/bitbake/lib/bb/parse/ast.py b/bitbake/lib/bb/parse/ast.py index d2ae09a4a4..d767882e53 100644 --- a/bitbake/lib/bb/parse/ast.py +++ b/bitbake/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 = {} -- cgit v1.2.3