Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
erp5
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Labels
Merge Requests
7
Merge Requests
7
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Jobs
Commits
Open sidebar
Jérome Perrin
erp5
Commits
03f7c962
Commit
03f7c962
authored
Mar 17, 2023
by
Jérome Perrin
1
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
XMLExportImport: WIP support pickle protocol 3
🚧
parent
b30bf1dd
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
239 additions
and
72 deletions
+239
-72
product/ERP5/Document/BusinessTemplate.py
product/ERP5/Document/BusinessTemplate.py
+6
-5
product/ERP5Type/XMLExportImport/__init__.py
product/ERP5Type/XMLExportImport/__init__.py
+27
-13
product/ERP5Type/XMLExportImport/ppml.py
product/ERP5Type/XMLExportImport/ppml.py
+206
-54
No files found.
product/ERP5/Document/BusinessTemplate.py
View file @
03f7c962
...
@@ -78,7 +78,7 @@ from OFS.Traversable import NotFound
...
@@ -78,7 +78,7 @@ from OFS.Traversable import NotFound
from
OFS
import
SimpleItem
from
OFS
import
SimpleItem
from
OFS.Image
import
Pdata
from
OFS.Image
import
Pdata
import
coverage
import
coverage
from
io
import
BytesIO
from
io
import
BytesIO
,
StringIO
from
copy
import
deepcopy
from
copy
import
deepcopy
from
zExceptions
import
BadRequest
from
zExceptions
import
BadRequest
from
Products.ERP5Type.XMLExportImport
import
exportXML
,
customImporters
from
Products.ERP5Type.XMLExportImport
import
exportXML
,
customImporters
...
@@ -347,10 +347,11 @@ class BusinessTemplateArchive(object):
...
@@ -347,10 +347,11 @@ class BusinessTemplateArchive(object):
try
:
try
:
write
=
self
.
_writeFile
write
=
self
.
_writeFile
except
AttributeError
:
except
AttributeError
:
if
not
isinstance
(
obj
,
(
bytes
,
str
)
):
if
hasattr
(
obj
,
'read'
):
obj
.
seek
(
0
)
obj
.
seek
(
0
)
obj
=
obj
.
read
()
obj
=
obj
.
read
()
elif
not
isinstance
(
obj
,
bytes
):
#import pdb; pdb.set_trace()
if
not
isinstance
(
obj
,
bytes
):
obj
=
obj
.
encode
(
'utf-8'
)
obj
=
obj
.
encode
(
'utf-8'
)
self
.
revision
.
hash
(
path
,
obj
)
self
.
revision
.
hash
(
path
,
obj
)
self
.
_writeString
(
obj
,
path
)
self
.
_writeString
(
obj
,
path
)
...
@@ -865,9 +866,9 @@ class ObjectTemplateItem(BaseTemplateItem):
...
@@ -865,9 +866,9 @@ class ObjectTemplateItem(BaseTemplateItem):
obj
=
self
.
removeProperties
(
obj
,
1
,
keep_workflow_history
=
True
)
obj
=
self
.
removeProperties
(
obj
,
1
,
keep_workflow_history
=
True
)
transaction
.
savepoint
(
optimistic
=
True
)
transaction
.
savepoint
(
optimistic
=
True
)
f
=
Bytes
IO
()
f
=
String
IO
()
exportXML
(
obj
.
_p_jar
,
obj
.
_p_oid
,
f
)
exportXML
(
obj
.
_p_jar
,
obj
.
_p_oid
,
f
)
bta
.
addObject
(
f
,
key
,
path
=
path
)
bta
.
addObject
(
f
.
getvalue
().
encode
()
,
key
,
path
=
path
)
if
catalog_method_template_item
:
if
catalog_method_template_item
:
# add all datas specific to catalog inside one file
# add all datas specific to catalog inside one file
...
...
product/ERP5Type/XMLExportImport/__init__.py
View file @
03f7c962
...
@@ -48,7 +48,7 @@ from lxml import etree
...
@@ -48,7 +48,7 @@ from lxml import etree
from
lxml.etree
import
Element
,
SubElement
from
lxml.etree
import
Element
,
SubElement
from
xml_marshaller.xml_marshaller
import
Marshaller
from
xml_marshaller.xml_marshaller
import
Marshaller
from
OFS.Image
import
Pdata
from
OFS.Image
import
Pdata
from
base64
import
standard_b64encode
from
base64
import
standard_b64encode
,
encodebytes
from
hashlib
import
sha1
from
hashlib
import
sha1
from
Products.ERP5Type.Utils
import
ensure_list
from
Products.ERP5Type.Utils
import
ensure_list
#from zLOG import LOG
#from zLOG import LOG
...
@@ -223,7 +223,6 @@ def Folder_asXML(object, omit_xml_declaration=True, root=None):
...
@@ -223,7 +223,6 @@ def Folder_asXML(object, omit_xml_declaration=True, root=None):
## The code below was initially from OFS.XMLExportImport
## The code below was initially from OFS.XMLExportImport
from
six
import
string_types
as
basestring
from
six
import
string_types
as
basestring
from
base64
import
encodestring
from
ZODB.serialize
import
referencesf
from
ZODB.serialize
import
referencesf
from
ZODB.ExportImport
import
TemporaryFile
,
export_end_marker
from
ZODB.ExportImport
import
TemporaryFile
,
export_end_marker
from
ZODB.utils
import
p64
from
ZODB.utils
import
p64
...
@@ -253,7 +252,7 @@ def reorderPickle(jar, p):
...
@@ -253,7 +252,7 @@ def reorderPickle(jar, p):
new_oid
=
storage
.
new_oid
):
new_oid
=
storage
.
new_oid
):
"Remap a persistent id to an existing ID and create a ghost for it."
"Remap a persistent id to an existing ID and create a ghost for it."
print
(
'persistent_load1'
,
ooid
)
if
isinstance
(
ooid
,
tuple
):
ooid
,
klass
=
ooid
if
isinstance
(
ooid
,
tuple
):
ooid
,
klass
=
ooid
else
:
klass
=
None
else
:
klass
=
None
...
@@ -270,34 +269,43 @@ def reorderPickle(jar, p):
...
@@ -270,34 +269,43 @@ def reorderPickle(jar, p):
unpickler
.
persistent_load
=
persistent_load
unpickler
.
persistent_load
=
persistent_load
newp
=
BytesIO
()
newp
=
BytesIO
()
pickler
=
OrderedPickler
(
newp
,
1
)
pickler
=
OrderedPickler
(
newp
,
3
)
pickler
.
persistent_id
=
persistent_id
pickler
.
persistent_id
=
persistent_id
classdef
=
unpickler
.
load
()
classdef
=
unpickler
.
load
()
obj
=
unpickler
.
load
()
obj
=
unpickler
.
load
()
pickler
.
dump
(
classdef
)
pickler
.
dump
(
classdef
)
pickler
.
dump
(
obj
)
pickler
.
dump
(
obj
)
if
0
:
# debug
debugp
=
BytesIO
()
debugpickler
=
OrderedPickler
(
debugp
,
3
)
debugpickler
.
persistent_id
=
persistent_id
debugpickler
.
dump
(
obj
)
import
pickletools
print
(
debugp
.
getvalue
())
print
(
pickletools
.
dis
(
debugp
.
getvalue
()))
p
=
newp
.
getvalue
()
p
=
newp
.
getvalue
()
return
obj
,
p
return
obj
,
p
def
_mapOid
(
id_mapping
,
oid
):
def
_mapOid
(
id_mapping
,
oid
):
idprefix
=
str
(
u64
(
oid
))
idprefix
=
str
(
u64
(
oid
))
id
=
id_mapping
[
idprefix
]
id
=
id_mapping
[
idprefix
]
old_aka
=
encode
string
(
oid
)[:
-
1
]
old_aka
=
encode
bytes
(
oid
)[:
-
1
]
aka
=
encode
string
(
p64
(
long_
(
id
)))[:
-
1
]
# Rebuild oid based on mapped id
aka
=
encode
bytes
(
p64
(
long_
(
id
)))[:
-
1
]
# Rebuild oid based on mapped id
id_mapping
.
setConvertedAka
(
old_aka
,
aka
)
id_mapping
.
setConvertedAka
(
old_aka
,
aka
)
return
idprefix
+
'.'
,
id
,
aka
return
idprefix
+
'.'
,
id
,
aka
def
XMLrecord
(
oid
,
plen
,
p
,
id_mapping
):
def
XMLrecord
(
oid
,
plen
,
p
,
id_mapping
):
# Proceed as usual
# Proceed as usual
q
=
ppml
.
ToXMLUnpickler
f
=
BytesIO
(
p
)
f
=
BytesIO
(
p
)
u
=
ppml
.
ToXMLUnpickler
(
f
)
u
=
q
(
f
)
u
.
idprefix
,
id
,
aka
=
_mapOid
(
id_mapping
,
oid
)
u
.
idprefix
,
id
,
aka
=
_mapOid
(
id_mapping
,
oid
)
p
=
u
.
load
(
id_mapping
=
id_mapping
).
__str__
(
4
)
p
=
u
.
load
(
id_mapping
=
id_mapping
).
__str__
(
4
)
if
f
.
tell
()
<
plen
:
if
f
.
tell
()
<
plen
:
p
=
p
+
u
.
load
(
id_mapping
=
id_mapping
).
__str__
(
4
)
p
=
p
+
u
.
load
(
id_mapping
=
id_mapping
).
__str__
(
4
)
String
=
' <record id="%s" aka="%s">
\
n
%s </record>
\
n
'
%
(
id
,
aka
,
p
)
String
=
' <record id="%s" aka="%s">
\
n
%s </record>
\
n
'
%
(
id
,
aka
.
decode
()
,
p
)
return
String
return
String
def
exportXML
(
jar
,
oid
,
file
=
None
):
def
exportXML
(
jar
,
oid
,
file
=
None
):
...
@@ -334,15 +342,21 @@ def exportXML(jar, oid, file=None):
...
@@ -334,15 +342,21 @@ def exportXML(jar, oid, file=None):
# Do real export
# Do real export
if
file
is
None
:
if
file
is
None
:
file
=
TemporaryFile
()
file
=
TemporaryFile
(
mode
=
'w'
)
elif
isinstance
(
file
,
basestring
):
elif
isinstance
(
file
,
basestring
):
file
=
open
(
file
,
'w
+b
'
)
file
=
open
(
file
,
'w'
)
write
=
file
.
write
write
=
file
.
write
write
(
'<?xml version="1.0"?>
\
n
<ZopeData>
\
n
'
)
write
(
'<?xml version="1.0"?>
\
n
<ZopeData>
\
n
'
)
for
oid
in
reordered_oid_list
:
for
oid
in
reordered_oid_list
:
p
=
getReorderedPickle
(
oid
)
p
=
getReorderedPickle
(
oid
)
write
(
XMLrecord
(
oid
,
len
(
p
),
p
,
id_mapping
))
write
(
XMLrecord
(
oid
,
len
(
p
),
p
,
id_mapping
))
write
(
'</ZopeData>
\
n
'
)
write
(
'</ZopeData>
\
n
'
)
if
0
:
try
:
print
(
file
.
getvalue
())
except
AttributeError
:
pass
import
pdb
;
pdb
.
set_trace
()
return
file
return
file
class
zopedata
:
class
zopedata
:
...
...
product/ERP5Type/XMLExportImport/ppml.py
View file @
03f7c962
...
@@ -159,6 +159,10 @@ class Long(Scalar):
...
@@ -159,6 +159,10 @@ class Long(Scalar):
return
result
return
result
class
String
(
Scalar
):
class
String
(
Scalar
):
def
tag_name
(
self
):
return
self
.
__class__
.
__name__
.
lower
()
encoding
=
None
encoding
=
None
def
__init__
(
self
,
v
,
mapping
,
encoding
=
''
):
def
__init__
(
self
,
v
,
mapping
,
encoding
=
''
):
...
@@ -173,8 +177,8 @@ class String(Scalar):
...
@@ -173,8 +177,8 @@ class String(Scalar):
# This is used when strings represent references which need to
# This is used when strings represent references which need to
# be converted.
# be converted.
encoding
=
'base64'
encoding
=
'base64'
v
=
base64
.
encode
string
(
self
.
_v
)[:
-
1
]
v
=
base64
.
encode
bytes
(
self
.
_v
)[:
-
1
]
self
.
_v
=
self
.
mapping
.
convertBase64
(
v
)
self
.
_v
=
self
.
mapping
.
convertBase64
(
v
)
.
decode
()
else
:
else
:
encoding
,
self
.
_v
=
convert
(
self
.
_v
)
encoding
,
self
.
_v
=
convert
(
self
.
_v
)
self
.
encoding
=
encoding
self
.
encoding
=
encoding
...
@@ -184,7 +188,7 @@ class String(Scalar):
...
@@ -184,7 +188,7 @@ class String(Scalar):
encoding
=
''
# JPS repr is default encoding
encoding
=
''
# JPS repr is default encoding
else
:
else
:
encoding
=
' encoding="%s"'
%
encoding
encoding
=
' encoding="%s"'
%
encoding
name
=
self
.
__class__
.
__name__
.
lower
()
name
=
self
.
tag_name
()
result
=
'<%s%s%s>%s</%s>'
%
(
name
,
id
,
encoding
,
v
,
name
)
result
=
'<%s%s%s>%s</%s>'
%
(
name
,
id
,
encoding
,
v
,
name
)
if
hasattr
(
self
,
'id'
):
if
hasattr
(
self
,
'id'
):
# The value is Immutable - let us add it the the immutable mapping
# The value is Immutable - let us add it the the immutable mapping
...
@@ -193,8 +197,14 @@ class String(Scalar):
...
@@ -193,8 +197,14 @@ class String(Scalar):
return
'%s%s
\
n
'
%
(
' '
*
indent
,
result
)
return
'%s%s
\
n
'
%
(
' '
*
indent
,
result
)
class
Unicode
(
String
):
class
Unicode
(
String
):
def
value
(
self
):
def
tag_name
(
self
):
return
self
.
_v
.
encode
(
'utf-8'
)
if
six
.
PY3
:
return
'string'
return
super
(
Unicode
,
self
).
tag_name
()
class
Bytes
(
String
):
pass
class
Wrapper
:
class
Wrapper
:
def
__init__
(
self
,
v
,
mapping
):
def
__init__
(
self
,
v
,
mapping
):
...
@@ -480,88 +490,169 @@ class ToXMLUnpickler(Unpickler):
...
@@ -480,88 +490,169 @@ class ToXMLUnpickler(Unpickler):
def
load_persid
(
self
):
def
load_persid
(
self
):
pid
=
self
.
readline
()[:
-
1
]
pid
=
self
.
readline
()[:
-
1
]
self
.
append
(
self
.
persistent_load
(
String
(
pid
,
self
.
id_mapping
)))
self
.
append
(
self
.
persistent_load
(
String
(
pid
,
self
.
id_mapping
)))
if
six
.
PY2
:
dispatch
[
PERSID
]
=
load_persid
dispatch
[
PERSID
]
=
load_persid
dispatch
[
PERSID
[
0
]]
=
load_persid
def
load_binpersid
(
self
):
pid
=
self
.
stack
.
pop
()
self
.
append
(
self
.
persistent_load
(
pid
))
if
six
.
PY2
:
dispatch
[
BINPERSID
]
=
load_binpersid
dispatch
[
BINPERSID
[
0
]]
=
load_binpersid
def
load_none
(
self
):
def
load_none
(
self
):
self
.
append
(
none
)
self
.
append
(
none
)
if
six
.
PY2
:
dispatch
[
NONE
]
=
load_none
dispatch
[
NONE
]
=
load_none
dispatch
[
NONE
[
0
]]
=
load_none
def
load_int
(
self
):
def
load_int
(
self
):
self
.
append
(
Int
(
int
(
self
.
readline
()[:
-
1
]),
self
.
id_mapping
))
self
.
append
(
Int
(
int
(
self
.
readline
()[:
-
1
]),
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
INT
]
=
load_int
dispatch
[
INT
]
=
load_int
dispatch
[
INT
[
0
]]
=
load_int
def
load_binint
(
self
):
def
load_binint
(
self
):
self
.
append
(
Int
(
mloads
(
'i'
+
self
.
read
(
4
)),
self
.
id_mapping
))
self
.
append
(
Int
(
mloads
(
b'i'
+
self
.
read
(
4
)),
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
BININT
]
=
load_binint
dispatch
[
BININT
]
=
load_binint
dispatch
[
BININT
[
0
]]
=
load_binint
def
load_binint1
(
self
):
def
load_binint1
(
self
):
self
.
append
(
Int
(
mloads
(
'i'
+
self
.
read
(
1
)
+
'
\
000
\
000
\
000
'
),
self
.
id_mapping
))
self
.
append
(
Int
(
mloads
(
b'i'
+
self
.
read
(
1
)
+
b'
\
000
\
000
\
000
'
),
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
BININT1
]
=
load_binint1
dispatch
[
BININT1
]
=
load_binint1
dispatch
[
BININT1
[
0
]]
=
load_binint1
def
load_binint2
(
self
):
def
load_binint2
(
self
):
self
.
append
(
Int
(
mloads
(
'i'
+
self
.
read
(
2
)
+
'
\
000
\
000
'
),
self
.
id_mapping
))
self
.
append
(
Int
(
mloads
(
b'i'
+
self
.
read
(
2
)
+
b'
\
000
\
000
'
),
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
BININT2
]
=
load_binint2
dispatch
[
BININT2
]
=
load_binint2
dispatch
[
BININT2
[
0
]]
=
load_binint2
def
load_long
(
self
):
def
load_long
(
self
):
self
.
append
(
Long
(
long_
(
self
.
readline
()[:
-
1
],
0
),
self
.
id_mapping
))
self
.
append
(
Long
(
long_
(
self
.
readline
()[:
-
1
],
0
),
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
LONG
]
=
load_long
dispatch
[
LONG
]
=
load_long
dispatch
[
LONG
[
0
]]
=
load_long
def
load_float
(
self
):
def
load_float
(
self
):
self
.
append
(
Float
(
float
(
self
.
readline
()[:
-
1
]),
self
.
id_mapping
))
self
.
append
(
Float
(
float
(
self
.
readline
()[:
-
1
]),
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
FLOAT
]
=
load_float
dispatch
[
FLOAT
]
=
load_float
dispatch
[
FLOAT
[
0
]]
=
load_float
def
load_binfloat
(
self
,
unpack
=
struct
.
unpack
):
def
load_binfloat
(
self
,
unpack
=
struct
.
unpack
):
self
.
append
(
Float
(
unpack
(
'>d'
,
self
.
read
(
8
))[
0
],
self
.
id_mapping
))
self
.
append
(
Float
(
unpack
(
'>d'
,
self
.
read
(
8
))[
0
],
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
BINFLOAT
]
=
load_binfloat
dispatch
[
BINFLOAT
]
=
load_binfloat
dispatch
[
BINFLOAT
[
0
]]
=
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__'
:
{}}),
self
.
id_mapping
))
# Let's be careful
{
'__builtins__'
:
{}}),
self
.
id_mapping
))
# Let's be careful
if
six
.
PY2
:
dispatch
[
STRING
]
=
load_string
dispatch
[
STRING
]
=
load_string
dispatch
[
STRING
[
0
]]
=
load_string
def
load_binstring
(
self
):
def
load_binstring
(
self
):
len
=
mloads
(
'i'
+
self
.
read
(
4
))
len
=
mloads
(
b
'i'
+
self
.
read
(
4
))
self
.
append
(
String
(
self
.
read
(
len
),
self
.
id_mapping
))
self
.
append
(
String
(
self
.
read
(
len
),
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
BINSTRING
]
=
load_binstring
dispatch
[
BINSTRING
]
=
load_binstring
dispatch
[
BINSTRING
[
0
]]
=
load_binstring
def
load_unicode
(
self
):
def
load_unicode
(
self
):
self
.
append
(
Unicode
(
six
.
text_type
(
eval
(
self
.
readline
()[:
-
1
],
line
=
self
.
readline
()
self
.
append
(
Unicode
(
six
.
text_type
(
eval
(
line
[:
-
1
],
{
'__builtins__'
:
{}})),
self
.
id_mapping
))
# Let's be careful
{
'__builtins__'
:
{}})),
self
.
id_mapping
))
# Let's be careful
if
six
.
PY2
:
dispatch
[
UNICODE
]
=
load_unicode
dispatch
[
UNICODE
]
=
load_unicode
dispatch
[
UNICODE
[
0
]]
=
load_unicode
def
load_binunicode
(
self
):
def
load_binunicode
(
self
):
len
=
mloads
(
'i'
+
self
.
read
(
4
))
len
=
mloads
(
b
'i'
+
self
.
read
(
4
))
self
.
append
(
Unicode
(
six
.
text_type
(
self
.
read
(
len
),
'utf-8'
),
self
.
id_mapping
))
self
.
append
(
Unicode
(
six
.
text_type
(
self
.
read
(
len
),
'utf-8'
),
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
BINUNICODE
]
=
load_binunicode
dispatch
[
BINUNICODE
]
=
load_binunicode
dispatch
[
BINUNICODE
[
0
]]
=
load_binunicode
def
load_short_binstring
(
self
):
def
load_short_binstring
(
self
):
len
=
mloads
(
'i'
+
self
.
read
(
1
)
+
'
\
000
\
000
\
000
'
)
len
=
mloads
(
b'i'
+
self
.
read
(
1
)
+
b
'
\
000
\
000
\
000
'
)
self
.
append
(
String
(
self
.
read
(
len
),
self
.
id_mapping
))
self
.
append
(
String
(
self
.
read
(
len
),
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
SHORT_BINSTRING
]
=
load_short_binstring
dispatch
[
SHORT_BINSTRING
]
=
load_short_binstring
dispatch
[
SHORT_BINSTRING
[
0
]]
=
load_short_binstring
def
load_binbytes
(
self
):
len
=
mloads
(
b'i'
+
self
.
read
(
4
))
self
.
append
(
Bytes
(
self
.
read
(
len
),
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
BINBYTES
]
=
load_binbytes
dispatch
[
BINBYTES
[
0
]]
=
load_binbytes
def
load_short_binbytes
(
self
):
len
=
mloads
(
b'i'
+
self
.
read
(
1
)
+
b'
\
000
\
000
\
000
'
)
self
.
append
(
Bytes
(
self
.
read
(
len
),
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
SHORT_BINBYTES
]
=
load_short_binbytes
dispatch
[
SHORT_BINBYTES
[
0
]]
=
load_short_binbytes
def
load_tuple
(
self
):
def
load_tuple
(
self
):
k
=
self
.
marker
()
k
=
self
.
marker
()
#LOG('load_tuple, k',0,k)
#LOG('load_tuple, k',0,k)
#LOG('load_tuple, stack[k+1:]',0,self.stack[k+1:])
#LOG('load_tuple, stack[k+1:]',0,self.stack[k+1:])
self
.
stack
[
k
:]
=
[
Tuple
(
self
.
id_mapping
,
v
=
self
.
stack
[
k
+
1
:])]
self
.
stack
[
k
:]
=
[
Tuple
(
self
.
id_mapping
,
v
=
self
.
stack
[
k
+
1
:])]
if
six
.
PY2
:
dispatch
[
TUPLE
]
=
load_tuple
dispatch
[
TUPLE
]
=
load_tuple
dispatch
[
TUPLE
[
0
]]
=
load_tuple
def
load_tuple1
(
self
):
k
=
self
.
marker
()
self
.
stack
[
-
1
]
=
Tuple
(
self
.
id_mapping
,
v
=
(
self
.
stack
[
-
1
],))
if
six
.
PY2
:
dispatch
[
TUPLE1
]
=
load_tuple1
dispatch
[
TUPLE1
[
0
]]
=
load_tuple1
def
load_tuple2
(
self
):
k
=
self
.
marker
()
self
.
stack
[
-
2
:]
=
[
Tuple
(
self
.
id_mapping
,
v
=
(
self
.
stack
[
-
2
],
self
.
stack
[
-
1
]))]
if
six
.
PY2
:
dispatch
[
TUPLE2
]
=
load_tuple2
dispatch
[
TUPLE2
[
0
]]
=
load_tuple2
def
load_tuple3
(
self
):
k
=
self
.
marker
()
self
.
stack
[
-
3
:]
=
[
Tuple
(
self
.
id_mapping
,
v
=
(
self
.
stack
[
-
3
],
self
.
stack
[
-
2
],
self
.
stack
[
-
1
]))]
if
six
.
PY2
:
dispatch
[
TUPLE3
]
=
load_tuple3
dispatch
[
TUPLE3
[
0
]]
=
load_tuple3
def
load_empty_tuple
(
self
):
def
load_empty_tuple
(
self
):
self
.
stack
.
append
(
Tuple
(
self
.
id_mapping
))
self
.
stack
.
append
(
Tuple
(
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
EMPTY_TUPLE
]
=
load_empty_tuple
dispatch
[
EMPTY_TUPLE
]
=
load_empty_tuple
dispatch
[
EMPTY_TUPLE
[
0
]]
=
load_empty_tuple
def
load_empty_list
(
self
):
def
load_empty_list
(
self
):
self
.
stack
.
append
(
List
(
self
.
id_mapping
))
self
.
stack
.
append
(
List
(
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
EMPTY_LIST
]
=
load_empty_list
dispatch
[
EMPTY_LIST
]
=
load_empty_list
dispatch
[
EMPTY_LIST
[
0
]]
=
load_empty_list
def
load_empty_dictionary
(
self
):
def
load_empty_dictionary
(
self
):
self
.
stack
.
append
(
Dictionary
(
self
.
id_mapping
))
self
.
stack
.
append
(
Dictionary
(
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
EMPTY_DICT
]
=
load_empty_dictionary
dispatch
[
EMPTY_DICT
]
=
load_empty_dictionary
dispatch
[
EMPTY_DICT
[
0
]]
=
load_empty_dictionary
def
load_list
(
self
):
def
load_list
(
self
):
k
=
self
.
marker
()
k
=
self
.
marker
()
self
.
stack
[
k
:]
=
[
List
(
self
.
id_mapping
,
v
=
self
.
stack
[
k
+
1
:])]
self
.
stack
[
k
:]
=
[
List
(
self
.
id_mapping
,
v
=
self
.
stack
[
k
+
1
:])]
if
six
.
PY2
:
dispatch
[
LIST
]
=
load_list
dispatch
[
LIST
]
=
load_list
dispatch
[
LIST
[
0
]]
=
load_list
def
load_dict
(
self
):
def
load_dict
(
self
):
k
=
self
.
marker
()
k
=
self
.
marker
()
...
@@ -572,17 +663,21 @@ class ToXMLUnpickler(Unpickler):
...
@@ -572,17 +663,21 @@ class ToXMLUnpickler(Unpickler):
value
=
items
[
i
+
1
]
value
=
items
[
i
+
1
]
d
[
key
]
=
value
d
[
key
]
=
value
self
.
stack
[
k
:]
=
[
d
]
self
.
stack
[
k
:]
=
[
d
]
if
six
.
PY2
:
dispatch
[
DICT
]
=
load_dict
dispatch
[
DICT
]
=
load_dict
dispatch
[
DICT
[
0
]]
=
load_dict
def
load_inst
(
self
):
def
load_inst
(
self
):
k
=
self
.
marker
()
k
=
self
.
marker
()
args
=
Tuple
(
self
.
id_mapping
,
v
=
self
.
stack
[
k
+
1
:])
args
=
Tuple
(
self
.
id_mapping
,
v
=
self
.
stack
[
k
+
1
:])
del
self
.
stack
[
k
:]
del
self
.
stack
[
k
:]
module
=
self
.
readline
()[:
-
1
]
module
=
self
.
readline
()[:
-
1
]
.
decode
()
name
=
self
.
readline
()[:
-
1
]
name
=
self
.
readline
()[:
-
1
]
.
decode
()
value
=
Object
(
Global
(
module
,
name
,
self
.
id_mapping
),
args
,
self
.
id_mapping
)
value
=
Object
(
Global
(
module
,
name
,
self
.
id_mapping
),
args
,
self
.
id_mapping
)
self
.
append
(
value
)
self
.
append
(
value
)
if
six
.
PY2
:
dispatch
[
INST
]
=
load_inst
dispatch
[
INST
]
=
load_inst
dispatch
[
INST
[
0
]]
=
load_inst
def
load_obj
(
self
):
def
load_obj
(
self
):
stack
=
self
.
stack
stack
=
self
.
stack
...
@@ -593,13 +688,29 @@ class ToXMLUnpickler(Unpickler):
...
@@ -593,13 +688,29 @@ class ToXMLUnpickler(Unpickler):
del
stack
[
k
:]
del
stack
[
k
:]
value
=
Object
(
klass
,
args
,
self
.
id_mapping
)
value
=
Object
(
klass
,
args
,
self
.
id_mapping
)
self
.
append
(
value
)
self
.
append
(
value
)
if
six
.
PY2
:
dispatch
[
OBJ
]
=
load_obj
dispatch
[
OBJ
]
=
load_obj
dispatch
[
OBJ
[
0
]]
=
load_obj
def
load_newobj
(
self
):
# TODO: not really sure of this one, maybe we need
# a NewObj instead of Object
args
=
self
.
stack
.
pop
()
cls
=
self
.
stack
[
-
1
]
obj
=
Object
(
cls
,
args
,
self
.
id_mapping
)
self
.
stack
[
-
1
]
=
obj
print
(
'load_newobj'
,
self
.
stack
)
if
six
.
PY2
:
dispatch
[
NEWOBJ
]
=
load_newobj
dispatch
[
NEWOBJ
[
0
]]
=
load_newobj
def
load_global
(
self
):
def
load_global
(
self
):
module
=
self
.
readline
()[:
-
1
]
module
=
self
.
readline
()[:
-
1
]
.
decode
()
name
=
self
.
readline
()[:
-
1
]
name
=
self
.
readline
()[:
-
1
]
.
decode
()
self
.
append
(
Global
(
module
,
name
,
self
.
id_mapping
))
self
.
append
(
Global
(
module
,
name
,
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
GLOBAL
]
=
load_global
dispatch
[
GLOBAL
]
=
load_global
dispatch
[
GLOBAL
[
0
]]
=
load_global
def
load_reduce
(
self
):
def
load_reduce
(
self
):
stack
=
self
.
stack
stack
=
self
.
stack
...
@@ -610,38 +721,51 @@ class ToXMLUnpickler(Unpickler):
...
@@ -610,38 +721,51 @@ class ToXMLUnpickler(Unpickler):
value
=
Object
(
callable
,
arg_tup
,
self
.
id_mapping
)
value
=
Object
(
callable
,
arg_tup
,
self
.
id_mapping
)
self
.
append
(
value
)
self
.
append
(
value
)
if
six
.
PY2
:
dispatch
[
REDUCE
]
=
load_reduce
dispatch
[
REDUCE
]
=
load_reduce
dispatch
[
REDUCE
[
0
]]
=
load_reduce
idprefix
=
''
idprefix
=
''
def
load_get
(
self
):
def
load_get
(
self
):
self
.
append
(
Get
(
self
.
idprefix
+
self
.
readline
()[:
-
1
],
self
.
id_mapping
))
self
.
append
(
Get
(
self
.
idprefix
+
self
.
readline
()[:
-
1
],
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
GET
]
=
load_get
dispatch
[
GET
]
=
load_get
dispatch
[
GET
[
0
]]
=
load_get
def
load_binget
(
self
):
def
load_binget
(
self
):
i
=
mloads
(
'i'
+
self
.
read
(
1
)
+
'
\
000
\
000
\
000
'
)
i
=
mloads
(
b'i'
+
self
.
read
(
1
)
+
b
'
\
000
\
000
\
000
'
)
self
.
append
(
Get
(
self
.
idprefix
+
repr
(
i
),
self
.
id_mapping
))
self
.
append
(
Get
(
self
.
idprefix
+
repr
(
i
),
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
BINGET
]
=
load_binget
dispatch
[
BINGET
]
=
load_binget
dispatch
[
BINGET
[
0
]]
=
load_binget
def
load_long_binget
(
self
):
def
load_long_binget
(
self
):
i
=
mloads
(
'i'
+
self
.
read
(
4
))
i
=
mloads
(
b
'i'
+
self
.
read
(
4
))
self
.
append
(
Get
(
self
.
idprefix
+
repr
(
i
),
self
.
id_mapping
))
self
.
append
(
Get
(
self
.
idprefix
+
repr
(
i
),
self
.
id_mapping
))
if
six
.
PY2
:
dispatch
[
LONG_BINGET
]
=
load_long_binget
dispatch
[
LONG_BINGET
]
=
load_long_binget
dispatch
[
LONG_BINGET
[
0
]]
=
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
]
if
six
.
PY2
:
dispatch
[
PUT
]
=
load_put
dispatch
[
PUT
]
=
load_put
dispatch
[
PUT
[
0
]]
=
load_put
def
load_binput
(
self
):
def
load_binput
(
self
):
i
=
mloads
(
'i'
+
self
.
read
(
1
)
+
'
\
000
\
000
\
000
'
)
i
=
mloads
(
b'i'
+
self
.
read
(
1
)
+
b'
\
000
\
000
\
000
'
)
#LOG('load_binput', 0, 'self.stack = %r, self.idprefix+`i` = %r' % (self.stack, self.idprefix+`i`))
self
.
stack
[
-
1
].
id
=
self
.
idprefix
+
repr
(
i
)
self
.
stack
[
-
1
].
id
=
self
.
idprefix
+
repr
(
i
)
if
six
.
PY2
:
dispatch
[
BINPUT
]
=
load_binput
dispatch
[
BINPUT
]
=
load_binput
dispatch
[
BINPUT
[
0
]]
=
load_binput
def
load_long_binput
(
self
):
def
load_long_binput
(
self
):
i
=
mloads
(
'i'
+
self
.
read
(
4
))
i
=
mloads
(
b
'i'
+
self
.
read
(
4
))
self
.
stack
[
-
1
].
id
=
self
.
idprefix
+
repr
(
i
)
self
.
stack
[
-
1
].
id
=
self
.
idprefix
+
repr
(
i
)
if
six
.
PY2
:
dispatch
[
LONG_BINPUT
]
=
load_long_binput
dispatch
[
LONG_BINPUT
]
=
load_long_binput
dispatch
[
LONG_BINPUT
[
0
]]
=
load_long_binput
class
LogCall
:
class
LogCall
:
def
__init__
(
self
,
func
):
def
__init__
(
self
,
func
):
...
@@ -651,7 +775,7 @@ class ToXMLUnpickler(Unpickler):
...
@@ -651,7 +775,7 @@ class ToXMLUnpickler(Unpickler):
#LOG('LogCall', 0, 'self.stack = %r, func = %s' % (context.stack, self.func.__name__))
#LOG('LogCall', 0, 'self.stack = %r, func = %s' % (context.stack, self.func.__name__))
return
self
.
func
(
context
)
return
self
.
func
(
context
)
#for code in dispatch.keys():
#
for code in dispatch.keys():
# dispatch[code] = LogCall(dispatch[code])
# dispatch[code] = LogCall(dispatch[code])
def
ToXMLload
(
file
):
def
ToXMLload
(
file
):
...
@@ -711,7 +835,7 @@ def save_string(self, tag, data):
...
@@ -711,7 +835,7 @@ def save_string(self, tag, data):
a
=
data
[
1
]
a
=
data
[
1
]
v
=
b''
.
join
(
data
[
2
:])
v
=
b''
.
join
(
data
[
2
:])
encoding
=
a
.
get
(
'encoding'
,
'repr'
)
# JPS: repr is default encoding
encoding
=
a
.
get
(
'encoding'
,
'repr'
)
# JPS: repr is default encoding
if
encoding
is
not
''
:
if
encoding
!=
''
:
v
=
unconvert
(
encoding
,
v
)
v
=
unconvert
(
encoding
,
v
)
if
self
.
binary
:
if
self
.
binary
:
l
=
len
(
v
)
l
=
len
(
v
)
...
@@ -731,6 +855,27 @@ def save_string(self, tag, data):
...
@@ -731,6 +855,27 @@ def save_string(self, tag, data):
v
=
STRING
+
repr
(
v
)
+
'
\
n
'
v
=
STRING
+
repr
(
v
)
+
'
\
n
'
return
save_put
(
self
,
v
,
a
)
return
save_put
(
self
,
v
,
a
)
def
save_bytes
(
self
,
tag
,
data
):
a
=
data
[
1
]
v
=
b''
.
join
(
data
[
2
:])
encoding
=
a
.
get
(
'encoding'
,
'repr'
)
assert
encoding
==
'base64'
if
encoding
is
not
''
:
v
=
unconvert
(
encoding
,
v
)
if
self
.
binary
:
l
=
len
(
v
)
if
l
<
256
:
op
=
SHORT_BINBYTES
v
=
op
+
six
.
int2byte
(
l
)
+
v
else
:
op
=
BINBYTES
v
=
op
+
struct
.
pack
(
'<i'
,
l
)
+
v
else
:
# XXX used ??? seems wrong
v
=
BYTES
+
repr
(
v
)
+
'
\
n
'
return
save_put
(
self
,
v
,
a
)
def
save_unicode
(
self
,
tag
,
data
):
def
save_unicode
(
self
,
tag
,
data
):
binary
=
self
.
binary
binary
=
self
.
binary
v
=
b''
v
=
b''
...
@@ -820,6 +965,12 @@ def save_global(self, tag, data):
...
@@ -820,6 +965,12 @@ def save_global(self, tag, data):
def
save_persis
(
self
,
tag
,
data
):
def
save_persis
(
self
,
tag
,
data
):
v
=
data
[
2
]
v
=
data
[
2
]
if
self
.
binary
:
if
self
.
binary
:
if
isinstance
(
v
,
list
):
# XXX with binpersid we have:
# ['bytes', {'encoding': 'base64'}, b'AAAAAAAAAAI=']]
# but probably because something was wrong
import
pdb
;
pdb
.
set_trace
()
_
,
_
,
v
=
v
return
v
+
BINPERSID
return
v
+
BINPERSID
else
:
else
:
return
PERSID
+
v
return
PERSID
+
v
...
@@ -864,6 +1015,7 @@ class xmlPickler(NoBlanks, xyap):
...
@@ -864,6 +1015,7 @@ class xmlPickler(NoBlanks, xyap):
'int'
:
save_int
,
'int'
:
save_int
,
'long'
:
save_long
,
'long'
:
save_long
,
'float'
:
save_float
,
'float'
:
save_float
,
'bytes'
:
save_bytes
,
'string'
:
save_string
,
'string'
:
save_string
,
'unicode'
:
save_unicode
,
'unicode'
:
save_unicode
,
'reference'
:
save_reference
,
'reference'
:
save_reference
,
...
...
Jérome Perrin
@jerome
mentioned in commit
c870a036
·
Mar 19, 2023
mentioned in commit
c870a036
mentioned in commit c870a036a35f40897dc333840d48df2becc769fd
Toggle commit list
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