5 eventAppList = [] # This list maps App1 or App2 to a specific event
7 eventVarCounterMap = {}
15 # Mapping for event type and number of events
16 # e.g., switch has 2 events: on and off
17 eventTypeCounterMap = {'lock': 2,
32 'thermostatFanMode' : 5,
33 'thermostatOperatingState' : 5,
46 'colorTemperature' : 1,
57 'trackDescription' : 1,
61 'heatingSetpoint' : 1,
62 'coolingSetpoint' : 1,
63 'thermostatSetpoint' : 1}
65 # Mapping for specific event types
66 eventTypesMap = {'alarm.both': 'alarm',
67 'alarm.siren' : 'alarm',
68 'alarm.strobe' : 'alarm',
69 'alarm.off' : 'alarm',
70 'contact.open' : 'contact',
71 'contact.closed' : 'contact',
72 'tamper.tampered' : 'contact',
73 'doorState.open' : 'doorState',
74 'doorState.closed' : 'doorState',
76 'mode.away' : 'location',
77 'mode.home' : 'location',
78 'mode.night' : 'location',
79 'lock.locked' : 'lock',
80 'lock.unlocked' : 'lock',
81 'motion.active' : 'motion',
82 'motion.inactive' : 'motion',
83 'status.playing' : 'status',
84 'status.stopped' : 'status',
85 'status.paused' : 'status',
86 'mute.muted' : 'mute',
87 'mute.unmuted' : 'mute',
88 'presence.present' : 'presence',
89 'presence.not present' : 'presence',
90 'presence.not' : 'presence',
91 'smoke.detected' : 'smoke',
92 'smoke.clear' : 'smoke',
93 'smoke.tested' : 'smoke',
94 'carbonMonoxide.detected' : 'carbonMonoxide',
95 'carbonMonoxide.clear' : 'carbonMonoxide',
96 'carbonMonoxide.tested' : 'carbonMonoxide',
97 'thermostatMode.cool' : 'thermostatMode',
98 'thermostatMode.auto' : 'thermostatMode',
99 'thermostatMode.emergencyHeat' : 'thermostatMode',
100 'thermostatMode.heat' : 'thermostatMode',
101 'thermostatMode.off' : 'thermostatMode',
102 'thermostatFanMode.auto' : 'thermostatFanMode',
103 'thermostatFanMode.fanCirculate' : 'thermostatFanMode',
104 'thermostatFanMode.circulate' : 'thermostatFanMode',
105 'thermostatFanMode.fanOn' : 'thermostatFanMode',
106 'thermostatFanMode.on' : 'thermostatFanMode',
107 'fanMode' : 'thermostatFanMode',
108 'fanMode.auto' : 'thermostatFanMode',
109 'fanMode.fanCirculate' : 'thermostatFanMode',
110 'fanMode.circulate' : 'thermostatFanMode',
111 'fanMode.fanOn' : 'thermostatFanMode',
112 'fanMode.on' : 'thermostatFanMode',
113 'switch.on' : 'switch',
114 'switch.off' : 'switch',
115 'button.pushed' : 'button',
116 'button.held' : 'button',
117 'acceleration.active' : 'acceleration',
118 'acceleration.inactive' : 'acceleration',
119 'sleeping.sleeping' : 'sleeping',
120 'sleeping.not sleeping' : 'sleeping',
121 'water.dry' : 'water',
122 'water.wet' : 'water'}
127 Skip = ['\n', '\t', ' ']
128 Special = ["(", "\"", ":", ",", "{", "}", ")", "/", "*"]
154 def ExtractFunctions(F, appName):
161 while (Temp != "EOF"):
162 if (Temp == "def" or Temp == "private"):
164 if (Temp == "def" or Temp == "private"):
167 if (GetToken(F) == "("): #We have a function to create object for
168 if (appName == "App1"):
169 extractedFunctionsApp1.write("//Global Object for functions in subscribe method!\n")
170 extractedFunctionsApp1.write("def %s = this.&" % NameofFunc)
171 extractedFunctionsApp1.write("%s\n" % NameofFunc)
173 extractedFunctionsApp2.write("//Global Object for functions in subscribe method!\n")
174 extractedFunctionsApp2.write("def %s = this.&" % NameofFunc)
175 extractedFunctionsApp2.write("%s\n" % NameofFunc)
177 #Check input capability
178 if (Temp == "input"):
181 variable = GetToken(F)
182 Temp = GetToken(F) #Get '"'
183 Temp = GetToken(F) #Get ','
186 capability = GetToken(F)
187 capabilityMap[variable] = capability
189 #Check subscribed events
190 if (Temp == "subscribe"):
191 if (appName == "App1"):
199 while (Temp != "\"" and Temp != "app" and Temp != "location"):
201 if Temp == "location":
202 # See if we have another case for location
203 Temp = GetToken(F) # Get ','
204 Temp = GetToken(F) # Get '"'
208 # This is the special case where we will see, e.g., sunset, sunrise, etc.
213 #print "DEBUG: %s - %s" % (variable, Temp)
215 #print "DEBUG: location variable: %s" % Temp
217 #Translate and reduce through mapping
218 if Temp in eventTypesMap.keys():
219 Temp = eventTypesMap[Temp]
220 if Temp == "app" or Temp == "location" or Temp == "mode" or Temp == "sunset" or Temp == "sunrise" or Temp == "sunsetTime" or Temp == "sunriseTime":
221 if Temp not in eventList:
222 eventList.append(Temp)
223 if (appName == "App1"):
224 eventAppList.append("App1")
226 eventAppList.append("App2")
227 elif Temp not in eventList or (variable in capabilityMap.keys() and capabilityMap[variable] not in capabilityList):
228 # We do not repeat the same capability twice
229 capability = capabilityMap[variable]
230 capabilityList.append(capability)
231 eventList.append(Temp)
232 if (appName == "App1"):
233 eventAppList.append("App1")
235 eventAppList.append("App2")
236 if Temp in eventVarMap.keys():
237 listOfEvents = eventVarMap[Temp]
238 listOfEvents.append(variable)
240 eventVarMap[Temp] = [variable]
241 #print "DEBUG: %s - %s" % (variable, Temp)
245 #Check and analyze capabilities for physical interaction
246 AnalyzeCapabilities(Temp, appName, F)
250 #Warn if there is a potential for physical interaction
251 AnalyzePhysicalInteraction(app1Capabilities, app2Capabilities)
252 AnalyzePhysicalInteraction(app2Capabilities, app1Capabilities)
254 def AnalyzeCapabilities(Temp, appName, F):
256 if (Temp == "capability.switch" or
257 Temp == "capability.switchLevel" or
258 Temp == "capability.illuminanceMeasurement" or
259 Temp == "capability.colorControl" or
261 Temp == "capability.motionSensor" or
262 Temp == "capability.accelerationSensor" or
264 Temp == "capability.valve" or
265 Temp == "capability.waterSensor" or
267 Temp == "capability.musicPlayer" or
268 Temp == "capability.alarm" or
269 Temp == "capability.speechSynthesis" or
270 Temp == "capability.soundSensor"):
271 if (appName == "App1"):
272 app1Capabilities.append(Temp)
274 app2Capabilities.append(Temp)
275 if (Temp == "capability"):
276 Temp = GetToken(F) #Get '"'
277 Temp = GetToken(F) #Get 'Music'
278 Temp = Temp + GetToken(F) #Get 'Player'
279 if (Temp == "MusicPlayer"):
280 if (appName == "App1"):
281 app1Capabilities.append("capability.musicPlayer")
283 app2Capabilities.append("capability.musicPlayer")
285 def AnalyzePhysicalInteraction(app1Capab, app2Capab):
287 if ("capability.illuminanceMeasurement" in app1Capab) and ("capability.switch" in app2Capab or
288 "capability.switchLevel" in app2Capab or "capability.colorControl" in app2Capab):
289 print ("\nWARNING: Potential PHYSICAL CONFLICT (light) detected between App1 and App2!\n")
291 # TODO: Technically this is not entirely precise since we need to be able to detect that the other app creates motion
292 if ("capability.motionSensor" in app1Capab) or ("capability.accelerationSensor" in app1Capab):
293 print ("\nWARNING: Potential PHYSICAL CONFLICT (motion) detected between App1 and App2!\n")
295 if ("capability.waterSensor" in app1Capab) and ("capability.valve" in app2Capab or
296 "capability.switch" in app2Capab):
297 print ("\nWARNING: Potential PHYSICAL CONFLICT (water) detected between App1 and App2!\n")
299 if ("capability.soundSensor" in app1Capab) and ("capability.musicPlayer" in app2Capab or
300 "capability.alarm" in app2Capab or "capability.speechSynthesis" in app2Capab):
301 print ("\nWARNING: Potential PHYSICAL CONFLICT (sound) detected between App1 and App2!\n")
305 numOfActualEvents = 0
306 #print "DEBUG: eventlist: %d" % len(eventList)
307 #print "DEBUG: eventlist: %s" % eventList
308 for event in eventList:
309 #print "DEBUG: Event: %s %d" % (event, eventTypeCounterMap[event])
310 numOfActualEvents = numOfActualEvents + eventTypeCounterMap[event]
311 return numOfActualEvents
313 def ExtractEvents(extractedEvents):
318 global eventVarCounterMap
319 # Count the number of events
320 numOfActualEvents = CountEvents()
321 extractedEvents.write("while(true) {\n")
322 extractedEvents.write("\tdef eventNumber = Verify.getInt(0,%d)\n" % (numOfActualEvents - 1))
323 extractedEvents.write("\tswitch(eventNumber) {\n")
326 if "App2" in eventAppList:
327 indexApp2 = eventAppList.index("App2")
329 indexApp2 = len(eventList)
330 indexApp2Start = indexApp2
331 #print "DEBUG: App1: %d" % indexApp1
332 #print "DEBUG: App2: %d" % indexApp2
333 #print "DEBUG: eventList: %d" % len(eventList)
335 while counter < numOfActualEvents:
336 # Interleave events from App1 and App2
339 indexApp1 = indexApp1 + 1
340 if indexApp2 < len(eventList):
344 indexApp2 = indexApp2 + 1
345 if indexApp1 < indexApp2Start:
347 #print "DEBUG: i: %d" % i
348 extractedEvents.write("\t\tcase %d:\n" % counter)
349 if eventList[i] == "lock":
350 #Write two events subsequently
351 event = open("eventSimulator/lockLockedEvent.groovy", "r")
353 extractedEvents.write(line)
355 extractedEvents.write("\n\t\t\tbreak\n")
356 counter = counter + 1
357 extractedEvents.write("\t\tcase %d:\n" % counter)
358 event = open("eventSimulator/lockUnlockedEvent.groovy", "r")
360 extractedEvents.write(line)
362 elif eventList[i] == "unlock":
363 #Don't do anything for this case
364 counter = counter - 1
365 elif eventList[i] == "nfcTouch":
366 event = open("eventSimulator/nfcTouchEvent.groovy", "r")
368 extractedEvents.write(line)
370 elif eventList[i] == "app": #Case for Touched event
371 event = open("eventSimulator/appTouchEvent.groovy", "r")
373 extractedEvents.write(line)
375 elif eventList[i] == "button":
376 #Check which capability
377 variable = eventVarMap[eventList[i]]
378 if eventList[i] not in eventVarCounterMap.keys():
379 eventVarCounterMap[eventList[i]] = 1
382 eventVarCount = eventVarCounterMap[eventList[i]]
383 eventVarCounterMap[eventList[i]] = eventVarCount + 1
384 capability = capabilityMap[variable[eventVarCount]]
385 #Write two events subsequently
386 if capability == "capability.button":
387 event = open("eventSimulator/buttonHeldEvent.groovy", "r")
388 elif capability == "device.aeonKeyFob":
389 event = open("eventSimulator/aeonKeyFobHeldEvent.groovy", "r")
391 extractedEvents.write(line)
393 extractedEvents.write("\n\t\t\tbreak\n")
394 counter = counter + 1
395 extractedEvents.write("\t\tcase %d:\n" % counter)
396 if capability == "capability.button":
397 event = open("eventSimulator/buttonPushedEvent.groovy", "r")
398 elif capability == "device.aeonKeyFob":
399 event = open("eventSimulator/aeonKeyFobPushedEvent.groovy", "r")
401 extractedEvents.write(line)
403 elif eventList[i] == "water":
404 #Write two events subsequently
405 event = open("eventSimulator/waterDryEvent.groovy", "r")
407 extractedEvents.write(line)
409 extractedEvents.write("\n\t\t\tbreak\n")
410 counter = counter + 1
411 extractedEvents.write("\t\tcase %d:\n" % counter)
412 event = open("eventSimulator/waterWetEvent.groovy", "r")
414 extractedEvents.write(line)
416 elif eventList[i] == "presence":
417 #Check which capability
418 variable = eventVarMap[eventList[i]]
419 if eventList[i] not in eventVarCounterMap.keys():
420 eventVarCounterMap[eventList[i]] = 1
423 eventVarCount = eventVarCounterMap[eventList[i]]
424 eventVarCounterMap[eventList[i]] = eventVarCount + 1
425 capability = capabilityMap[variable[eventVarCount]]
426 #Write two events subsequently
427 if capability == "capability.presenceSensor":
428 event = open("eventSimulator/presencePresentEvent.groovy", "r")
429 elif capability == "capability.beacon":
430 event = open("eventSimulator/beaconPresentEvent.groovy", "r")
432 extractedEvents.write(line)
434 extractedEvents.write("\n\t\t\tbreak\n")
435 counter = counter + 1
436 extractedEvents.write("\t\tcase %d:\n" % counter)
437 if capability == "capability.presenceSensor":
438 event = open("eventSimulator/presenceLeftEvent.groovy", "r")
439 elif capability == "capability.beacon":
440 event = open("eventSimulator/beaconLeftEvent.groovy", "r")
442 extractedEvents.write(line)
444 elif eventList[i] == "doorState":
445 #Write two events subsequently
446 event = open("eventSimulator/doorOpenEvent.groovy", "r")
448 extractedEvents.write(line)
450 extractedEvents.write("\n\t\t\tbreak\n")
451 counter = counter + 1
452 extractedEvents.write("\t\tcase %d:\n" % counter)
453 event = open("eventSimulator/doorClosedEvent.groovy", "r")
455 extractedEvents.write(line)
457 elif eventList[i] == "motion":
458 #Write two events subsequently
459 event = open("eventSimulator/motionActiveEvent.groovy", "r")
461 extractedEvents.write(line)
463 extractedEvents.write("\n\t\t\tbreak\n")
464 counter = counter + 1
465 extractedEvents.write("\t\tcase %d:\n" % counter)
466 event = open("eventSimulator/motionInactiveEvent.groovy", "r")
468 extractedEvents.write(line)
470 elif eventList[i] == "smoke":
471 #Write three events subsequently
472 event = open("eventSimulator/smokeClearEvent.groovy", "r")
474 extractedEvents.write(line)
476 extractedEvents.write("\n\t\t\tbreak\n")
477 counter = counter + 1
478 extractedEvents.write("\t\tcase %d:\n" % counter)
479 event = open("eventSimulator/smokeDetectedEvent.groovy", "r")
481 extractedEvents.write(line)
483 extractedEvents.write("\n\t\t\tbreak\n")
484 counter = counter + 1
485 extractedEvents.write("\t\tcase %d:\n" % counter)
486 event = open("eventSimulator/smokeTestedEvent.groovy", "r")
488 extractedEvents.write(line)
490 elif eventList[i] == "carbonMonoxide":
491 #Check which capability
492 variable = eventVarMap[eventList[i]]
493 if eventList[i] not in eventVarCounterMap.keys():
494 eventVarCounterMap[eventList[i]] = 1
497 eventVarCount = eventVarCounterMap[eventList[i]]
498 eventVarCounterMap[eventList[i]] = eventVarCount + 1
499 capability = capabilityMap[variable[eventVarCount]]
500 #Write three events subsequently
501 if capability == "capability.smokeDetector":
502 event = open("eventSimulator/smokeCarbonMonoxideClearEvent.groovy", "r")
503 elif capability == "capability.carbonMonoxideDetector":
504 event = open("eventSimulator/carbonMonoxideClearEvent.groovy", "r")
506 extractedEvents.write(line)
508 extractedEvents.write("\n\t\t\tbreak\n")
509 counter = counter + 1
510 extractedEvents.write("\t\tcase %d:\n" % counter)
511 if capability == "capability.smokeDetector":
512 event = open("eventSimulator/smokeCarbonMonoxideDetectedEvent.groovy", "r")
513 elif capability == "capability.carbonMonoxideDetector":
514 event = open("eventSimulator/carbonMonoxideDetectedEvent.groovy", "r")
516 extractedEvents.write(line)
518 extractedEvents.write("\n\t\t\tbreak\n")
519 counter = counter + 1
520 extractedEvents.write("\t\tcase %d:\n" % counter)
521 if capability == "capability.smokeDetector":
522 event = open("eventSimulator/smokeCarbonMonoxideTestedEvent.groovy", "r")
523 elif capability == "capability.carbonMonoxideDetector":
524 event = open("eventSimulator/carbonMonoxideTestedEvent.groovy", "r")
526 extractedEvents.write(line)
528 elif eventList[i] == "battery":
529 #Check which capability
530 variable = eventVarMap[eventList[i]]
531 if eventList[i] not in eventVarCounterMap.keys():
532 eventVarCounterMap[eventList[i]] = 1
535 eventVarCount = eventVarCounterMap[eventList[i]]
536 eventVarCounterMap[eventList[i]] = eventVarCount + 1
537 capability = capabilityMap[variable[eventVarCount]]
538 if capability == "capability.smokeDetector":
539 event = open("eventSimulator/smokeDetectorBatteryEvent.groovy", "r")
540 elif capability == "capability.battery":
541 event = open("eventSimulator/batteryBatteryEvent.groovy", "r")
543 extractedEvents.write(line)
545 elif eventList[i] == "thermostatMode":
546 #Write five events subsequently
547 event = open("eventSimulator/thermostatAutoModeEvent.groovy", "r")
549 extractedEvents.write(line)
551 extractedEvents.write("\n\t\t\tbreak\n")
552 counter = counter + 1
553 extractedEvents.write("\t\tcase %d:\n" % counter)
554 event = open("eventSimulator/thermostatCoolModeEvent.groovy", "r")
556 extractedEvents.write(line)
558 extractedEvents.write("\n\t\t\tbreak\n")
559 counter = counter + 1
560 extractedEvents.write("\t\tcase %d:\n" % counter)
561 event = open("eventSimulator/thermostatEmergencyHeatModeEvent.groovy", "r")
563 extractedEvents.write(line)
565 extractedEvents.write("\n\t\t\tbreak\n")
566 counter = counter + 1
567 extractedEvents.write("\t\tcase %d:\n" % counter)
568 event = open("eventSimulator/thermostatHeatModeEvent.groovy", "r")
570 extractedEvents.write(line)
572 extractedEvents.write("\n\t\t\tbreak\n")
573 counter = counter + 1
574 extractedEvents.write("\t\tcase %d:\n" % counter)
575 event = open("eventSimulator/thermostatOffModeEvent.groovy", "r")
577 extractedEvents.write(line)
579 elif eventList[i] == "thermostatFanMode":
580 #Write five events subsequently
581 event = open("eventSimulator/thermostatAutoFanModeEvent.groovy", "r")
583 extractedEvents.write(line)
585 extractedEvents.write("\n\t\t\tbreak\n")
586 counter = counter + 1
587 extractedEvents.write("\t\tcase %d:\n" % counter)
588 event = open("eventSimulator/thermostatFanCirculateFanModeEvent.groovy", "r")
590 extractedEvents.write(line)
592 extractedEvents.write("\n\t\t\tbreak\n")
593 counter = counter + 1
594 extractedEvents.write("\t\tcase %d:\n" % counter)
595 event = open("eventSimulator/thermostatCirculateFanModeEvent.groovy", "r")
597 extractedEvents.write(line)
599 extractedEvents.write("\n\t\t\tbreak\n")
600 counter = counter + 1
601 extractedEvents.write("\t\tcase %d:\n" % counter)
602 event = open("eventSimulator/thermostatFanOnFanModeEvent.groovy", "r")
604 extractedEvents.write(line)
606 extractedEvents.write("\n\t\t\tbreak\n")
607 counter = counter + 1
608 extractedEvents.write("\t\tcase %d:\n" % counter)
609 event = open("eventSimulator/thermostatOnFanModeEvent.groovy", "r")
611 extractedEvents.write(line)
613 elif eventList[i] == "thermostatOperatingState":
614 #Write five events subsequently
615 event = open("eventSimulator/thermostatOperatingStateAutoEvent.groovy", "r")
617 extractedEvents.write(line)
619 extractedEvents.write("\n\t\t\tbreak\n")
620 counter = counter + 1
621 extractedEvents.write("\t\tcase %d:\n" % counter)
622 event = open("eventSimulator/thermostatOperatingStateCoolEvent.groovy", "r")
624 extractedEvents.write(line)
626 extractedEvents.write("\n\t\t\tbreak\n")
627 counter = counter + 1
628 extractedEvents.write("\t\tcase %d:\n" % counter)
629 event = open("eventSimulator/thermostatOperatingStateOffEvent.groovy", "r")
631 extractedEvents.write(line)
633 extractedEvents.write("\n\t\t\tbreak\n")
634 counter = counter + 1
635 extractedEvents.write("\t\tcase %d:\n" % counter)
636 event = open("eventSimulator/thermostatOperatingStateEmergencyHeatEvent.groovy", "r")
638 extractedEvents.write(line)
640 extractedEvents.write("\n\t\t\tbreak\n")
641 counter = counter + 1
642 extractedEvents.write("\t\tcase %d:\n" % counter)
643 event = open("eventSimulator/thermostatOperatingStateHeatEvent.groovy", "r")
645 extractedEvents.write(line)
647 elif eventList[i] == "switch":
648 #Check which capability
649 variable = eventVarMap[eventList[i]]
650 if eventList[i] not in eventVarCounterMap.keys():
651 eventVarCounterMap[eventList[i]] = 1
654 eventVarCount = eventVarCounterMap[eventList[i]]
655 eventVarCounterMap[eventList[i]] = eventVarCount + 1
656 capability = capabilityMap[variable[eventVarCount]]
657 #Write two events subsequently
658 if capability == "capability.switch":
659 event = open("eventSimulator/switchOnEvent.groovy", "r")
660 elif capability == "capability.switchLevel":
661 event = open("eventSimulator/switchLevelOnEvent.groovy", "r")
662 elif capability == "capability.relaySwitch":
663 event = open("eventSimulator/relaySwitchOnEvent.groovy", "r")
664 elif capability == "capability.colorControl":
665 event = open("eventSimulator/colorControlSwitchOnEvent.groovy", "r")
666 elif capability == "capability.colorTemperature":
667 event = open("eventSimulator/colorTemperatureSwitchOnEvent.groovy", "r")
669 extractedEvents.write(line)
671 extractedEvents.write("\n\t\t\tbreak\n")
672 counter = counter + 1
673 extractedEvents.write("\t\tcase %d:\n" % counter)
674 if capability == "capability.switch":
675 event = open("eventSimulator/switchOffEvent.groovy", "r")
676 elif capability == "capability.switchLevel":
677 event = open("eventSimulator/switchLevelOffEvent.groovy", "r")
678 elif capability == "capability.relaySwitch":
679 event = open("eventSimulator/relaySwitchOffEvent.groovy", "r")
680 elif capability == "capability.colorControl":
681 event = open("eventSimulator/colorControlSwitchOffEvent.groovy", "r")
682 elif capability == "capability.colorTemperature":
683 event = open("eventSimulator/colorTemperatureSwitchOffEvent.groovy", "r")
685 extractedEvents.write(line)
687 elif eventList[i] == "location": #Case for Location event
688 #Write three events subsequently
689 event = open("eventSimulator/locationHomeEvent.groovy", "r")
691 extractedEvents.write(line)
693 extractedEvents.write("\n\t\t\tbreak\n")
694 counter = counter + 1
695 extractedEvents.write("\t\tcase %d:\n" % counter)
696 event = open("eventSimulator/locationAwayEvent.groovy", "r")
698 extractedEvents.write(line)
700 extractedEvents.write("\n\t\t\tbreak\n")
701 counter = counter + 1
702 extractedEvents.write("\t\tcase %d:\n" % counter)
703 event = open("eventSimulator/locationNightEvent.groovy", "r")
705 extractedEvents.write(line)
707 elif eventList[i] == "sunrise":
708 event = open("eventSimulator/locationSunriseEvent.groovy", "r")
710 extractedEvents.write(line)
712 elif eventList[i] == "sunset":
713 event = open("eventSimulator/locationSunsetEvent.groovy", "r")
715 extractedEvents.write(line)
717 elif eventList[i] == "sunsetTime":
718 event = open("eventSimulator/locationSunsetTimeEvent.groovy", "r")
720 extractedEvents.write(line)
722 elif eventList[i] == "sunriseTime":
723 event = open("eventSimulator/locationSunriseTimeEvent.groovy", "r")
725 extractedEvents.write(line)
727 elif eventList[i] == "acceleration":
728 #Write two events subsequently
729 event = open("eventSimulator/accelerationActiveEvent.groovy", "r")
731 extractedEvents.write(line)
733 extractedEvents.write("\n\t\t\tbreak\n")
734 counter = counter + 1
735 extractedEvents.write("\t\tcase %d:\n" % counter)
736 event = open("eventSimulator/accelerationInactiveEvent.groovy", "r")
738 extractedEvents.write(line)
740 elif eventList[i] == "acceleration.active":
741 event = open("eventSimulator/accelerationDefaultActiveEvent.groovy", "r")
743 extractedEvents.write(line)
745 elif eventList[i] == "acceleration.inactive":
746 event = open("eventSimulator/accelerationDefaultInactiveEvent.groovy", "r")
748 extractedEvents.write(line)
750 elif eventList[i] == "sleeping":
751 #Write two events subsequently
752 event = open("eventSimulator/sleepSleepingEvent.groovy", "r")
754 extractedEvents.write(line)
756 extractedEvents.write("\n\t\t\tbreak\n")
757 counter = counter + 1
758 extractedEvents.write("\t\tcase %d:\n" % counter)
759 event = open("eventSimulator/sleepNotSleepingEvent.groovy", "r")
761 extractedEvents.write(line)
763 elif eventList[i] == "goal":
764 event = open("eventSimulator/stepGoalEvent.groovy", "r")
766 extractedEvents.write(line)
768 elif eventList[i] == "steps":
769 event = open("eventSimulator/stepStepsEvent.groovy", "r")
771 extractedEvents.write(line)
773 elif eventList[i] == "color":
774 event = open("eventSimulator/colorChangeEvent.groovy", "r")
776 extractedEvents.write(line)
778 elif eventList[i] == "colorTemperature":
779 event = open("eventSimulator/colorTemperatureEvent.groovy", "r")
781 extractedEvents.write(line)
783 elif eventList[i] == "hue":
784 event = open("eventSimulator/hueChangeEvent.groovy", "r")
786 extractedEvents.write(line)
788 elif eventList[i] == "saturation":
789 event = open("eventSimulator/saturationChangeEvent.groovy", "r")
791 extractedEvents.write(line)
793 elif eventList[i] == "energy":
794 event = open("eventSimulator/energyMeterEvent.groovy", "r")
796 extractedEvents.write(line)
798 elif eventList[i] == "power":
799 event = open("eventSimulator/powerMeterEvent.groovy", "r")
801 extractedEvents.write(line)
803 elif eventList[i] == "illuminance":
804 event = open("eventSimulator/illuminanceMeasurementEvent.groovy", "r")
806 extractedEvents.write(line)
808 elif eventList[i] == "humidity":
809 event = open("eventSimulator/humidityMeasurementEvent.groovy", "r")
811 extractedEvents.write(line)
813 elif eventList[i] == "alarm":
814 #Write four events subsequently
815 event = open("eventSimulator/alarmBothEvent.groovy", "r")
817 extractedEvents.write(line)
819 extractedEvents.write("\n\t\t\tbreak\n")
820 counter = counter + 1
821 extractedEvents.write("\t\tcase %d:\n" % counter)
822 event = open("eventSimulator/alarmSirenEvent.groovy", "r")
824 extractedEvents.write(line)
826 extractedEvents.write("\n\t\t\tbreak\n")
827 counter = counter + 1
828 extractedEvents.write("\t\tcase %d:\n" % counter)
829 event = open("eventSimulator/alarmStrobeEvent.groovy", "r")
831 extractedEvents.write(line)
833 extractedEvents.write("\n\t\t\tbreak\n")
834 counter = counter + 1
835 extractedEvents.write("\t\tcase %d:\n" % counter)
836 event = open("eventSimulator/alarmOffEvent.groovy", "r")
838 extractedEvents.write(line)
840 elif eventList[i] == "contact":
841 #Check which capability
842 variable = eventVarMap[eventList[i]]
843 if eventList[i] not in eventVarCounterMap.keys():
844 eventVarCounterMap[eventList[i]] = 1
847 eventVarCount = eventVarCounterMap[eventList[i]]
848 eventVarCounterMap[eventList[i]] = eventVarCount + 1
849 capability = capabilityMap[variable[eventVarCount]]
850 #Write two events subsequently
851 if capability == "capability.contactSensor":
852 event = open("eventSimulator/contactDefaultClosedEvent.groovy", "r")
853 elif capability == "capability.valve":
854 event = open("eventSimulator/valveClosedEvent.groovy", "r")
856 extractedEvents.write(line)
858 extractedEvents.write("\n\t\t\tbreak\n")
859 counter = counter + 1
860 extractedEvents.write("\t\tcase %d:\n" % counter)
861 if capability == "capability.contactSensor":
862 event = open("eventSimulator/contactDefaultOpenEvent.groovy", "r")
863 elif capability == "capability.valve":
864 event = open("eventSimulator/valveOpenEvent.groovy", "r")
866 extractedEvents.write(line)
868 elif eventList[i] == "status":
869 #Write three events subsequently
870 event = open("eventSimulator/musicPlayerPlayingEvent.groovy", "r")
872 extractedEvents.write(line)
874 extractedEvents.write("\n\t\t\tbreak\n")
875 counter = counter + 1
876 extractedEvents.write("\t\tcase %d:\n" % counter)
877 event = open("eventSimulator/musicPlayerStoppedEvent.groovy", "r")
879 extractedEvents.write(line)
881 extractedEvents.write("\n\t\t\tbreak\n")
882 counter = counter + 1
883 extractedEvents.write("\t\tcase %d:\n" % counter)
884 event = open("eventSimulator/musicPlayerPausedEvent.groovy", "r")
886 extractedEvents.write(line)
888 elif eventList[i] == "level":
889 #Check which capability
890 variable = eventVarMap[eventList[i]]
891 if eventList[i] not in eventVarCounterMap.keys():
892 eventVarCounterMap[eventList[i]] = 1
895 eventVarCount = eventVarCounterMap[eventList[i]]
896 eventVarCounterMap[eventList[i]] = eventVarCount + 1
897 capability = capabilityMap[variable[eventVarCount]]
898 if capability == "capability.musicPlayer":
899 event = open("eventSimulator/musicPlayerLevelEvent.groovy", "r")
900 elif capability == "capability.switchLevel":
901 event = open("eventSimulator/switchLevelEvent.groovy", "r")
902 elif capability == "capability.colorControl":
903 event = open("eventSimulator/colorLevelChangeEvent.groovy", "r")
905 extractedEvents.write(line)
907 elif eventList[i] == "trackDescription":
908 event = open("eventSimulator/musicPlayerTrackDescriptionEvent.groovy", "r")
910 extractedEvents.write(line)
912 elif eventList[i] == "trackData":
913 event = open("eventSimulator/musicPlayerTrackDataEvent.groovy", "r")
915 extractedEvents.write(line)
917 elif eventList[i] == "mute":
918 #Write two events subsequently
919 event = open("eventSimulator/musicPlayerUnmutedEvent.groovy", "r")
921 extractedEvents.write(line)
923 extractedEvents.write("\n\t\t\tbreak\n")
924 counter = counter + 1
925 extractedEvents.write("\t\tcase %d:\n" % counter)
926 event = open("eventSimulator/musicPlayerMutedEvent.groovy", "r")
928 extractedEvents.write(line)
930 elif eventList[i] == "temperature":
931 #Check which capability
932 variable = eventVarMap[eventList[i]]
933 if eventList[i] not in eventVarCounterMap.keys():
934 eventVarCounterMap[eventList[i]] = 1
937 eventVarCount = eventVarCounterMap[eventList[i]]
938 eventVarCounterMap[eventList[i]] = eventVarCount + 1
939 capability = capabilityMap[variable[eventVarCount]]
940 if capability == "capability.thermostat":
941 event = open("eventSimulator/temperatureEvent.groovy", "r")
942 elif capability == "capability.temperatureMeasurement":
943 event = open("eventSimulator/temperatureMeasurementEvent.groovy", "r")
945 extractedEvents.write(line)
947 elif eventList[i] == "heatingSetpoint":
948 event = open("eventSimulator/heatingSetpointEvent.groovy", "r")
950 extractedEvents.write(line)
952 elif eventList[i] == "coolingSetpoint":
953 event = open("eventSimulator/coolingSetpointEvent.groovy", "r")
955 extractedEvents.write(line)
957 elif eventList[i] == "thermostatSetpoint":
958 event = open("eventSimulator/thermostatSetpointEvent.groovy", "r")
960 extractedEvents.write(line)
963 ###TODO: Add more events later
964 extractedEvents.write("\n\t\t\tbreak\n")
965 counter = counter + 1
966 extractedEvents.write("\t}\n")
967 extractedEvents.write("}\n")
969 def CheckIfOnlyTouchEvents():
970 #Check and throw an error if it is all touch events
971 #This is called Direct-Direct interaction and we do not model-check for this case
972 onlyTouchEvents = True
973 for item in eventList:
974 if item != "nfcTouch" and item != "app":
975 onlyTouchEvents = False
976 if onlyTouchEvents is True and app1Subscribe is True and app2Subscribe is True:
977 # Write error log file
978 extractError = open("appCreationError.log", "w+")
979 extractError.write("Direct-Direct Interaction detected: we are skipping this pair...\n")
981 raise Exception("\n\nDirect-Direct Interaction detected: we are skipping this pair...\n\n")
984 #Extract objects to call functions from App1
985 F1 = open("Extractor/App1/App1.groovy", "r")
986 extractedFunctionsApp1 = open("Extractor/App1/extractedFunctionsApp1.groovy", "w+")
987 ExtractFunctions(F1, "App1")
990 #Extract objects to call functions from App2
991 F2 = open("Extractor/App2/App2.groovy", "r")
992 extractedFunctionsApp2 = open("Extractor/App2/extractedFunctionsApp2.groovy", "w+")
993 ExtractFunctions(F2, "App2")
996 #Prepare eventSimulator file while parsing the App1 and App2 files
997 extractedEvents = open("eventSimulator/eventSimulator.groovy", "w+")
998 CheckIfOnlyTouchEvents()
999 ExtractEvents(extractedEvents)
1000 extractedEvents.close()
1002 #Save the extracted methods and app1 in a same file to extract information
1003 extractorFile = open("Extractor/extractorFile.groovy", "w+")
1004 Extractor = open("Extractor/Extractor.groovy", "r")
1005 F1 = open("Extractor/App1/App1.groovy", "r")
1007 extractorFile.write("////////////////////\n")
1008 extractorFile.write("@Field App\n")
1009 extractorFile.write("App = \"App1\"")
1010 extractorFile.write("\n")
1011 for line in Extractor:
1012 extractorFile.write(line)
1013 extractorFile.write("\n\n")
1015 extractorFile.write(line)
1016 extractorFile.close()
1019 #Run the file to extract the objects
1020 os.system("groovy -classpath lib/jpf.jar Extractor/extractorFile.groovy")
1023 #Save the extracted methods and app2 in a same file to extract information
1024 extractorFile = open("Extractor/extractorFile.groovy", "w+")
1025 Extractor = open("Extractor/Extractor.groovy", "r")
1026 F2 = open("Extractor/App2/App2.groovy", "r")
1028 extractorFile.write("////////////////////\n")
1029 extractorFile.write("@Field App\n")
1030 extractorFile.write("App = \"App2\"")
1031 extractorFile.write("\n")
1032 for line in Extractor:
1033 extractorFile.write(line)
1034 extractorFile.write("\n\n")
1036 extractorFile.write(line)
1037 #Run the file to extract the objects
1038 extractorFile.close()
1041 os.system("groovy -classpath lib/jpf.jar Extractor/extractorFile.groovy")