Commit b4f9935b authored by Michel Pelletier's avatar Michel Pelletier

Removed raise of abstend id bug

parent ec2da131
...@@ -85,6 +85,7 @@ ...@@ -85,6 +85,7 @@
from Persistence import Persistent from Persistence import Persistent
import Acquisition import Acquisition
import ExtensionClass
import BTree, OIBTree, IOBTree, IIBTree import BTree, OIBTree, IOBTree, IIBTree
IIBucket=IIBTree.Bucket IIBucket=IIBTree.Bucket
from intSet import intSet from intSet import intSet
...@@ -126,7 +127,7 @@ def orify(seq, ...@@ -126,7 +127,7 @@ def orify(seq,
return apply(Query.Or,tuple(subqueries)) return apply(Query.Or,tuple(subqueries))
class Catalog(Persistent, Acquisition.Implicit): class Catalog(Persistent, Acquisition.Implicit, ExtensionClass.Base):
""" An Object Catalog """ An Object Catalog
An Object Catalog maintains a table of object metadata, and a An Object Catalog maintains a table of object metadata, and a
...@@ -141,7 +142,7 @@ class Catalog(Persistent, Acquisition.Implicit): ...@@ -141,7 +142,7 @@ class Catalog(Persistent, Acquisition.Implicit):
_v_brains = NoBrainer _v_brains = NoBrainer
_v_result_class = NoBrainer _v_result_class = NoBrainer
def __init__(self, brains=None): def __init__(self, vocabulary=None, brains=None):
self.schema = {} # mapping from attribute name to column number self.schema = {} # mapping from attribute name to column number
self.names = () # sequence of column names self.names = () # sequence of column names
...@@ -163,7 +164,12 @@ class Catalog(Persistent, Acquisition.Implicit): ...@@ -163,7 +164,12 @@ class Catalog(Persistent, Acquisition.Implicit):
# indexes can share a lexicon or have a private copy. Here, # indexes can share a lexicon or have a private copy. Here,
# we instantiate a lexicon to be shared by all text indexes. # we instantiate a lexicon to be shared by all text indexes.
# This may change. # This may change.
self.lexicon = Lexicon()
if type(vocabulary) is type(''):
self.lexicon = vocabulary
else:
#ack!
self.lexicon = Lexicon()
if brains is not None: if brains is not None:
self._v_brains = brains self._v_brains = brains
...@@ -352,6 +358,10 @@ class Catalog(Persistent, Acquisition.Implicit): ...@@ -352,6 +358,10 @@ class Catalog(Persistent, Acquisition.Implicit):
total = 0 total = 0
for x in self.indexes.values(): for x in self.indexes.values():
## tricky! indexes need to acquire now, and because they
## are in a standard dict __getattr__ isn't used, so
## acquisition doesn't kick in, we must explicitly wrap!
x = x.__of__(self)
if hasattr(x, 'index_object'): if hasattr(x, 'index_object'):
blah = x.index_object(i, object, threshold) blah = x.index_object(i, object, threshold)
total = total + blah total = total + blah
...@@ -369,12 +379,10 @@ class Catalog(Persistent, Acquisition.Implicit): ...@@ -369,12 +379,10 @@ class Catalog(Persistent, Acquisition.Implicit):
catalogued, otherwise it will not get removed from the catalog catalogued, otherwise it will not get removed from the catalog
""" """
if uid not in self.uids.keys():
raise ValueError, "Uncatalog of absent id %s" % `uid`
rid = self.uids[uid] rid = self.uids[uid]
for x in self.indexes.values(): for x in self.indexes.values():
x = x.__of__(self)
if hasattr(x, 'unindex_object'): if hasattr(x, 'unindex_object'):
try: try:
x.unindex_object(rid) x.unindex_object(rid)
...@@ -452,7 +460,7 @@ class Catalog(Persistent, Acquisition.Implicit): ...@@ -452,7 +460,7 @@ class Catalog(Persistent, Acquisition.Implicit):
if used is None: used={} if used is None: used={}
for i in self.indexes.keys(): for i in self.indexes.keys():
try: try:
index = self.indexes[i] index = self.indexes[i].__of__(self)
if hasattr(index,'_apply_index'): if hasattr(index,'_apply_index'):
r=index._apply_index(args) r=index._apply_index(args)
if r is not None: if r is not None:
......
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