Add a few comments. Change the way the protocol is checked (it must

be one of 0, 1 or 2).

I should note that the previous checkin also added NEWOBJ support to
the unpickler -- but there's nothing yet that generates this.
This commit is contained in:
Guido van Rossum 2003-01-28 15:19:53 +00:00
parent 3a41c61dd4
commit 1be3175992
1 changed files with 8 additions and 2 deletions

View File

@ -158,6 +158,9 @@ del x
_quotes = ["'", '"']
# Pickling machinery
class Pickler:
def __init__(self, file, proto=1):
@ -178,11 +181,11 @@ class Pickler:
object, or any other custom object that meets this interface.
"""
if not 0 <= proto <= 2:
if proto not in (0, 1, 2):
raise ValueError, "pickle protocol must be 0, 1 or 2"
self.write = file.write
self.memo = {}
self.proto = proto
self.proto = int(proto)
self.bin = proto >= 1
def clear_memo(self):
@ -639,6 +642,7 @@ class Pickler:
dispatch[BuiltinFunctionType] = save_global
dispatch[TypeType] = save_global
# Pickling helpers
def _keep_alive(x, memo):
"""Keeps a reference to the object x in the memo.
@ -683,6 +687,8 @@ def whichmodule(func, funcname):
return name
# Unpickling machinery
class Unpickler:
def __init__(self, file):