Include files are no longer to be considered Jinja2 templates, but individual THINGS

in included files can still be templated just like top level playbooks.  Resolves
some issues about statements being evaluated before facts were available
This commit is contained in:
Michael DeHaan 2012-05-02 00:28:19 -04:00
parent aec8995fd9
commit 81b8190fc5
3 changed files with 12 additions and 6 deletions

View file

@ -23,6 +23,7 @@ Ansible Changes By Release
* service module works better on Ubuntu * service module works better on Ubuntu
* git module now does resets and such to work more smoothly on updates * git module now does resets and such to work more smoothly on updates
* fix to internals of hacking/test-module development script * fix to internals of hacking/test-module development script
* ansible-pull script and example playbook (extreme scaling, remediation)
0.3 "Baluchitherium" -- April 23, 2012 0.3 "Baluchitherium" -- April 23, 2012

View file

@ -165,7 +165,7 @@ class PlayBook(object):
include_vars[k] = v include_vars[k] = v
inject_vars = play_vars.copy() inject_vars = play_vars.copy()
inject_vars.update(include_vars) inject_vars.update(include_vars)
included = utils.template_from_file(path, inject_vars, SETUP_CACHE) included = utils.template_from_file(path, inject_vars, SETUP_CACHE, no_engine=True)
included = utils.parse_yaml(included) included = utils.parse_yaml(included)
for x in included: for x in included:
if len(include_vars): if len(include_vars):

View file

@ -230,21 +230,26 @@ def varReplace(raw, vars):
return ''.join(done) return ''.join(done)
def template(text, vars, setup_cache): def template(text, vars, setup_cache, no_engine=False):
''' run a text buffer through the templating engine ''' ''' run a text buffer through the templating engine '''
vars = vars.copy() vars = vars.copy()
text = varReplace(str(text), vars) text = varReplace(str(text), vars)
vars['hostvars'] = setup_cache vars['hostvars'] = setup_cache
template = jinja2.Template(text) if no_engine:
return template.render(vars) # used when processing include: directives so that Jinja is evaluated
# in a later context when more variables are available
return text
else:
template = jinja2.Template(text)
return template.render(vars)
def double_template(text, vars, setup_cache): def double_template(text, vars, setup_cache):
return template(template(text, vars, setup_cache), vars, setup_cache) return template(template(text, vars, setup_cache), vars, setup_cache)
def template_from_file(path, vars, setup_cache): def template_from_file(path, vars, setup_cache, no_engine=False):
''' run a file through the templating engine ''' ''' run a file through the templating engine '''
data = file(path).read() data = file(path).read()
return template(data, vars, setup_cache) return template(data, vars, setup_cache, no_engine=no_engine)
def parse_yaml(data): def parse_yaml(data):
return yaml.load(data) return yaml.load(data)