[Python-checkins] r42600 - python/trunk/Python/ast.c

jeremy.hylton python-checkins at python.org
Mon Feb 27 17:50:36 CET 2006


Author: jeremy.hylton
Date: Mon Feb 27 17:50:35 2006
New Revision: 42600

Modified:
   python/trunk/Python/ast.c
Log:
Simplify ast_for_trailer() in anticipation of more changes.

Modified: python/trunk/Python/ast.c
==============================================================================
--- python/trunk/Python/ast.c	(original)
+++ python/trunk/Python/ast.c	Mon Feb 27 17:50:35 2006
@@ -1389,24 +1389,26 @@
 ast_for_trailer(struct compiling *c, const node *n, expr_ty left_expr)
 {
     /* trailer: '(' [arglist] ')' | '[' subscriptlist ']' | '.' NAME */
-    expr_ty e;
     REQ(n, trailer);
     if (TYPE(CHILD(n, 0)) == LPAR) {
         if (NCH(n) == 2)
-            e = Call(left_expr, NULL, NULL, NULL, NULL, LINENO(n), c->c_arena);
+            return Call(left_expr, NULL, NULL, NULL, NULL, LINENO(n), c->c_arena);
         else
-            e = ast_for_call(c, CHILD(n, 1), left_expr);
+            return ast_for_call(c, CHILD(n, 1), left_expr);
+    }
+    else if (TYPE(CHILD(n, 0)) == DOT ) {
+        return Attribute(left_expr, NEW_IDENTIFIER(CHILD(n, 1)), Load,
+                         LINENO(n), c->c_arena);
     }
-    else if (TYPE(CHILD(n, 0)) == LSQB) {
+    else {
+        REQ(CHILD(n, 0), LSQB);
         REQ(CHILD(n, 2), RSQB);
         n = CHILD(n, 1);
         if (NCH(n) <= 2) {
             slice_ty slc = ast_for_slice(c, CHILD(n, 0));
             if (!slc)
                 return NULL;
-            e = Subscript(left_expr, slc, Load, LINENO(n), c->c_arena);
-            if (!e)
-                return NULL;
+            return Subscript(left_expr, slc, Load, LINENO(n), c->c_arena);
         }
         else {
             int j;
@@ -1420,18 +1422,10 @@
                     return NULL;
                 asdl_seq_SET(slices, j / 2, slc);
             }
-            e = Subscript(left_expr, ExtSlice(slices, c->c_arena),
-                          Load, LINENO(n), c->c_arena);
-            if (!e)
-                return NULL;
+            return Subscript(left_expr, ExtSlice(slices, c->c_arena),
+                             Load, LINENO(n), c->c_arena);
         }
     }
-    else {
-        assert(TYPE(CHILD(n, 0)) == DOT);
-        e = Attribute(left_expr, NEW_IDENTIFIER(CHILD(n, 1)), Load, LINENO(n),
-                      c->c_arena);
-    }
-    return e;
 }
 
 static expr_ty


More information about the Python-checkins mailing list