added gracefull shutdown
[des2015.git] / dsl / xtend / src / robots / missions / generator / TaskDSLGenerator.xtend
index ff72ba4..5af781f 100644 (file)
@@ -45,7 +45,7 @@ public class Missions{
        public static LinkedList<Mission> getMissions(final SensorCollector sensors, RegulatedMotor rightMotor,
                        RegulatedMotor leftMotor, RegulatedMotor measMotor){
                LinkedList<Mission> missions = new LinkedList<Mission>();
-               «FOR m : mission»
+               «FOR m : mission SEPARATOR "));" AFTER "));"»
                missions.add(new Mission("«m.name»", new Behavior[]{
                        «FOR b : m.behaviours SEPARATOR "," AFTER ","»new «b.name»Behaviour(sensors, rightMotor, leftMotor, measMotor)
                        «ENDFOR»
@@ -54,7 +54,7 @@ public class Missions{
                                        return «printExpression(m.se)»;
                                }
                        }}
-               «ENDFOR»));
+               «ENDFOR»
                return missions;
        }
 }      
@@ -73,7 +73,7 @@ public class «b.name»Behaviour extends BasicBehaviour {
        }
        «IF b.tc != null»
        @Override public boolean takeControl(){
-               return getSuppressed() == SuppressedState.IN_ACTION || «printExpression(b.tc)»;
+               return «printExpression(b.tc)»;
        }
        «ENDIF»
        
@@ -89,23 +89,30 @@ public class «b.name»Behaviour extends BasicBehaviour {
                                «a.whichMotor.d.toString()»Motor.«a.moveDir.d.toString()»();
                        «ELSEIF a.time != null»
                        time = System.currentTimeMillis();
-                       while(getSuppressed() != SuppressedState.SUPPRESSED«IF a.time.time > 0» && System.currentTimeMillis()-time>«a.time.time»«ENDIF»){
+                       while(!suppressed«IF a.time.time > 0» && System.currentTimeMillis()-time<«a.time.time»«ENDIF»){
                                Thread.yield(); 
                        }
-                       «ELSEIF a.turnDir != null»
+                       «ELSEIF a.turnType != null»
                                «IF a.acc > 0»
                                        leftMotor.setAcceleration(«a.acc»);
                                        leftMotor.setSpeed(«a.spd»);
                                        rightMotor.setAcceleration(«a.acc»);
                                        rightMotor.setSpeed(«a.spd»);
                                «ENDIF»
-                       «a.turnDir.d.toString()»Turn(«a.degrees»);
+                               «IF a.turnType.turnDir != null»
+                                       «a.turnType.turnDir.d.toString()»Turn(«a.turnType.degrees»);
+                               «ELSE»
+                                       turnRandom(«a.turnType.start», «a.turnType.end»);
+                               «ENDIF»
+                       «ELSEIF a.rl != null»
+                       measure«a.rl.d.toString()»();
                        «ELSE»
-                       measure();
+                       if(!suppressed){
+                               sensors.saveVar("«a.varName.toString()»");
+                       }
                        «ENDIF»
                «ENDFOR»
                LCDPrinter.print("Stop: «b.name»");
-               reset();
        }
 }
        '''
@@ -120,8 +127,8 @@ public class Constants{
        
        def CharSequence printExpression(StoppingExpression e)'''
        «IF e.scond != null»
-               «IF !e.scond.colors.nullOrEmpty»
-               sensors.collected(new int[]{«FOR c : e.scond.colors SEPARATOR ","»«c.d.ordinal»«ENDFOR»})
+               «IF e.scond.varName != null»
+               sensors.collected("«e.scond.varName.toString()»")
                «ELSEIF e.scond.touch != null»
                sensors.«e.scond.touch.d.toString()»Touch()
                «ELSEIF e.scond.light != null»
@@ -130,12 +137,16 @@ public class Constants{
                sensors.«e.scond.dist.d.toString()»Distance()
                «ELSEIF e.scond.color != null»
                sensors.color() == «e.scond.color.d.ordinal»
+               «ELSE»
+               false
                «ENDIF»
+       «ELSEIF e.negscond != null»
+               !(«printExpression(e.negscond)»)
        «ELSE»
                «IF e.op.d.equals(OperatorE.AND)»
                        «FOR ex : e.s BEFORE "(" SEPARATOR "&&" AFTER ")"»«printExpression(ex)»«ENDFOR»
                «ELSE»
                        «FOR ex : e.s BEFORE "(" SEPARATOR "||" AFTER ")"»«printExpression(ex)»«ENDFOR»
-               «ENDIF»       
+               «ENDIF»
        «ENDIF»'''
 }
\ No newline at end of file