diff options
| author | Walter Dörwald <walter@livinglogic.de> | 2007-06-08 15:33:46 +0000 | 
|---|---|---|
| committer | Walter Dörwald <walter@livinglogic.de> | 2007-06-08 15:33:46 +0000 | 
| commit | 3f1e65cfde6ebfc1be580bac44fda5c15176f30b (patch) | |
| tree | 87199c83775984026b93c2c7179e271ad94ab8b1 /Lib/Cookie.py | |
| parent | 9b775535f828bedc30f3f52a04afec049b6aa25a (diff) | |
| download | cpython-git-3f1e65cfde6ebfc1be580bac44fda5c15176f30b.tar.gz | |
Fix Cookie.py: Fix example in the docstring (encoded SerialCookies contain
unicode now). Fix _quote() and Morsel.set() which were using str8.translate().
As cPickle.dumps() returns bytes now value_encode() and value_decode() methods
must encode/decode (however output() might better return a bytes object).
Diffstat (limited to 'Lib/Cookie.py')
| -rw-r--r-- | Lib/Cookie.py | 22 | 
1 files changed, 10 insertions, 12 deletions
| diff --git a/Lib/Cookie.py b/Lib/Cookie.py index 153adc5684..0cd32445e5 100644 --- a/Lib/Cookie.py +++ b/Lib/Cookie.py @@ -163,7 +163,7 @@ values, however.)     >>> C["string"].value     'seven'     >>> C.output().replace('p0', 'p1') # Hack for cPickle/pickle differences -   'Set-Cookie: number="I7\\012."\r\nSet-Cookie: string="S\'seven\'\\012p1\\012."' +   'Set-Cookie: number="I7\\012."\r\nSet-Cookie: string="Vseven\\012p1\\012."'  Be warned, however, if SerialCookie cannot de-serialize a value (because  it isn't a valid pickle'd object), IT WILL RAISE AN EXCEPTION. @@ -305,16 +305,14 @@ _Translator       = {      '\375' : '\\375',  '\376' : '\\376',  '\377' : '\\377'      } -_idmap = ''.join(chr(x) for x in range(256)) - -def _quote(str, LegalChars=_LegalChars, idmap=_idmap): +def _quote(str, LegalChars=_LegalChars):      #      # If the string does not need to be double-quoted,      # then just return the string.  Otherwise, surround      # the string in doublequotes and precede quote (with a \)      # special characters.      # -    if "" == str.translate(idmap, LegalChars): +    if len(filter(LegalChars.__contains__, str)) == len(str):          return str      else:          return '"' + _nulljoin( map(_Translator.get, str, str) ) + '"' @@ -439,12 +437,12 @@ class Morsel(dict):          return K.lower() in self._reserved      # end isReservedKey -    def set(self, key, val, coded_val, LegalChars=_LegalChars, idmap=_idmap): +    def set(self, key, val, coded_val, LegalChars=_LegalChars):          # First we verify that the key isn't a reserved word          # Second we make sure it only contains legal characters          if key.lower() in self._reserved:              raise CookieError("Attempt to set a reserved key: %s" % key) -        if "" != key.translate(idmap, LegalChars): +        if len(filter(LegalChars.__contains__, key)) != len(key):              raise CookieError("Illegal key value: %s" % key)          # It's a good key, so save it. @@ -680,9 +678,9 @@ class SerialCookie(BaseCookie):      # end __init__      def value_decode(self, val):          # This could raise an exception! -        return loads( _unquote(val) ), val +        return loads( _unquote(val).encode('latin-1') ), val      def value_encode(self, val): -        return val, _quote( dumps(val) ) +        return val, _quote( dumps(val).decode('latin-1') )  # end SerialCookie  class SmartCookie(BaseCookie): @@ -706,14 +704,14 @@ class SmartCookie(BaseCookie):      def value_decode(self, val):          strval = _unquote(val)          try: -            return loads(strval), val +            return loads(strval.encode('latin-1')), val          except:              return strval, val      def value_encode(self, val): -        if type(val) == type(""): +        if isinstance(val, str):              return val, _quote(val)          else: -            return val, _quote( dumps(val) ) +            return val, _quote( dumps(val).decode('latin-1') )  # end SmartCookie | 
