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,
31 'thermostatFanMode' : 5,
32 'thermostatOperatingState' : 5,
45 'colorTemperature' : 1,
56 'trackDescription' : 1,
60 'heatingSetpoint' : 1,
61 'coolingSetpoint' : 1,
62 'thermostatSetpoint' : 1}
64 # Mapping for specific event types
65 eventTypesMap = {'alarm.both': 'alarm',
66 'alarm.siren' : 'alarm',
67 'alarm.strobe' : 'alarm',
68 'alarm.off' : 'alarm',
69 'contact.open' : 'contact',
70 'contact.closed' : 'contact',
71 'tamper.tampered' : 'contact',
72 'doorState.open' : 'doorState',
73 'doorState.closed' : 'doorState',
75 'mode.away' : 'location',
76 'mode.home' : 'location',
77 'mode.night' : 'location',
78 'lock.locked' : 'lock',
79 'lock.unlocked' : 'lock',
80 'motion.active' : 'motion',
81 'motion.inactive' : 'motion',
82 'status.playing' : 'status',
83 'status.stopped' : 'status',
84 'status.paused' : 'status',
85 'mute.muted' : 'mute',
86 'mute.unmuted' : 'mute',
87 'presence.present' : 'presence',
88 'presence.not present' : 'presence',
89 'presence.not' : 'presence',
90 'smoke.detected' : 'smoke',
91 'smoke.clear' : 'smoke',
92 'smoke.tested' : 'smoke',
93 'carbonMonoxide.detected' : 'carbonMonoxide',
94 'carbonMonoxide.clear' : 'carbonMonoxide',
95 'carbonMonoxide.tested' : 'carbonMonoxide',
96 'thermostatMode.cool' : 'thermostatMode',
97 'thermostatMode.auto' : 'thermostatMode',
98 'thermostatMode.emergencyHeat' : 'thermostatMode',
99 'thermostatMode.heat' : 'thermostatMode',
100 'thermostatMode.off' : 'thermostatMode',
101 'thermostatFanMode.auto' : 'thermostatFanMode',
102 'thermostatFanMode.fanCirculate' : 'thermostatFanMode',
103 'thermostatFanMode.circulate' : 'thermostatFanMode',
104 'thermostatFanMode.fanOn' : 'thermostatFanMode',
105 'thermostatFanMode.on' : 'thermostatFanMode',
106 'fanMode' : 'thermostatFanMode',
107 'fanMode.auto' : 'thermostatFanMode',
108 'fanMode.fanCirculate' : 'thermostatFanMode',
109 'fanMode.circulate' : 'thermostatFanMode',
110 'fanMode.fanOn' : 'thermostatFanMode',
111 'fanMode.on' : 'thermostatFanMode',
112 'switch.on' : 'switch',
113 'switch.off' : 'switch',
114 'button.pushed' : 'button',
115 'button.held' : 'button',
116 'acceleration.active' : 'acceleration',
117 'acceleration.inactive' : 'acceleration',
118 'sleeping.sleeping' : 'sleeping',
119 'sleeping.not sleeping' : 'sleeping',
120 'water.dry' : 'water',
121 'water.wet' : 'water'}
126 Skip = ['\n', '\t', ' ']
127 Special = ["(", "\"", ":", ",", "{", "}", ")", "/", "*"]
153 def ExtractFunctions(F, appName):
160 while (Temp != "EOF"):
161 if (Temp == "def" or Temp == "private"):
163 if (Temp == "def" or Temp == "private"):
166 if (GetToken(F) == "("): #We have a function to create object for
167 if (appName == "App1"):
168 extractedFunctionsApp1.write("//Global Object for functions in subscribe method!\n")
169 extractedFunctionsApp1.write("def %s = this.&" % NameofFunc)
170 extractedFunctionsApp1.write("%s\n" % NameofFunc)
172 extractedFunctionsApp2.write("//Global Object for functions in subscribe method!\n")
173 extractedFunctionsApp2.write("def %s = this.&" % NameofFunc)
174 extractedFunctionsApp2.write("%s\n" % NameofFunc)
176 #Check input capability
177 if (Temp == "input"):
180 variable = GetToken(F)
181 Temp = GetToken(F) #Get '"'
182 Temp = GetToken(F) #Get ','
185 capability = GetToken(F)
186 capabilityMap[variable] = capability
188 #Check subscribed events
189 if (Temp == "subscribe"):
190 if (appName == "App1"):
198 while (Temp != "\"" and Temp != "app" and Temp != "location"):
200 if Temp == "location":
201 # See if we have another case for location
202 Temp = GetToken(F) # Get ','
203 Temp = GetToken(F) # Get '"'
207 # This is the special case where we will see, e.g., sunset, sunrise, etc.
212 #print "DEBUG: %s - %s" % (variable, Temp)
214 #print "DEBUG: location variable: %s" % Temp
216 #This is a bogus event, just skip it...
219 #Translate and reduce through mapping
220 if Temp in eventTypesMap.keys():
221 Temp = eventTypesMap[Temp]
222 if Temp == "app" or Temp == "location" or Temp == "mode" or Temp == "sunset" or Temp == "sunrise" or Temp == "sunsetTime" or Temp == "sunriseTime":
223 if Temp not in eventList:
224 eventList.append(Temp)
225 if (appName == "App1"):
226 eventAppList.append("App1")
228 eventAppList.append("App2")
229 elif Temp not in eventList or (variable in capabilityMap.keys() and capabilityMap[variable] not in capabilityList):
230 # We do not repeat the same capability twice
231 capability = capabilityMap[variable]
232 capabilityList.append(capability)
233 eventList.append(Temp)
234 if (appName == "App1"):
235 eventAppList.append("App1")
237 eventAppList.append("App2")
238 if Temp in eventVarMap.keys():
239 listOfEvents = eventVarMap[Temp]
240 listOfEvents.append(variable)
242 eventVarMap[Temp] = [variable]
243 #print "DEBUG: %s - %s" % (variable, Temp)
247 #Check and analyze capabilities for physical interaction
248 AnalyzeCapabilities(Temp, appName, F)
252 #Warn if there is a potential for physical interaction
253 AnalyzePhysicalInteraction(app1Capabilities, app2Capabilities)
254 AnalyzePhysicalInteraction(app2Capabilities, app1Capabilities)
256 def AnalyzeCapabilities(Temp, appName, F):
258 if (Temp == "capability.switch" or
259 Temp == "capability.switchLevel" or
260 Temp == "capability.illuminanceMeasurement" or
261 Temp == "capability.colorControl" or
263 Temp == "capability.motionSensor" or
264 Temp == "capability.accelerationSensor" or
266 Temp == "capability.valve" or
267 Temp == "capability.waterSensor" or
269 Temp == "capability.musicPlayer" or
270 Temp == "capability.alarm" or
271 Temp == "capability.speechSynthesis" or
272 Temp == "capability.soundSensor"):
273 if (appName == "App1"):
274 app1Capabilities.append(Temp)
276 app2Capabilities.append(Temp)
277 if (Temp == "capability"):
278 Temp = GetToken(F) #Get '"'
279 Temp = GetToken(F) #Get 'Music'
280 Temp = Temp + GetToken(F) #Get 'Player'
281 if (Temp == "MusicPlayer"):
282 if (appName == "App1"):
283 app1Capabilities.append("capability.musicPlayer")
285 app2Capabilities.append("capability.musicPlayer")
287 def AnalyzePhysicalInteraction(app1Capab, app2Capab):
289 if ("capability.illuminanceMeasurement" in app1Capab) and ("capability.switch" in app2Capab or
290 "capability.switchLevel" in app2Capab or "capability.colorControl" in app2Capab):
291 print ("\nWARNING: Potential PHYSICAL CONFLICT (light) detected between App1 and App2!\n")
293 # TODO: Technically this is not entirely precise since we need to be able to detect that the other app creates motion
294 if ("capability.motionSensor" in app1Capab) or ("capability.accelerationSensor" in app1Capab):
295 print ("\nWARNING: Potential PHYSICAL CONFLICT (motion) detected between App1 and App2!\n")
297 if ("capability.waterSensor" in app1Capab) and ("capability.valve" in app2Capab or
298 "capability.switch" in app2Capab):
299 print ("\nWARNING: Potential PHYSICAL CONFLICT (water) detected between App1 and App2!\n")
301 if ("capability.soundSensor" in app1Capab) and ("capability.musicPlayer" in app2Capab or
302 "capability.alarm" in app2Capab or "capability.speechSynthesis" in app2Capab):
303 print ("\nWARNING: Potential PHYSICAL CONFLICT (sound) detected between App1 and App2!\n")
307 numOfActualEvents = 0
308 #print "DEBUG: eventlist: %d" % len(eventList)
309 #print "DEBUG: eventlist: %s" % eventList
310 for event in eventList:
311 #print "DEBUG: Event: %s %d" % (event, eventTypeCounterMap[event])
312 numOfActualEvents = numOfActualEvents + eventTypeCounterMap[event]
313 return numOfActualEvents
315 def ExtractEvents(extractedEvents):
320 global eventVarCounterMap
321 # Count the number of events
322 numOfActualEvents = CountEvents()
323 extractedEvents.write("while(true) {\n")
324 extractedEvents.write("\tdef eventNumber = Verify.getInt(0,%d)\n" % (numOfActualEvents - 1))
325 extractedEvents.write("\tswitch(eventNumber) {\n")
328 if "App2" in eventAppList:
329 indexApp2 = eventAppList.index("App2")
331 indexApp2 = len(eventList)
332 indexApp2Start = indexApp2
333 #print "DEBUG: App1: %d" % indexApp1
334 #print "DEBUG: App2: %d" % indexApp2
335 #print "DEBUG: eventList: %d" % len(eventList)
338 while counter < numOfActualEvents:
339 # Interleave events from App1 and App2
342 indexApp1 = indexApp1 + 1
343 if indexApp2 < len(eventList):
347 indexApp2 = indexApp2 + 1
348 if indexApp1 < indexApp2Start:
350 #print "DEBUG: i: %d" % i
351 extractedEvents.write("\t\tcase %d:\n" % counter)
352 if eventList[i] == "lock":
353 #Write two events subsequently
354 event = open("eventSimulator/lockLockedEvent.groovy", "r")
356 extractedEvents.write(line)
358 extractedEvents.write("\n\t\t\tbreak\n")
359 counter = counter + 1
360 extractedEvents.write("\t\tcase %d:\n" % counter)
361 event = open("eventSimulator/lockUnlockedEvent.groovy", "r")
363 extractedEvents.write(line)
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] == "sleeping":
741 #Write two events subsequently
742 event = open("eventSimulator/sleepSleepingEvent.groovy", "r")
744 extractedEvents.write(line)
746 extractedEvents.write("\n\t\t\tbreak\n")
747 counter = counter + 1
748 extractedEvents.write("\t\tcase %d:\n" % counter)
749 event = open("eventSimulator/sleepNotSleepingEvent.groovy", "r")
751 extractedEvents.write(line)
753 elif eventList[i] == "goal":
754 #Write two events subsequently
755 event = open("eventSimulator/stepGoalHighEvent.groovy", "r")
757 extractedEvents.write(line)
759 extractedEvents.write("\n\t\t\tbreak\n")
760 counter = counter + 1
761 extractedEvents.write("\t\tcase %d:\n" % counter)
762 event = open("eventSimulator/stepGoalLowEvent.groovy", "r")
764 extractedEvents.write(line)
766 elif eventList[i] == "steps":
767 #Write two events subsequently
768 event = open("eventSimulator/stepStepsHighEvent.groovy", "r")
770 extractedEvents.write(line)
772 extractedEvents.write("\n\t\t\tbreak\n")
773 counter = counter + 1
774 extractedEvents.write("\t\tcase %d:\n" % counter)
775 event = open("eventSimulator/stepStepsLowEvent.groovy", "r")
777 extractedEvents.write(line)
779 elif eventList[i] == "color":
780 event = open("eventSimulator/colorChangeEvent.groovy", "r")
782 extractedEvents.write(line)
784 elif eventList[i] == "colorTemperature":
785 event = open("eventSimulator/colorTemperatureEvent.groovy", "r")
787 extractedEvents.write(line)
789 elif eventList[i] == "hue":
790 event = open("eventSimulator/hueChangeEvent.groovy", "r")
792 extractedEvents.write(line)
794 elif eventList[i] == "saturation":
795 event = open("eventSimulator/saturationChangeEvent.groovy", "r")
797 extractedEvents.write(line)
799 elif eventList[i] == "energy":
800 event = open("eventSimulator/energyMeterEvent.groovy", "r")
802 extractedEvents.write(line)
804 elif eventList[i] == "power":
805 #Write two events subsequently
806 event = open("eventSimulator/powerMeterHighPowerEvent.groovy", "r")
808 extractedEvents.write(line)
810 extractedEvents.write("\n\t\t\tbreak\n")
811 counter = counter + 1
812 extractedEvents.write("\t\tcase %d:\n" % counter)
813 event = open("eventSimulator/powerMeterLowPowerEvent.groovy", "r")
815 extractedEvents.write(line)
817 elif eventList[i] == "illuminance":
818 event = open("eventSimulator/illuminanceMeasurementEvent.groovy", "r")
820 extractedEvents.write(line)
822 elif eventList[i] == "humidity":
823 event = open("eventSimulator/humidityMeasurementEvent.groovy", "r")
825 extractedEvents.write(line)
827 elif eventList[i] == "alarm":
828 #Write four events subsequently
829 event = open("eventSimulator/alarmBothEvent.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/alarmSirenEvent.groovy", "r")
838 extractedEvents.write(line)
840 extractedEvents.write("\n\t\t\tbreak\n")
841 counter = counter + 1
842 extractedEvents.write("\t\tcase %d:\n" % counter)
843 event = open("eventSimulator/alarmStrobeEvent.groovy", "r")
845 extractedEvents.write(line)
847 extractedEvents.write("\n\t\t\tbreak\n")
848 counter = counter + 1
849 extractedEvents.write("\t\tcase %d:\n" % counter)
850 event = open("eventSimulator/alarmOffEvent.groovy", "r")
852 extractedEvents.write(line)
854 elif eventList[i] == "contact":
855 #Check which capability
856 variable = eventVarMap[eventList[i]]
857 if eventList[i] not in eventVarCounterMap.keys():
858 eventVarCounterMap[eventList[i]] = 1
861 eventVarCount = eventVarCounterMap[eventList[i]]
862 eventVarCounterMap[eventList[i]] = eventVarCount + 1
863 capability = capabilityMap[variable[eventVarCount]]
864 #Write two events subsequently
865 if capability == "capability.contactSensor":
866 event = open("eventSimulator/contactDefaultClosedEvent.groovy", "r")
867 elif capability == "capability.valve":
868 event = open("eventSimulator/valveClosedEvent.groovy", "r")
870 extractedEvents.write(line)
872 extractedEvents.write("\n\t\t\tbreak\n")
873 counter = counter + 1
874 extractedEvents.write("\t\tcase %d:\n" % counter)
875 if capability == "capability.contactSensor":
876 event = open("eventSimulator/contactDefaultOpenEvent.groovy", "r")
877 elif capability == "capability.valve":
878 event = open("eventSimulator/valveOpenEvent.groovy", "r")
880 extractedEvents.write(line)
882 elif eventList[i] == "status":
883 #Write three events subsequently
884 event = open("eventSimulator/musicPlayerPlayingEvent.groovy", "r")
886 extractedEvents.write(line)
888 extractedEvents.write("\n\t\t\tbreak\n")
889 counter = counter + 1
890 extractedEvents.write("\t\tcase %d:\n" % counter)
891 event = open("eventSimulator/musicPlayerStoppedEvent.groovy", "r")
893 extractedEvents.write(line)
895 extractedEvents.write("\n\t\t\tbreak\n")
896 counter = counter + 1
897 extractedEvents.write("\t\tcase %d:\n" % counter)
898 event = open("eventSimulator/musicPlayerPausedEvent.groovy", "r")
900 extractedEvents.write(line)
902 elif eventList[i] == "level":
903 #Check which capability
904 variable = eventVarMap[eventList[i]]
905 if eventList[i] not in eventVarCounterMap.keys():
906 eventVarCounterMap[eventList[i]] = 1
909 eventVarCount = eventVarCounterMap[eventList[i]]
910 eventVarCounterMap[eventList[i]] = eventVarCount + 1
911 capability = capabilityMap[variable[eventVarCount]]
912 if capability == "capability.musicPlayer":
913 event = open("eventSimulator/musicPlayerLevelEvent.groovy", "r")
914 elif capability == "capability.switchLevel":
915 event = open("eventSimulator/switchLevelEvent.groovy", "r")
916 elif capability == "capability.colorControl":
917 event = open("eventSimulator/colorLevelChangeEvent.groovy", "r")
919 extractedEvents.write(line)
921 elif eventList[i] == "trackDescription":
922 event = open("eventSimulator/musicPlayerTrackDescriptionEvent.groovy", "r")
924 extractedEvents.write(line)
926 elif eventList[i] == "trackData":
927 event = open("eventSimulator/musicPlayerTrackDataEvent.groovy", "r")
929 extractedEvents.write(line)
931 elif eventList[i] == "mute":
932 #Write two events subsequently
933 event = open("eventSimulator/musicPlayerUnmutedEvent.groovy", "r")
935 extractedEvents.write(line)
937 extractedEvents.write("\n\t\t\tbreak\n")
938 counter = counter + 1
939 extractedEvents.write("\t\tcase %d:\n" % counter)
940 event = open("eventSimulator/musicPlayerMutedEvent.groovy", "r")
942 extractedEvents.write(line)
944 elif eventList[i] == "temperature":
945 #Check which capability
946 variable = eventVarMap[eventList[i]]
947 if eventList[i] not in eventVarCounterMap.keys():
948 eventVarCounterMap[eventList[i]] = 1
951 eventVarCount = eventVarCounterMap[eventList[i]]
952 eventVarCounterMap[eventList[i]] = eventVarCount + 1
953 capability = capabilityMap[variable[eventVarCount]]
954 #Write two events subsequently
955 if capability == "capability.thermostat":
956 event = open("eventSimulator/temperatureHighEvent.groovy", "r")
957 elif capability == "capability.temperatureMeasurement":
958 event = open("eventSimulator/temperatureHighMeasurementEvent.groovy", "r")
960 extractedEvents.write(line)
962 extractedEvents.write("\n\t\t\tbreak\n")
963 counter = counter + 1
964 extractedEvents.write("\t\tcase %d:\n" % counter)
965 if capability == "capability.thermostat":
966 event = open("eventSimulator/temperatureLowEvent.groovy", "r")
967 elif capability == "capability.temperatureMeasurement":
968 event = open("eventSimulator/temperatureLowMeasurementEvent.groovy", "r")
970 extractedEvents.write(line)
972 elif eventList[i] == "heatingSetpoint":
973 event = open("eventSimulator/heatingSetpointEvent.groovy", "r")
975 extractedEvents.write(line)
977 elif eventList[i] == "coolingSetpoint":
978 event = open("eventSimulator/coolingSetpointEvent.groovy", "r")
980 extractedEvents.write(line)
982 elif eventList[i] == "thermostatSetpoint":
983 event = open("eventSimulator/thermostatSetpointEvent.groovy", "r")
985 extractedEvents.write(line)
988 ###TODO: Add more events later
989 extractedEvents.write("\n\t\t\tbreak\n")
990 counter = counter + 1
991 extractedEvents.write("\t}\n")
992 extractedEvents.write("}\n")
994 def CheckIfOnlyTouchEvents():
995 #Check and throw an error if it is all touch events
996 #This is called Direct-Direct interaction and we do not model-check for this case
997 onlyTouchEvents = True
998 for item in eventList:
999 if item != "nfcTouch" and item != "app":
1000 onlyTouchEvents = False
1001 if onlyTouchEvents is True and app1Subscribe is True and app2Subscribe is True:
1002 # Write error log file
1003 extractError = open("appCreationError.log", "w+")
1004 extractError.write("Direct-Direct Interaction detected: we are skipping this pair...\n")
1005 extractError.close()
1006 raise Exception("\n\nDirect-Direct Interaction detected: we are skipping this pair...\n\n")
1009 #Extract objects to call functions from App1
1010 F1 = open("Extractor/App1/App1.groovy", "r")
1011 extractedFunctionsApp1 = open("Extractor/App1/extractedFunctionsApp1.groovy", "w+")
1012 ExtractFunctions(F1, "App1")
1015 #Extract objects to call functions from App2
1016 F2 = open("Extractor/App2/App2.groovy", "r")
1017 extractedFunctionsApp2 = open("Extractor/App2/extractedFunctionsApp2.groovy", "w+")
1018 ExtractFunctions(F2, "App2")
1021 #Prepare eventSimulator file while parsing the App1 and App2 files
1022 extractedEvents = open("eventSimulator/eventSimulator.groovy", "w+")
1023 CheckIfOnlyTouchEvents()
1024 ExtractEvents(extractedEvents)
1025 extractedEvents.close()
1027 #Save the extracted methods and app1 in a same file to extract information
1028 extractorFile = open("Extractor/extractorFile.groovy", "w+")
1029 Extractor = open("Extractor/Extractor.groovy", "r")
1030 F1 = open("Extractor/App1/App1.groovy", "r")
1032 extractorFile.write("////////////////////\n")
1033 extractorFile.write("@Field App\n")
1034 extractorFile.write("App = \"App1\"")
1035 extractorFile.write("\n")
1036 for line in Extractor:
1037 extractorFile.write(line)
1038 extractorFile.write("\n\n")
1040 extractorFile.write(line)
1041 extractorFile.close()
1044 #Run the file to extract the objects
1045 os.system("groovy -classpath lib/jpf.jar Extractor/extractorFile.groovy")
1048 #Save the extracted methods and app2 in a same file to extract information
1049 extractorFile = open("Extractor/extractorFile.groovy", "w+")
1050 Extractor = open("Extractor/Extractor.groovy", "r")
1051 F2 = open("Extractor/App2/App2.groovy", "r")
1053 extractorFile.write("////////////////////\n")
1054 extractorFile.write("@Field App\n")
1055 extractorFile.write("App = \"App2\"")
1056 extractorFile.write("\n")
1057 for line in Extractor:
1058 extractorFile.write(line)
1059 extractorFile.write("\n\n")
1061 extractorFile.write(line)
1062 #Run the file to extract the objects
1063 extractorFile.close()
1066 os.system("groovy -classpath lib/jpf.jar Extractor/extractorFile.groovy")