Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Z
Zope
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
Zope
Commits
f1c1e00f
Commit
f1c1e00f
authored
Jul 01, 1999
by
joey
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
*** empty log message ***
parent
b01beadb
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
565 additions
and
124 deletions
+565
-124
utilities/ppml.py
utilities/ppml.py
+565
-124
No files found.
utilities/ppml.py
View file @
f1c1e00f
...
@@ -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
,
attr
s
):
self
.
_pickleids
=
{}
self
.
_pickleids
=
{}
return
[
tag
,
attr
]
return
[
tag
,
attr
s
]
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'
]
+
'
\
012
op'
+
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'
]
+
'
\
012
o
'
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
()
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment