From 269d4d58a924ba34b0f4cfa8bc9dce948a79e2ef Mon Sep 17 00:00:00 2001 From: Richard Purdie Date: Fri, 12 Feb 2010 14:41:28 +0000 Subject: bitbake: [parser] Preserve include vs. require behaviour (Bitbake rev: 6073a5b8e4ca8af8e1a8e0234fad7b08baf76c99) Signed-off-by: Richard Purdie --- bitbake/lib/bb/parse/ast.py | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) (limited to 'bitbake/lib/bb') diff --git a/bitbake/lib/bb/parse/ast.py b/bitbake/lib/bb/parse/ast.py index b6dadd1e2..55bf847d1 100644 --- a/bitbake/lib/bb/parse/ast.py +++ b/bitbake/lib/bb/parse/ast.py @@ -40,10 +40,11 @@ class StatementGroup: map(lambda x: x.eval(data), self.statements) class IncludeNode: - def __init__(self, what_file, fn, lineno): + def __init__(self, what_file, fn, lineno, force): self.what_file = what_file self.from_fn = fn self.from_lineno = lineno + self.force = force def eval(self, data): """ @@ -54,7 +55,10 @@ class IncludeNode: # TODO: Cache those includes... statements = StatementGroup() - bb.parse.ConfHandler.include(statements, self.from_fn, s, data, False) + if force: + bb.parse.ConfHandler.include(statements, self.from_fn, s, data, "include required") + else: + bb.parse.ConfHandler.include(statements, self.from_fn, s, data, False) statements.eval(data) class ExportNode: @@ -107,7 +111,7 @@ class DataNode: def handleInclude(statements, m, fn, lineno, data, force): # AST handling - statements.append(IncludeNode(m.group(1), fn, lineno)) + statements.append(IncludeNode(m.group(1), fn, lineno, force)) s = bb.data.expand(m.group(1), data) bb.msg.debug(3, bb.msg.domain.Parsing, "CONF %s:%d: including %s" % (fn, lineno, s)) -- cgit v1.2.3