6774: Recursive call in GEDCOM export preview calculation

svn: r22649
This commit is contained in:
Doug Blank 2013-07-05 15:03:40 +00:00
parent a7e76d9a30
commit 75eef28af7

@ -58,24 +58,32 @@ class ReferencedBySelectionProxyDb(ProxyDbBase):
# Build lists of referenced objects # Build lists of referenced objects
# iter through whatever object(s) you want to start # iter through whatever object(s) you want to start
# the trace. # the trace.
self.queue = []
if all_people: if all_people:
# Do not add references to those not already included # Do not add references to those not already included
self.restricted_to["Person"] = [x for x in self.restricted_to["Person"] = [x for x in
self.db.iter_person_handles()] self.db.iter_person_handles()]
# Spread activation to all other items: # Spread activation to all other items:
for handle in self.restricted_to["Person"]: for handle in self.restricted_to["Person"]:
self.process_object("Person", handle) self.queue_object("Person", handle)
else: else:
# get rid of orphaned people: # get rid of orphaned people:
# first, get all of the links from people: # first, get all of the links from people:
for person in self.db.iter_people(): for person in self.db.iter_people():
self.process_person(person, reference=False) self.queue_object("Person", person, False)
# save those people: # save those people:
self.restricted_to["Person"] = self.referenced["Person"] self.restricted_to["Person"] = self.referenced["Person"]
# reset, and just follow those people # reset, and just follow those people
self.reset_references() self.reset_references()
for handle in self.restricted_to["Person"]: for handle in self.restricted_to["Person"]:
self.process_object("Person", handle) self.queue_object("Person", handle)
# process:
while len(self.queue):
obj_type, handle, reference = self.queue.pop()
self.process_object(obj_type, handle, reference)
def queue_object(self, obj_type, handle, reference=True):
self.queue.append((obj_type, handle, reference))
def reset_references(self): def reset_references(self):
self.referenced = { self.referenced = {
@ -91,11 +99,11 @@ class ReferencedBySelectionProxyDb(ProxyDbBase):
"Tag": set(), "Tag": set(),
} }
def process_object(self, class_name, handle): def process_object(self, class_name, handle, reference=True):
if class_name == "Person": if class_name == "Person":
obj = self.db.get_person_from_handle(handle) obj = self.db.get_person_from_handle(handle)
if obj: if obj:
self.process_person(obj) self.process_person(obj, reference)
elif class_name == "Family": elif class_name == "Family":
obj = self.db.get_family_from_handle(handle) obj = self.db.get_family_from_handle(handle)
if obj: if obj:
@ -152,7 +160,7 @@ class ReferencedBySelectionProxyDb(ProxyDbBase):
# include backward references to this object: # include backward references to this object:
for (class_name, handle) in self.db.find_backlink_handles( for (class_name, handle) in self.db.find_backlink_handles(
person.handle, ["Person", "Family"]): person.handle, ["Person", "Family"]):
self.process_object(class_name, handle) self.queue_object(class_name, handle)
name = person.get_primary_name() name = person.get_primary_name()
if name: if name:
@ -161,12 +169,12 @@ class ReferencedBySelectionProxyDb(ProxyDbBase):
for handle in person.get_family_handle_list(): for handle in person.get_family_handle_list():
family = self.db.get_family_from_handle(handle) family = self.db.get_family_from_handle(handle)
if family: if family:
self.process_family(family) self.queue_object("Family", family.handle)
for handle in person.get_parent_family_handle_list(): for handle in person.get_parent_family_handle_list():
family = self.db.get_family_from_handle(handle) family = self.db.get_family_from_handle(handle)
if family: if family:
self.process_family(family) self.queue_object("Family", family.handle)
for name in person.get_alternate_names(): for name in person.get_alternate_names():
if name: if name:
@ -197,12 +205,12 @@ class ReferencedBySelectionProxyDb(ProxyDbBase):
return return
self.referenced["Family"].add(family.handle) self.referenced["Family"].add(family.handle)
self.process_object("Person", family.mother_handle) self.queue_object("Person", family.mother_handle)
self.process_object("Person", family.father_handle) self.queue_object("Person", family.father_handle)
for child_ref in family.get_child_ref_list(): for child_ref in family.get_child_ref_list():
if not child_ref: if not child_ref:
continue continue
self.process_object("Person", child_ref.ref) self.queue_object("Person", child_ref.ref)
self.process_notes(child_ref) self.process_notes(child_ref)
self.process_citation_ref_list(child_ref) self.process_citation_ref_list(child_ref)
@ -323,7 +331,7 @@ class ReferencedBySelectionProxyDb(ProxyDbBase):
if obj_class == "Media": # bug6493 if obj_class == "Media": # bug6493
obj_class = "MediaObject" obj_class = "MediaObject"
if prop == "handle": if prop == "handle":
self.process_object(obj_class, value) self.queue_object(obj_class, value)
def process_notes(self, original_obj): def process_notes(self, original_obj):
""" Find all of the primary objects referred to """ """ Find all of the primary objects referred to """
@ -401,7 +409,7 @@ class ReferencedBySelectionProxyDb(ProxyDbBase):
fam_handle = lds_ord.get_family_handle() fam_handle = lds_ord.get_family_handle()
fam = self.db.get_family_from_handle(fam_handle) fam = self.db.get_family_from_handle(fam_handle)
if fam: if fam:
self.process_family(fam) self.queue_object("Family", fam_handle)
place_handle = lds_ord.get_place_handle() place_handle = lds_ord.get_place_handle()
if place_handle: if place_handle:
@ -420,7 +428,7 @@ class ReferencedBySelectionProxyDb(ProxyDbBase):
self.process_notes(person_ref) self.process_notes(person_ref)
person = self.db.get_person_from_handle(person_ref.ref) person = self.db.get_person_from_handle(person_ref.ref)
if person: if person:
self.process_person(person) self.queue_object("Person", person.handle)
def process_event_ref(self, event_ref): def process_event_ref(self, event_ref):
""" Find all of the primary objects referred to """ """ Find all of the primary objects referred to """