diff options
author | Holger Freyther <ich@tamarin.(none)> | 2009-05-19 10:02:55 +0200 |
---|---|---|
committer | Richard Purdie <rpurdie@linux.intel.com> | 2010-02-15 17:07:46 +0000 |
commit | a5bb5d625edfe3f23970f38165ef15ad7167efa4 (patch) | |
tree | 3e04367d08cc22597d393a58100e967d5e27c60c | |
parent | 7cfe3a5e1548c97de8842cfffa8cecc0c6b01690 (diff) | |
download | openembedded-core-a5bb5d625edfe3f23970f38165ef15ad7167efa4.tar.gz openembedded-core-a5bb5d625edfe3f23970f38165ef15ad7167efa4.tar.bz2 openembedded-core-a5bb5d625edfe3f23970f38165ef15ad7167efa4.zip |
bitbake: [parser] Move methodflags over to the ast
Signed-off-by: Richard Purdie <rpurdie@linux.intel.com>
-rw-r--r-- | bitbake/lib/bb/parse/ast.py | 38 |
1 files changed, 23 insertions, 15 deletions
diff --git a/bitbake/lib/bb/parse/ast.py b/bitbake/lib/bb/parse/ast.py index 2a2fe1d519..8296fd0a79 100644 --- a/bitbake/lib/bb/parse/ast.py +++ b/bitbake/lib/bb/parse/ast.py @@ -149,8 +149,27 @@ class PythonMethodNode: if not self.root in __parsed_methods__: text = '\n'.join(self.body) bb.methodpool.insert_method(self.root, text, self.fn) - - + +class MethodFlagsNode: + def __init__(self, key, m): + self.key = key + self.m = m + + def eval(self, data): + if bb.data.getVar(self.key, data): + # clean up old version of this piece of metadata, as its + # flags could cause problems + bb.data.setVarFlag(self.key, 'python', None, data) + bb.data.setVarFlag(self.key, 'fakeroot', None, data) + if self.m.group("py") is not None: + bb.data.setVarFlag(self.key, "python", "1", data) + else: + bb.data.delVarFlag(self.key, "python", data) + if self.m.group("fr") is not None: + bb.data.setVarFlag(self.key, "fakeroot", "1", data) + else: + bb.data.delVarFlag(self.key, "fakeroot", data) + def handleInclude(statements, m, fn, lineno, data, force): # AST handling statements.append(IncludeNode(m.group(1), fn, lineno, force)) @@ -177,19 +196,8 @@ def handlePythonMethod(statements, root, body, fn): statements[-1].eval(None) def handleMethodFlags(statements, key, m, d): - if bb.data.getVar(key, d): - # Clean up old version of this piece of metadata, as its - # flags could cause problems - bb.data.setVarFlag(key, 'python', None, d) - bb.data.setVarFlag(key, 'fakeroot', None, d) - if m.group("py") is not None: - bb.data.setVarFlag(key, "python", "1", d) - else: - bb.data.delVarFlag(key, "python", d) - if m.group("fr") is not None: - bb.data.setVarFlag(key, "fakeroot", "1", d) - else: - bb.data.delVarFlag(key, "fakeroot", d) + statements.append(MethodFlagsNode(key, m)) + statements[-1].eval(d) def handleExportFuncs(statements, m, classes, d): fns = m.group(1) |