X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=Runner.py;h=ed4e62c38741d48a67263ebabe2a7029e3558862;hb=c02e3b520b797a7e31b25f4a27ec08050912112f;hp=9c2da707ff75911e62a88c7ca8b9cfe3181190d2;hpb=7bc2c68bdfb07a54d6e8399e7514d715c78a2398;p=smartthings-infrastructure.git diff --git a/Runner.py b/Runner.py index 9c2da70..ed4e62c 100644 --- a/Runner.py +++ b/Runner.py @@ -15,15 +15,25 @@ GlobalVariablesEachApp = open("GlobalVariables/"+"GlobalVariablesEachApp.groovy" setLocationMode = open("Methods/"+"setLocationMode.groovy", "r") subscribe = open("Methods/"+"subscribe.groovy", "r") runIn = open("Methods/"+"runIn.groovy", "r") +runDaily = open("Methods/"+"runDaily.groovy", "r") unschedule = open("Methods/"+"unschedule.groovy", "r") sendNotificationToContacts = open("Methods/"+"sendNotificationToContacts.groovy", "r") sendSms = open("Methods/"+"sendSms.groovy", "r") sendPush = open("Methods/"+"sendPush.groovy", "r") eventHandler = open("Methods/"+"eventHandler.groovy", "r") schedule = open("Methods/"+"schedule.groovy", "r") +httpPostJson = open("Methods/"+"httpPostJson.groovy", "r") now = open("Methods/"+"now.groovy", "r") getTemperatureScale = open("Methods/"+"getTemperatureScale.groovy", "r") getSunriseAndSunset = open("Methods/"+"getSunriseAndSunset.groovy", "r") +runEvery15Minutes = open("Methods/"+"runEvery15Minutes.groovy", "r") +timeToday = open("Methods/"+"timeToday.groovy", "r") +sendNotification = open("Methods/"+"sendNotification.groovy", "r") +canSchedule = open("Methods/"+"canSchedule.groovy", "r") +createAccessToken = open("Methods/"+"createAccessToken.groovy", "r") +runOnce = open("Methods/"+"runOnce.groovy", "r") +parseJson = open("Methods/"+"parseJson.groovy", "r") +unsubscribe = open("Methods/"+"unsubscribe.groovy", "r") App1 = open("Extractor/"+"App1/App1.groovy", "r") extractedObjectsApp1 = open("Extractor/"+"App1/extractedObjectsApp1.groovy", "r") extractedObjectsConstructorApp1 = open("Extractor/"+"App1/extractedObjectsConstructorApp1.groovy", "r") @@ -35,6 +45,7 @@ extractedFunctionsApp1 = open("Extractor/"+"App1/extractedFunctionsApp1.groovy", Out.write("//Infrastructure for SmartThings Application\n") Out.write("//Importing Libraries\n") Out.write("import groovy.transform.Field\n") +Out.write("import groovy.json.JsonSlurper\n") Out.write("\n") Out.write("//Importing Classes\n") Out.write("import ContactSensor.ContactSensor\n") @@ -80,6 +91,37 @@ Out.write("import ColorControl.ColorControl\n") Out.write("import ColorControl.ColorControls\n") Out.write("import EnergyMeter.EnergyMeter\n") Out.write("import EnergyMeter.EnergyMeters\n") +Out.write("import IlluminanceMeasurement.IlluminanceMeasurement\n") +Out.write("import IlluminanceMeasurement.IlluminanceMeasurements\n") +Out.write("import PowerMeter.PowerMeter\n") +Out.write("import PowerMeter.PowerMeters\n") +Out.write("import RelativeHumidityMeasurement.RelativeHumidityMeasurement\n") +Out.write("import RelativeHumidityMeasurement.RelativeHumidityMeasurements\n") +Out.write("import RelaySwitch.RelaySwitch\n") +Out.write("import RelaySwitch.RelaySwitches\n") +Out.write("import SleepSensor.SleepSensor\n") +Out.write("import SleepSensor.SleepSensors\n") +Out.write("import StepSensor.StepSensor\n") +Out.write("import StepSensor.StepSensors\n") +Out.write("import SwitchLevel.SwitchLevel\n") +Out.write("import SwitchLevel.SwitchLevels\n") +Out.write("import TemperatureMeasurement.TemperatureMeasurement\n") +Out.write("import TemperatureMeasurement.TemperatureMeasurements\n") +Out.write("import WaterSensor.WaterSensor\n") +Out.write("import WaterSensor.WaterSensors\n") +Out.write("import Valve.Valve\n") +Out.write("import Valve.Valves\n") +Out.write("import MobilePresence.MobilePresence\n") +Out.write("import MobilePresence.MobilePresences\n") +Out.write("import ColorTemperature.ColorTemperature\n") +Out.write("import ColorTemperature.ColorTemperatures\n") +Out.write("import Button.Button\n") +Out.write("import Button.Buttons\n") +Out.write("import ThreeAxis.ThreeAxis\n") +Out.write("import ThreeAxis.ThreeAxises\n") +Out.write("import Momentary.Momentary\n") +Out.write("import Momentary.Momentaries\n") +Out.write("import RemainingDevices.RemainingDevices\n") Out.write("import Event.Event\n") Out.write("import Timer.SimulatedTimer\n") Out.write("\n") @@ -91,13 +133,18 @@ for line in eventHandler: Out.write(line) Out.write("\n") Out.write("//GlobalVariables for both Apps\n") +Out.write("@Field def init = Verify.getBoolean()\n\n") for line in GlobalVariablesBothApps: Out.write(line) Out.write("\n") +Out.write("//clear init flag now we are done with it\n") +Out.write("init = false\n") Out.write("//Application #1\n") Out.write("class App1 {\n") Out.write("\tdef reference\n") Out.write("\tdef location\n") +Out.write("\t// A local variable added for conflict detection tool\n") +Out.write("\tdef location_mode\n") Out.write("\tdef app\n") Out.write("\n") Out.write("\t//Extracted objects for App1\n") @@ -126,6 +173,8 @@ for line in subscribe: Out.write("\t"+line) for line in runIn: Out.write("\t"+line) +for line in runDaily: + Out.write("\t"+line) for line in unschedule: Out.write("\t"+line) for line in sendNotificationToContacts: @@ -142,6 +191,24 @@ for line in getTemperatureScale: Out.write("\t"+line) for line in getSunriseAndSunset: Out.write("\t"+line) +for line in httpPostJson: + Out.write("\t"+line) +for line in runEvery15Minutes: + Out.write("\t"+line) +for line in timeToday: + Out.write("\t"+line) +for line in sendNotification: + Out.write("\t"+line) +for line in canSchedule: + Out.write("\t"+line) +for line in createAccessToken: + Out.write("\t"+line) +for line in runOnce: + Out.write("\t"+line) +for line in parseJson: + Out.write("\t"+line) +for line in unsubscribe: + Out.write("\t"+line) Out.write("\n") Start = 0 for line in App1: @@ -159,14 +226,25 @@ GlobalVariablesEachApp = open("GlobalVariables/"+"GlobalVariablesEachApp.groovy" setLocationMode = open("Methods/"+"setLocationMode.groovy", "r") subscribe = open("Methods/"+"subscribe.groovy", "r") runIn = open("Methods/"+"runIn.groovy", "r") +runDaily = open("Methods/"+"runDaily.groovy", "r") unschedule = open("Methods/"+"unschedule.groovy", "r") sendNotificationToContacts = open("Methods/"+"sendNotificationToContacts.groovy", "r") sendSms = open("Methods/"+"sendSms.groovy", "r") +sendPush = open("Methods/"+"sendPush.groovy", "r") eventHandler = open("Methods/"+"eventHandler.groovy", "r") schedule = open("Methods/"+"schedule.groovy", "r") now = open("Methods/"+"now.groovy", "r") getTemperatureScale = open("Methods/"+"getTemperatureScale.groovy", "r") getSunriseAndSunset = open("Methods/"+"getSunriseAndSunset.groovy", "r") +httpPostJson = open("Methods/"+"httpPostJson.groovy", "r") +runEvery15Minutes = open("Methods/"+"runEvery15Minutes.groovy", "r") +timeToday = open("Methods/"+"timeToday.groovy", "r") +sendNotification = open("Methods/"+"sendNotification.groovy", "r") +canSchedule = open("Methods/"+"canSchedule.groovy", "r") +createAccessToken = open("Methods/"+"createAccessToken.groovy", "r") +runOnce = open("Methods/"+"runOnce.groovy", "r") +parseJson = open("Methods/"+"parseJson.groovy", "r") +unsubscribe = open("Methods/"+"unsubscribe.groovy", "r") App2 = open("Extractor/"+"App2/App2.groovy", "r") extractedObjectsApp2 = open("Extractor/"+"App2/extractedObjectsApp2.groovy", "r") extractedObjectsConstructorApp2 = open("Extractor/"+"App2/extractedObjectsConstructorApp2.groovy", "r") @@ -176,6 +254,8 @@ Out.write("//Application #2\n") Out.write("class App2 {\n") Out.write("\tdef reference\n") Out.write("\tdef location\n") +Out.write("\t// A local variable added for conflict detection tool\n") +Out.write("\tdef location_mode\n") Out.write("\tdef app\n") Out.write("\n") Out.write("\t//Extracted objects for App2\n") @@ -204,6 +284,8 @@ for line in subscribe: Out.write("\t"+line) for line in runIn: Out.write("\t"+line) +for line in runDaily: + Out.write("\t"+line) for line in unschedule: Out.write("\t"+line) for line in sendNotificationToContacts: @@ -220,6 +302,24 @@ for line in getTemperatureScale: Out.write("\t"+line) for line in getSunriseAndSunset: Out.write("\t"+line) +for line in httpPostJson: + Out.write("\t"+line) +for line in runEvery15Minutes: + Out.write("\t"+line) +for line in timeToday: + Out.write("\t"+line) +for line in sendNotification: + Out.write("\t"+line) +for line in canSchedule: + Out.write("\t"+line) +for line in createAccessToken: + Out.write("\t"+line) +for line in runOnce: + Out.write("\t"+line) +for line in parseJson: + Out.write("\t"+line) +for line in unsubscribe: + Out.write("\t"+line) Out.write("\n") Start = 0 for line in App2: @@ -229,11 +329,24 @@ for line in App2: Out.write("\t"+line) Out.write("}\n") Out.write("\n") -Out.write("@Field def app1 = new App1(this)\n") -Out.write("@Field def app2 = new App2(this)\n") -Out.write("app1.installed()\n") -Out.write("app2.installed()\n") -Out.write("\n") +Out.write("@Field def app1\n") +Out.write("@Field def app2\n") +Out.write("//def initOrder = Verify.getBoolean()\n") +Out.write("//if (initOrder) {\n") +Out.write("\tapp1 = new App1(this)\n") +Out.write("\tapp2 = new App2(this)\n") +Out.write("//} else {\n") +Out.write("\t//app2 = new App2(this)\n") +Out.write("\t//app1 = new App1(this)\n") +Out.write("//}\n\n") +Out.write("//def installOrder = Verify.getBoolean()\n") +Out.write("//if (installOrder) {\n") +Out.write("\tapp1.installed()\n") +Out.write("\tapp2.installed()\n") +Out.write("//} else {\n") +Out.write("\t//app2.installed()\n") +Out.write("\t//app1.installed()\n") +Out.write("//}\n\n") for line in eventSimulator: Out.write(line) Out.close()