Commit 02e86f6b authored by Chris McDonough's avatar Chris McDonough

Merge fix for unecessary modification of keyword indexes to trunk.

parent 11703404
...@@ -118,28 +118,32 @@ class UnKeywordIndex(UnIndex): ...@@ -118,28 +118,32 @@ class UnKeywordIndex(UnIndex):
if type(newKeywords) is StringType: if type(newKeywords) is StringType:
newKeywords = (newKeywords, ) newKeywords = (newKeywords, )
# Now comes the fun part, we need to figure out what's changed
# if anything from the previous record.
oldKeywords = self._unindex.get(documentId, None) oldKeywords = self._unindex.get(documentId, None)
if oldKeywords is None: if oldKeywords is None:
# we've got a new document, let's not futz around.
try: try:
for kw in newKeywords: for kw in newKeywords:
self.insertForwardIndexEntry(kw, documentId) self.insertForwardIndexEntry(kw, documentId)
self._unindex[documentId] = list(newKeywords)
except TypeError: except TypeError:
return 0 return 0
else: else:
# we have an existing entry for this document, and we need
# to figure out if any of the keywords have actually changed
if type(oldKeywords) is not OOSet: oldKeywords=OOSet(oldKeywords) if type(oldKeywords) is not OOSet: oldKeywords=OOSet(oldKeywords)
newKeywords=OOSet(newKeywords) newKeywords=OOSet(newKeywords)
self.unindex_objectKeywords( fdiff = difference(oldKeywords, newKeywords)
documentId, difference(oldKeywords, newKeywords)) rdiff = difference(newKeywords, oldKeywords)
for kw in difference(newKeywords, oldKeywords): if fdiff or rdiff:
self.insertForwardIndexEntry(kw, documentId) # if we've got forward or reverse changes
self._unindex[documentId] = list(newKeywords)
self._unindex[documentId] = list(newKeywords) if fdiff:
self.unindex_objectKeywords(documentId, fdiff)
if rdiff:
for kw in rdiff:
self.insertForwardIndexEntry(kw, documentId)
return 1 return 1
def unindex_objectKeywords(self, documentId, keywords): def unindex_objectKeywords(self, documentId, keywords):
""" carefully unindex the object with integer id 'documentId'""" """ carefully unindex the object with integer id 'documentId'"""
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment