Fix for the directory inventory source where depth information on the group was being discarded
due to initial copy. New model will reuse the first object and copy attributes on the second.
This commit is contained in:
parent
be33bcf16f
commit
c52abd40b0
1 changed files with 13 additions and 6 deletions
|
@ -62,15 +62,22 @@ class InventoryDirectory(object):
|
||||||
# This takes a lot of code because we can't directly use any of the objects, as they have to blend
|
# This takes a lot of code because we can't directly use any of the objects, as they have to blend
|
||||||
for name, group in parser.groups.iteritems():
|
for name, group in parser.groups.iteritems():
|
||||||
if name not in self.groups:
|
if name not in self.groups:
|
||||||
self.groups[name] = Group(name)
|
self.groups[name] = group
|
||||||
for k, v in group.get_variables().iteritems():
|
else:
|
||||||
self.groups[name].set_variable(k, v)
|
# group is already there, copy variables
|
||||||
|
# note: depth numbers on duplicates may be bogus
|
||||||
|
for k, v in group.get_variables().iteritems():
|
||||||
|
self.groups[name].set_variable(k, v)
|
||||||
for host in group.get_hosts():
|
for host in group.get_hosts():
|
||||||
if host.name not in self.hosts:
|
if host.name not in self.hosts:
|
||||||
self.hosts[host.name] = Host(host.name)
|
self.hosts[host.name] = host
|
||||||
for k, v in host.vars.iteritems():
|
else:
|
||||||
self.hosts[host.name].set_variable(k, v)
|
# host is already there, copy variables
|
||||||
|
# note: depth numbers on duplicates may be bogus
|
||||||
|
for k, v in host.vars.iteritems():
|
||||||
|
self.hosts[host.name].set_variable(k, v)
|
||||||
self.groups[name].add_host(self.hosts[host.name])
|
self.groups[name].add_host(self.hosts[host.name])
|
||||||
|
|
||||||
# This needs to be a second loop to ensure all the parent groups exist
|
# This needs to be a second loop to ensure all the parent groups exist
|
||||||
for name, group in parser.groups.iteritems():
|
for name, group in parser.groups.iteritems():
|
||||||
for ancestor in group.get_ancestors():
|
for ancestor in group.get_ancestors():
|
||||||
|
|
Loading…
Reference in a new issue