Commit c616b8dd authored by Michel Pelletier's avatar Michel Pelletier

Fixed the case where sort_on and a text index were specified, now, the

sort_index allways wins and the results are not sorted by score info
parent a2e8d29e
...@@ -481,7 +481,7 @@ class Catalog(Persistent, Acquisition.Implicit): ...@@ -481,7 +481,7 @@ class Catalog(Persistent, Acquisition.Implicit):
for k, intset in sort_index._index.items(): for k, intset in sort_index._index.items():
append((k,LazyMap(self.__getitem__, intset))) append((k,LazyMap(self.__getitem__, intset)))
elif rs: elif rs:
if type(rs) is IIBType: if sort_index is None and type(rs) is IIBType:
# then there is score information. Build a new result # then there is score information. Build a new result
# set, sort it by score, reverse it, compute the # set, sort it by score, reverse it, compute the
# normalized score, and Lazify it. # normalized score, and Lazify it.
...@@ -505,7 +505,10 @@ class Catalog(Persistent, Acquisition.Implicit): ...@@ -505,7 +505,10 @@ class Catalog(Persistent, Acquisition.Implicit):
# context of text index query. This should probably # context of text index query. This should probably
# sort by relevance first, then the 'sort-on' attribute. # sort by relevance first, then the 'sort-on' attribute.
for k, intset in sort_index._index.items(): for k, intset in sort_index._index.items():
intset=intset.intersection(rs) if type(rs) is IIBType:
intset=rs.intersection(intset)
else:
intset=intset.intersection(rs)
if intset: if intset:
append((k,LazyMap(self.__getitem__, intset))) append((k,LazyMap(self.__getitem__, intset)))
......
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