diff options
| author | Benjamin Peterson <benjamin@python.org> | 2009-05-09 01:01:14 (GMT) |
|---|---|---|
| committer | Benjamin Peterson <benjamin@python.org> | 2009-05-09 01:01:14 (GMT) |
| commit | 84ad84e0bb15e7c64109e88060afdcb60ae7b740 (patch) | |
| tree | 5469c776c1f0fd812ae194e39544fca7dd3130b9 /Lib/lib2to3/pytree.py | |
| parent | 5edb1a1b0add465bae25121ee4278a9ec6009005 (diff) | |
| download | cpython-84ad84e0bb15e7c64109e88060afdcb60ae7b740.zip cpython-84ad84e0bb15e7c64109e88060afdcb60ae7b740.tar.gz cpython-84ad84e0bb15e7c64109e88060afdcb60ae7b740.tar.bz2 | |
Merged revisions 72491-72493 via svnmerge from
svn+ssh://pythondev@svn.python.org/sandbox/trunk/2to3/lib2to3
........
r72491 | benjamin.peterson | 2009-05-08 19:33:27 -0500 (Fri, 08 May 2009) | 7 lines
make 2to3 use unicode internally on 2.x
This started out as a fix for #2660, but became this large refactoring
when I realized the dire state this was in. 2to3 now uses
tokenize.detect_encoding to decode the files correctly into unicode.
........
r72492 | benjamin.peterson | 2009-05-08 19:35:38 -0500 (Fri, 08 May 2009) | 1 line
remove compat code
........
r72493 | benjamin.peterson | 2009-05-08 19:54:15 -0500 (Fri, 08 May 2009) | 1 line
add a test for \r\n newlines
........
Diffstat (limited to 'Lib/lib2to3/pytree.py')
| -rw-r--r-- | Lib/lib2to3/pytree.py | 20 |
1 files changed, 15 insertions, 5 deletions
diff --git a/Lib/lib2to3/pytree.py b/Lib/lib2to3/pytree.py index 3a36da2..6f73aa9 100644 --- a/Lib/lib2to3/pytree.py +++ b/Lib/lib2to3/pytree.py @@ -213,9 +213,13 @@ class Base(object): """ next_sib = self.next_sibling if next_sib is None: - return "" + return u"" return next_sib.get_prefix() + if sys.version_info < (3, 0): + def __str__(self): + return unicode(self).encode("ascii") + class Node(Base): @@ -245,13 +249,16 @@ class Node(Base): type_repr(self.type), self.children) - def __str__(self): + def __unicode__(self): """ Return a pretty string representation. This reproduces the input source exactly. """ - return "".join(map(str, self.children)) + return u"".join(map(unicode, self.children)) + + if sys.version_info > (3, 0): + __str__ = __unicode__ def _eq(self, other): """Compare two nodes for equality.""" @@ -353,13 +360,16 @@ class Leaf(Base): self.type, self.value) - def __str__(self): + def __unicode__(self): """ Return a pretty string representation. This reproduces the input source exactly. """ - return self.prefix + str(self.value) + return self.prefix + unicode(self.value) + + if sys.version_info > (3, 0): + __str__ = __unicode__ def _eq(self, other): """Compare two nodes for equality.""" |
