Evaluation optimizations.
authorJoe Wreschnig <joe.wreschnig@gmail.com>
Tue, 16 Mar 2010 10:01:31 +0000 (03:01 -0700)
committerJoe Wreschnig <joe.wreschnig@gmail.com>
Tue, 16 Mar 2010 10:01:31 +0000 (03:01 -0700)
bulletml/expr.py
bulletml/impl.py
bulletml/parser.py

index 9ca82ec128a98a369df1855f52aec7a86aefd47d..33f7d44bf1af0ba57be9955ec30b461a8c6064c3 100644 (file)
@@ -57,7 +57,7 @@ class NumberDef(object):
         if self.__value is not None:
             return self.__value
         rand = random.random()
-        variables = dict(rand=rand, rank=rank, params=params)
+        variables = { 'rand': rand, 'rank': rank, 'params': params }
         return eval(self.__expr, variables)
 
     def __repr__(self):
index 4dde9fb4b608115ad2dec45a6426a89255282faf..9139f9c6b463eb6bb920c46ccb05d92b66930e50 100644 (file)
@@ -238,9 +238,9 @@ class Bullet(object):
         self.actions = []
         if rank is None:
             rank = parent.rank if parent else 0.5
-        for action, params in actions:
-            # New bullets reset the parent hierarchy.
-            self.actions.append(Action(self, None, action, params, rank))
+        # New bullets reset the parent hierarchy.
+        self.actions = [Action(self, None, action, params, rank)
+                        for action, params in actions]
 
     def __repr__(self):
         return ("%s(%r, %r, accel=%r, direction=%r, speed=%r, "
index 187fa86e7df4dc5f866abd741c4939f9b62c7579..933be80847c0b31c186173b82c2ee418712f93a2 100644 (file)
@@ -36,10 +36,7 @@ class ParamList(object):
                     self.params.append(NumberDef(subelem.text))
 
     def __call__(self, params, rank):
-        new_params = [param(params, rank) for param in self.params]
-        while len(new_params) < len(params):
-            new_params.append(params[len(new_params)])
-        return new_params
+        return [param(params, rank) for param in self.params]
 
     def __repr__(self):
         return "%s(%r)" % (type(self).__name__, self.params)
@@ -210,9 +207,7 @@ class BulletDef(object):
                 self.actions.append(ActionRef(doc, subelem))
 
     def __call__(self, params, rank):
-        actions = []
-        for action in self.actions:
-            actions.append(action(params, rank))
+        actions = [action(params, rank) for action in self.actions]
         return (
             self.direction and self.direction(params, rank),
             self.speed and self.speed(params, rank),