Commit f1c1e00f authored by joey's avatar joey

*** empty log message ***

parent b01beadb
...@@ -93,8 +93,12 @@ from string import replace ...@@ -93,8 +93,12 @@ from string import replace
import struct import struct
import base64 import base64
import string import string
import xmllib, pickle import regex
import pickle
import tempfile
import marshal
ListType=type([])
# Create a list of all the characters # Create a list of all the characters
L = map(chr,range(256)) L = map(chr,range(256))
...@@ -139,21 +143,49 @@ def unconvert(encoding,S): ...@@ -139,21 +143,49 @@ def unconvert(encoding,S):
original = base64.decodestring(S) original = base64.decodestring(S)
else: else:
x = string.replace(S, '\n', '') x = string.replace(S, '\n', '')
original = eval("'"+x+"'") original = eval("'"+x+"'")
return original return original
t32 = 1L << 32
def p64(v, pack=struct.pack):
if v < t32: h=0
else:
h=v/t32
v=v%t32
return pack(">II", h, v)
def u64(v, unpack=struct.unpack):
h, v = unpack(">ii", v)
if v < 0: v=t32-v
if h:
if h < 0: h=t32-h
v=h*t32+v
return v
def cp(f1, f2, l):
read=f1.read
write=f2.write
n=8192
while l > 0:
if n > l: n=l
d=read(n)
write(d)
l = l - len(d)
class Global: class Global:
def __init__(self, module, name): def __init__(self, module, name):
self.module=module self.module=module
self.name=name self.name=name
def __str__(self, indent=0): def __str__(self, indent=0):
if hasattr(self, 'id'): id=' id="%s"' % self.id if hasattr(self, 'id'): id=' id="%s"' % self.id
else: id='' else: id=''
name=string.lower(self.__class__.__name__) name=string.lower(self.__class__.__name__)
return '%s<%s%s name="%s" module="%s"/>\n' % ( return '%s<%s%s name="%s" module="%s"/>\n' % (
' '*indent, name, id, self.name, self.module) ' '*indent, name, id, self.name, self.module)
class Scalar: class Scalar:
...@@ -163,16 +195,16 @@ class Scalar: ...@@ -163,16 +195,16 @@ class Scalar:
def value(self): return self._v def value(self): return self._v
def __str__(self, indent=0): def __str__(self, indent=0):
if hasattr(self, 'id'): id=' id="%s"' % self.id if hasattr(self, 'id'): id=' id="%s"' % self.id
else: id='' else: id=''
name=string.lower(self.__class__.__name__) name=string.lower(self.__class__.__name__)
return '%s<%s%s>%s</%s>\n' % ( return '%s<%s%s>%s</%s>\n' % (
' '*indent, name, id, self.value(), name) ' '*indent, name, id, self.value(), name)
def xmlstr(v): def xmlstr(v):
v=`v` v=`v`
if v[:1]=='\'': if v[:1]=='\'':
v=string.replace(v,'"','\\"') v=string.replace(v,'"','\\"')
v=replace(v,'%','\\045') v=replace(v,'%','\\045')
v=replace(v,'&','\\046') v=replace(v,'&','\\046')
return v[1:-1] return v[1:-1]
...@@ -186,7 +218,6 @@ class String(Scalar): ...@@ -186,7 +218,6 @@ class String(Scalar):
encoding, v = convert(v) encoding, v = convert(v)
self.encoding=encoding self.encoding=encoding
self._v=v self._v=v
def value(self): return self._v
def __str__(self,indent=0): def __str__(self,indent=0):
if hasattr(self,'id'):id=' id="%s"' % self.id if hasattr(self,'id'):id=' id="%s"' % self.id
else: id='' else: id=''
...@@ -203,29 +234,29 @@ class Wrapper: ...@@ -203,29 +234,29 @@ class Wrapper:
def value(self): return self._v def value(self): return self._v
def __str__(self, indent=0): def __str__(self, indent=0):
if hasattr(self, 'id'): id=' id="%s"' % self.id if hasattr(self, 'id'): id=' id="%s"' % self.id
else: id='' else: id=''
name=string.lower(self.__class__.__name__) name=string.lower(self.__class__.__name__)
v=self._v v=self._v
i=' '*indent i=' '*indent
if isinstance(v,Scalar): if isinstance(v,Scalar):
return '%s<%s%s> %s </%s>\n' % (i, name, id, str(v)[:-1], name) return '%s<%s%s> %s </%s>\n' % (i, name, id, str(v)[:-1], name)
else: else:
v=v.__str__(indent+2) v=v.__str__(indent+2)
return '%s<%s%s>\n%s%s</%s>\n' % (i, name, id, v, i, name) return '%s<%s%s>\n%s%s</%s>\n' % (i, name, id, v, i, name)
class Collection: class Collection:
def __str__(self, indent=0): def __str__(self, indent=0):
if hasattr(self, 'id'): id=' id="%s"' % self.id if hasattr(self, 'id'): id=' id="%s"' % self.id
else: id='' else: id=''
name=string.lower(self.__class__.__name__) name=string.lower(self.__class__.__name__)
i=' '*indent i=' '*indent
if self: if self:
return '%s<%s%s>\n%s%s</%s>\n' % ( return '%s<%s%s>\n%s%s</%s>\n' % (
i, name, id, self.value(indent+2), i, name) i, name, id, self.value(indent+2), i, name)
else: else:
return '%s<%s%s/>\n' % (i, name, id) return '%s<%s%s/>\n' % (i, name, id)
class Key(Wrapper): pass class Key(Wrapper): pass
class Value(Wrapper): pass class Value(Wrapper): pass
...@@ -235,35 +266,35 @@ class Dictionary(Collection): ...@@ -235,35 +266,35 @@ class Dictionary(Collection):
def __len__(self): return len(self._d) def __len__(self): return len(self._d)
def __setitem__(self, k, v): self._d[k]=v def __setitem__(self, k, v): self._d[k]=v
def value(self, indent): def value(self, indent):
return string.join( return string.join(
map(lambda i, ind=' '*indent, indent=indent+4: map(lambda i, ind=' '*indent, indent=indent+4:
'%s<item>\n' '%s<item>\n'
'%s' '%s'
'%s' '%s'
'%s</item>\n' '%s</item>\n'
% %
(ind, (ind,
Key(i[0]).__str__(indent), Key(i[0]).__str__(indent),
Value(i[1]).__str__(indent), Value(i[1]).__str__(indent),
ind), ind),
self._d.items() self._d.items()
), ),
'') '')
class Sequence(Collection): class Sequence(Collection):
def __init__(self, v=None): def __init__(self, v=None):
if not v: v=[] if not v: v=[]
self._subs=v self._subs=v
def __len__(self): return len(self._subs) def __len__(self): return len(self._subs)
def append(self, v): self._subs.append(v) def append(self, v): self._subs.append(v)
def value(self, indent): def value(self, indent):
return string.join(map( return string.join(map(
lambda v, indent=indent: v.__str__(indent), lambda v, indent=indent: v.__str__(indent),
self._subs),'') self._subs),'')
class List(Sequence): pass class List(Sequence): pass
class Tuple(Sequence): pass class Tuple(Sequence): pass
...@@ -280,18 +311,134 @@ none=none() ...@@ -280,18 +311,134 @@ none=none()
class Reference(Scalar): class Reference(Scalar):
def __init__(self, v): self._v=v def __init__(self, v): self._v=v
def __str__(self, indent=0): def __str__(self, indent=0):
v=self._v v=self._v
name=string.lower(self.__class__.__name__) name=string.lower(self.__class__.__name__)
return '%s<%s id="%s"/>\n' % (' '*indent,name,v) return '%s<%s id="%s"/>\n' % (' '*indent,name,v)
Get=Reference Get=Reference
class Object(Sequence): class Object(Sequence):
def __init__(self, klass, args): def __init__(self, klass, args):
self._subs=[Klass(klass), args] self._subs=[Klass(klass), args]
def __setstate__(self, v): self.append(State(v)) def __setstate__(self, v): self.append(State(v))
class ZopeData:
def __init__(self, parser, tag, attrs):
self._pos=0
self.file=parser.file
self.tempfile=parser.tempfile
def append(self, transaction, f=None):
file=self.file
write=file.write
tfile=self.tempfile
dlen=tfile.tell()
tfile.seek(0)
id=transaction.serial
user, desc, ext = transaction._ude
transaction._ude=None
tlen=transaction._thl
pos=self._pos
file.seek(pos)
tl=tlen+dlen
stl=p64(tl)
write(struct.pack(
">8s" "8s" "c" "H" "H" "H"
, id, stl, ' ', len(user), len(desc), len(ext),
))
if user: write(user)
if desc: write(desc)
if ext: write(ext)
cp(tfile,file,dlen)
write(stl)
self._pos=pos+tl+8
class Transaction:
def __init__(self, parser, tag, attrs):
self.file=parser.file
self.tempfile=parser.tempfile
self.tempfile.seek(0)
tyme=attrs['time']
start=0
stop=string.find(tyme[start:],'-')+start
year=string.atoi(tyme[start:stop])
start=stop+1
stop=string.find(tyme[start:],'-')+start
month=string.atoi(tyme[start:stop])
start=stop+1
stop=string.find(tyme[start:],' ')+start
day=string.atoi(tyme[start:stop])
start=stop+1
stop=string.find(tyme[start:],':')+start
hour=string.atoi(tyme[start:stop])
start=stop+1
stop=string.find(tyme[start:],':')+start
minute=string.atoi(tyme[start:stop])
start=stop+1
second=string.atof(tyme[start:])
t=(((((year-1900)*12+month-1)*31+day-1)*24+hour)*60+minute)
t=struct.pack(">If",t,second*(1L<<32)/60)
self.serial=t
self._user=user=''
self._descr=desc=''
self._ext=ext=''
self._thl= 23+len(user)+len(desc)+len(ext)
self._ude= user, desc, ext
self._index={}
self._tindex=[]
self._pos=0
self._oid='\0\0\0\0\0\0\0\0'
def append(self, data):
version=''
old=self._index.get(self._oid,0)
pnv=None
if old:
file=self.file
file.seek(old)
read=file.read
h=read(42)
doid,oserial,sprev,stloc,vlen,splen = unpack(">8s8s8s8sH8s", h)
if doid != self.serial: raise CorruptedDataError, h
# if vlen:
# pnv=read(8)
# if (len(version) != vlen or
# (read(8)
# and version !=read(vlen))):
# raise POSException.VersionLockError, oid
# if self.serial !=oserial: raise POSException.ConflictError
tfile=self.tempfile
write=tfile.write
pos=self._pos
serial=self.serial
oid=self._oid
here=tfile.tell()+pos+self._thl
self._tindex.append(self._oid, here)
serial=self.serial
write(struct.pack(">8s8s8s8sH8s", oid, serial, p64(old), p64(pos),
len(version), p64(len(data))))
# if version:
# if pnv: write(pnv)
# else: write(p64(old))
# tvindex=self._tvindex
# pv=tvindex.get(version, 0) or self._vindexpos(version,0)
# write(p64(pv))
# tvindex[version]=here
# write(version)
for x in data[2:]:
write(x)
return serial
class ToXMLUnpickler(Unpickler): class ToXMLUnpickler(Unpickler):
def load(self): return Pickle(Unpickler.load(self)) def load(self): return Pickle(Unpickler.load(self))
...@@ -300,7 +447,7 @@ class ToXMLUnpickler(Unpickler): ...@@ -300,7 +447,7 @@ class ToXMLUnpickler(Unpickler):
dispatch.update(Unpickler.dispatch) dispatch.update(Unpickler.dispatch)
def persistent_load(self, v): def persistent_load(self, v):
return Persistent(v) return Persistent(v)
def load_persid(self): def load_persid(self):
pid = self.readline()[:-1] pid = self.readline()[:-1]
...@@ -335,9 +482,13 @@ class ToXMLUnpickler(Unpickler): ...@@ -335,9 +482,13 @@ class ToXMLUnpickler(Unpickler):
self.append(Float(string.atof(self.readline()[:-1]))) self.append(Float(string.atof(self.readline()[:-1])))
dispatch[FLOAT] = load_float dispatch[FLOAT] = load_float
def load_binfloat(self, unpack=struct.unpack):
self.append(Float(unpack('>d', self.read(8))[0]))
dispatch[BINFLOAT] = load_binfloat
def load_string(self): def load_string(self):
self.append(String(eval(self.readline()[:-1], self.append(String(eval(self.readline()[:-1],
{'__builtins__': {}}))) # Let's be careful {'__builtins__': {}}))) # Let's be careful
dispatch[STRING] = load_string dispatch[STRING] = load_string
def load_binstring(self): def load_binstring(self):
...@@ -389,7 +540,7 @@ class ToXMLUnpickler(Unpickler): ...@@ -389,7 +540,7 @@ class ToXMLUnpickler(Unpickler):
del self.stack[k:] del self.stack[k:]
module = self.readline()[:-1] module = self.readline()[:-1]
name = self.readline()[:-1] name = self.readline()[:-1]
value=Object(Global(module, name), args) value=Object(Global(module, name), args)
self.append(value) self.append(value)
dispatch[INST] = load_inst dispatch[INST] = load_inst
...@@ -400,7 +551,7 @@ class ToXMLUnpickler(Unpickler): ...@@ -400,7 +551,7 @@ class ToXMLUnpickler(Unpickler):
del stack[k + 1] del stack[k + 1]
args = Tuple(stack[k + 1:]) args = Tuple(stack[k + 1:])
del stack[k:] del stack[k:]
value=Object(klass,args) value=Object(klass,args)
self.append(value) self.append(value)
dispatch[OBJ] = load_obj dispatch[OBJ] = load_obj
...@@ -417,7 +568,7 @@ class ToXMLUnpickler(Unpickler): ...@@ -417,7 +568,7 @@ class ToXMLUnpickler(Unpickler):
arg_tup = stack[-1] arg_tup = stack[-1]
del stack[-2:] del stack[-2:]
value=Object(callable, arg_tup) value=Object(callable, arg_tup)
self.append(value) self.append(value)
dispatch[REDUCE] = load_reduce dispatch[REDUCE] = load_reduce
...@@ -438,22 +589,20 @@ class ToXMLUnpickler(Unpickler): ...@@ -438,22 +589,20 @@ class ToXMLUnpickler(Unpickler):
dispatch[LONG_BINGET] = load_long_binget dispatch[LONG_BINGET] = load_long_binget
def load_put(self): def load_put(self):
self.stack[-1].id=self.idprefix+self.readline()[:-1] self.stack[-1].id=self.idprefix+self.readline()[:-1]
dispatch[PUT] = load_put dispatch[PUT] = load_put
def load_binput(self): def load_binput(self):
i = mloads('i' + self.read(1) + '\000\000\000') i = mloads('i' + self.read(1) + '\000\000\000')
self.stack[-1].id=self.idprefix+`i` self.stack[-1].id=self.idprefix+`i`
dispatch[BINPUT] = load_binput dispatch[BINPUT] = load_binput
def load_long_binput(self): def load_long_binput(self):
i = mloads('i' + self.read(4)) i = mloads('i' + self.read(4))
self.stack[-1].id=self.idprefix+`i` self.stack[-1].id=self.idprefix+`i`
dispatch[LONG_BINPUT] = load_long_binput dispatch[LONG_BINPUT] = load_long_binput
def ToXMLload(file): def ToXMLload(file):
return ToXMLUnpickler(file).load() return ToXMLUnpickler(file).load()
...@@ -461,21 +610,29 @@ def ToXMLloads(str): ...@@ -461,21 +610,29 @@ def ToXMLloads(str):
file = StringIO(str) file = StringIO(str)
return ToXMLUnpickler(file).load() return ToXMLUnpickler(file).load()
class xyap:
class XYap:
start_handlers={} start_handlers={}
end_handlers={} end_handlers={}
def __init__(self): def __init__(self, file, binary=0):
xmllib.XMLParser.__init__(self)
top=[] top=[]
self.file=file
self.tempfile=tempfile.TemporaryFile()
self._stack=_stack=[top] self._stack=_stack=[top]
self.push=_stack.append self.push=_stack.append
self.append=top.append self.append=top.append
self.binary=binary
def handle_data(self, data): self.append(data) def handle_data(self, data): self.append(data)
def unknown_starttag(self, tag, attrs): def unknown_starttag(self, tag, attrs):
if type(attrs) is ListType:
x=0
temp={}
while x<len(attrs):
temp[attrs[x]]=attrs[x+1]
x=x+2
attrs=temp
start=self.start_handlers start=self.start_handlers
if start.has_key(tag): tag = start[tag](self, tag, attrs) if start.has_key(tag): tag = start[tag](self, tag, attrs)
else: tag = [tag, attrs] else: tag = [tag, attrs]
...@@ -500,9 +657,9 @@ def name(self, tag, data, join=string.join, strip=string.strip): ...@@ -500,9 +657,9 @@ def name(self, tag, data, join=string.join, strip=string.strip):
return strip(join(data[2:],'')) return strip(join(data[2:],''))
def start_pickle(self, tag, attr): def start_pickle(self, tag, attrs):
self._pickleids={} self._pickleids={}
return [tag,attr] return [tag,attrs]
def end_string(self, tag, data): def end_string(self, tag, data):
v=data[2] v=data[2]
...@@ -541,7 +698,7 @@ def end_item(self, tag, data): ...@@ -541,7 +698,7 @@ def end_item(self, tag, data):
v=data[2:] v=data[2:]
return v return v
class xmlUnpickler(NoBlanks, XYap, xmllib.XMLParser): class xmlUnpickler(NoBlanks, xyap):
start_handlers={'pickle': start_pickle} start_handlers={'pickle': start_pickle}
end_handlers={ end_handlers={
'int': 'int':
...@@ -573,62 +730,155 @@ def save_none(self, tag, data): ...@@ -573,62 +730,155 @@ def save_none(self, tag, data):
return 'N' return 'N'
def save_int(self, tag, data): def save_int(self, tag, data):
binary=self.binary
if binary:
v=string.atoi(name(self, tag, data))
i=mdumps(v)[1:]
if (i[-2:] == '\000\000'):
if (i[-3] == '\000'):
v='K'+i[:-3]
return v
v='M'+i[:-2]
return v
v='J'+i
return v
v='I'+name(self, tag, data)+'\012' v='I'+name(self, tag, data)+'\012'
return v return v
def save_float(self, tag, data): def save_float(self, tag, data):
v='F'+name(self, tag, data)+'\012' binary=self.binary
if binary: v='G'+struct.pack('>d',string.atof(name(self, tag, data)))
else: v='F'+name(self, tag, data)+'\012'
return v return v
def save_string(self, tag, data): def save_string(self, tag, data):
v=data[2] binary=self.binary
if len(data)>2: v=data[2]
else: v=''
a=data[1] a=data[1]
encoding=a['encoding'] encoding=a['encoding']
if encoding is not '': if encoding is not '':
v=base.unconvert(encoding,v) v=unconvert(encoding,v)
id=a['id'] put='p'
prefix=string.rfind(id,'.') if binary:
if prefix>=0: id=id[prefix:] l=len(v)
v="S'"+v+"'\012"+"p"+id+"\012" s=mdumps(l)[1:]
if (l<256):
v='U'+s[0]+v
else:
v='T'+s+v
put='q'
else: v="S'"+v+"'\012"
if a.has_key('id'):
id=a['id']
prefix=string.rfind(id,'.')
if prefix>=0: id=id[prefix+1:]
if binary:
id=string.atoi(id)
s=mdumps(id)[1:]
if (id < 256):
id=s[0]
put='q'
else:
id=s
put='r'
v=v+put+id
else: v=v+put+id+"\012"
return v return v
def save_tuple(self, tag, data): def save_tuple(self, tag, data):
binary=self.binary
T=data[2:] T=data[2:]
a=data[1] a=data[1]
v='' v=''
put='p'
for x in T: for x in T:
v=v+x v=v+x
id=a['id'] if v is '': return ')'
prefix=string.rfind(id,'.') v='('+v+'t'
if prefix>=0: id=id[prefix:] if a.has_key('id'):
if a.has_key('id'): v='('+v+'tp'+id+'\012' id=a['id']
prefix=string.rfind(id,'.')
if prefix>=0: id=id[prefix+1:]
if binary:
id=string.atoi(id)
s=mdumps(id)[1:]
if (id < 256):
id=s[0]
put='q'
else:
id=s
put='r'
v=v+put+id
else:
v=v+put+id+'\012'
return v return v
def save_list(self, tag, data): def save_list(self, tag, data):
binary=self.binary
L=data[2:] L=data[2:]
a=data[1] a=data[1]
id=a['id'] v=''
prefix=string.rfind(id,'.')
if prefix>=0: id=id[prefix:]
v='(lp'+id+'\012'
x=0 x=0
while x<len(L): if a.has_key('id'):
v=v+L[x]+'a' id=a['id']
x=x+1 prefix=string.rfind(id,'.')
if prefix>=0: id=id[prefix+1:]
if binary:
while x<len(L):
v=v+L[x]
x=x+1
if id:
id=string.atoi(id)
s=mdumps(id)[1:]
if (id < 256):
id=s[0]
put='q'
else:
id=s
put='r'
if v is not '':
v=']'+put+id+'('+v+'e'
else: v=']'+put+id
else:
while x<len(L):
v=v+L[x]+'a'
x=x+1
if id:
v='(lp'+id+'\012'+v
if v=='': v=']'
return v return v
def save_dict(self, tag, data): def save_dict(self, tag, data):
binary=self.binary
D=data[2:] D=data[2:]
a=data[1] a=data[1]
id=a['id'] id=a['id']
prefix=string.rfind(id,'.') prefix=string.rfind(id,'.')
if prefix>=0: id=id[prefix:] if prefix>=0: id=id[prefix+1:]
v='(dp'+id+'\012' if binary:
x=0 id=string.atoi(id)
while x<len(D): s=mdumps(id)[1:]
v=v+D[x]+'s' if (id < 256):
x=x+1 id=s[0]
if a.has_key('id'): self._pickleids[a['id']]=D put='q'
else:
id=s
put='r'
v='}'+put+id
if len(D)>0: v=v+'('
x=0
while x < len(D):
v=v+D[x]
x=x+1
v=v+'u'
else:
v='(dp'+id+'\012'
x=0
while x<len(D):
v=v+D[x]+'s'
x=x+1
return v return v
def save_item(self, tag, data): def save_item(self, tag, data):
...@@ -642,43 +892,171 @@ def save_pickle(self, tag, data): ...@@ -642,43 +892,171 @@ def save_pickle(self, tag, data):
return v return v
def save_reference(self, tag, data): def save_reference(self, tag, data):
binary=self.binary
a=data[1] a=data[1]
id=a['id'] id=a['id']
prefix=string.rfind(id,'.') prefix=string.rfind(id,'.')
if prefix>=0: id=id[prefix:] if prefix>=0: id=id[prefix+1:]
v='g'+id+'\012' get='g'
if binary:
id=string.atoi(id)
s=mdumps(id)[1:]
if (id < 256):
id=s[0]
get='h'
else:
id=s
get='j'
v=get+id
else: v=get+id+'\012'
return v return v
def save_object(self, tag, data): def save_object(self, tag, data):
binary=self.binary
a=data[1] a=data[1]
v='(c' v='(c'
for x in data[2:]: j=0
v=v+x
id=a['id'] id=a['id']
prefix=string.rfind(id,'.') prefix=string.rfind(id,'.')
if prefix>=0: id=id[prefix:] if prefix>=0: id=id[prefix+1:]
v=v+'p'+id+'\012'+'b' put='p'
if binary:
id=string.atoi(id)
s=mdumps(id)[1:]
if (id < 256):
id=s[0]
put='q'
else:
id=s
put='r'
for x in data[2:]:
if j==0: v=v + x
elif j==1:
x=x[1:]
stop=string.rfind(x,'t')
if stop>=0: x=x[:stop]
v=v+x+'o'+put+id
elif j==2: v=v+x
j=j+1
else:
for x in data[2:]:
if j==0: v=v+x
elif j==1:
x=x[1:]
stop=string.rfind(x,'t')
if stop>=0: x=x[:stop]
v=v+x+'o'+put+id+'\012'
elif j==2: v=v+x
j=j+1
v=v+'b'
if a.has_key('id'): self._pickleids[a['id']]=v if a.has_key('id'): self._pickleids[a['id']]=v
return v return v
def save_global(self, tag, data): def save_global(self, tag, data):
binary=self.binary
a=data[1] a=data[1]
if a.has_key('id'): if a.has_key('id'):
id=a['id'] id=a['id']
prefix=string.rfind(id,'.') prefix=string.rfind(id,'.')
if prefix>=0: id=id[prefix:] if prefix>=0: id=id[prefix+1:]
v=a['module']+'\012'+a['name']+'\012op'+id+'\012' put='p'
if binary:
id=string.atoi(id)
s=mdumps(id)[1:]
if (id < 256):
id=s[0]
put='q'
else:
id=s
put='r'
v=a['module']+'\012'+a['name']+'\012'+put+id
else:
v=a['module']+'\012'+a['name']+'\012'+put+id+'\012'
self._pickleids[a['id']]=v self._pickleids[a['id']]=v
else: v=a['module']+'\012'+a['name']+'\012o' else: v=a['module']+'\012'+a['name']+'\012'
return v return v
def save_persis(self, tag, data): def save_persis(self, tag, data):
v=data[2] v=data[2]
if v[0]=='(' and v[1]=='I':
f=regex.search('\012',v)
change=v[2:f]
change=p64(string.atoi(change))
v=v[:1]+"S'"+change+"'"+v[f:]
if v[0]=='I':
f=regex.search('\012',v)
change=v[1:f]
change=p64(string.atoi(change)+1)
v="S'"+change+"'"+v[f:]
v=v+'Q' v=v+'Q'
return v return v
def save_user(self, tag, data):
transaction=self._transaction
if len(data)>2: v=data[2]
else: v=''
self._user=v
transaction._thl=self._transaction._thl+len(v)
transaction._ude=v,transaction._ude[1],transaction._ude[2]
return v
def save_description(self, tag, data):
transaction=self._transaction
if len(data)>2: v=data[2]
else: v=''
a=data[1]
if a.has_key('encoding'): encoding=a['encoding']
else: encoding=''
if encoding:
v=unconvert(encoding,v)
transaction._descr=v
transaction._thl=transaction._thl+len(v)
transaction._ude=transaction._ude[0],v,transaction._ude[2]
return v
def save_rec(self, tag, data):
a=data[1]
if a.has_key('id'):
a['id']=p64(string.atoi(a['id'])+1)
if a.has_key('time'):
start=0
stop=string.find(a['time'][start:],'-')+start
year=string.atoi(a['time'][start:stop])
start=stop+1
stop=string.find(a['time'][start:],'-')+start
month=string.atoi(a['time'][start:stop])
start=stop+1
stop=string.find(a['time'][start:],' ')+start
day=string.atoi(a['time'][start:stop])
start=stop+1
stop=string.find(a['time'][start:],':')+start
hour=string.atoi(a['time'][start:stop])
start=stop+1
stop=string.find(a['time'][start:],':')+start
minute=string.atoi(a['time'][start:stop])
start=stop+1
second=string.atof(a['time'][start:])
a['time']=struct.pack(">If",(((((year-1900)*12)+month-1)*31+day-1)*24+
hour)*60 +minute, second*(1L<<32)/60)
data[1]=a
return data
def start_transaction(self, tag, attrs):
self._transaction=Transaction(self, tag, attrs)
return self._transaction
def start_ZopeData(self, tag, attrs):
self._ZopeData=ZopeData(self, tag, attrs)
return self._ZopeData
class xmlPickler(xmlUnpickler): class xmlPickler(xmlUnpickler):
start_handlers={'pickle':start_pickle} start_handlers={'pickle': start_pickle,
'transaction': start_transaction,
'ZopeData': start_ZopeData,
}
end_handlers={ end_handlers={
'pickle': save_pickle, 'pickle': save_pickle,
'none': save_none, 'none': save_none,
...@@ -697,6 +1075,9 @@ class xmlPickler(xmlUnpickler): ...@@ -697,6 +1075,9 @@ class xmlPickler(xmlUnpickler):
'state': lambda self, tag, data: data[2], 'state': lambda self, tag, data: data[2],
'global': save_global, 'global': save_global,
'persistent': save_persis, 'persistent': save_persis,
'user': save_user,
'description': save_description,
'rec': save_rec,
} }
...@@ -706,9 +1087,60 @@ class C: ...@@ -706,9 +1087,60 @@ class C:
def __cmp__(self, other): def __cmp__(self, other):
return cmp(self.__dict__, other.__dict__) return cmp(self.__dict__, other.__dict__)
def test(): def test():
import xmllib
c=C()
c.foo=1
c.bar=2
x=[0,1,2,3]
y=('abc','abc',c,c)
x.append(y)
x.append(y)
t=()
l=[]
s=''
x.append(t)
x.append(l)
x.append(s)
x.append(55555)
x.append(13)
r=[x]
print x
f=pickle.dumps(x)
print f
r.append(f)
q=ToXMLloads(f)
q=str(q)
# q='<?xml version="1.0">\n'+q
print q
r.append(q)
file=''
F=xmlPickler(file)
p=xmllib.XMLParser()
p.start_handlers=F.start_handlers
p.end_handlers=F.end_handlers
p.handle_data=F.handle_data
p.unknown_starttag=F.unknown_starttag
p.unknown_endtag=F.unknown_endtag
p._stack=F._stack
p.push=F.push
p.append=F.append
p.file=file
p.tempfile=tempfile.TemporaryFile()
data=string.split(q,'\n')
for l in data:
p.feed(l)
p.close()
z=p._stack
z=z[0][0]
print z, '\012'
r.append(z)
l=pickle.loads(z)
print l, '\012'
r.append(l)
def test1():
import xml.parsers.pyexpat
c=C() c=C()
c.foo=1 c.foo=1
c.bar=2 c.bar=2
...@@ -716,22 +1148,31 @@ def test(): ...@@ -716,22 +1148,31 @@ def test():
y=('abc','abc',c,c) y=('abc','abc',c,c)
x.append(y) x.append(y)
x.append(y) x.append(y)
t=()
l=[]
s=''
x.append(t)
x.append(l)
x.append(s)
x.append(5) x.append(5)
x.append(13)
print x, '\012' print x, '\012'
f=pickle.dumps(x) f=pickle.dumps(x)
print f, '\012' print f, '\012'
p=ToXMLloads(f) q=ToXMLloads(f)
print p, '\012' q=str(q)
F=xmlPickler() q='<?xml version="1.0">\n'+q
data=string.split(str(p),'\n') print q, '\012'
for l in data: file=''
F.feed(l) F=xmlPickler(file)
F.close p=xml.parsers.pyexpat.ParserCreate()
r=F._stack p.CharacterDataHandler=F.handle_data
p.StartElementHandler=F.unknown_starttag
p.EndElementHandler=F.unknown_endtag
r=p.Parse(q)
print r, '\012' print r, '\012'
print r[0][0], '\012'
print pickle.loads(r[0][0]), '\012'
if __name__ == '__main__': if __name__ == '__main__':
test() test()
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