pickle.dumps(db(query).select() now always works and loads restore the full object (almost)

This commit is contained in:
mdipierro
2012-09-29 23:20:37 -05:00
parent 4745ce42f9
commit d0d8a4827e
2 changed files with 22 additions and 26 deletions
+1 -1
View File
@@ -1 +1 @@
Version 2.0.9 (2012-09-29 22:33:02) dev
Version 2.0.9 (2012-09-29 23:20:28) dev
+21 -25
View File
@@ -1947,7 +1947,7 @@ class BaseAdapter(ConnectionPool):
db._referee_name % dict(
table=rfield.tablename,field=rfield.name)
if referee_link and not referee_link in colset:
colset[referee_link] = Set(db,rfield == id)
colset[referee_link] = LazySet(rfield,id)
else:
if not '_extra' in new_row:
new_row['_extra'] = Row()
@@ -6445,15 +6445,6 @@ class Row(object):
del d[k]
return d
def Row_unpickler(data):
return Row(cPickle.loads(data))
def Row_pickler(data):
return Row_unpickler, (cPickle.dumps(data.as_dict(datetime_to_str=False)),)
copy_reg.pickle(Row, Row_pickler, Row_unpickler)
################################################################################
# Everything below should be independent of the specifics of the database
# and should work for RDBMs and some NoSQL databases
@@ -6685,8 +6676,6 @@ class DAL(object):
if hasattr(self,'_adapter'): return
print 'in init'
if not decode_credentials:
credential_decoder = lambda cred: cred
else:
@@ -8849,10 +8838,12 @@ class Set(object):
class RecordUpdater(object):
def __init__(self, colset, table, id):
self.colset, self.table, self.id = colset, table, id
self.colset, self.db, self.tablename, self.id = \
colset, table._db, table._tablename, id
def __call__(self, **fields):
colset, table, id = self.colset, self.table, self.id
colset, db, tablename, id = self.colset, self.db, self.tablename, self.id
table = db[tablename]
newfields = fields or dict(colset)
for fieldname in newfields.keys():
if not fieldname in table.fields or table[fieldname].type=='id':
@@ -8863,9 +8854,23 @@ class RecordUpdater(object):
class RecordDeleter(object):
def __init__(self, table, id):
self.table, self.id = table,id
self.db, self.tablename, self.id = table._db, table._tablename, id
def __call__(self):
return self.table._db(self.table._id==self.id).delete()
return self.db(self.db[self.tablename]._id==self.id).delete()
class LazySet(object):
def __init__(self, field, id):
self.db, self.tablename, self.fieldname, self.id = \
field.db, field._tablename, field.name, id
def _getset(self):
query = self.db[self.tablename][self.fieldname]==self.id
return Set(self.db,query)
def select(self,*a,**b):
return self._getset().select(*a,**b)
def delete(self,*a,**b):
return self._getset().update(*a,**b)
def __call__(self,*a,**b):
return self._getset()(*a,**b)
class VirtualCommand(object):
@@ -9242,15 +9247,6 @@ class Rows(object):
import gluon.contrib.simplejson as simplejson
return simplejson.dumps(items)
# def Rows_unpickler(data):
# return cPickle.loads(data)
#
# def Rows_pickler(data):
# return Rows_unpickler, \
# (cPickle.dumps(data.as_list(storage_to_dict=False,
# datetime_to_str=False)),)
# copy_reg.pickle(Rows, Rows_pickler, Rows_unpickler)
################################################################################
# dummy function used to define some doctests