Skip to content

Commit

Permalink
Merge p3yk branch with the trunk up to revision 45595. This breaks a …
Browse files Browse the repository at this point in the history
…fair

number of tests, all because of the codecs/_multibytecodecs issue described
here (it's not a Py3K issue, just something Py3K discovers):
http://mail.python.org/pipermail/python-dev/2006-April/064051.html

Hye-Shik Chang promised to look for a fix, so no need to fix it here. The
tests that are expected to break are:

test_codecencodings_cn
test_codecencodings_hk
test_codecencodings_jp
test_codecencodings_kr
test_codecencodings_tw
test_codecs
test_multibytecodec

This merge fixes an actual test failure (test_weakref) in this branch,
though, so I believe merging is the right thing to do anyway.
  • Loading branch information
Yhg1s committed Apr 21, 2006
1 parent 9ada3d6 commit 49fd7fa
Show file tree
Hide file tree
Showing 640 changed files with 52,451 additions and 18,619 deletions.
249 changes: 235 additions & 14 deletions Demo/parser/unparse.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
"Usage: unparse.py <path to source file>"
import sys
import _ast
import cStringIO
import os

class Unparser:
"""Methods in this class recursively traverse an AST and
Expand Down Expand Up @@ -70,6 +73,18 @@ def _Import(self, t):
if a.asname:
self.write(" as "+a.asname)

def _ImportFrom(self, t):
self.fill("from ")
self.write(t.module)
self.write(" import ")
for i, a in enumerate(t.names):
if i == 0:
self.write(", ")
self.write(a.name)
if a.asname:
self.write(" as "+a.asname)
# XXX(jpe) what is level for?

def _Assign(self, t):
self.fill()
for target in t.targets:
Expand All @@ -88,6 +103,36 @@ def _Return(self, t):
if t.value:
self.dispatch(t.value)

def _Pass(self, t):
self.fill("pass")

def _Break(self, t):
self.fill("break")

def _Continue(self, t):
self.fill("continue")

def _Delete(self, t):
self.fill("del ")
self.dispatch(t.targets)

def _Assert(self, t):
self.fill("assert ")
self.dispatch(t.test)
if t.msg:
self.write(", ")
self.dispatch(t.msg)

def _Exec(self, t):
self.fill("exec ")
self.dispatch(t.body)
if t.globals:
self.write(" in ")
self.dispatch(t.globals)
if t.locals:
self.write(", ")
self.dispatch(t.locals)

def _Print(self, t):
self.fill("print ")
do_comma = False
Expand All @@ -102,6 +147,67 @@ def _Print(self, t):
if not t.nl:
self.write(",")

def _Global(self, t):
self.fill("global")
for i, n in enumerate(t.names):
if i != 0:
self.write(",")
self.write(" " + n)

def _Yield(self, t):
self.fill("yield")
if t.value:
self.write(" (")
self.dispatch(t.value)
self.write(")")

def _Raise(self, t):
self.fill('raise ')
if t.type:
self.dispatch(t.type)
if t.inst:
self.write(", ")
self.dispatch(t.inst)
if t.tback:
self.write(", ")
self.dispatch(t.tback)

def _TryExcept(self, t):
self.fill("try")
self.enter()
self.dispatch(t.body)
self.leave()

for ex in t.handlers:
self.dispatch(ex)
if t.orelse:
self.fill("else")
self.enter()
self.dispatch(t.orelse)
self.leave()

def _TryFinally(self, t):
self.fill("try")
self.enter()
self.dispatch(t.body)
self.leave()

self.fill("finally")
self.enter()
self.dispatch(t.finalbody)
self.leave()

def _excepthandler(self, t):
self.fill("except ")
if t.type:
self.dispatch(t.type)
if t.name:
self.write(", ")
self.dispatch(t.name)
self.enter()
self.dispatch(t.body)
self.leave()

def _ClassDef(self, t):
self.write("\n")
self.fill("class "+t.name)
Expand All @@ -119,9 +225,24 @@ def _FunctionDef(self, t):
self.write("\n")
self.fill("def "+t.name + "(")
self.dispatch(t.args)
self.write(")")
self.enter()
self.dispatch(t.body)
self.leave()

def _For(self, t):
self.fill("for ")
self.dispatch(t.target)
self.write(" in ")
self.dispatch(t.iter)
self.enter()
self.dispatch(t.body)
self.leave()
if t.orelse:
self.fill("else")
self.enter()
self.dispatch(t.orelse)
self.leave

def _If(self, t):
self.fill("if ")
Expand All @@ -136,11 +257,9 @@ def _If(self, t):
self.dispatch(t.orelse)
self.leave()

def _For(self, t):
self.fill("for ")
self.dispatch(t.target)
self.write(" in ")
self.dispatch(t.iter)
def _While(self, t):
self.fill("while ")
self.dispatch(t.test)
self.enter()
self.dispatch(t.body)
self.leave()
Expand All @@ -150,13 +269,28 @@ def _For(self, t):
self.dispatch(t.orelse)
self.leave

def _With(self, t):
self.fill("with ")
self.dispatch(t.context_expr)
if t.optional_vars:
self.write(" as ")
self.dispatch(t.optional_vars)
self.enter()
self.dispatch(t.body)
self.leave()

# expr
def _Str(self, tree):
self.write(repr(tree.s))

def _Name(self, t):
self.write(t.id)

def _Repr(self, t):
self.write("`")
self.dispatch(t.value)
self.write("`")

def _Num(self, t):
self.write(repr(t.n))

Expand All @@ -167,6 +301,37 @@ def _List(self, t):
self.write(", ")
self.write("]")

def _ListComp(self, t):
self.write("[")
self.dispatch(t.elt)
for gen in t.generators:
self.dispatch(gen)
self.write("]")

def _GeneratorExp(self, t):
self.write("(")
self.dispatch(t.elt)
for gen in t.generators:
self.dispatch(gen)
self.write(")")

def _comprehension(self, t):
self.write(" for ")
self.dispatch(t.target)
self.write(" in ")
self.dispatch(t.iter)
for if_clause in t.ifs:
self.write(" if ")
self.dispatch(if_clause)

def _IfExp(self, t):
self.dispatch(t.body)
self.write(" if ")
self.dispatch(t.test)
if t.orelse:
self.write(" else ")
self.dispatch(t.orelse)

def _Dict(self, t):
self.write("{")
for k,v in zip(t.keys, t.values):
Expand Down Expand Up @@ -194,8 +359,8 @@ def _UnaryOp(self, t):
self.write(")")

binop = { "Add":"+", "Sub":"-", "Mult":"*", "Div":"/", "Mod":"%",
"RShift":"<<", "BitOr":"|", "BitXor":"^", "BitAnd":"&",
"FloorDiv":"//"}
"LShift":">>", "RShift":"<<", "BitOr":"|", "BitXor":"^", "BitAnd":"&",
"FloorDiv":"//", "Pow": "**"}
def _BinOp(self, t):
self.write("(")
self.dispatch(t.left)
Expand All @@ -213,6 +378,15 @@ def _Compare(self, t):
self.dispatch(e)
self.write(")")

boolops = {_ast.And: 'and', _ast.Or: 'or'}
def _BoolOp(self, t):
self.write("(")
self.dispatch(t.values[0])
for v in t.values[1:]:
self.write(" %s " % self.boolops[t.op.__class__])
self.dispatch(v)
self.write(")")

def _Attribute(self,t):
self.dispatch(t.value)
self.write(".")
Expand All @@ -234,12 +408,12 @@ def _Call(self, t):
if comma: self.write(", ")
else: comma = True
self.write("*")
self.dispatch(t.stararg)
self.dispatch(t.starargs)
if t.kwargs:
if comma: self.write(", ")
else: comma = True
self.write("**")
self.dispatch(t.stararg)
self.dispatch(t.kwargs)
self.write(")")

def _Subscript(self, t):
Expand All @@ -249,6 +423,9 @@ def _Subscript(self, t):
self.write("]")

# slice
def _Ellipsis(self, t):
self.write("...")

def _Index(self, t):
self.dispatch(t.value)

Expand All @@ -262,6 +439,12 @@ def _Slice(self, t):
self.write(":")
self.dispatch(t.step)

def _ExtSlice(self, t):
for i, d in enumerate(t.dims):
if i != 0:
self.write(': ')
self.dispatch(d)

# others
def _arguments(self, t):
first = True
Expand All @@ -283,13 +466,51 @@ def _arguments(self, t):
if t.kwarg:
if first:first = False
else: self.write(", ")
self.write("**"+self.kwarg)
self.write(")")
self.write("**"+t.kwarg)

def _keyword(self, t):
self.write(t.arg)
self.write("=")
self.dispatch(t.value)

def _Lambda(self, t):
self.write("lambda ")
self.dispatch(t.args)
self.write(": ")
self.dispatch(t.body)

def roundtrip(filename):
def roundtrip(filename, output=sys.stdout):
source = open(filename).read()
tree = compile(source, filename, "exec", 0x400)
Unparser(tree)
Unparser(tree, output)



def testdir(a):
try:
names = [n for n in os.listdir(a) if n.endswith('.py')]
except OSError:
print >> sys.stderr, "Directory not readable: %s" % a
else:
for n in names:
fullname = os.path.join(a, n)
if os.path.isfile(fullname):
output = cStringIO.StringIO()
print 'Testing %s' % fullname
try:
roundtrip(fullname, output)
except Exception, e:
print ' Failed to compile, exception is %s' % repr(e)
elif os.path.isdir(fullname):
testdir(fullname)

def main(args):
if args[0] == '--testdir':
for a in args[1:]:
testdir(a)
else:
for a in args:
roundtrip(a)

if __name__=='__main__':
roundtrip(sys.argv[1])
main(sys.argv[1:])
10 changes: 5 additions & 5 deletions Demo/pdist/makechangelog.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@

import sys
import string
import regex
import re
import getopt
import time

Expand Down Expand Up @@ -35,9 +35,9 @@ def main():
for rev in allrevs:
formatrev(rev, prefix)

parsedateprog = regex.compile(
'^date: \([0-9]+\)/\([0-9]+\)/\([0-9]+\) ' +
'\([0-9]+\):\([0-9]+\):\([0-9]+\); author: \([^ ;]+\)')
parsedateprog = re.compile(
'^date: ([0-9]+)/([0-9]+)/([0-9]+) ' +
'([0-9]+):([0-9]+):([0-9]+); author: ([^ ;]+)')

authormap = {
'guido': 'Guido van Rossum <guido@cnri.reston.va.us>',
Expand Down Expand Up @@ -70,7 +70,7 @@ def formatrev(rev, prefix):
print
print

startprog = regex.compile("^Working file: \(.*\)$")
startprog = re.compile("^Working file: (.*)$")

def getnextfile(f):
while 1:
Expand Down
Loading

0 comments on commit 49fd7fa

Please sign in to comment.