Merge pull request #12114 from ilya-epifanov/devel

fixed hostvars access in conjunction with --limit usage
pull/12078/head
James Cammarata 9 years ago
commit 1170a453c8

@ -178,7 +178,7 @@ class Inventory(object):
return [x for x in term.findall(pattern) if x] return [x for x in term.findall(pattern) if x]
def get_hosts(self, pattern="all"): def get_hosts(self, pattern="all", ignore_limits_and_restrictions=False):
""" """
Takes a pattern or list of patterns and returns a list of matching Takes a pattern or list of patterns and returns a list of matching
inventory host names, taking into account any active restrictions inventory host names, taking into account any active restrictions
@ -196,6 +196,8 @@ class Inventory(object):
patterns = self._split_pattern(pattern) patterns = self._split_pattern(pattern)
hosts = self._evaluate_patterns(patterns) hosts = self._evaluate_patterns(patterns)
# mainly useful for hostvars[host] access
if not ignore_limits_and_restrictions:
# exclude hosts not in a subset, if defined # exclude hosts not in a subset, if defined
if self._subset: if self._subset:
subset = self._evaluate_patterns(self._subset) subset = self._evaluate_patterns(self._subset)

@ -43,7 +43,7 @@ class HostVars(collections.Mapping):
# in inventory # in inventory
restriction = inventory._restriction restriction = inventory._restriction
inventory.remove_restriction() inventory.remove_restriction()
hosts = inventory.get_hosts() hosts = inventory.get_hosts(ignore_limits_and_restrictions=True)
inventory.restrict_to_hosts(restriction) inventory.restrict_to_hosts(restriction)
# check to see if localhost is in the hosts list, as we # check to see if localhost is in the hosts list, as we

Loading…
Cancel
Save