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
144
Merge Requests
144
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Jobs
Commits
Open sidebar
nexedi
erp5
Commits
376bc263
Commit
376bc263
authored
Apr 27, 2022
by
Arnaud Fontaine
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
py3: XMLExportImport: Port to Python3.
parent
8be67a1f
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
82 additions
and
69 deletions
+82
-69
product/ERP5/Document/BusinessTemplate.py
product/ERP5/Document/BusinessTemplate.py
+1
-2
product/ERP5Type/XMLExportImport/__init__.py
product/ERP5Type/XMLExportImport/__init__.py
+9
-4
product/ERP5Type/XMLExportImport/ppml.py
product/ERP5Type/XMLExportImport/ppml.py
+64
-50
product/ERP5Type/XMLExportImport/xyap.py
product/ERP5Type/XMLExportImport/xyap.py
+7
-7
product/ERP5Type/patches/ObjectManager.py
product/ERP5Type/patches/ObjectManager.py
+1
-6
No files found.
product/ERP5/Document/BusinessTemplate.py
View file @
376bc263
...
...
@@ -79,8 +79,7 @@ from OFS.Image import Pdata
from
io
import
BytesIO
as
StringIO
from
copy
import
deepcopy
from
zExceptions
import
BadRequest
from
Products.ERP5Type.XMLExportImport
import
exportXML
from
OFS.ObjectManager
import
customImporters
from
Products.ERP5Type.XMLExportImport
import
exportXML
,
customImporters
from
Products.ERP5Type.Workflow
import
WorkflowHistoryList
from
zLOG
import
LOG
,
WARNING
,
INFO
from
warnings
import
warn
...
...
product/ERP5Type/XMLExportImport/__init__.py
View file @
376bc263
...
...
@@ -235,7 +235,7 @@ from inspect import getargspec
from
OFS
import
ObjectManager
from
.
import
ppml
magic
=
'<?xm'
# importXML(jar, file, clue)}
magic
=
b
'<?xm'
# importXML(jar, file, clue)}
def
reorderPickle
(
jar
,
p
):
try
:
...
...
@@ -351,7 +351,7 @@ class zopedata:
def
__init__
(
self
,
parser
,
tag
,
attrs
):
self
.
file
=
parser
.
file
write
=
self
.
file
.
write
write
(
'ZEXP'
)
write
(
b
'ZEXP'
)
def
append
(
self
,
data
):
file
=
self
.
file
...
...
@@ -378,7 +378,7 @@ def save_record(parser, tag, data):
a
=
data
[
1
]
if
'id'
in
a
:
oid
=
a
[
'id'
]
oid
=
p64
(
int
(
oid
))
v
=
''
v
=
b
''
for
x
in
data
[
2
:]:
v
=
v
+
x
l
=
p64
(
len
(
v
))
...
...
@@ -402,7 +402,8 @@ def importXML(jar, file, clue=''):
# So we have to declare an encoding but not use unicode, so the unpickler
# can deal with the utf-8 strings directly
p
=
xml
.
parsers
.
expat
.
ParserCreate
(
'utf-8'
)
p
.
returns_unicode
=
False
if
six
.
PY2
:
p
.
returns_unicode
=
False
# </patch>
p
.
CharacterDataHandler
=
F
.
handle_data
p
.
StartElementHandler
=
F
.
unknown_starttag
...
...
@@ -410,3 +411,7 @@ def importXML(jar, file, clue=''):
r
=
p
.
Parse
(
data
)
outfile
.
seek
(
0
)
return
jar
.
importFile
(
outfile
,
clue
)
customImporters
=
{
magic
:
importXML
}
product/ERP5Type/XMLExportImport/ppml.py
View file @
376bc263
...
...
@@ -15,13 +15,16 @@
"""Provide conversion between Python pickles and XML
"""
from
pickle
import
*
from
zodbpickle.pickle
import
*
# Python3 C implementation does not have Unpickler.dispatch attribute
from
zodbpickle.pickle_3
import
_Unpickler
as
Unpickler
import
struct
import
base64
import
re
from
marshal
import
loads
as
mloads
from
.xyap
import
NoBlanks
from
.xyap
import
xyap
from
Products.ERP5Type.Utils
import
str2bytes
import
six
from
marshal
import
dumps
as
mdumps
...
...
@@ -29,6 +32,13 @@ from marshal import dumps as mdumps
binary
=
re
.
compile
(
'[^
\
x1f
-
\
x7f
]'
).
search
if
six
.
PY2
:
data_encoding
=
'raw_unicode_escape'
long_
=
long
else
:
data_encoding
=
'utf-8'
long_
=
int
def
escape
(
s
,
encoding
=
'repr'
):
if
binary
(
s
)
and
isinstance
(
s
,
str
):
s
=
base64
.
encodestring
(
s
)[:
-
1
]
...
...
@@ -47,9 +57,9 @@ def unescape(s, encoding):
if
encoding
==
'base64'
:
return
base64
.
decodestring
(
s
)
else
:
s
=
s
.
replace
(
'<'
,
'<'
)
s
=
s
.
replace
(
'>'
,
'>'
)
return
s
.
replace
(
'&'
,
'&'
)
s
=
s
.
replace
(
b'<'
,
b
'<'
)
s
=
s
.
replace
(
b'>'
,
b
'>'
)
return
s
.
replace
(
b'&'
,
b
'&'
)
# For converting to a more readable expression.
reprs
=
{}
...
...
@@ -99,7 +109,7 @@ def unconvert(encoding,S):
if
encoding
==
'base64'
:
return
base64
.
decodestring
(
S
)
else
:
return
eval
(
"'"
+
S
.
replace
(
'
\
n
'
,
''
)
+
"'"
)
return
str2bytes
(
eval
(
b"'"
+
S
.
replace
(
b'
\
n
'
,
b''
)
+
b"'"
)
)
class
Global
:
def
__init__
(
self
,
module
,
name
,
mapping
):
...
...
@@ -338,7 +348,7 @@ class NoBlanks:
# Ignore element data between elements (eg '<e> <f> </f> </e>')...
if
data
.
strip
():
if
isinstance
(
data
,
six
.
text_type
):
data
=
data
.
encode
(
'raw_unicode_escape'
)
data
=
data
.
encode
(
data_encoding
)
self
.
append
(
data
)
# Except for strings and unicode data as whitespaces should be
...
...
@@ -362,7 +372,7 @@ class NoBlanks:
self
.
previous_stack_end
=
None
if
isinstance
(
data
,
six
.
text_type
):
data
=
data
.
encode
(
'raw_unicode_escape'
)
data
=
data
.
encode
(
data_encoding
)
self
.
append
(
data
)
...
...
@@ -461,7 +471,7 @@ class ToXMLUnpickler(Unpickler):
return
Pickle
(
Unpickler
.
load
(
self
),
self
.
id_mapping
)
dispatch
=
{}
dispatch
.
update
(
Unpickler
.
dispatch
)
dispatch
.
update
(
Unpickler
.
dispatch
.
copy
()
)
def
persistent_load
(
self
,
v
):
return
Persistent
(
v
,
self
.
id_mapping
)
...
...
@@ -492,7 +502,7 @@ class ToXMLUnpickler(Unpickler):
dispatch
[
BININT2
]
=
load_binint2
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
))
dispatch
[
LONG
]
=
load_long
def
load_float
(
self
):
...
...
@@ -652,7 +662,7 @@ def ToXMLloads(str):
return
ToXMLUnpickler
(
file
).
load
()
def
name
(
self
,
tag
,
data
):
return
''
.
join
(
data
[
2
:]).
strip
()
return
b
''
.
join
(
data
[
2
:]).
strip
()
def
start_pickle
(
self
,
tag
,
attrs
):
self
.
_pickleids
=
{}
...
...
@@ -663,19 +673,19 @@ def save_int(self, tag, data):
v
=
int
(
name
(
self
,
tag
,
data
))
if
v
>=
0
:
if
v
<=
0xff
:
return
BININT1
+
chr
(
v
)
return
BININT1
+
bytes
([
v
]
)
if
v
<=
0xffff
:
return
'%c%c%c'
%
(
BININT2
,
v
&
0xff
,
v
>>
8
)
return
BININT2
+
b'%c%c'
%
(
v
&
0xff
,
v
>>
8
)
hb
=
v
>>
31
if
hb
==
0
or
hb
==
-
1
:
return
BININT
+
struct
.
pack
(
'<i'
,
v
)
return
INT
+
name
(
self
,
tag
,
data
)
+
'
\
n
'
return
INT
+
name
(
self
,
tag
,
data
)
+
b
'
\
n
'
def
save_float
(
self
,
tag
,
data
):
if
self
.
binary
:
return
BINFLOAT
+
struct
.
pack
(
'>d'
,
float
(
name
(
self
,
tag
,
data
)))
else
:
return
FLOAT
+
name
(
self
,
tag
,
data
)
+
'
\
n
'
return
FLOAT
+
name
(
self
,
tag
,
data
)
+
b
'
\
n
'
def
save_put
(
self
,
v
,
attrs
):
id
=
attrs
.
get
(
'id'
,
''
)
...
...
@@ -688,38 +698,41 @@ def save_put(self, v, attrs):
if
self
.
binary
:
id
=
int
(
id
)
if
id
<
256
:
id
=
BINPUT
+
chr
(
id
)
id
=
BINPUT
+
str2bytes
(
chr
(
id
)
)
else
:
id
=
LONG_BINPUT
+
struct
.
pack
(
'<i'
,
id
)
else
:
id
=
PUT
+
repr
(
id
)
+
'
\
n
'
id
=
PUT
+
repr
(
id
)
+
b
'
\
n
'
return
v
+
id
return
v
def
save_string
(
self
,
tag
,
data
):
binary
=
self
.
binary
v
=
''
a
=
data
[
1
]
if
len
(
data
)
>
2
:
v
=
''
.
join
(
data
[
2
:])
encoding
=
a
.
get
(
'encoding'
,
'repr'
)
# JPS: repr is default encoding
a
=
data
[
1
]
v
=
b''
.
join
(
data
[
2
:])
encoding
=
a
.
get
(
'encoding'
,
'repr'
)
# JPS: repr is default encoding
if
encoding
is
not
''
:
v
=
unconvert
(
encoding
,
v
)
put
=
'p'
if
binary
:
l
=
len
(
v
)
s
=
mdumps
(
l
)[
1
:]
if
(
l
<
256
):
v
=
'U'
+
s
[
0
]
+
v
v
=
unconvert
(
encoding
,
v
)
if
self
.
binary
:
l
=
len
(
v
)
if
l
<
256
:
if
encoding
==
'base64'
:
op
=
SHORT_BINBYTES
else
:
op
=
SHORT_BINSTRING
v
=
op
+
bytes
([
l
])
+
v
else
:
v
=
'T'
+
s
+
v
put
=
'q'
else
:
v
=
"S'"
+
v
+
"'
\
012
"
if
encoding
==
'base64'
:
op
=
BINBYTES
else
:
op
=
BINSTRING
v
=
op
+
struct
.
pack
(
'<i'
,
l
)
+
v
else
:
v
=
STRING
+
repr
(
v
)
+
'
\
n
'
return
save_put
(
self
,
v
,
a
)
def
save_unicode
(
self
,
tag
,
data
):
binary
=
self
.
binary
v
=
''
v
=
b
''
a
=
data
[
1
]
if
len
(
data
)
>
2
:
for
x
in
data
[
2
:]:
...
...
@@ -738,14 +751,14 @@ def save_tuple(self, tag, data):
T
=
data
[
2
:]
if
not
T
:
return
EMPTY_TUPLE
return
save_put
(
self
,
MARK
+
''
.
join
(
T
)
+
TUPLE
,
data
[
1
])
return
save_put
(
self
,
MARK
+
b
''
.
join
(
T
)
+
TUPLE
,
data
[
1
])
def
save_list
(
self
,
tag
,
data
):
L
=
data
[
2
:]
if
self
.
binary
:
v
=
save_put
(
self
,
EMPTY_LIST
,
data
[
1
])
if
L
:
v
=
v
+
MARK
+
''
.
join
(
L
)
+
APPENDS
v
=
v
+
MARK
+
b
''
.
join
(
L
)
+
APPENDS
else
:
v
=
save_put
(
self
,
MARK
+
LIST
,
data
[
1
])
if
L
:
...
...
@@ -757,7 +770,7 @@ def save_dict(self, tag, data):
if
self
.
binary
:
v
=
save_put
(
self
,
EMPTY_DICT
,
data
[
1
])
if
D
:
v
=
v
+
MARK
+
''
.
join
(
D
)
+
SETITEMS
v
=
v
+
MARK
+
b
''
.
join
(
D
)
+
SETITEMS
else
:
v
=
save_put
(
self
,
MARK
+
DICT
,
data
[
1
])
if
D
:
...
...
@@ -773,34 +786,35 @@ def save_reference(self, tag, data):
if
self
.
binary
:
id
=
int
(
id
)
if
id
<
256
:
return
BINGET
+
chr
(
id
)
return
BINGET
+
str2bytes
(
chr
(
id
)
)
else
:
return
LONG_BINGET
+
struct
.
pack
(
'<i'
,
i
)
else
:
return
GET
+
repr
(
id
)
+
'
\
n
'
return
GET
+
repr
(
id
)
+
b
'
\
n
'
def
save_object
(
self
,
tag
,
data
):
if
len
(
data
)
==
5
:
#OBJECT
v
=
'('
+
data
[
2
]
v
=
b
'('
+
data
[
2
]
x
=
data
[
3
][
1
:]
stop
=
x
.
rfind
(
't'
)
# This seems
stop
=
x
.
rfind
(
b
't'
)
# This seems
if
stop
>=
0
:
x
=
x
[:
stop
]
# wrong!
v
=
save_put
(
self
,
v
+
x
+
'o'
,
data
[
1
])
v
=
v
+
data
[
4
]
+
'b'
# state
v
=
save_put
(
self
,
v
+
x
+
b
'o'
,
data
[
1
])
v
=
v
+
data
[
4
]
+
b
'b'
# state
return
v
else
:
#REDUCE
#data does not contain state.(See Object.__setstate__ definition)
#So, we can assume that this is a reduce. (Yusei)
v
=
'('
+
data
[
2
]
v
=
b
'('
+
data
[
2
]
v
=
save_put
(
self
,
data
[
2
]
+
data
[
3
],
data
[
1
])
v
=
v
+
'R'
v
=
v
+
b
'R'
return
v
def
save_global
(
self
,
tag
,
data
):
a
=
data
[
1
]
return
save_put
(
self
,
GLOBAL
+
a
[
'module'
]
+
'
\
n
'
+
a
[
'name'
]
+
'
\
n
'
,
a
)
return
save_put
(
self
,
GLOBAL
+
str2bytes
(
a
[
'module'
])
+
b'
\
n
'
+
str2bytes
(
a
[
'name'
])
+
b'
\
n
'
,
a
)
def
save_persis
(
self
,
tag
,
data
):
v
=
data
[
2
]
...
...
@@ -813,16 +827,16 @@ def save_pickle_start(self, tag, attrs):
return
[
tag
,
attrs
]
def
save_pickle
(
self
,
tag
,
data
):
return
data
[
2
]
+
'.'
return
data
[
2
]
+
b
'.'
def
save_none
(
self
,
tag
,
data
):
return
'N'
return
b
'N'
def
save_long
(
self
,
tag
,
data
):
return
'L'
+
data
[
2
]
+
'L
\
012
'
return
b'L'
+
data
[
2
]
+
b
'L
\
012
'
def
save_item
(
self
,
tag
,
data
):
return
''
.
join
(
data
[
2
:])
return
b
''
.
join
(
data
[
2
:])
def
save_value
(
self
,
tag
,
data
):
return
data
[
2
]
...
...
@@ -837,7 +851,7 @@ class xmlPickler(NoBlanks, xyap):
if
tag
in
end
:
top
=
end
[
tag
](
self
,
tag
,
top
)
if
isinstance
(
top
,
six
.
text_type
):
top
=
top
.
encode
(
'raw_unicode_escape'
)
top
=
top
.
encode
(
data_encoding
)
append
(
top
)
start_handlers
=
{
...
...
product/ERP5Type/XMLExportImport/xyap.py
View file @
376bc263
...
...
@@ -94,21 +94,21 @@ class xmlrpc(NoBlanks, XYap):
'param'
:
lambda
self
,
tag
,
data
:
data
[
2
],
'value'
:
lambda
self
,
tag
,
data
:
data
[
2
],
'i4'
:
lambda
self
,
tag
,
data
,
atoi
=
string
.
atoi
,
name
=
name
:
lambda
self
,
tag
,
data
,
atoi
=
int
,
name
=
name
:
atoi
(
name
(
self
,
tag
,
data
)),
'int'
:
lambda
self
,
tag
,
data
,
atoi
=
string
.
atoi
,
name
=
name
:
lambda
self
,
tag
,
data
,
atoi
=
int
,
name
=
name
:
atoi
(
name
(
self
,
tag
,
data
)),
'boolean'
:
lambda
self
,
tag
,
data
,
atoi
=
string
.
atoi
,
name
=
name
:
lambda
self
,
tag
,
data
,
atoi
=
int
,
name
=
name
:
atoi
(
name
(
self
,
tag
,
data
)),
'string'
:
lambda
self
,
tag
,
data
,
join
=
string
.
join
:
join
(
data
[
2
:]
,
''
),
'string'
:
lambda
self
,
tag
,
data
,
join
=
''
.
join
:
join
(
data
[
2
:]),
'double'
:
lambda
self
,
tag
,
data
,
atof
=
string
.
atof
,
name
=
name
:
lambda
self
,
tag
,
data
,
atof
=
float
,
name
=
name
:
atof
(
name
(
self
,
tag
,
data
)),
'float'
:
lambda
self
,
tag
,
data
,
atof
=
string
.
atof
,
name
=
name
:
lambda
self
,
tag
,
data
,
atof
=
float
,
name
=
name
:
atof
(
name
(
self
,
tag
,
data
)),
'struct'
:
struct
,
'member'
:
tuplef
,
...
...
product/ERP5Type/patches/ObjectManager.py
View file @
376bc263
...
...
@@ -14,12 +14,7 @@
# Import: add rename feature and make _importObjectFromFile return the object
from
OFS.ObjectManager
import
ObjectManager
from
OFS.XMLExportImport
import
importXML
from
OFS.XMLExportImport
import
magic
customImporters
=
{
magic
:
importXML
,
}
from
Products.ERP5Type.XMLExportImport
import
customImporters
def
ObjectManager_importObjectFromFile
(
self
,
filepath
,
verify
=
1
,
set_owner
=
1
,
id
=
None
,
suppress_events
=
False
):
#LOG('_importObjectFromFile, filepath',0,filepath)
...
...
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