Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
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
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
cc313061
Commit
cc313061
authored
Jun 11, 2008
by
Alexandre Vassalotti
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Issue 2917: Merge the pickle and cPickle module.
parent
1e637b73
Changes
8
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
4685 additions
and
126 deletions
+4685
-126
Lib/pickle.py
Lib/pickle.py
+74
-83
Lib/pickletools.py
Lib/pickletools.py
+12
-10
Lib/test/pickletester.py
Lib/test/pickletester.py
+13
-12
Lib/test/test_pickle.py
Lib/test/test_pickle.py
+34
-19
Lib/test/test_pickletools.py
Lib/test/test_pickletools.py
+0
-2
Misc/NEWS
Misc/NEWS
+4
-0
Modules/_pickle.c
Modules/_pickle.c
+4546
-0
setup.py
setup.py
+2
-0
No files found.
Lib/pickle.py
View file @
cc313061
This diff is collapsed.
Click to expand it.
Lib/pickletools.py
View file @
cc313061
...
@@ -2079,11 +2079,12 @@ _dis_test = r"""
...
@@ -2079,11 +2079,12 @@ _dis_test = r"""
70: t TUPLE (MARK at 49)
70: t TUPLE (MARK at 49)
71: p PUT 5
71: p PUT 5
74: R REDUCE
74: R REDUCE
75: V UNICODE 'def'
75: p PUT 6
80: p PUT 6
78: V UNICODE 'def'
83: s SETITEM
83: p PUT 7
84: a APPEND
86: s SETITEM
85: . STOP
87: a APPEND
88: . STOP
highest protocol among opcodes = 0
highest protocol among opcodes = 0
Try again with a "binary" pickle.
Try again with a "binary" pickle.
...
@@ -2115,11 +2116,12 @@ Try again with a "binary" pickle.
...
@@ -2115,11 +2116,12 @@ Try again with a "binary" pickle.
49: t TUPLE (MARK at 37)
49: t TUPLE (MARK at 37)
50: q BINPUT 5
50: q BINPUT 5
52: R REDUCE
52: R REDUCE
53: X BINUNICODE 'def'
53: q BINPUT 6
61: q BINPUT 6
55: X BINUNICODE 'def'
63: s SETITEM
63: q BINPUT 7
64: e APPENDS (MARK at 3)
65: s SETITEM
65: . STOP
66: e APPENDS (MARK at 3)
67: . STOP
highest protocol among opcodes = 1
highest protocol among opcodes = 1
Exercise the INST/OBJ/BUILD family.
Exercise the INST/OBJ/BUILD family.
...
...
Lib/test/pickletester.py
View file @
cc313061
...
@@ -362,7 +362,7 @@ def create_data():
...
@@ -362,7 +362,7 @@ def create_data():
return
x
return
x
class
AbstractPickleTests
(
unittest
.
TestCase
):
class
AbstractPickleTests
(
unittest
.
TestCase
):
# Subclass must define self.dumps, self.loads
, self.error
.
# Subclass must define self.dumps, self.loads.
_testdata
=
create_data
()
_testdata
=
create_data
()
...
@@ -463,8 +463,9 @@ class AbstractPickleTests(unittest.TestCase):
...
@@ -463,8 +463,9 @@ class AbstractPickleTests(unittest.TestCase):
self
.
assertEqual
(
list
(
x
[
0
].
attr
.
keys
()),
[
1
])
self
.
assertEqual
(
list
(
x
[
0
].
attr
.
keys
()),
[
1
])
self
.
assert_
(
x
[
0
].
attr
[
1
]
is
x
)
self
.
assert_
(
x
[
0
].
attr
[
1
]
is
x
)
def
test_garyp
(
self
):
def
test_get
(
self
):
self
.
assertRaises
(
self
.
error
,
self
.
loads
,
b'garyp'
)
self
.
assertRaises
(
KeyError
,
self
.
loads
,
b'g0
\
n
p0'
)
self
.
assertEquals
(
self
.
loads
(
b'((Kdtp0
\
n
h
\
x00
l.))'
),
[(
100
,),
(
100
,)])
def
test_insecure_strings
(
self
):
def
test_insecure_strings
(
self
):
# XXX Some of these tests are temporarily disabled
# XXX Some of these tests are temporarily disabled
...
@@ -955,7 +956,7 @@ class AbstractPickleModuleTests(unittest.TestCase):
...
@@ -955,7 +956,7 @@ class AbstractPickleModuleTests(unittest.TestCase):
f
=
open
(
TESTFN
,
"wb"
)
f
=
open
(
TESTFN
,
"wb"
)
try
:
try
:
f
.
close
()
f
.
close
()
self
.
assertRaises
(
ValueError
,
self
.
modu
le
.
dump
,
123
,
f
)
self
.
assertRaises
(
ValueError
,
pick
le
.
dump
,
123
,
f
)
finally
:
finally
:
os
.
remove
(
TESTFN
)
os
.
remove
(
TESTFN
)
...
@@ -964,24 +965,24 @@ class AbstractPickleModuleTests(unittest.TestCase):
...
@@ -964,24 +965,24 @@ class AbstractPickleModuleTests(unittest.TestCase):
f
=
open
(
TESTFN
,
"wb"
)
f
=
open
(
TESTFN
,
"wb"
)
try
:
try
:
f
.
close
()
f
.
close
()
self
.
assertRaises
(
ValueError
,
self
.
modu
le
.
dump
,
123
,
f
)
self
.
assertRaises
(
ValueError
,
pick
le
.
dump
,
123
,
f
)
finally
:
finally
:
os
.
remove
(
TESTFN
)
os
.
remove
(
TESTFN
)
def
test_highest_protocol
(
self
):
def
test_highest_protocol
(
self
):
# Of course this needs to be changed when HIGHEST_PROTOCOL changes.
# Of course this needs to be changed when HIGHEST_PROTOCOL changes.
self
.
assertEqual
(
self
.
modu
le
.
HIGHEST_PROTOCOL
,
3
)
self
.
assertEqual
(
pick
le
.
HIGHEST_PROTOCOL
,
3
)
def
test_callapi
(
self
):
def
test_callapi
(
self
):
from
io
import
BytesIO
from
io
import
BytesIO
f
=
BytesIO
()
f
=
BytesIO
()
# With and without keyword arguments
# With and without keyword arguments
self
.
modu
le
.
dump
(
123
,
f
,
-
1
)
pick
le
.
dump
(
123
,
f
,
-
1
)
self
.
modu
le
.
dump
(
123
,
file
=
f
,
protocol
=-
1
)
pick
le
.
dump
(
123
,
file
=
f
,
protocol
=-
1
)
self
.
modu
le
.
dumps
(
123
,
-
1
)
pick
le
.
dumps
(
123
,
-
1
)
self
.
modu
le
.
dumps
(
123
,
protocol
=-
1
)
pick
le
.
dumps
(
123
,
protocol
=-
1
)
self
.
modu
le
.
Pickler
(
f
,
-
1
)
pick
le
.
Pickler
(
f
,
-
1
)
self
.
modu
le
.
Pickler
(
f
,
protocol
=-
1
)
pick
le
.
Pickler
(
f
,
protocol
=-
1
)
class
AbstractPersistentPicklerTests
(
unittest
.
TestCase
):
class
AbstractPersistentPicklerTests
(
unittest
.
TestCase
):
...
...
Lib/test/test_pickle.py
View file @
cc313061
...
@@ -7,37 +7,42 @@ from test.pickletester import AbstractPickleTests
...
@@ -7,37 +7,42 @@ from test.pickletester import AbstractPickleTests
from
test.pickletester
import
AbstractPickleModuleTests
from
test.pickletester
import
AbstractPickleModuleTests
from
test.pickletester
import
AbstractPersistentPicklerTests
from
test.pickletester
import
AbstractPersistentPicklerTests
class
PickleTests
(
AbstractPickleTests
,
AbstractPickleModuleTests
):
try
:
import
_pickle
has_c_implementation
=
True
except
ImportError
:
has_c_implementation
=
False
module
=
pickle
error
=
KeyError
def
dumps
(
self
,
arg
,
proto
=
None
):
class
PickleTests
(
AbstractPickleModuleTests
):
return
pickle
.
dumps
(
arg
,
proto
)
pass
def
loads
(
self
,
buf
):
return
pickle
.
loads
(
buf
)
class
PicklerTests
(
AbstractPickleTests
):
class
P
yP
icklerTests
(
AbstractPickleTests
):
error
=
KeyError
pickler
=
pickle
.
_Pickler
unpickler
=
pickle
.
_Unpickler
def
dumps
(
self
,
arg
,
proto
=
None
):
def
dumps
(
self
,
arg
,
proto
=
None
):
f
=
io
.
BytesIO
()
f
=
io
.
BytesIO
()
p
=
pickle
.
P
ickler
(
f
,
proto
)
p
=
self
.
p
ickler
(
f
,
proto
)
p
.
dump
(
arg
)
p
.
dump
(
arg
)
f
.
seek
(
0
)
f
.
seek
(
0
)
return
bytes
(
f
.
read
())
return
bytes
(
f
.
read
())
def
loads
(
self
,
buf
):
def
loads
(
self
,
buf
):
f
=
io
.
BytesIO
(
buf
)
f
=
io
.
BytesIO
(
buf
)
u
=
pickle
.
U
npickler
(
f
)
u
=
self
.
u
npickler
(
f
)
return
u
.
load
()
return
u
.
load
()
class
PersPicklerTests
(
AbstractPersistentPicklerTests
):
class
PyPersPicklerTests
(
AbstractPersistentPicklerTests
):
pickler
=
pickle
.
_Pickler
unpickler
=
pickle
.
_Unpickler
def
dumps
(
self
,
arg
,
proto
=
None
):
def
dumps
(
self
,
arg
,
proto
=
None
):
class
PersPickler
(
pickle
.
P
ickler
):
class
PersPickler
(
self
.
p
ickler
):
def
persistent_id
(
subself
,
obj
):
def
persistent_id
(
subself
,
obj
):
return
self
.
persistent_id
(
obj
)
return
self
.
persistent_id
(
obj
)
f
=
io
.
BytesIO
()
f
=
io
.
BytesIO
()
...
@@ -47,19 +52,29 @@ class PersPicklerTests(AbstractPersistentPicklerTests):
...
@@ -47,19 +52,29 @@ class PersPicklerTests(AbstractPersistentPicklerTests):
return
f
.
read
()
return
f
.
read
()
def
loads
(
self
,
buf
):
def
loads
(
self
,
buf
):
class
PersUnpickler
(
pickle
.
U
npickler
):
class
PersUnpickler
(
self
.
u
npickler
):
def
persistent_load
(
subself
,
obj
):
def
persistent_load
(
subself
,
obj
):
return
self
.
persistent_load
(
obj
)
return
self
.
persistent_load
(
obj
)
f
=
io
.
BytesIO
(
buf
)
f
=
io
.
BytesIO
(
buf
)
u
=
PersUnpickler
(
f
)
u
=
PersUnpickler
(
f
)
return
u
.
load
()
return
u
.
load
()
if
has_c_implementation
:
class
CPicklerTests
(
PyPicklerTests
):
pickler
=
_pickle
.
Pickler
unpickler
=
_pickle
.
Unpickler
class
CPersPicklerTests
(
PyPersPicklerTests
):
pickler
=
_pickle
.
Pickler
unpickler
=
_pickle
.
Unpickler
def
test_main
():
def
test_main
():
support
.
run_unittest
(
tests
=
[
PickleTests
,
PyPicklerTests
,
PyPersPicklerTests
]
PickleTests
,
if
has_c_implementation
:
PicklerTests
,
tests
.
extend
([
CPicklerTests
,
CPersPicklerTests
])
PersPicklerTests
support
.
run_unittest
(
*
tests
)
)
support
.
run_doctest
(
pickle
)
support
.
run_doctest
(
pickle
)
if
__name__
==
"__main__"
:
if
__name__
==
"__main__"
:
...
...
Lib/test/test_pickletools.py
View file @
cc313061
...
@@ -12,8 +12,6 @@ class OptimizedPickleTests(AbstractPickleTests, AbstractPickleModuleTests):
...
@@ -12,8 +12,6 @@ class OptimizedPickleTests(AbstractPickleTests, AbstractPickleModuleTests):
def
loads
(
self
,
buf
):
def
loads
(
self
,
buf
):
return
pickle
.
loads
(
buf
)
return
pickle
.
loads
(
buf
)
module
=
pickle
error
=
KeyError
def
test_main
():
def
test_main
():
support
.
run_unittest
(
OptimizedPickleTests
)
support
.
run_unittest
(
OptimizedPickleTests
)
...
...
Misc/NEWS
View file @
cc313061
...
@@ -78,6 +78,10 @@ Extension Modules
...
@@ -78,6 +78,10 @@ Extension Modules
Library
Library
-------
-------
- The ``pickle`` module is now automatically use an optimized C
implementation of Pickler and Unpickler when available. The
``cPickle`` module is no longer needed.
- Removed the ``htmllib`` and ``sgmllib`` modules.
- Removed the ``htmllib`` and ``sgmllib`` modules.
- The deprecated ``SmartCookie`` and ``SimpleCookie`` classes have
- The deprecated ``SmartCookie`` and ``SimpleCookie`` classes have
...
...
Modules/_pickle.c
0 → 100644
View file @
cc313061
This diff is collapsed.
Click to expand it.
setup.py
View file @
cc313061
...
@@ -422,6 +422,8 @@ class PyBuildExt(build_ext):
...
@@ -422,6 +422,8 @@ class PyBuildExt(build_ext):
exts
.
append
(
Extension
(
"_functools"
,
[
"_functoolsmodule.c"
])
)
exts
.
append
(
Extension
(
"_functools"
,
[
"_functoolsmodule.c"
])
)
# Memory-based IO accelerator modules
# Memory-based IO accelerator modules
exts
.
append
(
Extension
(
"_bytesio"
,
[
"_bytesio.c"
])
)
exts
.
append
(
Extension
(
"_bytesio"
,
[
"_bytesio.c"
])
)
# C-optimized pickle replacement
exts
.
append
(
Extension
(
"_pickle"
,
[
"_pickle.c"
])
)
# atexit
# atexit
exts
.
append
(
Extension
(
"atexit"
,
[
"atexitmodule.c"
])
)
exts
.
append
(
Extension
(
"atexit"
,
[
"atexitmodule.c"
])
)
# _json speedups
# _json speedups
...
...
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