socket.makefile raises ValueError when mode = 'rt'

Dave Angel d at davea.name
Wed Jan 9 08:54:53 EST 2013


On 01/09/2013 08:22 AM, Antoon Pardon wrote:
> This is using python 3.2.
>
> I am writing somekind of wrapper around the ftplib. So
> that you can work with it as if you are working with
> local files.
>
> The idea is that you start with making a connection like
>
> rmt = FTP(...)
>
> and then do something like the following
>
> rmtfl = rmt.open("rmtfilename", "rt")
> for ln in rmtfl:
>     treat(ln)
>
> This is part of the code:
>
> class ftpfile:
>     def __init__(self, cn, rfn, mode, bound = False):
>         self.ftp = cn
>         self.bound = bound
>         if 'b' in mode:
>             self.ftp.voidcmd('TYPE I')
>         else:
>             self.ftp.voidcmd('TYPE A')
>         if 'r' in mode:
>             self.cnct =  self.ftp.transfercmd("RETR %s" % rfn)
>             self.fl = self.cnct.makefile(mode)
>         elif 'w' in mode:
>             self.cnct =  self.ftp.transfercmd("STOR %s" % rfn)
>             self.fl = self.cnct.makefile(mode, newline = '\r\n')
>         else:
>             raise ValueError("%s: invalide mode" % mode)
>
> The problem is with makefile. If mode contains a "t" I get
> the following traceback:
>
> Traceback (most recent call last):
>   File "ftputil.tpy", line 14, in test_textftp
>     rmtfl1 = rmt.open('ftp1.py', 'wt')
>   File "/local/home/apardon/src/projecten/py3lib/ftputil.py", line 76,
> in open
>     return ftpfile(ftp, fn, mode, True)
>   File "/local/home/apardon/src/projecten/py3lib/ftputil.py", line 15,
> in __init__
>     self.fl = self.cnct.makefile(mode, newline = '\r\n')
>   File "/usr/lib/python3.2/socket.py", line 151, in makefile
>     raise ValueError("invalid mode %r (only r, w, b allowed)")
> ValueError: invalid mode %r (only r, w, b allowed)
>
> But the documentation states:
> socket.makefile(mode='r', buffering=None, *, encoding=None, errors=None,
> newline=None)
>     Return a file object associated with the socket. The exact returned
> type depends on the arguments given to makefile(). These arguments are
> interpreted the same way as by the built-in open() function.
>
> And since 't' is allowed in the mode of the built-in open() function I
> would consider this a bug.
> Unless I am missing something?

I believe that 't' was a new addition to mode, for Python 3.x     So
perhaps the socket library hasn't kept consistent with it.

I don't really know the socket library.  Does it even support text
mode?  Does that make sense?  Remember that text mode means a different
thing in 3.x than it did in 2.x



-- 

DaveA




More information about the Python-list mailing list