Neal Norwitz | 19b0f40 | 2005-11-15 04:52:16 +0000 | [diff] [blame] | 1 | -- ASDL's five builtin types are identifier, int, string, object, bool |
Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 2 | |
Martin v. Löwis | eae93b7 | 2006-02-28 00:12:47 +0000 | [diff] [blame] | 3 | module Python version "$Revision$" |
Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 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, |
Christian Heimes | 5224d28 | 2008-02-23 15:01:05 +0000 | [diff] [blame] | 13 | stmt* body, expr* decorator_list) |
| 14 | | ClassDef(identifier name, expr* bases, stmt* body, expr *decorator_list) |
Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 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) |
Guido van Rossum | c2e2074 | 2006-02-27 22:32:47 +0000 | [diff] [blame] | 28 | | With(expr context_expr, expr? optional_vars, stmt* body) |
Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 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) |
Thomas Wouters | f7f438b | 2006-02-28 16:09:29 +0000 | [diff] [blame] | 37 | | ImportFrom(identifier module, alias* names, int? level) |
Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 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 |
Martin v. Löwis | 49c5da1 | 2006-03-01 22:49:05 +0000 | [diff] [blame] | 49 | -- col_offset is the byte offset in the utf8 string the parser uses |
| 50 | attributes (int lineno, int col_offset) |
Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 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) |
Thomas Wouters | dca3b9c | 2006-02-27 00:24:13 +0000 | [diff] [blame] | 57 | | IfExp(expr test, expr body, expr orelse) |
Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 58 | | Dict(expr* keys, expr* values) |
| 59 | | ListComp(expr elt, comprehension* generators) |
| 60 | | GeneratorExp(expr elt, comprehension* generators) |
Jeremy Hylton | c960f26 | 2006-01-27 15:18:39 +0000 | [diff] [blame] | 61 | -- the grammar constrains where yield expressions can occur |
Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 62 | | Yield(expr? value) |
| 63 | -- need sequences for compare to distinguish between |
| 64 | -- x < 4 < 3 and (x < 4) < 3 |
| 65 | | Compare(expr left, cmpop* ops, expr* comparators) |
| 66 | | Call(expr func, expr* args, keyword* keywords, |
| 67 | expr? starargs, expr? kwargs) |
| 68 | | Repr(expr value) |
| 69 | | Num(object n) -- a number as a PyObject. |
| 70 | | Str(string s) -- need to specify raw, unicode, etc? |
| 71 | -- other literals? bools? |
| 72 | |
| 73 | -- the following expression can appear in assignment context |
| 74 | | Attribute(expr value, identifier attr, expr_context ctx) |
| 75 | | Subscript(expr value, slice slice, expr_context ctx) |
| 76 | | Name(identifier id, expr_context ctx) |
| 77 | | List(expr* elts, expr_context ctx) |
Brett Cannon | 1fbe3ab | 2007-02-11 05:36:00 +0000 | [diff] [blame] | 78 | | Tuple(expr* elts, expr_context ctx) |
Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 79 | |
Martin v. Löwis | 49c5da1 | 2006-03-01 22:49:05 +0000 | [diff] [blame] | 80 | -- col_offset is the byte offset in the utf8 string the parser uses |
| 81 | attributes (int lineno, int col_offset) |
Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 82 | |
| 83 | expr_context = Load | Store | Del | AugLoad | AugStore | Param |
| 84 | |
| 85 | slice = Ellipsis | Slice(expr? lower, expr? upper, expr? step) |
| 86 | | ExtSlice(slice* dims) |
| 87 | | Index(expr value) |
| 88 | |
| 89 | boolop = And | Or |
| 90 | |
| 91 | operator = Add | Sub | Mult | Div | Mod | Pow | LShift |
| 92 | | RShift | BitOr | BitXor | BitAnd | FloorDiv |
| 93 | |
| 94 | unaryop = Invert | Not | UAdd | USub |
| 95 | |
| 96 | cmpop = Eq | NotEq | Lt | LtE | Gt | GtE | Is | IsNot | In | NotIn |
| 97 | |
| 98 | comprehension = (expr target, expr iter, expr* ifs) |
| 99 | |
| 100 | -- not sure what to call the first argument for raise and except |
Jeremy Hylton | 2f327c1 | 2006-04-04 04:00:23 +0000 | [diff] [blame] | 101 | -- TODO(jhylton): Figure out if there is a better way to handle |
| 102 | -- lineno and col_offset fields, particularly when |
| 103 | -- ast is exposed to Python. |
| 104 | excepthandler = (expr? type, expr? name, stmt* body, int lineno, |
| 105 | int col_offset) |
Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 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 | } |