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] == "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 #Write two events subsequently
800 event = open("eventSimulator/powerMeterHighPowerEvent.groovy", "r")
802 extractedEvents.write(line)
804 extractedEvents.write("\n\t\t\tbreak\n")
805 counter = counter + 1
806 extractedEvents.write("\t\tcase %d:\n" % counter)
807 event = open("eventSimulator/powerMeterLowPowerEvent.groovy", "r")
809 extractedEvents.write(line)
811 elif eventList[i] == "illuminance":
812 event = open("eventSimulator/illuminanceMeasurementEvent.groovy", "r")
814 extractedEvents.write(line)
816 elif eventList[i] == "humidity":
817 event = open("eventSimulator/humidityMeasurementEvent.groovy", "r")
819 extractedEvents.write(line)
821 elif eventList[i] == "alarm":
822 #Write four events subsequently
823 event = open("eventSimulator/alarmBothEvent.groovy", "r")
825 extractedEvents.write(line)
827 extractedEvents.write("\n\t\t\tbreak\n")
828 counter = counter + 1
829 extractedEvents.write("\t\tcase %d:\n" % counter)
830 event = open("eventSimulator/alarmSirenEvent.groovy", "r")
832 extractedEvents.write(line)
834 extractedEvents.write("\n\t\t\tbreak\n")
835 counter = counter + 1
836 extractedEvents.write("\t\tcase %d:\n" % counter)
837 event = open("eventSimulator/alarmStrobeEvent.groovy", "r")
839 extractedEvents.write(line)
841 extractedEvents.write("\n\t\t\tbreak\n")
842 counter = counter + 1
843 extractedEvents.write("\t\tcase %d:\n" % counter)
844 event = open("eventSimulator/alarmOffEvent.groovy", "r")
846 extractedEvents.write(line)
848 elif eventList[i] == "contact":
849 #Check which capability
850 variable = eventVarMap[eventList[i]]
851 if eventList[i] not in eventVarCounterMap.keys():
852 eventVarCounterMap[eventList[i]] = 1
855 eventVarCount = eventVarCounterMap[eventList[i]]
856 eventVarCounterMap[eventList[i]] = eventVarCount + 1
857 capability = capabilityMap[variable[eventVarCount]]
858 #Write two events subsequently
859 if capability == "capability.contactSensor":
860 event = open("eventSimulator/contactDefaultClosedEvent.groovy", "r")
861 elif capability == "capability.valve":
862 event = open("eventSimulator/valveClosedEvent.groovy", "r")
864 extractedEvents.write(line)
866 extractedEvents.write("\n\t\t\tbreak\n")
867 counter = counter + 1
868 extractedEvents.write("\t\tcase %d:\n" % counter)
869 if capability == "capability.contactSensor":
870 event = open("eventSimulator/contactDefaultOpenEvent.groovy", "r")
871 elif capability == "capability.valve":
872 event = open("eventSimulator/valveOpenEvent.groovy", "r")
874 extractedEvents.write(line)
876 elif eventList[i] == "status":
877 #Write three events subsequently
878 event = open("eventSimulator/musicPlayerPlayingEvent.groovy", "r")
880 extractedEvents.write(line)
882 extractedEvents.write("\n\t\t\tbreak\n")
883 counter = counter + 1
884 extractedEvents.write("\t\tcase %d:\n" % counter)
885 event = open("eventSimulator/musicPlayerStoppedEvent.groovy", "r")
887 extractedEvents.write(line)
889 extractedEvents.write("\n\t\t\tbreak\n")
890 counter = counter + 1
891 extractedEvents.write("\t\tcase %d:\n" % counter)
892 event = open("eventSimulator/musicPlayerPausedEvent.groovy", "r")
894 extractedEvents.write(line)
896 elif eventList[i] == "level":
897 #Check which capability
898 variable = eventVarMap[eventList[i]]
899 if eventList[i] not in eventVarCounterMap.keys():
900 eventVarCounterMap[eventList[i]] = 1
903 eventVarCount = eventVarCounterMap[eventList[i]]
904 eventVarCounterMap[eventList[i]] = eventVarCount + 1
905 capability = capabilityMap[variable[eventVarCount]]
906 if capability == "capability.musicPlayer":
907 event = open("eventSimulator/musicPlayerLevelEvent.groovy", "r")
908 elif capability == "capability.switchLevel":
909 event = open("eventSimulator/switchLevelEvent.groovy", "r")
910 elif capability == "capability.colorControl":
911 event = open("eventSimulator/colorLevelChangeEvent.groovy", "r")
913 extractedEvents.write(line)
915 elif eventList[i] == "trackDescription":
916 event = open("eventSimulator/musicPlayerTrackDescriptionEvent.groovy", "r")
918 extractedEvents.write(line)
920 elif eventList[i] == "trackData":
921 event = open("eventSimulator/musicPlayerTrackDataEvent.groovy", "r")
923 extractedEvents.write(line)
925 elif eventList[i] == "mute":
926 #Write two events subsequently
927 event = open("eventSimulator/musicPlayerUnmutedEvent.groovy", "r")
929 extractedEvents.write(line)
931 extractedEvents.write("\n\t\t\tbreak\n")
932 counter = counter + 1
933 extractedEvents.write("\t\tcase %d:\n" % counter)
934 event = open("eventSimulator/musicPlayerMutedEvent.groovy", "r")
936 extractedEvents.write(line)
938 elif eventList[i] == "temperature":
939 #Check which capability
940 variable = eventVarMap[eventList[i]]
941 if eventList[i] not in eventVarCounterMap.keys():
942 eventVarCounterMap[eventList[i]] = 1
945 eventVarCount = eventVarCounterMap[eventList[i]]
946 eventVarCounterMap[eventList[i]] = eventVarCount + 1
947 capability = capabilityMap[variable[eventVarCount]]
948 if capability == "capability.thermostat":
949 event = open("eventSimulator/temperatureEvent.groovy", "r")
950 elif capability == "capability.temperatureMeasurement":
951 event = open("eventSimulator/temperatureMeasurementEvent.groovy", "r")
953 extractedEvents.write(line)
955 elif eventList[i] == "heatingSetpoint":
956 event = open("eventSimulator/heatingSetpointEvent.groovy", "r")
958 extractedEvents.write(line)
960 elif eventList[i] == "coolingSetpoint":
961 event = open("eventSimulator/coolingSetpointEvent.groovy", "r")
963 extractedEvents.write(line)
965 elif eventList[i] == "thermostatSetpoint":
966 event = open("eventSimulator/thermostatSetpointEvent.groovy", "r")
968 extractedEvents.write(line)
971 ###TODO: Add more events later
972 extractedEvents.write("\n\t\t\tbreak\n")
973 counter = counter + 1
974 extractedEvents.write("\t}\n")
975 extractedEvents.write("}\n")
977 def CheckIfOnlyTouchEvents():
978 #Check and throw an error if it is all touch events
979 #This is called Direct-Direct interaction and we do not model-check for this case
980 onlyTouchEvents = True
981 for item in eventList:
982 if item != "nfcTouch" and item != "app":
983 onlyTouchEvents = False
984 if onlyTouchEvents is True and app1Subscribe is True and app2Subscribe is True:
985 # Write error log file
986 extractError = open("appCreationError.log", "w+")
987 extractError.write("Direct-Direct Interaction detected: we are skipping this pair...\n")
989 raise Exception("\n\nDirect-Direct Interaction detected: we are skipping this pair...\n\n")
992 #Extract objects to call functions from App1
993 F1 = open("Extractor/App1/App1.groovy", "r")
994 extractedFunctionsApp1 = open("Extractor/App1/extractedFunctionsApp1.groovy", "w+")
995 ExtractFunctions(F1, "App1")
998 #Extract objects to call functions from App2
999 F2 = open("Extractor/App2/App2.groovy", "r")
1000 extractedFunctionsApp2 = open("Extractor/App2/extractedFunctionsApp2.groovy", "w+")
1001 ExtractFunctions(F2, "App2")
1004 #Prepare eventSimulator file while parsing the App1 and App2 files
1005 extractedEvents = open("eventSimulator/eventSimulator.groovy", "w+")
1006 CheckIfOnlyTouchEvents()
1007 ExtractEvents(extractedEvents)
1008 extractedEvents.close()
1010 #Save the extracted methods and app1 in a same file to extract information
1011 extractorFile = open("Extractor/extractorFile.groovy", "w+")
1012 Extractor = open("Extractor/Extractor.groovy", "r")
1013 F1 = open("Extractor/App1/App1.groovy", "r")
1015 extractorFile.write("////////////////////\n")
1016 extractorFile.write("@Field App\n")
1017 extractorFile.write("App = \"App1\"")
1018 extractorFile.write("\n")
1019 for line in Extractor:
1020 extractorFile.write(line)
1021 extractorFile.write("\n\n")
1023 extractorFile.write(line)
1024 extractorFile.close()
1027 #Run the file to extract the objects
1028 os.system("groovy -classpath lib/jpf.jar Extractor/extractorFile.groovy")
1031 #Save the extracted methods and app2 in a same file to extract information
1032 extractorFile = open("Extractor/extractorFile.groovy", "w+")
1033 Extractor = open("Extractor/Extractor.groovy", "r")
1034 F2 = open("Extractor/App2/App2.groovy", "r")
1036 extractorFile.write("////////////////////\n")
1037 extractorFile.write("@Field App\n")
1038 extractorFile.write("App = \"App2\"")
1039 extractorFile.write("\n")
1040 for line in Extractor:
1041 extractorFile.write(line)
1042 extractorFile.write("\n\n")
1044 extractorFile.write(line)
1045 #Run the file to extract the objects
1046 extractorFile.close()
1049 os.system("groovy -classpath lib/jpf.jar Extractor/extractorFile.groovy")