[Python-bugs-list] [ python-Bugs-440707 ] doctest crashes on cross-platform .pyc

noreply@sourceforge.net noreply@sourceforge.net
Fri, 13 Jul 2001 02:30:08 -0700


Bugs item #440707, was opened at 2001-07-12 08:51
You can respond by visiting: 
http://sourceforge.net/tracker/?func=detail&atid=105470&aid=440707&group_id=5470

Category: None
Group: None
Status: Open
Resolution: None
Priority: 5
Submitted By: David Goodger (goodger)
Assigned to: Nobody/Anonymous (nobody)
Summary: doctest crashes on cross-platform .pyc

Initial Comment:
doctest.py raises an exception when run on true cross-
platform .pyc files (i.e., MacOS .py compiled with 
compileall.compile_dir on Windows). The problem is, 
_extract_examples splits up __doc__ strings with:

    lines = s.split("\n")

MacOS-compiled-on-Windows .pyc __doc__ strings contain 
\r, not \n. The fix is to replace the line above (line 
5 of _extract_examples) with:

    lines = s.splitlines() + ['']

The reason for the "+ ['']" is that the behavior of 
s.splitlines() is subtly different from s.split("\n"): 
splitlines() doesn't return a final null string at the 
end of, say, "one\ntwo\n", whereas split("\n") does. 
(Is this difference of behavior a bug? If not, should 
it be described in the docs?)

The "+ ['']" also circumvents errors when the 
docstring doesn't end with a newline, ie:

    """
    >>> print 'hi'
    hi"""


----------------------------------------------------------------------

>Comment By: Tim Peters (tim_one)
Date: 2001-07-13 02:30

Message:
Logged In: YES 
user_id=31435

Which version of Python are you using?

Guido is baffled (as am I) because a modern py_compile.py 
(which produces the .pyc files) contains these lines:

f = open(file)
codestring = f.read()
codestring = codestring.replace("\r\n","\n")
codestring = codestring.replace("\r","\n")

That is, there's simply no way a carriage return can 
survive.  The checkin comment that introduced this hack 
(it's "a hack" because Python doesn't *generally* try to 
support non-native line conventions -- you're skating on 
the edge here at best) reads:

revision 1.16
date: 2000/09/15 06:57:26;  author: loewis;  state: Exp;  
lines: +5 -0
Support \r in source files. Closes bug #101425.


----------------------------------------------------------------------

Comment By: David Goodger (goodger)
Date: 2001-07-12 21:29

Message:
Logged In: YES 
user_id=7733

I'm doing MacOS-based cross-platform development. I 
like to keep the working files with Mac line-endings. So I 
run this "test_all" script on Windows:

    python -c 'import compileall; 
compileall.compile_dir(".")'
    python test_utils.pyc
    ...

If test_utils.py has \r line endings, docstrings in 
test_utils.pyc also end up with \r line endings. (The 
.pyc's are generated on Windows, from Mac-format .py 
files.) This breaks doctest. Perhaps compileall.py is the 
module with the bug? Or is my approach flawed or too 
rare to merit attention? :-)

----------------------------------------------------------------------

Comment By: Guido van Rossum (gvanrossum)
Date: 2001-07-12 13:54

Message:
Logged In: YES 
user_id=6380

I experimented (on Windows) and looked at the source some
more, and I cannot see how a \r could ever have ended up in
the .pyc file for a newline, no matter how or where the .pyc
file was written.

The only other theory that might explain what you see is
that when you transfered the .pyc file from Windows to Mac,
\n got translated into \r.


----------------------------------------------------------------------

Comment By: Guido van Rossum (gvanrossum)
Date: 2001-07-12 13:27

Message:
Logged In: YES 
user_id=6380

I'll have to look into this more, but I strongly recommend
against fixing doctest in the way you suggest.  The bug must
somehow be in the portability of .pyc files.  I'm surprised
that string literals compiled on Windows contain \r in the
.pyc file.  Are you *sure* this is what causes your problem?

----------------------------------------------------------------------

You can respond by visiting: 
http://sourceforge.net/tracker/?func=detail&atid=105470&aid=440707&group_id=5470