Port to Python 3.

This commit is contained in:
Itamar Turner-Trauring 2021-01-04 11:05:59 -05:00
parent 744e205763
commit a54aeae338
3 changed files with 30 additions and 5 deletions

View File

@ -1,3 +1,15 @@
"""
Ported to Python 3.
"""
from __future__ import absolute_import
from __future__ import division
from __future__ import print_function
from __future__ import unicode_literals
from future.utils import PY2
if PY2:
from future.builtins import filter, map, zip, ascii, chr, hex, input, next, oct, open, pow, round, super, bytes, dict, list, object, range, str, max, min # noqa: F401
from six import ensure_str from six import ensure_str
from zope.interface import implementer from zope.interface import implementer
@ -104,7 +116,7 @@ class Handler(object):
def _get_parent(self, path): def _get_parent(self, path):
# fire with (parentnode, childname) # fire with (parentnode, childname)
path = [unicode(p) for p in path] path = [str(p) for p in path]
if not path: if not path:
raise NoParentError raise NoParentError
childname = path[-1] childname = path[-1]
@ -183,7 +195,7 @@ class Handler(object):
def _get_root(self, path): def _get_root(self, path):
# return (root, remaining_path) # return (root, remaining_path)
path = [unicode(p) for p in path] path = [str(p) for p in path]
if path and path[0] == "uri": if path and path[0] == "uri":
d = defer.maybeDeferred(self.client.create_node_from_uri, d = defer.maybeDeferred(self.client.create_node_from_uri,
str(path[1])) str(path[1]))
@ -262,7 +274,7 @@ class Handler(object):
d.addCallback(_list) d.addCallback(_list)
def _render(children): def _render(children):
results = [] results = []
for (name, childnode) in children.items(): for (name, childnode) in list(children.items()):
# the interface claims that the result should have a unicode # the interface claims that the result should have a unicode
# object as the name, but it fails unless you give it a # object as the name, but it fails unless you give it a
# bytestring # bytestring
@ -280,7 +292,7 @@ class Handler(object):
return d return d
def openForWriting(self, path): def openForWriting(self, path):
path = [unicode(p) for p in path] path = [str(p) for p in path]
if not path: if not path:
raise ftp.PermissionDeniedError("cannot STOR to root directory") raise ftp.PermissionDeniedError("cannot STOR to root directory")
childname = path[-1] childname = path[-1]
@ -315,7 +327,7 @@ class Dispatcher(object):
class FTPServer(service.MultiService): class FTPServer(service.MultiService):
def __init__(self, client, accountfile, accounturl, ftp_portstr): def __init__(self, client, accountfile, accounturl, ftp_portstr):
precondition(isinstance(accountfile, (unicode, type(None))), accountfile) precondition(isinstance(accountfile, (str, type(None))), accountfile)
service.MultiService.__init__(self) service.MultiService.__init__(self)
r = Dispatcher(client) r = Dispatcher(client)

View File

@ -1,3 +1,14 @@
"""
Ported to Python 3.
"""
from __future__ import absolute_import
from __future__ import division
from __future__ import print_function
from __future__ import unicode_literals
from future.utils import PY2
if PY2:
from future.builtins import filter, map, zip, ascii, chr, hex, input, next, oct, open, pow, round, super, bytes, dict, list, object, range, str, max, min # noqa: F401
from twisted.trial import unittest from twisted.trial import unittest

View File

@ -35,6 +35,7 @@ PORTED_MODULES = [
"allmydata.crypto.rsa", "allmydata.crypto.rsa",
"allmydata.crypto.util", "allmydata.crypto.util",
"allmydata.dirnode", "allmydata.dirnode",
"allmydata.frontends.ftpd",
"allmydata.hashtree", "allmydata.hashtree",
"allmydata.immutable.checker", "allmydata.immutable.checker",
"allmydata.immutable.downloader", "allmydata.immutable.downloader",
@ -146,6 +147,7 @@ PORTED_TEST_MODULES = [
"allmydata.test.test_encode", "allmydata.test.test_encode",
"allmydata.test.test_encodingutil", "allmydata.test.test_encodingutil",
"allmydata.test.test_filenode", "allmydata.test.test_filenode",
"allmydata.test.test_ftp",
"allmydata.test.test_happiness", "allmydata.test.test_happiness",
"allmydata.test.test_hashtree", "allmydata.test.test_hashtree",
"allmydata.test.test_hashutil", "allmydata.test.test_hashutil",