Commit c4dfd456 authored by Michel Pelletier's avatar Michel Pelletier

Fixed circular reference and added setstate to preserve the brain.

Made minor optimizations.
parent 78d1ddcc
...@@ -157,13 +157,14 @@ class Catalog(Persistent, Acquisition.Implicit): ...@@ -157,13 +157,14 @@ class Catalog(Persistent, Acquisition.Implicit):
""" returns instances of self._v_brains, or whatever is passed """ returns instances of self._v_brains, or whatever is passed
into self.useBrains. into self.useBrains.
""" """
self.useBrains(self._v_brains)
r=self._v_result_class(self.data[index]).__of__(self.aq_parent) r=self._v_result_class(self.data[index]).__of__(self.aq_parent)
r.data_record_id_ = index r.data_record_id_ = index
return r return r
def __setstate__(self, state):
Persistent.__setstate__(self, state)
self.useBrains(self._v_brains)
def useBrains(self, brains): def useBrains(self, brains):
...@@ -178,11 +179,9 @@ class Catalog(Persistent, Acquisition.Implicit): ...@@ -178,11 +179,9 @@ class Catalog(Persistent, Acquisition.Implicit):
return self.__record_schema__.has_key(key) return self.__record_schema__.has_key(key)
scopy={} scopy={}
for key, value in self.schema.items(): scopy = self.schema.copy()
scopy[key]=value
scopy['data_record_id_']=len(self.schema.keys())
mybrains.__theCircularGottaCoverUpABugRefOfJoy = mybrains scopy['data_record_id_']=len(self.schema.keys())
mybrains.__record_schema__ = scopy mybrains.__record_schema__ = scopy
self._v_brains = brains self._v_brains = brains
...@@ -386,7 +385,6 @@ class Catalog(Persistent, Acquisition.Implicit): ...@@ -386,7 +385,6 @@ class Catalog(Persistent, Acquisition.Implicit):
def instantiate(self, record): def instantiate(self, record):
self.useBrains(self._v_brains)
r=self._v_result_class(record[1]) r=self._v_result_class(record[1])
r.data_record_id_ = record[0] r.data_record_id_ = record[0]
...@@ -443,9 +441,6 @@ class Catalog(Persistent, Acquisition.Implicit): ...@@ -443,9 +441,6 @@ class Catalog(Persistent, Acquisition.Implicit):
type(''): Query.String, type(''): Query.String,
}, **kw): }, **kw):
self.useBrains(self._v_brains)
################################################################# #################################################################
# Get search arguments: # Get search arguments:
if REQUEST is None and not kw: if REQUEST is None and not kw:
......
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