aboutsummaryrefslogtreecommitdiffstats
path: root/libbe
diff options
context:
space:
mode:
Diffstat (limited to 'libbe')
-rw-r--r--libbe/bugdir.py14
1 files changed, 8 insertions, 6 deletions
diff --git a/libbe/bugdir.py b/libbe/bugdir.py
index 0399a82..a3a388c 100644
--- a/libbe/bugdir.py
+++ b/libbe/bugdir.py
@@ -255,14 +255,16 @@ class BugDir (list, settings_object.SavedSettingsObject):
def new_bug(self, summary=None, _uuid=None):
bg = bug.Bug(bugdir=self, uuid=_uuid, summary=summary,
from_storage=False)
- self.append(bg)
+ self.append(bg, update=True)
return bg
- def append(self, bug):
+ def append(self, bug, update=False):
super(BugDir, self).append(bug)
- self._bug_map_gen()
- if hasattr(self, '_uuids_cache') and not bug.uuid in self._uuids_cache:
- self._uuids_cache.add(bug.uuid)
+ if update:
+ self._bug_map_gen()
+ if (hasattr(self, '_uuids_cache') and
+ not bug.uuid in self._uuids_cache):
+ self._uuids_cache.add(bug.uuid)
def remove_bug(self, bug):
if hasattr(self, '_uuids_cache') and bug.uuid in self._uuids_cache:
@@ -443,7 +445,7 @@ class BugDir (list, settings_object.SavedSettingsObject):
bg = bug.Bug(bugdir=self)
bg.from_xml(
child, preserve_uuids=preserve_uuids, verbose=verbose)
- self.append(bg)
+ self.append(bg, update=True)
continue
elif child.tag in tags:
if child.text == None or len(child.text) == 0: