From dde2376c4e2d85ba2dc8a9b71f44a17682d49574 Mon Sep 17 00:00:00 2001 From: Zooko O'Whielacronx Date: Mon, 22 Dec 2008 16:22:37 -0700 Subject: [PATCH] =?UTF-8?q?util/base32:=20loosen=20the=20precondition=20fo?= =?UTF-8?q?rbidding=20unicode=20and=20requiring=20str=20--=20now=20it=20re?= =?UTF-8?q?quires=20either=20unicode=20or=20str=20Hopefully=20this=20will?= =?UTF-8?q?=20make=20it=20so=20that=20tests=20pass=20with=20Fran=C3=A7ois?= =?UTF-8?q?=20Deppierraz's=20patch=20to=20fix=20the=20tahoe=20cli's=20hand?= =?UTF-8?q?ling=20of=20unicode=20argument.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/allmydata/util/base32.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/allmydata/util/base32.py b/src/allmydata/util/base32.py index c5e5017ed..148a869c8 100644 --- a/src/allmydata/util/base32.py +++ b/src/allmydata/util/base32.py @@ -179,12 +179,13 @@ def init_s5(): s5 = init_s5() def could_be_base32_encoded(s, s8=s8, tr=string.translate, identitytranstable=identitytranstable, chars=chars): + precondition(isinstance(s, (str, unicode)), s) if s == '': return True - precondition(not isinstance(s, unicode), s) return s8[len(s)%8][ord(s[-1])] and not tr(s, identitytranstable, chars) def could_be_base32_encoded_l(s, lengthinbits, s5=s5, tr=string.translate, identitytranstable=identitytranstable, chars=chars): + precondition(isinstance(s, (str, unicode)), s) if s == '': return True assert lengthinbits%5 < len(s5), lengthinbits