update language'
[des2015.git] / dsl / xtend / src / robots / missions / generator / TaskDSLGenerator.xtend
index 9aecf7e..06f9654 100644 (file)
@@ -8,10 +8,8 @@ import org.eclipse.emf.ecore.resource.Resource
 import org.eclipse.xtext.generator.IFileSystemAccess
 import org.eclipse.xtext.generator.IGenerator
 import robots.missions.taskDSL.Behaviour
-import robots.missions.taskDSL.OperatorE
-import robots.missions.taskDSL.Robot
-import robots.missions.taskDSL.StoppingExpression
 import robots.missions.taskDSL.Mission
+import robots.missions.taskDSL.Robot
 
 /**
  * Generates code from your model files on save.
@@ -25,7 +23,7 @@ class TaskDSLGenerator implements IGenerator {
                if(root != null){
                        fsa.generateFile("nl/ru/des/Constants.java", makeConstants(root));
                        fsa.generateFile("nl/ru/des/Behaviours.java", makeBehaviours(root.behaviour));
-                       fsa.generateFile("nl/ru/des/Missions.java", makeMissions(root.mission));
+                       //fsa.generateFile("nl/ru/des/Missions.java", makeMissions(root.mission));
                }
        }
        
@@ -33,14 +31,13 @@ class TaskDSLGenerator implements IGenerator {
 package nl.ru.des;
 
 import java.util.LinkedList;
-import java.util.List;
 
 import lejos.hardware.motor.EV3LargeRegulatedMotor;
 import lejos.robotics.subsumption.Behavior;
 import nl.ru.des.Behaviours;
 
 public class Missions{
-       public static List<Mission> getMissions(SensorCollector sensors, EV3LargeRegulatedMotor rightMotor,
+       public static LinkedList<Mission> getMissions(SensorCollector sensors, EV3LargeRegulatedMotor rightMotor,
                        EV3LargeRegulatedMotor leftMotor, ColorMemory colors){
                LinkedList<Mission> missions = new LinkedList<Mission>();
                «FOR m : list»
@@ -50,7 +47,7 @@ public class Missions{
                        «ENDFOR»,
                        new ShutdownBehaviour(sensors, rightMotor, leftMotor, colors){
                                @Override public boolean takeControl(){
-                                       return Â«printExpression(m.se)»;
+                                       return »;
                                }
                        }}
                «ENDFOR»));
@@ -63,17 +60,18 @@ public class Missions{
 package nl.ru.des;
 
 import lejos.hardware.motor.EV3LargeRegulatedMotor;
+import nl.ru.des.sensors.SensorCollector;
 
 public class Behaviours{
        «FOR b : list»
        public static class «b.name»Behaviour extends BasicBehaviour {
                public «b.name»Behaviour(SensorCollector sensors, EV3LargeRegulatedMotor rightMotor,
-                               EV3LargeRegulatedMotor leftMotor, ColorMemory colors){
-                       super(sensors, rightMotor, leftMotor, colors);
+                               EV3LargeRegulatedMotor leftMotor,  EV3LargeRegulatedMotor measMotor){
+                       super(sensors, rightMotor, leftMotor, measMotor);
                }
                «IF b.tc != null»
                @Override public boolean takeControl(){
-                       return «printExpression(b.tc)»;
+                       return ;
                }
                «ENDIF»
                
@@ -86,6 +84,8 @@ public class Behaviours{
                                        «a.whichMotor.d.toString()»Motor.setSpeed(«a.spd»);
                                        «ENDIF»
                                        «a.whichMotor.d.toString()»Motor.«a.dir.d.toString()»();
+                               «ELSEIF a.measureWhat != null»
+                               «a.measureWhat.d.toString()»Measure();
                                «ELSE»
                                time = System.currentTimeMillis();
                                while(!suppressed«IF a.time.time > 0» && System.currentTimeMillis()-time>«a.time.time»«ENDIF»){
@@ -99,26 +99,7 @@ public class Behaviours{
        «ENDFOR»
 }
        '''
-       
-       def CharSequence printExpression(StoppingExpression e)'''
-       «IF e.scond != null»
-               «IF !e.scond.colors.nullOrEmpty»
-               colors.containsAll(new int[]{«FOR c : e.scond.colors SEPARATOR ","»«c.d.ordinal»«ENDFOR»})
-               «ELSEIF e.scond.touch != null»
-               sensors.«e.scond.touch.d.toString()»Touch()
-               «ELSEIF e.scond.op != null»
-               sensors.distance() «e.scond.op.d.toString()» «e.scond.dist»
-               «ELSEIF e.scond.color != null»
-               sensors.color() == «e.scond.color.d.ordinal»
-               «ENDIF»
-       «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»
-       '''
+
        
        def CharSequence makeConstants(Robot robot)'''
 package nl.ru.des;
@@ -128,4 +109,4 @@ public class Constants{
        public final static int acceleration = «robot.acc»;
 }'''
        
-}
+}
\ No newline at end of file