summaryrefslogtreecommitdiffstats
path: root/lib/bb/parse/ast.py
diff options
context:
space:
mode:
authorHolger Freyther <ich@tamarin.(none)>2009-05-19 10:02:55 +0200
committerRichard Purdie <rpurdie@linux.intel.com>2010-02-12 17:59:15 +0000
commit61d2e778302799d4a8f40c406923742cea405fa8 (patch)
treef5c9e639571eec2a1095fd97cada2f615197b738 /lib/bb/parse/ast.py
parent9c97696f37499b4d0ec5c034c51e4cf6bc425ba2 (diff)
downloadbitbake-61d2e778302799d4a8f40c406923742cea405fa8.tar.gz
[parser] Move methodflags over to the ast
Diffstat (limited to 'lib/bb/parse/ast.py')
-rw-r--r--lib/bb/parse/ast.py38
1 files changed, 23 insertions, 15 deletions
diff --git a/lib/bb/parse/ast.py b/lib/bb/parse/ast.py
index 2a2fe1d51..8296fd0a7 100644
--- a/lib/bb/parse/ast.py
+++ b/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)