From 3a64dd25f4cb77e4d45d677ebef67d546eeab72e Mon Sep 17 00:00:00 2001 From: Doug Blank Date: Wed, 12 Aug 2015 11:21:37 -0400 Subject: [PATCH] Databases: deal with TAG_KEY; assign gramps_id, if necessary --- gramps/gen/db/generic.py | 18 +++++++++--------- gramps/plugins/database/dictionarydb.py | 1 + gramps/webapp/djangodb.py | 1 + 3 files changed, 11 insertions(+), 9 deletions(-) diff --git a/gramps/gen/db/generic.py b/gramps/gen/db/generic.py index 51511ea12..fb60ad566 100644 --- a/gramps/gen/db/generic.py +++ b/gramps/gen/db/generic.py @@ -1352,7 +1352,7 @@ class DbGeneric(DbWriteBase, DbReadBase, UpdateCallback, Callback): def add_person(self, person, trans, set_gid=True): if not person.handle: person.handle = create_id() - if not person.gramps_id and set_gid: + if (not person.gramps_id) or set_gid: person.gramps_id = self.find_next_person_gramps_id() self.commit_person(person, trans) return person.handle @@ -1360,7 +1360,7 @@ class DbGeneric(DbWriteBase, DbReadBase, UpdateCallback, Callback): def add_family(self, family, trans, set_gid=True): if not family.handle: family.handle = create_id() - if not family.gramps_id and set_gid: + if (not family.gramps_id) or set_gid: family.gramps_id = self.find_next_family_gramps_id() self.commit_family(family, trans) return family.handle @@ -1368,7 +1368,7 @@ class DbGeneric(DbWriteBase, DbReadBase, UpdateCallback, Callback): def add_citation(self, citation, trans, set_gid=True): if not citation.handle: citation.handle = create_id() - if not citation.gramps_id and set_gid: + if (not citation.gramps_id) or set_gid: citation.gramps_id = self.find_next_citation_gramps_id() self.commit_citation(citation, trans) return citation.handle @@ -1376,7 +1376,7 @@ class DbGeneric(DbWriteBase, DbReadBase, UpdateCallback, Callback): def add_source(self, source, trans, set_gid=True): if not source.handle: source.handle = create_id() - if not source.gramps_id and set_gid: + if (not source.gramps_id) or set_gid: source.gramps_id = self.find_next_source_gramps_id() self.commit_source(source, trans) return source.handle @@ -1384,7 +1384,7 @@ class DbGeneric(DbWriteBase, DbReadBase, UpdateCallback, Callback): def add_repository(self, repository, trans, set_gid=True): if not repository.handle: repository.handle = create_id() - if not repository.gramps_id and set_gid: + if (not repository.gramps_id) or set_gid: repository.gramps_id = self.find_next_repository_gramps_id() self.commit_repository(repository, trans) return repository.handle @@ -1392,7 +1392,7 @@ class DbGeneric(DbWriteBase, DbReadBase, UpdateCallback, Callback): def add_note(self, note, trans, set_gid=True): if not note.handle: note.handle = create_id() - if not note.gramps_id and set_gid: + if (not note.gramps_id) or set_gid: note.gramps_id = self.find_next_note_gramps_id() self.commit_note(note, trans) return note.handle @@ -1400,7 +1400,7 @@ class DbGeneric(DbWriteBase, DbReadBase, UpdateCallback, Callback): def add_place(self, place, trans, set_gid=True): if not place.handle: place.handle = create_id() - if not place.gramps_id and set_gid: + if (not place.gramps_id) or set_gid: place.gramps_id = self.find_next_place_gramps_id() self.commit_place(place, trans) return place.handle @@ -1408,7 +1408,7 @@ class DbGeneric(DbWriteBase, DbReadBase, UpdateCallback, Callback): def add_event(self, event, trans, set_gid=True): if not event.handle: event.handle = create_id() - if not event.gramps_id and set_gid: + if (not event.gramps_id) or set_gid: event.gramps_id = self.find_next_event_gramps_id() self.commit_event(event, trans) return event.handle @@ -1428,7 +1428,7 @@ class DbGeneric(DbWriteBase, DbReadBase, UpdateCallback, Callback): """ if not obj.handle: obj.handle = create_id() - if not obj.gramps_id and set_gid: + if (not obj.gramps_id) or set_gid: obj.gramps_id = self.find_next_object_gramps_id() self.commit_media_object(obj, transaction) return obj.handle diff --git a/gramps/plugins/database/dictionarydb.py b/gramps/plugins/database/dictionarydb.py index 9ca35794a..e7bd16495 100644 --- a/gramps/plugins/database/dictionarydb.py +++ b/gramps/plugins/database/dictionarydb.py @@ -604,6 +604,7 @@ class DictionaryDb(DbGeneric): PLACE_KEY: "place", REPOSITORY_KEY: "repository", NOTE_KEY: "note", + TAG_KEY: "tag", } if self.readonly or not handle: return diff --git a/gramps/webapp/djangodb.py b/gramps/webapp/djangodb.py index 652223e6f..c78d55758 100644 --- a/gramps/webapp/djangodb.py +++ b/gramps/webapp/djangodb.py @@ -401,6 +401,7 @@ class DbDjango(DbGeneric): PLACE_KEY: "place", REPOSITORY_KEY: "repository", NOTE_KEY: "note", + TAG_KEY: "tag", } table = getattr(self.dji, key2table[key].title()) table.filter(handle=handle)[0].delete()