Commit 5b7d13fa authored by Julien Muchembled's avatar Julien Muchembled

Small optimizations in catalogObjectList

git-svn-id: https://svn.erp5.org/repos/public/erp5/trunk@30522 20353a03-c40f-0410-a6d1-a30d3c3de9de
parent b271df8b
No related merge requests found
...@@ -1291,30 +1291,24 @@ class Catalog(Folder, ...@@ -1291,30 +1291,24 @@ class Catalog(Folder,
assigned_uid_dict = {} assigned_uid_dict = {}
for object in object_list: for object in object_list:
if getattr(aq_base(object), 'uid', None) is None: uid = getattr(aq_base(object), 'uid', None)
# Several Tool objects have uid=0 (not 0L) from the beginning, but
# we need an unique uid for each object.
if uid is None or isinstance(uid, int) and uid == 0:
try: try:
object.uid = self.newUid() object.uid = self.newUid()
except ConflictError: except ConflictError:
raise raise
except: except:
raise RuntimeError, 'could not set missing uid for %r' % (object,) raise RuntimeError, 'could not set missing uid for %r' % (object,)
elif isinstance(object.uid, int) and object.uid == 0:
# Several Tool objects have uid=0 (not 0L) from the beginning, but
# we need an unique uid for each object.
object.uid = self.newUid()
elif check_uid: elif check_uid:
uid = object.uid
if uid in assigned_uid_dict: if uid in assigned_uid_dict:
raise ValueError('uid of %r is %r and ' raise ValueError('uid of %r is %r and '
'is already assigned to %s in catalog !!! This can be fatal.' % 'is already assigned to %s in catalog !!! This can be fatal.' %
(object, uid, assigned_uid_dict[uid])) (object, uid, assigned_uid_dict[uid]))
path = object.getPath() path = object.getPath()
index = path_uid_dict.get(path, None) index = path_uid_dict.get(path)
try:
index = long(index)
except TypeError:
index = None
if index is not None: if index is not None:
if index < 0: if index < 0:
raise CatalogError, 'A negative uid %d is used for %s. Your catalog is broken. Recreate your catalog.' % (index, path) raise CatalogError, 'A negative uid %d is used for %s. Your catalog is broken. Recreate your catalog.' % (index, path)
...@@ -1333,9 +1327,9 @@ class Catalog(Folder, ...@@ -1333,9 +1327,9 @@ class Catalog(Folder,
#LOG('catalogObject', 0, 'uid = %r, catalog_path = %r' % (uid, catalog_path)) #LOG('catalogObject', 0, 'uid = %r, catalog_path = %r' % (uid, catalog_path))
if catalog_path == "reserved": if catalog_path == "reserved":
# Reserved line in catalog table # Reserved line in catalog table
klass = self.__class__ lock = self.__class__._reserved_uid_lock
try: try:
klass._reserved_uid_lock.acquire() lock.acquire()
uid_buffer = self.getUIDBuffer() uid_buffer = self.getUIDBuffer()
if uid_buffer is not None: if uid_buffer is not None:
# This is the case where: # This is the case where:
...@@ -1351,7 +1345,7 @@ class Catalog(Folder, ...@@ -1351,7 +1345,7 @@ class Catalog(Folder,
except ValueError: except ValueError:
pass pass
finally: finally:
klass._reserved_uid_lock.release() lock.release()
elif catalog_path is not None: elif catalog_path is not None:
# An uid conflict happened... Why? # An uid conflict happened... Why?
# can be due to path length # can be due to path length
......
...@@ -839,7 +839,7 @@ class ZCatalog(Folder, Persistent, Implicit): ...@@ -839,7 +839,7 @@ class ZCatalog(Folder, Persistent, Implicit):
if wrapped_object_list: if wrapped_object_list:
destination_catalog.catalogObjectList(wrapped_object_list,**kw) destination_catalog.catalogObjectList(wrapped_object_list,**kw)
object_list[:] = failed_object_list[:] object_list[:] = failed_object_list
def uncatalog_object(self, uid=None,path=None, sql_catalog_id=None): def uncatalog_object(self, uid=None,path=None, sql_catalog_id=None):
""" wrapper around catalog """ """ wrapper around catalog """
......
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