X-Git-Url: https://git.martlubbers.net/?a=blobdiff_plain;f=dsl%2Fxtend%2Fsrc%2Frobots%2Fmissions%2FTaskDSL.xtext;h=7fb398a0cee692cb23bfc72d6c9d485c0661d389;hb=8ac11d4775c780e307727b0e5dc865cf64517a59;hp=65351f933c68e1cf45a27bfe1aecbd9b7e49814f;hpb=476c651adb42cd9be8758e4f6ef2fe9ee2519fd5;p=des2015.git diff --git a/dsl/xtend/src/robots/missions/TaskDSL.xtext b/dsl/xtend/src/robots/missions/TaskDSL.xtext index 65351f9..7fb398a 100644 --- a/dsl/xtend/src/robots/missions/TaskDSL.xtext +++ b/dsl/xtend/src/robots/missions/TaskDSL.xtext @@ -13,38 +13,44 @@ Mission: StoppingExpression: '(' op=Operator s+=StoppingExpression s+=StoppingExpression+ ')' | - 'not ' negscond=StoppingCondition | + 'not ' negscond=StoppingExpression | scond=StoppingCondition; StoppingCondition: - 'Collected at least' colors+=Color+ | + 'flag set' varName=ID | 'Touched on' touch=LeftRight | 'Light on' light=LeftRight | - 'No object in sight on ' dist=BackFront | - 'Color is' color=Color; + 'Distance dangerous at ' dist=BackFront | + 'Color is' color=Color | + {StoppingCondition} 'Never'; -Behaviour: 'Behaviour' name=ID +Behaviour: 'Behaviour' name=ID 'take control:' tc=StoppingExpression? - 'action:' actions+=Action+; + 'action:' actions+=Action+ + ; Action: whichMotor=LeftRight 'motor' moveDir=Direction ('with speed' spd=INT 'acceleration' acc=INT)? | - 'turn' turnDir=LeftRight degrees=INT ('with speed' spd=INT 'acceleration' acc=INT)? | - 'measure' measureWhat=RockLake | - 'wait' time=Time; + 'turn' turnType=Turn ('with speed' spd=INT 'acceleration' acc=INT)? | + 'measure' rl=RockLake| + 'wait' time=Time | + 'set flag' varName=ID; + +Turn: + turnDir=LeftRight 'exactly' degrees=INT 'degrees'| + 'randomly' start=INT 'to' end=INT 'degrees' +; Time: time=INT 'ms' | {Time} 'forever'; RockLake: d=RockLakeE; -enum RockLakeE: ROCK='rock' | LAKE='lake'; +enum RockLakeE: ROCK='Rock' | LAKE='Lake'; Direction: d=DirectionE; enum DirectionE: BACKWARDS = 'backward' | FORWARDS = 'forward'; Operator: d=OperatorE; -enum OperatorE: AND = 'and' | OR = 'or'; +enum OperatorE: AND = '&&' | OR = '||'; BackFront: d=BackFrontE; enum BackFrontE: BACK = 'back' | FRONT = 'front'; -Comparison: d=ComparisonE; -enum ComparisonE: GE='>' | LE='<'; LeftRight: d=LeftRightE; enum LeftRightE: LEFT='left' | RIGHT='right'; Color: d=ColorE;