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:
parent
aec8995fd9
commit
81b8190fc5
3 changed files with 12 additions and 6 deletions
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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):
|
||||||
|
|
|
@ -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)
|
||||||
|
|
Loading…
Reference in a new issue