[2] | 1 | -- ASDL's five builtin types are identifier, int, string, object, bool
|
---|
| 2 |
|
---|
[391] | 3 | module Python version "$Revision$"
|
---|
[2] | 4 | {
|
---|
| 5 | mod = Module(stmt* body)
|
---|
| 6 | | Interactive(stmt* body)
|
---|
| 7 | | Expression(expr body)
|
---|
| 8 |
|
---|
| 9 | -- not really an actual node but useful in Jython's typesystem.
|
---|
| 10 | | Suite(stmt* body)
|
---|
| 11 |
|
---|
| 12 | stmt = FunctionDef(identifier name, arguments args,
|
---|
| 13 | stmt* body, expr* decorator_list)
|
---|
[391] | 14 | | ClassDef(identifier name, expr* bases, stmt* body, expr* decorator_list)
|
---|
[2] | 15 | | Return(expr? value)
|
---|
| 16 |
|
---|
| 17 | | Delete(expr* targets)
|
---|
| 18 | | Assign(expr* targets, expr value)
|
---|
| 19 | | AugAssign(expr target, operator op, expr value)
|
---|
| 20 |
|
---|
| 21 | -- not sure if bool is allowed, can always use int
|
---|
| 22 | | Print(expr? dest, expr* values, bool nl)
|
---|
| 23 |
|
---|
| 24 | -- use 'orelse' because else is a keyword in target languages
|
---|
| 25 | | For(expr target, expr iter, stmt* body, stmt* orelse)
|
---|
| 26 | | While(expr test, stmt* body, stmt* orelse)
|
---|
| 27 | | If(expr test, stmt* body, stmt* orelse)
|
---|
| 28 | | With(expr context_expr, expr? optional_vars, stmt* body)
|
---|
| 29 |
|
---|
| 30 | -- 'type' is a bad name
|
---|
| 31 | | Raise(expr? type, expr? inst, expr? tback)
|
---|
| 32 | | TryExcept(stmt* body, excepthandler* handlers, stmt* orelse)
|
---|
| 33 | | TryFinally(stmt* body, stmt* finalbody)
|
---|
| 34 | | Assert(expr test, expr? msg)
|
---|
| 35 |
|
---|
| 36 | | Import(alias* names)
|
---|
[391] | 37 | | ImportFrom(identifier? module, alias* names, int? level)
|
---|
[2] | 38 |
|
---|
| 39 | -- Doesn't capture requirement that locals must be
|
---|
| 40 | -- defined if globals is
|
---|
| 41 | -- still supports use as a function!
|
---|
| 42 | | Exec(expr body, expr? globals, expr? locals)
|
---|
| 43 |
|
---|
| 44 | | Global(identifier* names)
|
---|
| 45 | | Expr(expr value)
|
---|
| 46 | | Pass | Break | Continue
|
---|
| 47 |
|
---|
| 48 | -- XXX Jython will be different
|
---|
| 49 | -- col_offset is the byte offset in the utf8 string the parser uses
|
---|
| 50 | attributes (int lineno, int col_offset)
|
---|
| 51 |
|
---|
| 52 | -- BoolOp() can use left & right?
|
---|
| 53 | expr = BoolOp(boolop op, expr* values)
|
---|
| 54 | | BinOp(expr left, operator op, expr right)
|
---|
| 55 | | UnaryOp(unaryop op, expr operand)
|
---|
| 56 | | Lambda(arguments args, expr body)
|
---|
| 57 | | IfExp(expr test, expr body, expr orelse)
|
---|
| 58 | | Dict(expr* keys, expr* values)
|
---|
[391] | 59 | | Set(expr* elts)
|
---|
[2] | 60 | | ListComp(expr elt, comprehension* generators)
|
---|
[391] | 61 | | SetComp(expr elt, comprehension* generators)
|
---|
| 62 | | DictComp(expr key, expr value, comprehension* generators)
|
---|
[2] | 63 | | GeneratorExp(expr elt, comprehension* generators)
|
---|
| 64 | -- the grammar constrains where yield expressions can occur
|
---|
| 65 | | Yield(expr? value)
|
---|
| 66 | -- need sequences for compare to distinguish between
|
---|
| 67 | -- x < 4 < 3 and (x < 4) < 3
|
---|
| 68 | | Compare(expr left, cmpop* ops, expr* comparators)
|
---|
| 69 | | Call(expr func, expr* args, keyword* keywords,
|
---|
| 70 | expr? starargs, expr? kwargs)
|
---|
| 71 | | Repr(expr value)
|
---|
| 72 | | Num(object n) -- a number as a PyObject.
|
---|
| 73 | | Str(string s) -- need to specify raw, unicode, etc?
|
---|
| 74 | -- other literals? bools?
|
---|
| 75 |
|
---|
| 76 | -- the following expression can appear in assignment context
|
---|
| 77 | | Attribute(expr value, identifier attr, expr_context ctx)
|
---|
| 78 | | Subscript(expr value, slice slice, expr_context ctx)
|
---|
| 79 | | Name(identifier id, expr_context ctx)
|
---|
| 80 | | List(expr* elts, expr_context ctx)
|
---|
| 81 | | Tuple(expr* elts, expr_context ctx)
|
---|
| 82 |
|
---|
| 83 | -- col_offset is the byte offset in the utf8 string the parser uses
|
---|
| 84 | attributes (int lineno, int col_offset)
|
---|
| 85 |
|
---|
| 86 | expr_context = Load | Store | Del | AugLoad | AugStore | Param
|
---|
| 87 |
|
---|
| 88 | slice = Ellipsis | Slice(expr? lower, expr? upper, expr? step)
|
---|
| 89 | | ExtSlice(slice* dims)
|
---|
| 90 | | Index(expr value)
|
---|
| 91 |
|
---|
| 92 | boolop = And | Or
|
---|
| 93 |
|
---|
| 94 | operator = Add | Sub | Mult | Div | Mod | Pow | LShift
|
---|
| 95 | | RShift | BitOr | BitXor | BitAnd | FloorDiv
|
---|
| 96 |
|
---|
| 97 | unaryop = Invert | Not | UAdd | USub
|
---|
| 98 |
|
---|
| 99 | cmpop = Eq | NotEq | Lt | LtE | Gt | GtE | Is | IsNot | In | NotIn
|
---|
| 100 |
|
---|
| 101 | comprehension = (expr target, expr iter, expr* ifs)
|
---|
| 102 |
|
---|
| 103 | -- not sure what to call the first argument for raise and except
|
---|
| 104 | excepthandler = ExceptHandler(expr? type, expr? name, stmt* body)
|
---|
| 105 | attributes (int lineno, int col_offset)
|
---|
| 106 |
|
---|
| 107 | arguments = (expr* args, identifier? vararg,
|
---|
| 108 | identifier? kwarg, expr* defaults)
|
---|
| 109 |
|
---|
| 110 | -- keyword arguments supplied to call
|
---|
| 111 | keyword = (identifier arg, expr value)
|
---|
| 112 |
|
---|
| 113 | -- import name with optional 'as' alias.
|
---|
| 114 | alias = (identifier name, identifier? asname)
|
---|
| 115 | }
|
---|